X-Git-Url: https://git.sur5r.net/?p=i3%2Fi3;a=blobdiff_plain;f=src%2Fassignments.c;fp=src%2Fassignments.c;h=abacc0a3658990b0e752749e6ff8146afdf24039;hp=a0f5d5a747b79f02c23d1dfe478b5ef59c9e03ae;hb=1847938d4eeba98260cc79ca45a11a134274c2ea;hpb=c54f5008395b10c046f380cc3069ff779e5d2877 diff --git a/src/assignments.c b/src/assignments.c index a0f5d5a7..abacc0a3 100644 --- a/src/assignments.c +++ b/src/assignments.c @@ -22,7 +22,7 @@ void run_assignments(i3Window *window) { /* Check if any assignments match */ Assignment *current; TAILQ_FOREACH(current, &assignments, assignments) { - if (!match_matches_window(&(current->match), window)) + if (current->type != A_COMMAND || !match_matches_window(&(current->match), window)) continue; bool skip = false; @@ -45,19 +45,16 @@ void run_assignments(i3Window *window) { window->ran_assignments = srealloc(window->ran_assignments, sizeof(Assignment *) * window->nr_assignments); window->ran_assignments[window->nr_assignments - 1] = current; - DLOG("matching assignment, would do:\n"); - if (current->type == A_COMMAND) { - DLOG("execute command %s\n", current->dest.command); - char *full_command; - sasprintf(&full_command, "[id=\"%d\"] %s", window->id, current->dest.command); - CommandResult *result = parse_command(full_command, NULL); - free(full_command); + DLOG("matching assignment, execute command %s\n", current->dest.command); + char *full_command; + sasprintf(&full_command, "[id=\"%d\"] %s", window->id, current->dest.command); + CommandResult *result = parse_command(full_command, NULL); + free(full_command); - if (result->needs_tree_render) - needs_tree_render = true; + if (result->needs_tree_render) + needs_tree_render = true; - command_result_free(result); - } + command_result_free(result); } /* If any of the commands required re-rendering, we will do that now. */