mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-26 10:03:40 +03:00
Merge pull request #15833 from AsamK/busctl_introspect_method_signature
busctl: Add introspect support for methods with same name but different signature
This commit is contained in:
commit
844768c78b
@ -742,6 +742,9 @@ static void member_hash_func(const Member *m, struct siphash *state) {
|
|||||||
if (m->name)
|
if (m->name)
|
||||||
string_hash_func(m->name, state);
|
string_hash_func(m->name, state);
|
||||||
|
|
||||||
|
if (m->signature)
|
||||||
|
string_hash_func(m->signature, state);
|
||||||
|
|
||||||
if (m->interface)
|
if (m->interface)
|
||||||
string_hash_func(m->interface, state);
|
string_hash_func(m->interface, state);
|
||||||
}
|
}
|
||||||
@ -762,7 +765,11 @@ static int member_compare_func(const Member *x, const Member *y) {
|
|||||||
if (d != 0)
|
if (d != 0)
|
||||||
return d;
|
return d;
|
||||||
|
|
||||||
return strcmp_ptr(x->name, y->name);
|
d = strcmp_ptr(x->name, y->name);
|
||||||
|
if (d != 0)
|
||||||
|
return d;
|
||||||
|
|
||||||
|
return strcmp_ptr(x->signature, y->signature);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int member_compare_funcp(Member * const *a, Member * const *b) {
|
static int member_compare_funcp(Member * const *a, Member * const *b) {
|
||||||
@ -809,8 +816,9 @@ static int on_interface(const char *interface, uint64_t flags, void *userdata) {
|
|||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
r = set_put(members, m);
|
r = set_put(members, m);
|
||||||
if (r == -EEXIST)
|
if (r == 0)
|
||||||
return log_error_errno(r, "Invalid introspection data: duplicate interface '%s'.", interface);
|
return log_error_errno(SYNTHETIC_ERRNO(EEXIST),
|
||||||
|
"Invalid introspection data: duplicate interface '%s'.", interface);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
@ -852,8 +860,9 @@ static int on_method(const char *interface, const char *name, const char *signat
|
|||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
r = set_put(members, m);
|
r = set_put(members, m);
|
||||||
if (r == -EEXIST)
|
if (r == 0)
|
||||||
return log_error_errno(r, "Invalid introspection data: duplicate method '%s' on interface '%s'.", name, interface);
|
return log_error_errno(SYNTHETIC_ERRNO(EEXIST),
|
||||||
|
"Invalid introspection data: duplicate method '%s' on interface '%s'.", name, interface);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
@ -891,8 +900,9 @@ static int on_signal(const char *interface, const char *name, const char *signat
|
|||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
r = set_put(members, m);
|
r = set_put(members, m);
|
||||||
if (r == -EEXIST)
|
if (r == 0)
|
||||||
return log_error_errno(r, "Invalid introspection data: duplicate signal '%s' on interface '%s'.", name, interface);
|
return log_error_errno(SYNTHETIC_ERRNO(EEXIST),
|
||||||
|
"Invalid introspection data: duplicate signal '%s' on interface '%s'.", name, interface);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
@ -931,8 +941,9 @@ static int on_property(const char *interface, const char *name, const char *sign
|
|||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
r = set_put(members, m);
|
r = set_put(members, m);
|
||||||
if (r == -EEXIST)
|
if (r == 0)
|
||||||
return log_error_errno(r, "Invalid introspection data: duplicate property '%s' on interface '%s'.", name, interface);
|
return log_error_errno(SYNTHETIC_ERRNO(EEXIST),
|
||||||
|
"Invalid introspection data: duplicate property '%s' on interface '%s'.", name, interface);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user