diff options
author | David Oberhollenzer <david.oberhollenzer@tele2.at> | 2018-04-08 16:12:24 +0200 |
---|---|---|
committer | David Oberhollenzer <david.oberhollenzer@tele2.at> | 2018-04-08 16:12:24 +0200 |
commit | 6b788edfa40fd9c006f071ce764677e9dd2f9384 (patch) | |
tree | a8bb61438dfd86e6585361c04e096f42b5b175a4 /lib/src/splitkv.c | |
parent | 7d8ceb810faa085650d2d74e3d1c857b8b755ca3 (diff) |
Cleanup: rename/split splitkv.c
Signed-off-by: David Oberhollenzer <david.oberhollenzer@tele2.at>
Diffstat (limited to 'lib/src/splitkv.c')
-rw-r--r-- | lib/src/splitkv.c | 161 |
1 files changed, 0 insertions, 161 deletions
diff --git a/lib/src/splitkv.c b/lib/src/splitkv.c deleted file mode 100644 index 7d652d3..0000000 --- a/lib/src/splitkv.c +++ /dev/null @@ -1,161 +0,0 @@ -/* SPDX-License-Identifier: GPL-3.0-or-later */ -/* - * Copyright (C) 2018 - David Oberhollenzer - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program. If not, see <https://www.gnu.org/licenses/>. - */ -#include <stdlib.h> -#include <ctype.h> -#include <errno.h> - -#include "util.h" - -static int xdigit(int x) -{ - if (isupper(x)) - return x - 'A' + 0x0A; - if (islower(x)) - return x - 'a' + 0x0A; - return x - '0'; -} - -int unescape(char *src) -{ - char *dst = src; - int c; - - for (;;) { - while (*src != '"' && *src != '\0') - *(dst++) = *(src++); - - if (*src == '\0') - break; - - ++src; - - while ((c = *(src++)) != '"') { - if (c == '\0') - return -1; - - if (c == '\\') { - c = *(src++); - - switch (c) { - case 'a': c = '\a'; break; - case 'b': c = '\b'; break; - case 'f': c = '\f'; break; - case 'n': c = '\n'; break; - case 't': c = '\t'; break; - case '\\': - case '"': - break; - case 'x': - c = 0; - if (isxdigit(*src)) - c = (c<<4) | xdigit(*(src++)); - if (isxdigit(*src)) - c = (c<<4) | xdigit(*(src++)); - break; - case '0': - c = 0; - if (isdigit(*src) && *src < '8') - c = (c<<3) | (*(src++) - '0'); - if (isdigit(*src) && *src < '8') - c = (c<<3) | (*(src++) - '0'); - if (isdigit(*src) && *src < '8') - c = (c<<3) | (*(src++) - '0'); - break; - default: - return -1; - } - } - - *(dst++) = c; - } - } - - *(dst++) = '\0'; - return 0; -} - -char **split_argv(char *str) -{ - size_t i = 0, cap = 0, new_cap; - char **argv = NULL, **new; - char *ptr; - - ptr = str; - - for (;;) { - if (*ptr == ' ') { - ++ptr; - continue; - } - - if (i == cap) { - new_cap = cap ? cap * 2 : 16; - new = realloc(argv, sizeof(argv[0]) * new_cap); - - if (new == NULL) { - free(argv); - errno = ENOMEM; - return NULL; - } - - cap = new_cap; - argv = new; - } - - if (*ptr == '\0') { - argv[i++] = NULL; - break; - } - - argv[i++] = ptr; - - if (*ptr == '"') { - ++ptr; - while (*ptr != '\0' && *ptr != '"') { - if (ptr[0] == '\\' && ptr[1] != '\0') - ++ptr; - - ++ptr; - } - - if (*ptr == '"') - ++ptr; - - if (*ptr == ' ') { - *(ptr++) = '\0'; - } else if (*ptr != '\0') { - goto fail_str; - } - - if (unescape(argv[i - 1])) - goto fail_str; - } else { - while (*ptr != '\0' && *ptr != ' ') - ++ptr; - - if (*ptr == ' ') - *(ptr++) = '\0'; - } - } - - return argv; -fail_str: - free(argv); - errno = EINVAL; - return NULL; -} |