diff options
| author | Patrick Steinhardt <ps@pks.im> | 2025-04-15 11:38:14 +0200 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2025-04-15 08:24:34 -0700 |
| commit | d1fa670de07ec9d08fc1333b3addf746c7d304e2 (patch) | |
| tree | d8f8e7b3edbddb66ed00a787e79594003cfed847 /path.h | |
| parent | Merge branch 'ps/object-wo-the-repository' into ps/object-file-cleanup (diff) | |
| download | git-d1fa670de07ec9d08fc1333b3addf746c7d304e2.tar.gz git-d1fa670de07ec9d08fc1333b3addf746c7d304e2.zip | |
object-file: move `mkdir_in_gitdir()` into "path.c"
The `mkdir_in_gitdir()` function is similar to `safe_create_dir()`, but
the former is hosted in "object-file.c" whereas the latter is hosted in
"path.c". The latter code unit makes way more sense though as the logic
has nothing to do with object files in particular.
Move the file into "path.c". While at it, we:
- Rename the function to `safe_create_dir_in_gitdir()` so that the
function names are similar to one another.
- Remove the dependency on `the_repository` by making the callers pass
the repository instead.
Adjust callers accordingly.
Signed-off-by: Patrick Steinhardt <ps@pks.im>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'path.h')
| -rw-r--r-- | path.h | 11 |
1 files changed, 11 insertions, 0 deletions
@@ -221,6 +221,17 @@ char *xdg_cache_home(const char *filename); */ void safe_create_dir(struct repository *repo, const char *dir, int share); +/* + * Similar to `safe_create_dir()`, but with two differences: + * + * - It knows to resolve gitlink files for symlinked worktrees. + * + * - It always adjusts shared permissions. + * + * Returns a negative erorr code on error, 0 on success. + */ +int safe_create_dir_in_gitdir(struct repository *repo, const char *path); + # ifdef USE_THE_REPOSITORY_VARIABLE # include "strbuf.h" # include "repository.h" |
