summaryrefslogtreecommitdiffstats
path: root/setup.c
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2011-02-10 01:41:16 +0100
committerJunio C Hamano <gitster@pobox.com>2011-02-10 01:41:16 +0100
commit05f08e4c9ed4a9c34eb2d62300189a3e8a86b5a5 (patch)
tree798769c8699d41697857ab3977da2616f9714653 /setup.c
parentMerge branch 'ae/better-template-failure-report' (diff)
parentsetup: translate symlinks in filename when using absolute paths (diff)
downloadgit-05f08e4c9ed4a9c34eb2d62300189a3e8a86b5a5.tar.xz
git-05f08e4c9ed4a9c34eb2d62300189a3e8a86b5a5.zip
Merge branch 'cb/setup'
* cb/setup: setup: translate symlinks in filename when using absolute paths
Diffstat (limited to 'setup.c')
-rw-r--r--setup.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/setup.c b/setup.c
index dadc66659a..021d0133ae 100644
--- a/setup.c
+++ b/setup.c
@@ -7,10 +7,13 @@ static int inside_work_tree = -1;
char *prefix_path(const char *prefix, int len, const char *path)
{
const char *orig = path;
- char *sanitized = xmalloc(len + strlen(path) + 1);
- if (is_absolute_path(orig))
- strcpy(sanitized, path);
- else {
+ char *sanitized;
+ if (is_absolute_path(orig)) {
+ const char *temp = make_absolute_path(path);
+ sanitized = xmalloc(len + strlen(temp) + 1);
+ strcpy(sanitized, temp);
+ } else {
+ sanitized = xmalloc(len + strlen(path) + 1);
if (len)
memcpy(sanitized, prefix, len);
strcpy(sanitized + len, path);