1
0
mirror of https://github.com/systemd/systemd.git synced 2024-11-08 11:27:32 +03:00

analyze: add alias handling for --{from,to}-pattern options

`systemd-analyze dot --from-pattern default.target` works fine
This commit is contained in:
Evgeny Vereshchagin 2015-09-07 01:34:33 +03:00
parent 2009bcfd23
commit 4387795e0e

View File

@ -1016,7 +1016,7 @@ static int analyze_time(sd_bus *bus) {
return 0; return 0;
} }
static int graph_one_property(sd_bus *bus, const UnitInfo *u, const char* prop, const char *color, char* patterns[]) { static int graph_one_property(sd_bus *bus, const UnitInfo *u, const char* prop, const char *color, char* patterns[], char* from_patterns[], char* to_patterns[]) {
_cleanup_strv_free_ char **units = NULL; _cleanup_strv_free_ char **units = NULL;
char **unit; char **unit;
int r; int r;
@ -1028,9 +1028,9 @@ static int graph_one_property(sd_bus *bus, const UnitInfo *u, const char* prop,
match_patterns = strv_fnmatch(patterns, u->id, 0); match_patterns = strv_fnmatch(patterns, u->id, 0);
if (!strv_isempty(arg_dot_from_patterns) && if (!strv_isempty(from_patterns) &&
!match_patterns && !match_patterns &&
!strv_fnmatch(arg_dot_from_patterns, u->id, 0)) !strv_fnmatch(from_patterns, u->id, 0))
return 0; return 0;
r = bus_get_unit_property_strv(bus, u->unit_path, prop, &units); r = bus_get_unit_property_strv(bus, u->unit_path, prop, &units);
@ -1042,9 +1042,9 @@ static int graph_one_property(sd_bus *bus, const UnitInfo *u, const char* prop,
match_patterns2 = strv_fnmatch(patterns, *unit, 0); match_patterns2 = strv_fnmatch(patterns, *unit, 0);
if (!strv_isempty(arg_dot_to_patterns) && if (!strv_isempty(to_patterns) &&
!match_patterns2 && !match_patterns2 &&
!strv_fnmatch(arg_dot_to_patterns, *unit, 0)) !strv_fnmatch(to_patterns, *unit, 0))
continue; continue;
if (!strv_isempty(patterns) && !match_patterns && !match_patterns2) if (!strv_isempty(patterns) && !match_patterns && !match_patterns2)
@ -1056,35 +1056,35 @@ static int graph_one_property(sd_bus *bus, const UnitInfo *u, const char* prop,
return 0; return 0;
} }
static int graph_one(sd_bus *bus, const UnitInfo *u, char *patterns[]) { static int graph_one(sd_bus *bus, const UnitInfo *u, char *patterns[], char *from_patterns[], char *to_patterns[]) {
int r; int r;
assert(bus); assert(bus);
assert(u); assert(u);
if (arg_dot == DEP_ORDER ||arg_dot == DEP_ALL) { if (arg_dot == DEP_ORDER ||arg_dot == DEP_ALL) {
r = graph_one_property(bus, u, "After", "green", patterns); r = graph_one_property(bus, u, "After", "green", patterns, from_patterns, to_patterns);
if (r < 0) if (r < 0)
return r; return r;
} }
if (arg_dot == DEP_REQUIRE ||arg_dot == DEP_ALL) { if (arg_dot == DEP_REQUIRE ||arg_dot == DEP_ALL) {
r = graph_one_property(bus, u, "Requires", "black", patterns); r = graph_one_property(bus, u, "Requires", "black", patterns, from_patterns, to_patterns);
if (r < 0) if (r < 0)
return r; return r;
r = graph_one_property(bus, u, "RequiresOverridable", "black", patterns); r = graph_one_property(bus, u, "RequiresOverridable", "black", patterns, from_patterns, to_patterns);
if (r < 0) if (r < 0)
return r; return r;
r = graph_one_property(bus, u, "RequisiteOverridable", "darkblue", patterns); r = graph_one_property(bus, u, "RequisiteOverridable", "darkblue", patterns, from_patterns, to_patterns);
if (r < 0) if (r < 0)
return r; return r;
r = graph_one_property(bus, u, "Wants", "grey66", patterns); r = graph_one_property(bus, u, "Wants", "grey66", patterns, from_patterns, to_patterns);
if (r < 0) if (r < 0)
return r; return r;
r = graph_one_property(bus, u, "Conflicts", "red", patterns); r = graph_one_property(bus, u, "Conflicts", "red", patterns, from_patterns, to_patterns);
if (r < 0) if (r < 0)
return r; return r;
r = graph_one_property(bus, u, "ConflictedBy", "red", patterns); r = graph_one_property(bus, u, "ConflictedBy", "red", patterns, from_patterns, to_patterns);
if (r < 0) if (r < 0)
return r; return r;
} }
@ -1138,6 +1138,8 @@ static int dot(sd_bus *bus, char* patterns[]) {
_cleanup_bus_message_unref_ sd_bus_message *reply = NULL; _cleanup_bus_message_unref_ sd_bus_message *reply = NULL;
_cleanup_bus_error_free_ sd_bus_error error = SD_BUS_ERROR_NULL; _cleanup_bus_error_free_ sd_bus_error error = SD_BUS_ERROR_NULL;
_cleanup_strv_free_ char **expanded_patterns = NULL; _cleanup_strv_free_ char **expanded_patterns = NULL;
_cleanup_strv_free_ char **expanded_from_patterns = NULL;
_cleanup_strv_free_ char **expanded_to_patterns = NULL;
int r; int r;
UnitInfo u; UnitInfo u;
@ -1145,6 +1147,14 @@ static int dot(sd_bus *bus, char* patterns[]) {
if (r < 0) if (r < 0)
return r; return r;
r = expand_patterns(bus, arg_dot_from_patterns, &expanded_from_patterns);
if (r < 0)
return r;
r = expand_patterns(bus, arg_dot_to_patterns, &expanded_to_patterns);
if (r < 0)
return r;
r = sd_bus_call_method( r = sd_bus_call_method(
bus, bus,
"org.freedesktop.systemd1", "org.freedesktop.systemd1",
@ -1167,7 +1177,7 @@ static int dot(sd_bus *bus, char* patterns[]) {
while ((r = bus_parse_unit_info(reply, &u)) > 0) { while ((r = bus_parse_unit_info(reply, &u)) > 0) {
r = graph_one(bus, &u, expanded_patterns); r = graph_one(bus, &u, expanded_patterns, expanded_from_patterns, expanded_to_patterns);
if (r < 0) if (r < 0)
return r; return r;
} }