File: fsmonitor-path-utils.h

package info (click to toggle)
git 1%3A2.50.1-0.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 61,696 kB
  • sloc: ansic: 302,907; sh: 260,696; perl: 27,874; tcl: 22,303; makefile: 4,280; python: 3,442; javascript: 772; csh: 45; lisp: 12
file content (60 lines) | stat: -rw-r--r-- 1,416 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#ifndef FSM_PATH_UTILS_H
#define FSM_PATH_UTILS_H

#include "strbuf.h"

struct alias_info
{
	struct strbuf alias;
	struct strbuf points_to;
};

struct fs_info {
	int is_remote;
	char *typename;
};

/*
 * Get some basic filesystem information for the given path
 *
 * The caller owns the storage that is occupied by fs_info and
 * is responsible for releasing it.
 *
 * Returns -1 on error, zero otherwise.
 */
int fsmonitor__get_fs_info(const char *path, struct fs_info *fs_info);

/*
 * Determines if the filesystem that path resides on is remote.
 *
 * Returns -1 on error, 0 if not remote, 1 if remote.
 */
int fsmonitor__is_fs_remote(const char *path);

/*
 * Get the alias in given path, if any.
 *
 * Sets alias to the first alias that matches any part of the path.
 *
 * If an alias is found, info.alias and info.points_to are set to the
 * found mapping.
 *
 * Returns -1 on error, 0 otherwise.
 *
 * The caller owns the storage that is occupied by info.alias and
 * info.points_to and is responsible for releasing it.
 */
int fsmonitor__get_alias(const char *path, struct alias_info *info);

/*
 * Resolve the path against the given alias.
 *
 * Returns the resolved path if there is one, NULL otherwise.
 *
 * The caller owns the storage that the returned string occupies and
 * is responsible for releasing it.
 */
char *fsmonitor__resolve_alias(const char *path,
	const struct alias_info *info);

#endif