2023-03-21 14:25:58 +08:00
|
|
|
#ifndef ABSPATH_H
|
|
|
|
#define ABSPATH_H
|
|
|
|
|
|
|
|
int is_directory(const char *);
|
|
|
|
char *strbuf_realpath(struct strbuf *resolved, const char *path,
|
|
|
|
int die_on_error);
|
|
|
|
char *strbuf_realpath_forgiving(struct strbuf *resolved, const char *path,
|
|
|
|
int die_on_error);
|
|
|
|
char *real_pathdup(const char *path, int die_on_error);
|
|
|
|
const char *absolute_path(const char *path);
|
|
|
|
char *absolute_pathdup(const char *path);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Concatenate "prefix" (if len is non-zero) and "path", with no
|
|
|
|
* connecting characters (so "prefix" should end with a "/").
|
|
|
|
* Unlike prefix_path, this should be used if the named file does
|
|
|
|
* not have to interact with index entry; i.e. name of a random file
|
|
|
|
* on the filesystem.
|
|
|
|
*
|
|
|
|
* The return value is always a newly allocated string (even if the
|
|
|
|
* prefix was empty).
|
|
|
|
*/
|
|
|
|
char *prefix_filename(const char *prefix, const char *path);
|
|
|
|
|
|
|
|
/* Likewise, but path=="-" always yields "-" */
|
|
|
|
char *prefix_filename_except_for_dash(const char *prefix, const char *path);
|
|
|
|
|
|
|
|
static inline int is_absolute_path(const char *path)
|
|
|
|
{
|
|
|
|
return is_dir_sep(path[0]) || has_dos_drive_prefix(path);
|
|
|
|
}
|
|
|
|
|
2023-06-07 03:48:39 +08:00
|
|
|
/**
|
|
|
|
* Add a path to a buffer, converting a relative path to an
|
|
|
|
* absolute one in the process. Symbolic links are not
|
|
|
|
* resolved.
|
|
|
|
*/
|
|
|
|
void strbuf_add_absolute_path(struct strbuf *sb, const char *path);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Canonize `path` (make it absolute, resolve symlinks, remove extra
|
|
|
|
* slashes) and append it to `sb`. Die with an informative error
|
|
|
|
* message if there is a problem.
|
|
|
|
*
|
|
|
|
* The directory part of `path` (i.e., everything up to the last
|
|
|
|
* dir_sep) must denote a valid, existing directory, but the last
|
|
|
|
* component need not exist.
|
|
|
|
*
|
|
|
|
* Callers that don't mind links should use the more lightweight
|
|
|
|
* strbuf_add_absolute_path() instead.
|
|
|
|
*/
|
|
|
|
void strbuf_add_real_path(struct strbuf *sb, const char *path);
|
|
|
|
|
2023-03-21 14:25:58 +08:00
|
|
|
#endif /* ABSPATH_H */
|