summaryrefslogtreecommitdiff
path: root/apply.h
diff options
context:
space:
mode:
authorRené Scharfe <l.s.r@web.de>2022-01-07 12:16:53 (GMT)
committerJunio C Hamano <gitster@pobox.com>2022-01-07 19:40:44 (GMT)
commit4e9a3252531eab8af5559b25efac02b33f6ca5fe (patch)
tree04453b8ae45ef0fd7fbc528c78cd0aeba920b0c9 /apply.h
parente9d7761bb94f20acc98824275e317fa82436c25d (diff)
downloadgit-4e9a3252531eab8af5559b25efac02b33f6ca5fe.zip
git-4e9a3252531eab8af5559b25efac02b33f6ca5fe.tar.gz
git-4e9a3252531eab8af5559b25efac02b33f6ca5fe.tar.bz2
apply: use strsets to track symlinks
Symlink changes are tracked in a string_list, with the util pointer value indicating whether a symlink is kept or removed. Using fake pointer values requires awkward casts. Use one strset for each type of change instead to simplify and shorten the code. Original-patch-by: Jessica Clarke <jrtc27@jrtc27.com> Signed-off-by: René Scharfe <l.s.r@web.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'apply.h')
-rw-r--r--apply.h26
1 files changed, 11 insertions, 15 deletions
diff --git a/apply.h b/apply.h
index da3d95f..1f959c0 100644
--- a/apply.h
+++ b/apply.h
@@ -4,6 +4,7 @@
#include "hash.h"
#include "lockfile.h"
#include "string-list.h"
+#include "strmap.h"
struct repository;
@@ -25,20 +26,6 @@ enum apply_verbosity {
verbosity_verbose = 1
};
-/*
- * We need to keep track of how symlinks in the preimage are
- * manipulated by the patches. A patch to add a/b/c where a/b
- * is a symlink should not be allowed to affect the directory
- * the symlink points at, but if the same patch removes a/b,
- * it is perfectly fine, as the patch removes a/b to make room
- * to create a directory a/b so that a/b/c can be created.
- *
- * See also "struct string_list symlink_changes" in "struct
- * apply_state".
- */
-#define APPLY_SYMLINK_GOES_AWAY 01
-#define APPLY_SYMLINK_IN_RESULT 02
-
struct apply_state {
const char *prefix;
@@ -85,7 +72,16 @@ struct apply_state {
/* Various "current state" */
int linenr; /* current line number */
- struct string_list symlink_changes; /* we have to track symlinks */
+ /*
+ * We need to keep track of how symlinks in the preimage are
+ * manipulated by the patches. A patch to add a/b/c where a/b
+ * is a symlink should not be allowed to affect the directory
+ * the symlink points at, but if the same patch removes a/b,
+ * it is perfectly fine, as the patch removes a/b to make room
+ * to create a directory a/b so that a/b/c can be created.
+ */
+ struct strset removed_symlinks;
+ struct strset kept_symlinks;
/*
* For "diff-stat" like behaviour, we keep track of the biggest change