Introduce output_primary_name function
Currently simply returns output->name, but this will make it easier to change how output names are stored in the following commits. Also replace reading output->name with invocations of output_primary_name. Code which writes output->name is unchanged. Done using a mostly mechanical replacement of output->name to output_primary_name(output).
This commit is contained in:
parent
d0c9e81f04
commit
1b419431cd
|
@ -24,6 +24,12 @@ Con *output_get_content(Con *output);
|
||||||
*/
|
*/
|
||||||
Output *get_output_from_string(Output *current_output, const char *output_str);
|
Output *get_output_from_string(Output *current_output, const char *output_str);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves the primary name of an output.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
char *output_primary_name(Output *output);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the output for the given con.
|
* Returns the output for the given con.
|
||||||
*
|
*
|
||||||
|
|
|
@ -1264,7 +1264,7 @@ void con_move_to_output(Con *con, Output *output) {
|
||||||
Con *ws = NULL;
|
Con *ws = NULL;
|
||||||
GREP_FIRST(ws, output_get_content(output->con), workspace_is_visible(child));
|
GREP_FIRST(ws, output_get_content(output->con), workspace_is_visible(child));
|
||||||
assert(ws != NULL);
|
assert(ws != NULL);
|
||||||
DLOG("Moving con %p to output %s\n", con, output->name);
|
DLOG("Moving con %p to output %s\n", con, output_primary_name(output));
|
||||||
con_move_to_workspace(con, ws, false, false, false);
|
con_move_to_workspace(con, ws, false, false, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -49,7 +49,7 @@ void fake_outputs_init(const char *output_spec) {
|
||||||
} else {
|
} else {
|
||||||
new_output = scalloc(1, sizeof(Output));
|
new_output = scalloc(1, sizeof(Output));
|
||||||
sasprintf(&(new_output->name), "fake-%d", num_screens);
|
sasprintf(&(new_output->name), "fake-%d", num_screens);
|
||||||
DLOG("Created new fake output %s (%p)\n", new_output->name, new_output);
|
DLOG("Created new fake output %s (%p)\n", output_primary_name(new_output), new_output);
|
||||||
new_output->active = true;
|
new_output->active = true;
|
||||||
new_output->rect.x = x;
|
new_output->rect.x = x;
|
||||||
new_output->rect.y = y;
|
new_output->rect.y = y;
|
||||||
|
|
|
@ -388,7 +388,7 @@ static void handle_configure_request(xcb_configure_request_event_t *event) {
|
||||||
Con *current_output = con_get_output(con);
|
Con *current_output = con_get_output(con);
|
||||||
Output *target = get_output_containing(x, y);
|
Output *target = get_output_containing(x, y);
|
||||||
if (target != NULL && current_output != target->con) {
|
if (target != NULL && current_output != target->con) {
|
||||||
DLOG("Dock client is requested to be moved to output %s, moving it there.\n", target->name);
|
DLOG("Dock client is requested to be moved to output %s, moving it there.\n", output_primary_name(target));
|
||||||
Match *match;
|
Match *match;
|
||||||
Con *nc = con_for_window(target->con, con->window, &match);
|
Con *nc = con_for_window(target->con, con->window, &match);
|
||||||
DLOG("Dock client will be moved to container %p.\n", nc);
|
DLOG("Dock client will be moved to container %p.\n", nc);
|
||||||
|
|
|
@ -829,7 +829,7 @@ IPC_HANDLER(get_outputs) {
|
||||||
y(map_open);
|
y(map_open);
|
||||||
|
|
||||||
ystr("name");
|
ystr("name");
|
||||||
ystr(output->name);
|
ystr(output_primary_name(output));
|
||||||
|
|
||||||
ystr("active");
|
ystr("active");
|
||||||
y(bool, output->active);
|
y(bool, output->active);
|
||||||
|
|
|
@ -687,7 +687,7 @@ int main(int argc, char *argv[]) {
|
||||||
TAILQ_FOREACH(con, &(croot->nodes_head), nodes) {
|
TAILQ_FOREACH(con, &(croot->nodes_head), nodes) {
|
||||||
Output *output;
|
Output *output;
|
||||||
TAILQ_FOREACH(output, &outputs, outputs) {
|
TAILQ_FOREACH(output, &outputs, outputs) {
|
||||||
if (output->active || strcmp(con->name, output->name) != 0)
|
if (output->active || strcmp(con->name, output_primary_name(output)) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* This will correctly correlate the output with its content
|
/* This will correctly correlate the output with its content
|
||||||
|
|
|
@ -219,7 +219,7 @@ void manage_window(xcb_window_t window, xcb_get_window_attributes_cookie_t cooki
|
||||||
LOG("This window is of type dock\n");
|
LOG("This window is of type dock\n");
|
||||||
Output *output = get_output_containing(geom->x, geom->y);
|
Output *output = get_output_containing(geom->x, geom->y);
|
||||||
if (output != NULL) {
|
if (output != NULL) {
|
||||||
DLOG("Starting search at output %s\n", output->name);
|
DLOG("Starting search at output %s\n", output_primary_name(output));
|
||||||
search_at = output->con;
|
search_at = output->con;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -44,6 +44,14 @@ Output *get_output_from_string(Output *current_output, const char *output_str) {
|
||||||
return get_output_by_name(output_str, true);
|
return get_output_by_name(output_str, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Retrieves the primary name of an output.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
char *output_primary_name(Output *output) {
|
||||||
|
return output->name;
|
||||||
|
}
|
||||||
|
|
||||||
Output *get_output_for_con(Con *con) {
|
Output *get_output_for_con(Con *con) {
|
||||||
Con *output_con = con_get_output(con);
|
Con *output_con = con_get_output(con);
|
||||||
if (output_con == NULL) {
|
if (output_con == NULL) {
|
||||||
|
|
38
src/randr.c
38
src/randr.c
|
@ -49,7 +49,7 @@ Output *get_output_by_name(const char *name, const bool require_active) {
|
||||||
bool get_primary = (strcasecmp("primary", name) == 0);
|
bool get_primary = (strcasecmp("primary", name) == 0);
|
||||||
TAILQ_FOREACH(output, &outputs, outputs) {
|
TAILQ_FOREACH(output, &outputs, outputs) {
|
||||||
if ((output->primary && get_primary) ||
|
if ((output->primary && get_primary) ||
|
||||||
((!require_active || output->active) && strcasecmp(output->name, name) == 0)) {
|
((!require_active || output->active) && strcasecmp(output_primary_name(output), name) == 0)) {
|
||||||
return output;
|
return output;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -178,7 +178,7 @@ Output *get_output_next_wrap(direction_t direction, Output *current) {
|
||||||
}
|
}
|
||||||
if (!best)
|
if (!best)
|
||||||
best = current;
|
best = current;
|
||||||
DLOG("current = %s, best = %s\n", current->name, best->name);
|
DLOG("current = %s, best = %s\n", output_primary_name(current), output_primary_name(best));
|
||||||
return best;
|
return best;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -250,7 +250,7 @@ Output *get_output_next(direction_t direction, Output *current, output_close_far
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
DLOG("current = %s, best = %s\n", current->name, (best ? best->name : "NULL"));
|
DLOG("current = %s, best = %s\n", output_primary_name(current), (best ? output_primary_name(best) : "NULL"));
|
||||||
return best;
|
return best;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -280,12 +280,12 @@ void output_init_con(Output *output) {
|
||||||
Con *con = NULL, *current;
|
Con *con = NULL, *current;
|
||||||
bool reused = false;
|
bool reused = false;
|
||||||
|
|
||||||
DLOG("init_con for output %s\n", output->name);
|
DLOG("init_con for output %s\n", output_primary_name(output));
|
||||||
|
|
||||||
/* Search for a Con with that name directly below the root node. There
|
/* Search for a Con with that name directly below the root node. There
|
||||||
* might be one from a restored layout. */
|
* might be one from a restored layout. */
|
||||||
TAILQ_FOREACH(current, &(croot->nodes_head), nodes) {
|
TAILQ_FOREACH(current, &(croot->nodes_head), nodes) {
|
||||||
if (strcmp(current->name, output->name) != 0)
|
if (strcmp(current->name, output_primary_name(output)) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
con = current;
|
con = current;
|
||||||
|
@ -297,7 +297,7 @@ void output_init_con(Output *output) {
|
||||||
if (con == NULL) {
|
if (con == NULL) {
|
||||||
con = con_new(croot, NULL);
|
con = con_new(croot, NULL);
|
||||||
FREE(con->name);
|
FREE(con->name);
|
||||||
con->name = sstrdup(output->name);
|
con->name = sstrdup(output_primary_name(output));
|
||||||
con->type = CT_OUTPUT;
|
con->type = CT_OUTPUT;
|
||||||
con->layout = L_OUTPUT;
|
con->layout = L_OUTPUT;
|
||||||
con_fix_percent(croot);
|
con_fix_percent(croot);
|
||||||
|
@ -384,7 +384,7 @@ void init_ws_for_output(Output *output, Con *content) {
|
||||||
/* go through all assignments and move the existing workspaces to this output */
|
/* go through all assignments and move the existing workspaces to this output */
|
||||||
struct Workspace_Assignment *assignment;
|
struct Workspace_Assignment *assignment;
|
||||||
TAILQ_FOREACH(assignment, &ws_assignments, ws_assignments) {
|
TAILQ_FOREACH(assignment, &ws_assignments, ws_assignments) {
|
||||||
if (strcmp(assignment->output, output->name) != 0)
|
if (strcmp(assignment->output, output_primary_name(output)) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* check if this workspace actually exists */
|
/* check if this workspace actually exists */
|
||||||
|
@ -402,13 +402,13 @@ void init_ws_for_output(Output *output, Con *content) {
|
||||||
LOG("Workspace \"%s\" assigned to output \"%s\", but it is already "
|
LOG("Workspace \"%s\" assigned to output \"%s\", but it is already "
|
||||||
"there. Do you have two assignment directives for the same "
|
"there. Do you have two assignment directives for the same "
|
||||||
"workspace in your configuration file?\n",
|
"workspace in your configuration file?\n",
|
||||||
workspace->name, output->name);
|
workspace->name, output_primary_name(output));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* if so, move it over */
|
/* if so, move it over */
|
||||||
LOG("Moving workspace \"%s\" from output \"%s\" to \"%s\" due to assignment\n",
|
LOG("Moving workspace \"%s\" from output \"%s\" to \"%s\" due to assignment\n",
|
||||||
workspace->name, workspace_out->name, output->name);
|
workspace->name, workspace_out->name, output_primary_name(output));
|
||||||
|
|
||||||
/* if the workspace is currently visible on that output, we need to
|
/* if the workspace is currently visible on that output, we need to
|
||||||
* switch to a different workspace - otherwise the output would end up
|
* switch to a different workspace - otherwise the output would end up
|
||||||
|
@ -445,7 +445,7 @@ void init_ws_for_output(Output *output, Con *content) {
|
||||||
workspace_out->name);
|
workspace_out->name);
|
||||||
init_ws_for_output(get_output_by_name(workspace_out->name, true),
|
init_ws_for_output(get_output_by_name(workspace_out->name, true),
|
||||||
output_get_content(workspace_out));
|
output_get_content(workspace_out));
|
||||||
DLOG("Done re-initializing, continuing with \"%s\"\n", output->name);
|
DLOG("Done re-initializing, continuing with \"%s\"\n", output_primary_name(output));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -465,7 +465,7 @@ void init_ws_for_output(Output *output, Con *content) {
|
||||||
|
|
||||||
/* otherwise, we create the first assigned ws for this output */
|
/* otherwise, we create the first assigned ws for this output */
|
||||||
TAILQ_FOREACH(assignment, &ws_assignments, ws_assignments) {
|
TAILQ_FOREACH(assignment, &ws_assignments, ws_assignments) {
|
||||||
if (strcmp(assignment->output, output->name) != 0)
|
if (strcmp(assignment->output, output_primary_name(output)) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
LOG("Initializing first assigned workspace \"%s\" for output \"%s\"\n",
|
LOG("Initializing first assigned workspace \"%s\" for output \"%s\"\n",
|
||||||
|
@ -652,7 +652,7 @@ static void handle_output(xcb_connection_t *conn, xcb_randr_output_t id,
|
||||||
xcb_randr_get_output_info_name_length(output),
|
xcb_randr_get_output_info_name_length(output),
|
||||||
xcb_randr_get_output_info_name(output));
|
xcb_randr_get_output_info_name(output));
|
||||||
|
|
||||||
DLOG("found output with name %s\n", new->name);
|
DLOG("found output with name %s\n", output_primary_name(new));
|
||||||
|
|
||||||
/* Even if no CRTC is used at the moment, we store the output so that
|
/* Even if no CRTC is used at the moment, we store the output so that
|
||||||
* we do not need to change the list ever again (we only update the
|
* we do not need to change the list ever again (we only update the
|
||||||
|
@ -672,7 +672,7 @@ static void handle_output(xcb_connection_t *conn, xcb_randr_output_t id,
|
||||||
icookie = xcb_randr_get_crtc_info(conn, output->crtc, cts);
|
icookie = xcb_randr_get_crtc_info(conn, output->crtc, cts);
|
||||||
if ((crtc = xcb_randr_get_crtc_info_reply(conn, icookie, NULL)) == NULL) {
|
if ((crtc = xcb_randr_get_crtc_info_reply(conn, icookie, NULL)) == NULL) {
|
||||||
DLOG("Skipping output %s: could not get CRTC (%p)\n",
|
DLOG("Skipping output %s: could not get CRTC (%p)\n",
|
||||||
new->name, crtc);
|
output_primary_name(new), crtc);
|
||||||
free(new);
|
free(new);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -789,7 +789,7 @@ void randr_query_outputs(void) {
|
||||||
if (!output->active || output->to_be_disabled)
|
if (!output->active || output->to_be_disabled)
|
||||||
continue;
|
continue;
|
||||||
DLOG("output %p / %s, position (%d, %d), checking for clones\n",
|
DLOG("output %p / %s, position (%d, %d), checking for clones\n",
|
||||||
output, output->name, output->rect.x, output->rect.y);
|
output, output_primary_name(output), output->rect.x, output->rect.y);
|
||||||
|
|
||||||
for (other = output;
|
for (other = output;
|
||||||
other != TAILQ_END(&outputs);
|
other != TAILQ_END(&outputs);
|
||||||
|
@ -813,7 +813,7 @@ void randr_query_outputs(void) {
|
||||||
update_if_necessary(&(other->rect.width), width);
|
update_if_necessary(&(other->rect.width), width);
|
||||||
update_if_necessary(&(other->rect.height), height);
|
update_if_necessary(&(other->rect.height), height);
|
||||||
|
|
||||||
DLOG("disabling output %p (%s)\n", other, other->name);
|
DLOG("disabling output %p (%s)\n", other, output_primary_name(other));
|
||||||
other->to_be_disabled = true;
|
other->to_be_disabled = true;
|
||||||
|
|
||||||
DLOG("new output mode %d x %d, other mode %d x %d\n",
|
DLOG("new output mode %d x %d, other mode %d x %d\n",
|
||||||
|
@ -828,7 +828,7 @@ void randr_query_outputs(void) {
|
||||||
* LVDS1 gets disabled. */
|
* LVDS1 gets disabled. */
|
||||||
TAILQ_FOREACH(output, &outputs, outputs) {
|
TAILQ_FOREACH(output, &outputs, outputs) {
|
||||||
if (output->active && output->con == NULL) {
|
if (output->active && output->con == NULL) {
|
||||||
DLOG("Need to initialize a Con for output %s\n", output->name);
|
DLOG("Need to initialize a Con for output %s\n", output_primary_name(output));
|
||||||
output_init_con(output);
|
output_init_con(output);
|
||||||
output->changed = false;
|
output->changed = false;
|
||||||
}
|
}
|
||||||
|
@ -854,7 +854,7 @@ void randr_query_outputs(void) {
|
||||||
Con *content = output_get_content(output->con);
|
Con *content = output_get_content(output->con);
|
||||||
if (!TAILQ_EMPTY(&(content->nodes_head)))
|
if (!TAILQ_EMPTY(&(content->nodes_head)))
|
||||||
continue;
|
continue;
|
||||||
DLOG("Should add ws for output %s\n", output->name);
|
DLOG("Should add ws for output %s\n", output_primary_name(output));
|
||||||
init_ws_for_output(output, content);
|
init_ws_for_output(output, content);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -863,7 +863,7 @@ void randr_query_outputs(void) {
|
||||||
if (!output->primary || !output->con)
|
if (!output->primary || !output->con)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
DLOG("Focusing primary output %s\n", output->name);
|
DLOG("Focusing primary output %s\n", output_primary_name(output));
|
||||||
con_focus(con_descend_focused(output->con));
|
con_focus(con_descend_focused(output->con));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -881,7 +881,7 @@ void randr_disable_output(Output *output) {
|
||||||
assert(output->to_be_disabled);
|
assert(output->to_be_disabled);
|
||||||
|
|
||||||
output->active = false;
|
output->active = false;
|
||||||
DLOG("Output %s disabled, re-assigning workspaces/docks\n", output->name);
|
DLOG("Output %s disabled, re-assigning workspaces/docks\n", output_primary_name(output));
|
||||||
|
|
||||||
Output *first = get_first_output();
|
Output *first = get_first_output();
|
||||||
|
|
||||||
|
|
|
@ -537,7 +537,7 @@ static bool _tree_next(Con *con, char way, orientation_t orientation, bool wrap)
|
||||||
|
|
||||||
if (!current_output)
|
if (!current_output)
|
||||||
return false;
|
return false;
|
||||||
DLOG("Current output is %s\n", current_output->name);
|
DLOG("Current output is %s\n", output_primary_name(current_output));
|
||||||
|
|
||||||
/* Try to find next output */
|
/* Try to find next output */
|
||||||
direction_t direction;
|
direction_t direction;
|
||||||
|
@ -555,7 +555,7 @@ static bool _tree_next(Con *con, char way, orientation_t orientation, bool wrap)
|
||||||
next_output = get_output_next(direction, current_output, CLOSEST_OUTPUT);
|
next_output = get_output_next(direction, current_output, CLOSEST_OUTPUT);
|
||||||
if (!next_output)
|
if (!next_output)
|
||||||
return false;
|
return false;
|
||||||
DLOG("Next output is %s\n", next_output->name);
|
DLOG("Next output is %s\n", output_primary_name(next_output));
|
||||||
|
|
||||||
/* Find visible workspace on next output */
|
/* Find visible workspace on next output */
|
||||||
Con *workspace = NULL;
|
Con *workspace = NULL;
|
||||||
|
|
|
@ -188,7 +188,7 @@ Con *create_workspace_on_output(Output *output, Con *content) {
|
||||||
struct Workspace_Assignment *assignment;
|
struct Workspace_Assignment *assignment;
|
||||||
TAILQ_FOREACH(assignment, &ws_assignments, ws_assignments) {
|
TAILQ_FOREACH(assignment, &ws_assignments, ws_assignments) {
|
||||||
if (strcmp(assignment->name, target_name) != 0 ||
|
if (strcmp(assignment->name, target_name) != 0 ||
|
||||||
strcmp(assignment->output, output->name) == 0)
|
strcmp(assignment->output, output_primary_name(output)) == 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
assigned = true;
|
assigned = true;
|
||||||
|
@ -935,7 +935,7 @@ bool workspace_move_to_output(Con *ws, const char *name) {
|
||||||
bool used_assignment = false;
|
bool used_assignment = false;
|
||||||
struct Workspace_Assignment *assignment;
|
struct Workspace_Assignment *assignment;
|
||||||
TAILQ_FOREACH(assignment, &ws_assignments, ws_assignments) {
|
TAILQ_FOREACH(assignment, &ws_assignments, ws_assignments) {
|
||||||
if (assignment->output == NULL || strcmp(assignment->output, current_output->name) != 0)
|
if (assignment->output == NULL || strcmp(assignment->output, output_primary_name(current_output)) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* check if this workspace is already attached to the tree */
|
/* check if this workspace is already attached to the tree */
|
||||||
|
|
|
@ -56,7 +56,7 @@ static void query_screens(xcb_connection_t *conn) {
|
||||||
} else {
|
} else {
|
||||||
s = scalloc(1, sizeof(Output));
|
s = scalloc(1, sizeof(Output));
|
||||||
sasprintf(&(s->name), "xinerama-%d", num_screens);
|
sasprintf(&(s->name), "xinerama-%d", num_screens);
|
||||||
DLOG("Created new Xinerama screen %s (%p)\n", s->name, s);
|
DLOG("Created new Xinerama screen %s (%p)\n", output_primary_name(s), s);
|
||||||
s->active = true;
|
s->active = true;
|
||||||
s->rect.x = screen_info[screen].x_org;
|
s->rect.x = screen_info[screen].x_org;
|
||||||
s->rect.y = screen_info[screen].y_org;
|
s->rect.y = screen_info[screen].y_org;
|
||||||
|
|
Loading…
Reference in New Issue