diff options
author | Lennart Poettering <lennart@poettering.net> | 2015-04-10 14:43:37 +0200 |
---|---|---|
committer | Anthony G. Basile <blueness@gentoo.org> | 2015-04-12 17:46:37 -0400 |
commit | 453b353653156a2a542381dd0c4e7f8ab1ad45a7 (patch) | |
tree | 59166d613999217ad4e90dd71570ce9068e25f14 /src/shared | |
parent | 8b2a897e59663021a08b951886525c13e182ddf6 (diff) |
device-nodes: minor simplifications
Signed-off-by: Anthony G. Basile <blueness@gentoo.org>
Diffstat (limited to 'src/shared')
-rw-r--r-- | src/shared/device-nodes.c | 21 |
1 files changed, 15 insertions, 6 deletions
diff --git a/src/shared/device-nodes.c b/src/shared/device-nodes.c index 28d7664da4..0eb0f35e62 100644 --- a/src/shared/device-nodes.c +++ b/src/shared/device-nodes.c @@ -27,12 +27,14 @@ #include "utf8.h" int whitelisted_char_for_devnode(char c, const char *white) { + if ((c >= '0' && c <= '9') || (c >= 'A' && c <= 'Z') || (c >= 'a' && c <= 'z') || strchr("#+-.:=@_", c) != NULL || (white != NULL && strchr(white, c) != NULL)) return 1; + return 0; } @@ -47,27 +49,34 @@ int encode_devnode_name(const char *str, char *str_enc, size_t len) { seqlen = utf8_encoded_valid_unichar(&str[i]); if (seqlen > 1) { + if (len-j < (size_t)seqlen) - goto err; + return -EINVAL; + memcpy(&str_enc[j], &str[i], seqlen); j += seqlen; i += (seqlen-1); + } else if (str[i] == '\\' || !whitelisted_char_for_devnode(str[i], NULL)) { + if (len-j < 4) - goto err; + return -EINVAL; + sprintf(&str_enc[j], "\\x%02x", (unsigned char) str[i]); j += 4; + } else { if (len-j < 1) - goto err; + return -EINVAL; + str_enc[j] = str[i]; j++; } } + if (len-j < 1) - goto err; + return -EINVAL; + str_enc[j] = '\0'; return 0; -err: - return -EINVAL; } |