blob: 0092cbf3540e2fdfd2e882461ba39ba2a833b672 [file] [log] [blame]
David Reissae299be2008-05-19 23:48:54 -07001#include "cache.h"
Michael Haggerty31171d92012-10-28 17:16:24 +01002#include "string-list.h"
David Reissae299be2008-05-19 23:48:54 -07003
Michael Haggerty9e2326c2012-10-28 17:16:25 +01004/*
5 * A "string_list_each_func_t" function that normalizes an entry from
6 * GIT_CEILING_DIRECTORIES. If the path is unusable for some reason,
7 * die with an explanation.
8 */
9static int normalize_ceiling_entry(struct string_list_item *item, void *unused)
10{
11 const char *ceil = item->string;
12 int len = strlen(ceil);
13 char buf[PATH_MAX+1];
14
15 if (len == 0)
16 die("Empty path is not supported");
17 if (len > PATH_MAX)
18 die("Path \"%s\" is too long", ceil);
19 if (!is_absolute_path(ceil))
20 die("Path \"%s\" is not absolute", ceil);
21 if (normalize_path_copy(buf, ceil) < 0)
22 die("Path \"%s\" could not be normalized", ceil);
23 len = strlen(buf);
24 if (len > 1 && buf[len-1] == '/')
25 die("Normalized path \"%s\" ended with slash", buf);
26 free(item->string);
27 item->string = xstrdup(buf);
28 return 1;
29}
30
David Reissae299be2008-05-19 23:48:54 -070031int main(int argc, char **argv)
32{
Johannes Sixtf42302b2009-02-07 16:08:30 +010033 if (argc == 3 && !strcmp(argv[1], "normalize_path_copy")) {
Johannes Schindelinb8469ad2009-01-28 00:07:36 +010034 char *buf = xmalloc(PATH_MAX + 1);
Johannes Sixtf42302b2009-02-07 16:08:30 +010035 int rv = normalize_path_copy(buf, argv[2]);
36 if (rv)
37 buf = "++failed++";
David Reissae299be2008-05-19 23:48:54 -070038 puts(buf);
Johannes Sixt2cd85c42009-02-07 16:08:27 +010039 return 0;
David Reissae299be2008-05-19 23:48:54 -070040 }
41
Carlos Martín Nietoe2a57aa2011-03-17 12:26:46 +010042 if (argc >= 2 && !strcmp(argv[1], "real_path")) {
David Reissd553e732008-05-19 23:49:00 -070043 while (argc > 2) {
Carlos Martín Nietoe2a57aa2011-03-17 12:26:46 +010044 puts(real_path(argv[2]));
David Reissd553e732008-05-19 23:49:00 -070045 argc--;
46 argv++;
47 }
Johannes Sixt2cd85c42009-02-07 16:08:27 +010048 return 0;
David Reissd553e732008-05-19 23:49:00 -070049 }
50
Michael Haggerty87a246e2011-08-04 06:47:47 +020051 if (argc >= 2 && !strcmp(argv[1], "absolute_path")) {
52 while (argc > 2) {
53 puts(absolute_path(argv[2]));
54 argc--;
55 argv++;
56 }
57 return 0;
58 }
59
David Reiss0454dd92008-05-19 23:49:26 -070060 if (argc == 4 && !strcmp(argv[1], "longest_ancestor_length")) {
Michael Haggerty31171d92012-10-28 17:16:24 +010061 int len;
62 struct string_list ceiling_dirs = STRING_LIST_INIT_DUP;
Michael Haggerty9e2326c2012-10-28 17:16:25 +010063 char *path = xstrdup(argv[2]);
Michael Haggerty31171d92012-10-28 17:16:24 +010064
Michael Haggerty9e2326c2012-10-28 17:16:25 +010065 /*
66 * We have to normalize the arguments because under
67 * Windows, bash mangles arguments that look like
68 * absolute POSIX paths or colon-separate lists of
69 * absolute POSIX paths into DOS paths (e.g.,
70 * "/foo:/foo/bar" might be converted to
71 * "D:\Src\msysgit\foo;D:\Src\msysgit\foo\bar"),
72 * whereas longest_ancestor_length() requires paths
73 * that use forward slashes.
74 */
75 if (normalize_path_copy(path, path))
76 die("Path \"%s\" could not be normalized", argv[2]);
Michael Haggerty31171d92012-10-28 17:16:24 +010077 string_list_split(&ceiling_dirs, argv[3], PATH_SEP, -1);
Michael Haggerty9e2326c2012-10-28 17:16:25 +010078 filter_string_list(&ceiling_dirs, 0,
79 normalize_ceiling_entry, NULL);
80 len = longest_ancestor_length(path, &ceiling_dirs);
Michael Haggerty31171d92012-10-28 17:16:24 +010081 string_list_clear(&ceiling_dirs, 0);
Michael Haggerty9e2326c2012-10-28 17:16:25 +010082 free(path);
David Reiss0454dd92008-05-19 23:49:26 -070083 printf("%d\n", len);
Johannes Sixt2cd85c42009-02-07 16:08:27 +010084 return 0;
David Reiss0454dd92008-05-19 23:49:26 -070085 }
86
Michael Haggerty9e813722011-08-04 06:47:48 +020087 if (argc >= 4 && !strcmp(argv[1], "prefix_path")) {
88 char *prefix = argv[2];
89 int prefix_len = strlen(prefix);
90 int nongit_ok;
91 setup_git_directory_gently(&nongit_ok);
92 while (argc > 3) {
93 puts(prefix_path(prefix, prefix_len, argv[3]));
94 argc--;
95 argv++;
96 }
97 return 0;
98 }
99
Johannes Schindelin4fcc86b2009-02-19 20:10:49 +0100100 if (argc == 4 && !strcmp(argv[1], "strip_path_suffix")) {
101 char *prefix = strip_path_suffix(argv[2], argv[3]);
102 printf("%s\n", prefix ? prefix : "(null)");
103 return 0;
104 }
105
Johannes Sixt2cd85c42009-02-07 16:08:27 +0100106 fprintf(stderr, "%s: unknown function name: %s\n", argv[0],
107 argv[1] ? argv[1] : "(there was none)");
108 return 1;
David Reissae299be2008-05-19 23:48:54 -0700109}