Merge branch 'rs/strbuf-add-real-path'
An helper function to make it easier to append the result from real_path() to a strbuf has been added. * rs/strbuf-add-real-path: strbuf: add strbuf_add_real_path() cocci: use ALLOC_ARRAY
This commit is contained in:
commit
fc32293502
@ -24,3 +24,19 @@ expression n;
|
|||||||
@@
|
@@
|
||||||
- memcpy(dst, src, n * sizeof(T));
|
- memcpy(dst, src, n * sizeof(T));
|
||||||
+ COPY_ARRAY(dst, src, n);
|
+ COPY_ARRAY(dst, src, n);
|
||||||
|
|
||||||
|
@@
|
||||||
|
type T;
|
||||||
|
T *ptr;
|
||||||
|
expression n;
|
||||||
|
@@
|
||||||
|
- ptr = xmalloc(n * sizeof(*ptr));
|
||||||
|
+ ALLOC_ARRAY(ptr, n);
|
||||||
|
|
||||||
|
@@
|
||||||
|
type T;
|
||||||
|
T *ptr;
|
||||||
|
expression n;
|
||||||
|
@@
|
||||||
|
- ptr = xmalloc(n * sizeof(T));
|
||||||
|
+ ALLOC_ARRAY(ptr, n);
|
||||||
|
@ -38,3 +38,9 @@ expression E1, E2, E3;
|
|||||||
@@
|
@@
|
||||||
- strbuf_addstr(E1, find_unique_abbrev(E2, E3));
|
- strbuf_addstr(E1, find_unique_abbrev(E2, E3));
|
||||||
+ strbuf_add_unique_abbrev(E1, E2, E3);
|
+ strbuf_add_unique_abbrev(E1, E2, E3);
|
||||||
|
|
||||||
|
@@
|
||||||
|
expression E1, E2;
|
||||||
|
@@
|
||||||
|
- strbuf_addstr(E1, real_path(E2));
|
||||||
|
+ strbuf_add_real_path(E1, E2);
|
||||||
|
2
setup.c
2
setup.c
@ -254,7 +254,7 @@ int get_common_dir_noenv(struct strbuf *sb, const char *gitdir)
|
|||||||
if (!is_absolute_path(data.buf))
|
if (!is_absolute_path(data.buf))
|
||||||
strbuf_addf(&path, "%s/", gitdir);
|
strbuf_addf(&path, "%s/", gitdir);
|
||||||
strbuf_addbuf(&path, &data);
|
strbuf_addbuf(&path, &data);
|
||||||
strbuf_addstr(sb, real_path(path.buf));
|
strbuf_add_real_path(sb, path.buf);
|
||||||
ret = 1;
|
ret = 1;
|
||||||
} else {
|
} else {
|
||||||
strbuf_addstr(sb, gitdir);
|
strbuf_addstr(sb, gitdir);
|
||||||
|
11
strbuf.c
11
strbuf.c
@ -707,6 +707,17 @@ void strbuf_add_absolute_path(struct strbuf *sb, const char *path)
|
|||||||
strbuf_addstr(sb, path);
|
strbuf_addstr(sb, path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void strbuf_add_real_path(struct strbuf *sb, const char *path)
|
||||||
|
{
|
||||||
|
if (sb->len) {
|
||||||
|
struct strbuf resolved = STRBUF_INIT;
|
||||||
|
strbuf_realpath(&resolved, path, 1);
|
||||||
|
strbuf_addbuf(sb, &resolved);
|
||||||
|
strbuf_release(&resolved);
|
||||||
|
} else
|
||||||
|
strbuf_realpath(sb, path, 1);
|
||||||
|
}
|
||||||
|
|
||||||
int printf_ln(const char *fmt, ...)
|
int printf_ln(const char *fmt, ...)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
14
strbuf.h
14
strbuf.h
@ -441,6 +441,20 @@ extern int strbuf_getcwd(struct strbuf *sb);
|
|||||||
*/
|
*/
|
||||||
extern void strbuf_add_absolute_path(struct strbuf *sb, const char *path);
|
extern void strbuf_add_absolute_path(struct strbuf *sb, const char *path);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Canonize `path` (make it absolute, resolve symlinks, remove extra
|
||||||
|
* slashes) and append it to `sb`. Die with an informative error
|
||||||
|
* message if there is a problem.
|
||||||
|
*
|
||||||
|
* The directory part of `path` (i.e., everything up to the last
|
||||||
|
* dir_sep) must denote a valid, existing directory, but the last
|
||||||
|
* component need not exist.
|
||||||
|
*
|
||||||
|
* Callers that don't mind links should use the more lightweight
|
||||||
|
* strbuf_add_absolute_path() instead.
|
||||||
|
*/
|
||||||
|
extern void strbuf_add_real_path(struct strbuf *sb, const char *path);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Normalize in-place the path contained in the strbuf. See
|
* Normalize in-place the path contained in the strbuf. See
|
||||||
|
@ -175,7 +175,7 @@ struct worktree **get_worktrees(unsigned flags)
|
|||||||
struct dirent *d;
|
struct dirent *d;
|
||||||
int counter = 0, alloc = 2;
|
int counter = 0, alloc = 2;
|
||||||
|
|
||||||
list = xmalloc(alloc * sizeof(struct worktree *));
|
ALLOC_ARRAY(list, alloc);
|
||||||
|
|
||||||
list[counter++] = get_main_worktree();
|
list[counter++] = get_main_worktree();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user