naccyde / rpms / systemd

Forked from rpms/systemd a year ago
Clone
8d419f
From 272d6e85877bb436709ed54c02d3b68101e0438d Mon Sep 17 00:00:00 2001
8d419f
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
8d419f
Date: Mon, 9 May 2022 11:01:32 +0200
8d419f
Subject: [PATCH] shared/json: reduce scope of variables
8d419f
8d419f
(cherry picked from commit a4669764f7329d1e8a3d364db519500355cea5f0)
8d419f
Related: #2087652
8d419f
---
8d419f
 src/shared/json.c | 133 +++++++++++++++++++---------------------------
8d419f
 1 file changed, 54 insertions(+), 79 deletions(-)
8d419f
8d419f
diff --git a/src/shared/json.c b/src/shared/json.c
8d419f
index 6375b87a0b..d35874f8e3 100644
8d419f
--- a/src/shared/json.c
8d419f
+++ b/src/shared/json.c
8d419f
@@ -574,9 +574,6 @@ int json_variant_new_array(JsonVariant **ret, JsonVariant **array, size_t n) {
8d419f
 }
8d419f
 
8d419f
 int json_variant_new_array_bytes(JsonVariant **ret, const void *p, size_t n) {
8d419f
-        JsonVariant *v;
8d419f
-        size_t i;
8d419f
-
8d419f
         assert_return(ret, -EINVAL);
8d419f
         if (n == 0) {
8d419f
                 *ret = JSON_VARIANT_MAGIC_EMPTY_ARRAY;
8d419f
@@ -584,7 +581,7 @@ int json_variant_new_array_bytes(JsonVariant **ret, const void *p, size_t n) {
8d419f
         }
8d419f
         assert_return(p, -EINVAL);
8d419f
 
8d419f
-        v = new(JsonVariant, n + 1);
8d419f
+        JsonVariant *v = new(JsonVariant, n + 1);
8d419f
         if (!v)
8d419f
                 return -ENOMEM;
8d419f
 
8d419f
@@ -595,7 +592,7 @@ int json_variant_new_array_bytes(JsonVariant **ret, const void *p, size_t n) {
8d419f
                 .depth = 1,
8d419f
         };
8d419f
 
8d419f
-        for (i = 0; i < n; i++) {
8d419f
+        for (size_t i = 0; i < n; i++) {
8d419f
                 JsonVariant *w = v + 1 + i;
8d419f
 
8d419f
                 *w = (JsonVariant) {
8d419f
@@ -790,12 +787,9 @@ static void json_variant_free_inner(JsonVariant *v, bool force_sensitive) {
8d419f
                 return;
8d419f
         }
8d419f
 
8d419f
-        if (IN_SET(v->type, JSON_VARIANT_ARRAY, JSON_VARIANT_OBJECT)) {
8d419f
-                size_t i;
8d419f
-
8d419f
-                for (i = 0; i < v->n_elements; i++)
8d419f
+        if (IN_SET(v->type, JSON_VARIANT_ARRAY, JSON_VARIANT_OBJECT))
8d419f
+                for (size_t i = 0; i < v->n_elements; i++)
8d419f
                         json_variant_free_inner(v + 1 + i, sensitive);
8d419f
-        }
8d419f
 
8d419f
         if (sensitive)
8d419f
                 explicit_bzero_safe(v, json_variant_size(v));
8d419f
@@ -839,11 +833,9 @@ JsonVariant *json_variant_unref(JsonVariant *v) {
8d419f
 }
8d419f
 
8d419f
 void json_variant_unref_many(JsonVariant **array, size_t n) {
8d419f
-        size_t i;
8d419f
-
8d419f
         assert(array || n == 0);
8d419f
 
8d419f
-        for (i = 0; i < n; i++)
8d419f
+        for (size_t i = 0; i < n; i++)
8d419f
                 json_variant_unref(array[i]);
8d419f
 }
8d419f
 
8d419f
@@ -1218,8 +1210,6 @@ mismatch:
8d419f
 }
8d419f
 
8d419f
 JsonVariant *json_variant_by_key_full(JsonVariant *v, const char *key, JsonVariant **ret_key) {
8d419f
-        size_t i;
8d419f
-
8d419f
         if (!v)
8d419f
                 goto not_found;
8d419f
         if (!key)
8d419f
@@ -1241,6 +1231,7 @@ JsonVariant *json_variant_by_key_full(JsonVariant *v, const char *key, JsonVaria
8d419f
                 while (b > a) {
8d419f
                         JsonVariant *p;
8d419f
                         const char *f;
8d419f
+                        size_t i;
8d419f
                         int c;
8d419f
 
8d419f
                         i = (a + b) / 2;
8d419f
@@ -1264,7 +1255,7 @@ JsonVariant *json_variant_by_key_full(JsonVariant *v, const char *key, JsonVaria
8d419f
         }
8d419f
 
8d419f
         /* The variant is not sorted, hence search for the field linearly */
8d419f
-        for (i = 0; i < v->n_elements; i += 2) {
8d419f
+        for (size_t i = 0; i < v->n_elements; i += 2) {
8d419f
                 JsonVariant *p;
8d419f
 
8d419f
                 p = json_variant_dereference(v + 1 + i);
8d419f
@@ -1335,34 +1326,28 @@ bool json_variant_equal(JsonVariant *a, JsonVariant *b) {
8d419f
                 return true;
8d419f
 
8d419f
         case JSON_VARIANT_ARRAY: {
8d419f
-                size_t i, n;
8d419f
-
8d419f
-                n = json_variant_elements(a);
8d419f
+                size_t n = json_variant_elements(a);
8d419f
                 if (n != json_variant_elements(b))
8d419f
                         return false;
8d419f
 
8d419f
-                for (i = 0; i < n; i++) {
8d419f
+                for (size_t i = 0; i < n; i++)
8d419f
                         if (!json_variant_equal(json_variant_by_index(a, i), json_variant_by_index(b, i)))
8d419f
                                 return false;
8d419f
-                }
8d419f
 
8d419f
                 return true;
8d419f
         }
8d419f
 
8d419f
         case JSON_VARIANT_OBJECT: {
8d419f
-                size_t i, n;
8d419f
-
8d419f
-                n = json_variant_elements(a);
8d419f
+                size_t n = json_variant_elements(a);
8d419f
                 if (n != json_variant_elements(b))
8d419f
                         return false;
8d419f
 
8d419f
                 /* Iterate through all keys in 'a' */
8d419f
-                for (i = 0; i < n; i += 2) {
8d419f
+                for (size_t i = 0; i < n; i += 2) {
8d419f
                         bool found = false;
8d419f
-                        size_t j;
8d419f
 
8d419f
                         /* Match them against all keys in 'b' */
8d419f
-                        for (j = 0; j < n; j += 2) {
8d419f
+                        for (size_t j = 0; j < n; j += 2) {
8d419f
                                 JsonVariant *key_b;
8d419f
 
8d419f
                                 key_b = json_variant_by_index(b, j);
8d419f
@@ -1470,16 +1455,14 @@ static int print_source(FILE *f, JsonVariant *v, JsonFormatFlags flags, bool whi
8d419f
                 DECIMAL_STR_MAX(unsigned) -1;
8d419f
 
8d419f
         if (whitespace) {
8d419f
-                size_t i, n;
8d419f
-
8d419f
-                n = 1 + (v->source ? strlen(v->source->name) : 0) +
8d419f
-                        ((v->source && (v->line > 0 || v->column > 0)) ? 1 : 0) +
8d419f
-                        (v->line > 0 ? w : 0) +
8d419f
-                        (((v->source || v->line > 0) && v->column > 0) ? 1 : 0) +
8d419f
-                        (v->column > 0 ? k : 0) +
8d419f
-                        2;
8d419f
-
8d419f
-                for (i = 0; i < n; i++)
8d419f
+                size_t n = 1 + (v->source ? strlen(v->source->name) : 0) +
8d419f
+                               ((v->source && (v->line > 0 || v->column > 0)) ? 1 : 0) +
8d419f
+                               (v->line > 0 ? w : 0) +
8d419f
+                               (((v->source || v->line > 0) && v->column > 0) ? 1 : 0) +
8d419f
+                               (v->column > 0 ? k : 0) +
8d419f
+                               2;
8d419f
+
8d419f
+                for (size_t i = 0; i < n; i++)
8d419f
                         fputc(' ', f);
8d419f
         } else {
8d419f
                 fputc('[', f);
8d419f
@@ -1631,10 +1614,7 @@ static int json_format(FILE *f, JsonVariant *v, JsonFormatFlags flags, const cha
8d419f
                 break;
8d419f
 
8d419f
         case JSON_VARIANT_ARRAY: {
8d419f
-                size_t i, n;
8d419f
-
8d419f
-                n = json_variant_elements(v);
8d419f
-
8d419f
+                size_t n = json_variant_elements(v);
8d419f
                 if (n == 0)
8d419f
                         fputs("[]", f);
8d419f
                 else {
8d419f
@@ -1653,7 +1633,7 @@ static int json_format(FILE *f, JsonVariant *v, JsonFormatFlags flags, const cha
8d419f
                                 fputc('[', f);
8d419f
                         }
8d419f
 
8d419f
-                        for (i = 0; i < n; i++) {
8d419f
+                        for (size_t i = 0; i < n; i++) {
8d419f
                                 JsonVariant *e;
8d419f
 
8d419f
                                 assert_se(e = json_variant_by_index(v, i));
8d419f
@@ -1687,10 +1667,7 @@ static int json_format(FILE *f, JsonVariant *v, JsonFormatFlags flags, const cha
8d419f
         }
8d419f
 
8d419f
         case JSON_VARIANT_OBJECT: {
8d419f
-                size_t i, n;
8d419f
-
8d419f
-                n = json_variant_elements(v);
8d419f
-
8d419f
+                size_t n = json_variant_elements(v);
8d419f
                 if (n == 0)
8d419f
                         fputs("{}", f);
8d419f
                 else {
8d419f
@@ -1709,7 +1686,7 @@ static int json_format(FILE *f, JsonVariant *v, JsonFormatFlags flags, const cha
8d419f
                                 fputc('{', f);
8d419f
                         }
8d419f
 
8d419f
-                        for (i = 0; i < n; i += 2) {
8d419f
+                        for (size_t i = 0; i < n; i += 2) {
8d419f
                                 JsonVariant *e;
8d419f
 
8d419f
                                 e = json_variant_by_index(v, i);
8d419f
@@ -1826,7 +1803,7 @@ void json_variant_dump(JsonVariant *v, JsonFormatFlags flags, FILE *f, const cha
8d419f
 int json_variant_filter(JsonVariant **v, char **to_remove) {
8d419f
         _cleanup_(json_variant_unrefp) JsonVariant *w = NULL;
8d419f
         _cleanup_free_ JsonVariant **array = NULL;
8d419f
-        size_t i, n = 0, k = 0;
8d419f
+        size_t n = 0, k = 0;
8d419f
         int r;
8d419f
 
8d419f
         assert(v);
8d419f
@@ -1839,7 +1816,7 @@ int json_variant_filter(JsonVariant **v, char **to_remove) {
8d419f
         if (strv_isempty(to_remove))
8d419f
                 return 0;
8d419f
 
8d419f
-        for (i = 0; i < json_variant_elements(*v); i += 2) {
8d419f
+        for (size_t i = 0; i < json_variant_elements(*v); i += 2) {
8d419f
                 JsonVariant *p;
8d419f
 
8d419f
                 p = json_variant_by_index(*v, i);
8d419f
@@ -1881,7 +1858,7 @@ int json_variant_filter(JsonVariant **v, char **to_remove) {
8d419f
 int json_variant_set_field(JsonVariant **v, const char *field, JsonVariant *value) {
8d419f
         _cleanup_(json_variant_unrefp) JsonVariant *field_variant = NULL, *w = NULL;
8d419f
         _cleanup_free_ JsonVariant **array = NULL;
8d419f
-        size_t i, k = 0;
8d419f
+        size_t k = 0;
8d419f
         int r;
8d419f
 
8d419f
         assert(v);
8d419f
@@ -1896,7 +1873,7 @@ int json_variant_set_field(JsonVariant **v, const char *field, JsonVariant *valu
8d419f
                 if (!json_variant_is_object(*v))
8d419f
                         return -EINVAL;
8d419f
 
8d419f
-                for (i = 0; i < json_variant_elements(*v); i += 2) {
8d419f
+                for (size_t i = 0; i < json_variant_elements(*v); i += 2) {
8d419f
                         JsonVariant *p;
8d419f
 
8d419f
                         p = json_variant_by_index(*v, i);
8d419f
@@ -2007,7 +1984,7 @@ int json_variant_set_field_strv(JsonVariant **v, const char *field, char **l) {
8d419f
 int json_variant_merge(JsonVariant **v, JsonVariant *m) {
8d419f
         _cleanup_(json_variant_unrefp) JsonVariant *w = NULL;
8d419f
         _cleanup_free_ JsonVariant **array = NULL;
8d419f
-        size_t v_elements, m_elements, i, k;
8d419f
+        size_t v_elements, m_elements, k;
8d419f
         bool v_blank, m_blank;
8d419f
         int r;
8d419f
 
8d419f
@@ -2040,7 +2017,7 @@ int json_variant_merge(JsonVariant **v, JsonVariant *m) {
8d419f
                 return -ENOMEM;
8d419f
 
8d419f
         k = 0;
8d419f
-        for (i = 0; i < v_elements; i += 2) {
8d419f
+        for (size_t i = 0; i < v_elements; i += 2) {
8d419f
                 JsonVariant *u;
8d419f
 
8d419f
                 u = json_variant_by_index(*v, i);
8d419f
@@ -2054,7 +2031,7 @@ int json_variant_merge(JsonVariant **v, JsonVariant *m) {
8d419f
                 array[k++] = json_variant_by_index(*v, i + 1);
8d419f
         }
8d419f
 
8d419f
-        for (i = 0; i < m_elements; i++)
8d419f
+        for (size_t i = 0; i < m_elements; i++)
8d419f
                 array[k++] = json_variant_by_index(m, i);
8d419f
 
8d419f
         r = json_variant_new_object(&w, array, k);
8d419f
@@ -2089,19 +2066,17 @@ int json_variant_append_array(JsonVariant **v, JsonVariant *element) {
8d419f
         if (blank)
8d419f
                 r = json_variant_new_array(&nv, (JsonVariant*[]) { element }, 1);
8d419f
         else {
8d419f
-                _cleanup_free_ JsonVariant **array = NULL;
8d419f
-                size_t i;
8d419f
-
8d419f
-                array = new(JsonVariant*, json_variant_elements(*v) + 1);
8d419f
+                _cleanup_free_ JsonVariant **array = new(JsonVariant*, json_variant_elements(*v) + 1);
8d419f
                 if (!array)
8d419f
                         return -ENOMEM;
8d419f
 
8d419f
-                for (i = 0; i < json_variant_elements(*v); i++)
8d419f
+                size_t size = json_variant_elements(*v);
8d419f
+                for (size_t i = 0; i < size; i++)
8d419f
                         array[i] = json_variant_by_index(*v, i);
8d419f
 
8d419f
-                array[i] = element;
8d419f
+                array[size] = element;
8d419f
 
8d419f
-                r = json_variant_new_array(&nv, array, i + 1);
8d419f
+                r = json_variant_new_array(&nv, array, size + 1);
8d419f
         }
8d419f
         if (r < 0)
8d419f
                 return r;
8d419f
@@ -2116,7 +2091,6 @@ int json_variant_append_array(JsonVariant **v, JsonVariant *element) {
8d419f
 
8d419f
 int json_variant_strv(JsonVariant *v, char ***ret) {
8d419f
         char **l = NULL;
8d419f
-        size_t n, i;
8d419f
         bool sensitive;
8d419f
         int r;
8d419f
 
8d419f
@@ -2136,12 +2110,12 @@ int json_variant_strv(JsonVariant *v, char ***ret) {
8d419f
 
8d419f
         sensitive = v->sensitive;
8d419f
 
8d419f
-        n = json_variant_elements(v);
8d419f
+        size_t n = json_variant_elements(v);
8d419f
         l = new(char*, n+1);
8d419f
         if (!l)
8d419f
                 return -ENOMEM;
8d419f
 
8d419f
-        for (i = 0; i < n; i++) {
8d419f
+        for (size_t i = 0; i < n; i++) {
8d419f
                 JsonVariant *e;
8d419f
 
8d419f
                 assert_se(e = json_variant_by_index(v, i));
8d419f
@@ -2160,7 +2134,7 @@ int json_variant_strv(JsonVariant *v, char ***ret) {
8d419f
                 }
8d419f
         }
8d419f
 
8d419f
-        l[i] = NULL;
8d419f
+        l[n] = NULL;
8d419f
         *ret = TAKE_PTR(l);
8d419f
 
8d419f
         return 0;
8d419f
@@ -2847,7 +2821,7 @@ static int json_parse_internal(
8d419f
                 unsigned *column,
8d419f
                 bool continue_end) {
8d419f
 
8d419f
-        size_t n_stack = 1, i;
8d419f
+        size_t n_stack = 1;
8d419f
         unsigned line_buffer = 0, column_buffer = 0;
8d419f
         void *tokenizer_state = NULL;
8d419f
         JsonStack *stack = NULL;
8d419f
@@ -3186,7 +3160,7 @@ done:
8d419f
         r = 0;
8d419f
 
8d419f
 finish:
8d419f
-        for (i = 0; i < n_stack; i++)
8d419f
+        for (size_t i = 0; i < n_stack; i++)
8d419f
                 json_stack_release(stack + i);
8d419f
 
8d419f
         free(stack);
8d419f
@@ -3229,7 +3203,7 @@ int json_parse_file_at(FILE *f, int dir_fd, const char *path, JsonParseFlags fla
8d419f
 
8d419f
 int json_buildv(JsonVariant **ret, va_list ap) {
8d419f
         JsonStack *stack = NULL;
8d419f
-        size_t n_stack = 1, i;
8d419f
+        size_t n_stack = 1;
8d419f
         int r;
8d419f
 
8d419f
         assert_return(ret, -EINVAL);
8d419f
@@ -4147,7 +4121,7 @@ done:
8d419f
         r = 0;
8d419f
 
8d419f
 finish:
8d419f
-        for (i = 0; i < n_stack; i++)
8d419f
+        for (size_t i = 0; i < n_stack; i++)
8d419f
                 json_stack_release(stack + i);
8d419f
 
8d419f
         free(stack);
8d419f
@@ -4231,8 +4205,7 @@ int json_log_internal(
8d419f
 }
8d419f
 
8d419f
 int json_dispatch(JsonVariant *v, const JsonDispatch table[], JsonDispatchCallback bad, JsonDispatchFlags flags, void *userdata) {
8d419f
-        const JsonDispatch *p;
8d419f
-        size_t i, n, m;
8d419f
+        size_t m;
8d419f
         int r, done = 0;
8d419f
         bool *found;
8d419f
 
8d419f
@@ -4245,14 +4218,16 @@ int json_dispatch(JsonVariant *v, const JsonDispatch table[], JsonDispatchCallba
8d419f
                 return -EINVAL;
8d419f
         }
8d419f
 
8d419f
-        for (p = table, m = 0; p->name; p++)
8d419f
+        m = 0;
8d419f
+        for (const JsonDispatch *p = table; p->name; p++)
8d419f
                 m++;
8d419f
 
8d419f
         found = newa0(bool, m);
8d419f
 
8d419f
-        n = json_variant_elements(v);
8d419f
-        for (i = 0; i < n; i += 2) {
8d419f
+        size_t n = json_variant_elements(v);
8d419f
+        for (size_t i = 0; i < n; i += 2) {
8d419f
                 JsonVariant *key, *value;
8d419f
+                const JsonDispatch *p;
8d419f
 
8d419f
                 assert_se(key = json_variant_by_index(v, i));
8d419f
                 assert_se(value = json_variant_by_index(v, i+1));
8d419f
@@ -4326,7 +4301,7 @@ int json_dispatch(JsonVariant *v, const JsonDispatch table[], JsonDispatchCallba
8d419f
                 }
8d419f
         }
8d419f
 
8d419f
-        for (p = table; p->name; p++) {
8d419f
+        for (const JsonDispatch *p = table; p->name; p++) {
8d419f
                 JsonDispatchFlags merged_flags = p->flags | flags;
8d419f
 
8d419f
                 if ((merged_flags & JSON_MANDATORY) && !found[p-table]) {
8d419f
@@ -4621,7 +4596,7 @@ static int json_cmp_strings(const void *x, const void *y) {
8d419f
 int json_variant_sort(JsonVariant **v) {
8d419f
         _cleanup_free_ JsonVariant **a = NULL;
8d419f
         JsonVariant *n = NULL;
8d419f
-        size_t i, m;
8d419f
+        size_t m;
8d419f
         int r;
8d419f
 
8d419f
         assert(v);
8d419f
@@ -4639,7 +4614,7 @@ int json_variant_sort(JsonVariant **v) {
8d419f
         if (!a)
8d419f
                 return -ENOMEM;
8d419f
 
8d419f
-        for (i = 0; i < m; i++)
8d419f
+        for (size_t i = 0; i < m; i++)
8d419f
                 a[i] = json_variant_by_index(*v, i);
8d419f
 
8d419f
         qsort(a, m/2, sizeof(JsonVariant*)*2, json_cmp_strings);
8d419f
@@ -4662,7 +4637,7 @@ int json_variant_sort(JsonVariant **v) {
8d419f
 int json_variant_normalize(JsonVariant **v) {
8d419f
         _cleanup_free_ JsonVariant **a = NULL;
8d419f
         JsonVariant *n = NULL;
8d419f
-        size_t i, j, m;
8d419f
+        size_t i, m;
8d419f
         int r;
8d419f
 
8d419f
         assert(v);
8d419f
@@ -4714,7 +4689,7 @@ int json_variant_normalize(JsonVariant **v) {
8d419f
         r = 1;
8d419f
 
8d419f
 finish:
8d419f
-        for (j = 0; j < i; j++)
8d419f
+        for (size_t j = 0; j < i; j++)
8d419f
                 json_variant_unref(a[j]);
8d419f
 
8d419f
         return r;