提交 b40bdb7f 编写于 作者: K Kees Cook 提交者: Linus Torvalds

lib/string_helpers: rename "esc" arg to "only"

To further clarify the purpose of the "esc" argument, rename it to "only"
to reflect that it is a limit, not a list of additional characters to
escape.
Signed-off-by: NKees Cook <keescook@chromium.org>
Suggested-by: NRasmus Villemoes <linux@rasmusvillemoes.dk>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 d89a3f73
...@@ -48,24 +48,24 @@ static inline int string_unescape_any_inplace(char *buf) ...@@ -48,24 +48,24 @@ static inline int string_unescape_any_inplace(char *buf)
#define ESCAPE_HEX 0x20 #define ESCAPE_HEX 0x20
int string_escape_mem(const char *src, size_t isz, char *dst, size_t osz, int string_escape_mem(const char *src, size_t isz, char *dst, size_t osz,
unsigned int flags, const char *esc); unsigned int flags, const char *only);
static inline int string_escape_mem_any_np(const char *src, size_t isz, static inline int string_escape_mem_any_np(const char *src, size_t isz,
char *dst, size_t osz, const char *esc) char *dst, size_t osz, const char *only)
{ {
return string_escape_mem(src, isz, dst, osz, ESCAPE_ANY_NP, esc); return string_escape_mem(src, isz, dst, osz, ESCAPE_ANY_NP, only);
} }
static inline int string_escape_str(const char *src, char *dst, size_t sz, static inline int string_escape_str(const char *src, char *dst, size_t sz,
unsigned int flags, const char *esc) unsigned int flags, const char *only)
{ {
return string_escape_mem(src, strlen(src), dst, sz, flags, esc); return string_escape_mem(src, strlen(src), dst, sz, flags, only);
} }
static inline int string_escape_str_any_np(const char *src, char *dst, static inline int string_escape_str_any_np(const char *src, char *dst,
size_t sz, const char *esc) size_t sz, const char *only)
{ {
return string_escape_str(src, dst, sz, ESCAPE_ANY_NP, esc); return string_escape_str(src, dst, sz, ESCAPE_ANY_NP, only);
} }
#endif #endif
...@@ -432,8 +432,8 @@ static bool escape_hex(unsigned char c, char **dst, char *end) ...@@ -432,8 +432,8 @@ static bool escape_hex(unsigned char c, char **dst, char *end)
* all previous together * all previous together
* %ESCAPE_HEX: * %ESCAPE_HEX:
* '\xHH' - byte with hexadecimal value HH (2 digits) * '\xHH' - byte with hexadecimal value HH (2 digits)
* @esc: NULL-terminated string containing characters used to limit * @only: NULL-terminated string containing characters used to limit
* the selected escape class. If characters are included in @esc * the selected escape class. If characters are included in @only
* that would not normally be escaped by the classes selected * that would not normally be escaped by the classes selected
* in @flags, they will be copied to @dst unescaped. * in @flags, they will be copied to @dst unescaped.
* *
...@@ -442,7 +442,7 @@ static bool escape_hex(unsigned char c, char **dst, char *end) ...@@ -442,7 +442,7 @@ static bool escape_hex(unsigned char c, char **dst, char *end)
* in the following sequence. * in the following sequence.
* 1. The character is matched to the printable class, if asked, and in * 1. The character is matched to the printable class, if asked, and in
* case of match it passes through to the output. * case of match it passes through to the output.
* 2. The character is not matched to the one from @esc string and thus * 2. The character is not matched to the one from @only string and thus
* must go as-is to the output. * must go as-is to the output.
* 3. The character is checked if it falls into the class given by @flags. * 3. The character is checked if it falls into the class given by @flags.
* %ESCAPE_OCTAL and %ESCAPE_HEX are going last since they cover any * %ESCAPE_OCTAL and %ESCAPE_HEX are going last since they cover any
...@@ -460,11 +460,11 @@ static bool escape_hex(unsigned char c, char **dst, char *end) ...@@ -460,11 +460,11 @@ static bool escape_hex(unsigned char c, char **dst, char *end)
* dst for a '\0' terminator if and only if ret < osz. * dst for a '\0' terminator if and only if ret < osz.
*/ */
int string_escape_mem(const char *src, size_t isz, char *dst, size_t osz, int string_escape_mem(const char *src, size_t isz, char *dst, size_t osz,
unsigned int flags, const char *esc) unsigned int flags, const char *only)
{ {
char *p = dst; char *p = dst;
char *end = p + osz; char *end = p + osz;
bool is_dict = esc && *esc; bool is_dict = only && *only;
while (isz--) { while (isz--) {
unsigned char c = *src++; unsigned char c = *src++;
...@@ -473,7 +473,7 @@ int string_escape_mem(const char *src, size_t isz, char *dst, size_t osz, ...@@ -473,7 +473,7 @@ int string_escape_mem(const char *src, size_t isz, char *dst, size_t osz,
* Apply rules in the following sequence: * Apply rules in the following sequence:
* - the character is printable, when @flags has * - the character is printable, when @flags has
* %ESCAPE_NP bit set * %ESCAPE_NP bit set
* - the @esc string is supplied and does not contain a * - the @only string is supplied and does not contain a
* character under question * character under question
* - the character doesn't fall into a class of symbols * - the character doesn't fall into a class of symbols
* defined by given @flags * defined by given @flags
...@@ -481,7 +481,7 @@ int string_escape_mem(const char *src, size_t isz, char *dst, size_t osz, ...@@ -481,7 +481,7 @@ int string_escape_mem(const char *src, size_t isz, char *dst, size_t osz,
* output buffer. * output buffer.
*/ */
if ((flags & ESCAPE_NP && isprint(c)) || if ((flags & ESCAPE_NP && isprint(c)) ||
(is_dict && !strchr(esc, c))) { (is_dict && !strchr(only, c))) {
/* do nothing */ /* do nothing */
} else { } else {
if (flags & ESCAPE_SPACE && escape_space(c, &p, end)) if (flags & ESCAPE_SPACE && escape_space(c, &p, end))
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册