Tor 0.4.9.0-alpha-dev
|
Manipulate strings that contain filesystem paths. More...
#include "lib/fs/path.h"
#include "lib/malloc/malloc.h"
#include "lib/log/log.h"
#include "lib/log/util_bug.h"
#include "lib/container/smartlist.h"
#include "lib/sandbox/sandbox.h"
#include "lib/string/printf.h"
#include "lib/string/util_string.h"
#include "lib/string/compat_ctype.h"
#include "lib/string/compat_string.h"
#include "lib/fs/files.h"
#include "lib/fs/dir.h"
#include "lib/fs/userdb.h"
#include <dirent.h>
#include <glob.h>
#include <errno.h>
#include <string.h>
Go to the source code of this file.
Functions | |
char * | get_unquoted_path (const char *path) |
char * | expand_filename (const char *filename) |
int | path_is_relative (const char *filename) |
void | clean_fname_for_stat (char *name) |
int | get_parent_directory (char *fname) |
static char * | alloc_getcwd (void) |
char * | make_path_absolute (const char *fname) |
static bool | is_glob_char (const char *pattern, int pos) |
static bool | add_non_glob_path (const char *path, struct smartlist_t *result) |
static struct smartlist_t * | get_glob_paths (const char *pattern, unglob_fn unglob, bool final) |
struct smartlist_t * | tor_glob (const char *pattern) |
bool | has_glob (const char *s) |
static struct smartlist_t * | unglob_opened_files (const char *pattern, int prev_sep, int next_sep) |
struct smartlist_t * | get_glob_opened_files (const char *pattern) |
Manipulate strings that contain filesystem paths.
Definition in file path.c.
|
static |
|
static |
void clean_fname_for_stat | ( | char * | name | ) |
char * expand_filename | ( | const char * | filename | ) |
struct smartlist_t * get_glob_opened_files | ( | const char * | pattern | ) |
|
static |
Auxiliary function used by get_glob_opened_files and WIN32 tor_glob. Returns a list of paths obtained from pattern using unglob to expand each path fragment. If final is true, the paths are the result of the glob expansion of pattern (implements tor_glob). Otherwise, the paths are the paths opened by glob while expanding pattern (implements get_glob_opened_files). Returns NULL on failure.
Definition at line 418 of file path.c.
Referenced by get_glob_opened_files().
int get_parent_directory | ( | char * | fname | ) |
Modify fname to contain the name of its parent directory. Doesn't actually examine the filesystem; does a purely syntactic modification.
The parent of the root director is considered to be itself.
Path separators are the forward slash (/) everywhere and additionally the backslash () on Win32.
Cuts off any number of trailing path separators but otherwise ignores them for purposes of finding the parent directory.
Returns 0 if a parent directory was successfully found, -1 otherwise (fname did not have any path separators or only had them at the end).
char * get_unquoted_path | ( | const char * | path | ) |
bool has_glob | ( | const char * | s | ) |
Returns true if s contains characters that can be globbed. Returns false otherwise.
Definition at line 667 of file path.c.
Referenced by unglob_opened_files().
|
inlinestatic |
Returns true if the character at position pos in pattern is considered a glob. Returns false otherwise. Takes escaping into account on systems where escaping globs is supported.
Definition at line 372 of file path.c.
Referenced by get_glob_paths(), and has_glob().
char * make_path_absolute | ( | const char * | fname | ) |
Expand possibly relative path fname to an absolute path. Return a newly allocated string, which may be a duplicate of fname.
Definition at line 280 of file path.c.
Referenced by get_esc_cfile(), and warn_if_option_path_is_relative().
int path_is_relative | ( | const char * | filename | ) |
Return true iff filename is a relative path.
Definition at line 145 of file path.c.
Referenced by warn_if_option_path_is_relative().
struct smartlist_t * tor_glob | ( | const char * | pattern | ) |
|
static |
Expands globs in pattern for the path fragment between prev_sep and next_sep using tor_glob. Returns NULL on failure. Used by get_glob_opened_files. Implements unglob_fn, see its description for more details.
Definition at line 683 of file path.c.
Referenced by get_glob_opened_files().