7 * Return a statically allocated filename, either generically (mkpath), in
8 * the repository directory (git_path), or in a submodule's repository
9 * directory (git_path_submodule). In all cases, note that the result
10 * may be overwritten by another call to _any_ of the functions. Consider
11 * using the safer "dup" or "strbuf" formats below (in some cases, the
12 * unsafe versions have already been removed).
14 extern const char *mkpath(const char *fmt
, ...) __attribute__((format (printf
, 1, 2)));
15 extern const char *git_path(const char *fmt
, ...) __attribute__((format (printf
, 1, 2)));
16 extern const char *git_common_path(const char *fmt
, ...) __attribute__((format (printf
, 1, 2)));
18 extern char *mksnpath(char *buf
, size_t n
, const char *fmt
, ...)
19 __attribute__((format (printf
, 3, 4)));
20 extern void strbuf_git_path(struct strbuf
*sb
, const char *fmt
, ...)
21 __attribute__((format (printf
, 2, 3)));
22 extern void strbuf_git_common_path(struct strbuf
*sb
,
23 const struct repository
*repo
,
25 __attribute__((format (printf
, 3, 4)));
26 extern char *git_path_buf(struct strbuf
*buf
, const char *fmt
, ...)
27 __attribute__((format (printf
, 2, 3)));
28 extern int strbuf_git_path_submodule(struct strbuf
*sb
, const char *path
,
30 __attribute__((format (printf
, 3, 4)));
31 extern char *git_pathdup(const char *fmt
, ...)
32 __attribute__((format (printf
, 1, 2)));
33 extern char *mkpathdup(const char *fmt
, ...)
34 __attribute__((format (printf
, 1, 2)));
35 extern char *git_pathdup_submodule(const char *path
, const char *fmt
, ...)
36 __attribute__((format (printf
, 2, 3)));
38 extern char *repo_git_path(const struct repository
*repo
,
40 __attribute__((format (printf
, 2, 3)));
41 extern void strbuf_repo_git_path(struct strbuf
*sb
,
42 const struct repository
*repo
,
44 __attribute__((format (printf
, 3, 4)));
46 extern char *repo_worktree_path(const struct repository
*repo
,
48 __attribute__((format (printf
, 2, 3)));
49 extern void strbuf_repo_worktree_path(struct strbuf
*sb
,
50 const struct repository
*repo
,
52 __attribute__((format (printf
, 3, 4)));
54 extern void report_linked_checkout_garbage(void);
57 * You can define a static memoized git path like:
59 * static GIT_PATH_FUNC(git_path_foo, "FOO");
61 * or use one of the global ones below.
63 #define GIT_PATH_FUNC(func, filename) \
64 const char *func(void) \
68 ret = git_pathdup(filename); \
72 const char *git_path_cherry_pick_head(void);
73 const char *git_path_revert_head(void);
74 const char *git_path_squash_msg(void);
75 const char *git_path_merge_msg(void);
76 const char *git_path_merge_rr(void);
77 const char *git_path_merge_mode(void);
78 const char *git_path_merge_head(void);
79 const char *git_path_fetch_head(void);
80 const char *git_path_shallow(void);