Skip to content

Commit 3866e9c

Browse files
poetteringdaandemeyer
authored andcommitted
sd-json: add json_dispatch_const_path() helper
The new json_dispatch_const_path() is to json_dispatch_path() what sd_json_dispatch_const_string() is to sd_json_dispatch_ string(), i.e. doesn't implicitly strdup() the string, but gives you the pointer into the JSON structure, and thus requires you to keep it pinned.
1 parent b0d0b08 commit 3866e9c

File tree

2 files changed

+19
-4
lines changed

2 files changed

+19
-4
lines changed

src/libsystemd/sd-json/json-util.c

Lines changed: 18 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -125,14 +125,13 @@ int json_dispatch_in_addr(const char *name, sd_json_variant *variant, sd_json_di
125125
return 0;
126126
}
127127

128-
int json_dispatch_path(const char *name, sd_json_variant *variant, sd_json_dispatch_flags_t flags, void *userdata) {
129-
char **p = ASSERT_PTR(userdata);
130-
const char *path;
128+
int json_dispatch_const_path(const char *name, sd_json_variant *variant, sd_json_dispatch_flags_t flags, void *userdata) {
129+
const char **p = ASSERT_PTR(userdata), *path;
131130

132131
assert(variant);
133132

134133
if (sd_json_variant_is_null(variant)) {
135-
*p = mfree(*p);
134+
*p = NULL;
136135
return 0;
137136
}
138137

@@ -145,6 +144,21 @@ int json_dispatch_path(const char *name, sd_json_variant *variant, sd_json_dispa
145144
if (!path_is_absolute(path))
146145
return json_log(variant, flags, SYNTHETIC_ERRNO(EINVAL), "JSON field '%s' is not an absolute file system path.", strna(name));
147146

147+
*p = path;
148+
return 0;
149+
}
150+
151+
int json_dispatch_path(const char *name, sd_json_variant *variant, sd_json_dispatch_flags_t flags, void *userdata) {
152+
char **p = ASSERT_PTR(userdata);
153+
const char *path;
154+
int r;
155+
156+
assert_return(variant, -EINVAL);
157+
158+
r = json_dispatch_const_path(name, variant, flags, &path);
159+
if (r < 0)
160+
return r;
161+
148162
if (free_and_strdup(p, path) < 0)
149163
return json_log_oom(variant, flags);
150164

src/libsystemd/sd-json/json-util.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -113,6 +113,7 @@ int json_dispatch_user_group_name(const char *name, sd_json_variant *variant, sd
113113
int json_dispatch_const_user_group_name(const char *name, sd_json_variant *variant, sd_json_dispatch_flags_t flags, void *userdata);
114114
int json_dispatch_in_addr(const char *name, sd_json_variant *variant, sd_json_dispatch_flags_t flags, void *userdata);
115115
int json_dispatch_path(const char *name, sd_json_variant *variant, sd_json_dispatch_flags_t flags, void *userdata);
116+
int json_dispatch_const_path(const char *name, sd_json_variant *variant, sd_json_dispatch_flags_t flags, void *userdata);
116117
int json_dispatch_pidref(const char *name, sd_json_variant *variant, sd_json_dispatch_flags_t flags, void *userdata);
117118
int json_dispatch_devnum(const char *name, sd_json_variant *variant, sd_json_dispatch_flags_t flags, void *userdata);
118119
int json_dispatch_ifindex(const char *name, sd_json_variant *variant, sd_json_dispatch_flags_t flags, void *userdata);

0 commit comments

Comments
 (0)