Andrew's git
/
gitweb.git
/ diff
summary
|
log
|
commit
| diff |
tree
commit
grep
author
committer
pickaxe
?
re
checkout-index: work from subdirectory.
author
Junio C Hamano
<junkio@cox.net>
Sat, 26 Nov 2005 08:22:48 +0000
(
00:22
-0800)
committer
Junio C Hamano
<junkio@cox.net>
Tue, 29 Nov 2005 07:13:02 +0000
(23:13 -0800)
With this, git-checkout-index from a subdirectory works as
expected. Note that "git-checkout-index -a" checks out files
only in the current directory and under.
Signed-off-by: Junio C Hamano <junkio@cox.net>
checkout-index.c
patch
|
blob
|
history
raw
|
patch
|
inline
| side by side (parent:
61e2b01
)
diff --git
a/checkout-index.c
b/checkout-index.c
index dab3778a9585bcfde98be436255542df13aacddb..f1e716d4126c7dc9a0fd1be665dee9f8d0fbc87e 100644
(file)
--- a/
checkout-index.c
+++ b/
checkout-index.c
@@
-34,6
+34,9
@@
*/
#include "cache.h"
*/
#include "cache.h"
+static const char *prefix;
+static int prefix_length;
+
static struct checkout state = {
.base_dir = "",
.base_dir_len = 0,
static struct checkout state = {
.base_dir = "",
.base_dir_len = 0,
@@
-69,6
+72,10
@@
static int checkout_all(void)
struct cache_entry *ce = active_cache[i];
if (ce_stage(ce))
continue;
struct cache_entry *ce = active_cache[i];
if (ce_stage(ce))
continue;
+ if (prefix && *prefix &&
+ ( ce_namelen(ce) <= prefix_length ||
+ memcmp(prefix, ce->name, prefix_length) ))
+ continue;
if (checkout_entry(ce, &state) < 0)
errs++;
}
if (checkout_entry(ce, &state) < 0)
errs++;
}
@@
-91,6
+98,9
@@
int main(int argc, char **argv)
int newfd = -1;
int all = 0;
int newfd = -1;
int all = 0;
+ prefix = setup_git_directory();
+ prefix_length = prefix ? strlen(prefix) : 0;
+
if (read_cache() < 0) {
die("invalid cache");
}
if (read_cache() < 0) {
die("invalid cache");
}
@@
-155,7
+165,7
@@
int main(int argc, char **argv)
if (all)
die("git-checkout-index: don't mix '--all' and explicit filenames");
if (all)
die("git-checkout-index: don't mix '--all' and explicit filenames");
- checkout_file(
arg
);
+ checkout_file(
prefix_path(prefix, prefix_length, arg)
);
}
if (all)
}
if (all)