]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
network: json: make {network,device}_build_json() accept NULL
authorYu Watanabe <watanabe.yu+github@gmail.com>
Sun, 14 Nov 2021 05:53:36 +0000 (14:53 +0900)
committerYu Watanabe <watanabe.yu+github@gmail.com>
Thu, 25 Nov 2021 13:35:35 +0000 (22:35 +0900)
src/network/networkd-json.c

index cd39a8149ae00317a19a9c9df05d186b9364c9e5..e8e6daf0925ba4003c648d2b2667db45a970092c 100644 (file)
@@ -8,9 +8,13 @@
 #include "sort-util.h"
 
 static int network_build_json(Network *network, JsonVariant **ret) {
-        assert(network);
         assert(ret);
 
+        if (!network) {
+                *ret = NULL;
+                return 0;
+        }
+
         return json_build(ret, JSON_BUILD_OBJECT(
                                 JSON_BUILD_PAIR_STRING("NetworkFile", network->filename)));
 }
@@ -18,9 +22,13 @@ static int network_build_json(Network *network, JsonVariant **ret) {
 static int device_build_json(sd_device *device, JsonVariant **ret) {
         const char *link = NULL, *path = NULL, *vendor = NULL, *model = NULL;
 
-        assert(device);
         assert(ret);
 
+        if (!device) {
+                *ret = NULL;
+                return 0;
+        }
+
         (void) sd_device_get_property_value(device, "ID_NET_LINK_FILE", &link);
         (void) sd_device_get_property_value(device, "ID_PATH", &path);
 
@@ -38,7 +46,7 @@ static int device_build_json(sd_device *device, JsonVariant **ret) {
 }
 
 int link_build_json(Link *link, JsonVariant **ret) {
-        _cleanup_(json_variant_unrefp) JsonVariant *v = NULL;
+        _cleanup_(json_variant_unrefp) JsonVariant *v = NULL, *w = NULL;
         _cleanup_free_ char *type = NULL;
         int r;
 
@@ -65,29 +73,23 @@ int link_build_json(Link *link, JsonVariant **ret) {
         if (r < 0)
                 return r;
 
-        if (link->network) {
-                _cleanup_(json_variant_unrefp) JsonVariant *w = NULL;
-
-                r = network_build_json(link->network, &w);
-                if (r < 0)
-                        return r;
+        r = network_build_json(link->network, &w);
+        if (r < 0)
+                return r;
 
-                r = json_variant_merge(&v, w);
-                if (r < 0)
-                        return r;
-        }
+        r = json_variant_merge(&v, w);
+        if (r < 0)
+                return r;
 
-        if (link->sd_device) {
-                _cleanup_(json_variant_unrefp) JsonVariant *w = NULL;
+        w = json_variant_unref(w);
 
-                r = device_build_json(link->sd_device, &w);
-                if (r < 0)
-                        return r;
+        r = device_build_json(link->sd_device, &w);
+        if (r < 0)
+                return r;
 
-                r = json_variant_merge(&v, w);
-                if (r < 0)
-                        return r;
-        }
+        r = json_variant_merge(&v, w);
+        if (r < 0)
+                return r;
 
         *ret = TAKE_PTR(v);
         return 0;