diff options
| author | Burt P <pburt0@gmail.com> | 2017-07-17 15:14:30 -0500 | 
|---|---|---|
| committer | Leandro Pereira <leandro@hardinfo.org> | 2017-07-19 07:20:40 -0700 | 
| commit | 6a115300e6f7a9b3ad94a9b57cad8de425f9df37 (patch) | |
| tree | e26545a94a2dacf0037b200e952fa5f352d0d34b /modules/devices | |
| parent | eceee6259c66a8f16c702b8d6b4acd9abe3d5b53 (diff) | |
device tree: escape string values
Signed-off-by: Burt P <pburt0@gmail.com>
Diffstat (limited to 'modules/devices')
| -rw-r--r-- | modules/devices/devicetree.c | 19 | 
1 files changed, 16 insertions, 3 deletions
| diff --git a/modules/devices/devicetree.c b/modules/devices/devicetree.c index c61a6846..d9700854 100644 --- a/modules/devices/devicetree.c +++ b/modules/devices/devicetree.c @@ -79,6 +79,17 @@ gchar *hardinfo_clean_label(const gchar *v, int replacing) {      return clean;  } +gchar *hardinfo_clean_value(const gchar *v, int replacing) { +    gchar *clean; +    if (v == NULL) return NULL; +    gchar **vl = g_strsplit(v, "&", -1); +    clean = g_strjoinv("&", vl); +    g_strfreev(vl); +    if (replacing) +        g_free((gpointer)v); +    return clean; +} +  static int dt_guess_type(dt_raw *prop) {      char *tmp, *slash;      int i = 0, anc = 0, might_be_str = 1; @@ -116,7 +127,7 @@ static int dt_guess_type(dt_raw *prop) {  }  static char* dt_str(dt_raw *prop) { -    char *tmp, *next_str, *ret = NULL; +    char *tmp, *esc, *next_str, *ret = NULL;      int i, l, tl;      if (prop == NULL) return NULL; @@ -136,9 +147,11 @@ static char* dt_str(dt_raw *prop) {              next_str = prop->data;              while(next_str != NULL) {                  l = strlen(next_str); +                esc = g_strescape(next_str, NULL);                  tmp = g_strdup_printf("%s%s\"%s\"", -                        ret, strlen(ret) ? ", " : "", next_str); +                        ret, strlen(ret) ? ", " : "", esc);                  g_free(ret); +                g_free(esc);                  ret = tmp;                  tl += l + 1; next_str += l + 1;                  if (tl >= prop->length) break; @@ -218,7 +231,7 @@ gchar *get_node(char *np) {          while((fn = g_dir_read_name(dir)) != NULL) {              node_path = g_strdup_printf("%s/%s", np, fn);              prop = get_dt_raw(node_path); -            pstr = dt_str(prop); +            pstr = hardinfo_clean_value(dt_str(prop), 1);              lstr = hardinfo_clean_label(fn, 0);              if (prop->type == DT_NODE) {                  tmp = g_strdup_printf("%s%s=%s\n", | 
