mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-29 12:00:34 +00:00
Add git_buf_unescape and git__unescape to unescape all characters in a string (in-place)
This commit is contained in:
parent
944d250f96
commit
02a0d651d7
@ -426,17 +426,7 @@ int git_attr_fnmatch__parse(
|
|||||||
return -1;
|
return -1;
|
||||||
} else {
|
} else {
|
||||||
/* strip '\' that might have be used for internal whitespace */
|
/* strip '\' that might have be used for internal whitespace */
|
||||||
char *to = spec->pattern;
|
spec->length = git__unescape(spec->pattern);
|
||||||
for (scan = spec->pattern; *scan; to++, scan++) {
|
|
||||||
if (*scan == '\\')
|
|
||||||
scan++; /* skip '\' but include next char */
|
|
||||||
if (to != scan)
|
|
||||||
*to = *scan;
|
|
||||||
}
|
|
||||||
if (to != scan) {
|
|
||||||
*to = '\0';
|
|
||||||
spec->length = (to - spec->pattern);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -496,3 +496,7 @@ bool git_buf_is_binary(const git_buf *buf)
|
|||||||
return ((printable >> 7) < nonprintable);
|
return ((printable >> 7) < nonprintable);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void git_buf_unescape(git_buf *buf)
|
||||||
|
{
|
||||||
|
buf->size = git__unescape(buf->ptr);
|
||||||
|
}
|
||||||
|
@ -151,4 +151,7 @@ int git_buf_common_prefix(git_buf *buf, const git_strarray *strings);
|
|||||||
/* Check if buffer looks like it contains binary data */
|
/* Check if buffer looks like it contains binary data */
|
||||||
bool git_buf_is_binary(const git_buf *buf);
|
bool git_buf_is_binary(const git_buf *buf);
|
||||||
|
|
||||||
|
/* Unescape all characters in a buffer */
|
||||||
|
void git_buf_unescape(git_buf *buf);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
18
src/util.c
18
src/util.c
@ -435,3 +435,21 @@ int git__parse_bool(int *out, const char *value)
|
|||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_t git__unescape(char *str)
|
||||||
|
{
|
||||||
|
char *scan, *pos = str;
|
||||||
|
|
||||||
|
for (scan = str; *scan; pos++, scan++) {
|
||||||
|
if (*scan == '\\' && *(scan + 1) != '\0')
|
||||||
|
scan++; /* skip '\' but include next char */
|
||||||
|
if (pos != scan)
|
||||||
|
*pos = *scan;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pos != scan) {
|
||||||
|
*pos = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
return (pos - str);
|
||||||
|
}
|
||||||
|
@ -238,4 +238,13 @@ extern int git__parse_bool(int *out, const char *value);
|
|||||||
*/
|
*/
|
||||||
int git__date_parse(git_time_t *out, const char *date);
|
int git__date_parse(git_time_t *out, const char *date);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Unescapes a string in-place.
|
||||||
|
*
|
||||||
|
* Edge cases behavior:
|
||||||
|
* - "jackie\" -> "jacky\"
|
||||||
|
* - "chan\\" -> "chan\"
|
||||||
|
*/
|
||||||
|
extern size_t git__unescape(char *str);
|
||||||
|
|
||||||
#endif /* INCLUDE_util_h__ */
|
#endif /* INCLUDE_util_h__ */
|
||||||
|
@ -658,3 +658,23 @@ void test_core_buffer__puts_escaped(void)
|
|||||||
|
|
||||||
git_buf_free(&a);
|
git_buf_free(&a);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void assert_unescape(char *expected, char *to_unescape) {
|
||||||
|
git_buf buf = GIT_BUF_INIT;
|
||||||
|
|
||||||
|
cl_git_pass(git_buf_sets(&buf, to_unescape));
|
||||||
|
git_buf_unescape(&buf);
|
||||||
|
cl_assert_equal_s(expected, buf.ptr);
|
||||||
|
cl_assert_equal_i(strlen(expected), buf.size);
|
||||||
|
|
||||||
|
git_buf_free(&buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_core_buffer__unescape(void)
|
||||||
|
{
|
||||||
|
assert_unescape("Escaped\\", "Es\\ca\\ped\\");
|
||||||
|
assert_unescape("Es\\caped\\", "Es\\\\ca\\ped\\\\");
|
||||||
|
assert_unescape("\\", "\\");
|
||||||
|
assert_unescape("\\", "\\\\");
|
||||||
|
assert_unescape("", "");
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user