Merge branch 'bacardi55' of github.com:xorg62/wmfs
Conflicts: src/event.c
This commit is contained in:
37
src/client.c
37
src/client.c
@@ -898,11 +898,18 @@ client_manage(Window w, XWindowAttributes *wa, Bool ar)
|
||||
client_attach(c);
|
||||
client_set_rules(c);
|
||||
client_get_name(c);
|
||||
client_raise(c);
|
||||
setwinstate(c->win, NormalState);
|
||||
if(c->tag == (uint)seltag[selscreen])
|
||||
{
|
||||
client_raise(c);
|
||||
setwinstate(c->win, NormalState);
|
||||
}
|
||||
else
|
||||
client_hide(c);
|
||||
|
||||
ewmh_get_client_list();
|
||||
client_update_attributes(c);
|
||||
client_map(c);
|
||||
if(c->tag == (uint)seltag[selscreen])
|
||||
client_map(c);
|
||||
ewmh_manage_window_type(c);
|
||||
|
||||
if(ar)
|
||||
@@ -1628,3 +1635,27 @@ uicb_client_ignore_tag(uicb_t cmd)
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
/** Set current client as master
|
||||
*\para cmd uicb_t type unused
|
||||
*/
|
||||
void
|
||||
uicb_client_set_master(uicb_t cmd)
|
||||
{
|
||||
Client *c;
|
||||
(void)cmd;
|
||||
|
||||
/* get the first client */
|
||||
screen_get_sel();
|
||||
if(!sel || ishide(sel, selscreen))
|
||||
return;
|
||||
|
||||
for(c = clients; c && ishide(c, selscreen); c = c->next);
|
||||
|
||||
if (c && c != sel)
|
||||
{
|
||||
client_swap(c, sel);
|
||||
client_focus(c);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -50,6 +50,7 @@ const func_name_list_t func_list[] =
|
||||
{"client_move", uicb_client_move },
|
||||
{"client_resize", uicb_client_resize },
|
||||
{"client_ignore_tag", uicb_client_ignore_tag },
|
||||
{"client_set_master", uicb_client_set_master },
|
||||
{"toggle_max", uicb_togglemax },
|
||||
{"layout_next", uicb_layout_next },
|
||||
{"layout_prev", uicb_layout_prev },
|
||||
@@ -98,6 +99,7 @@ const func_name_list_t func_list[] =
|
||||
{"clientlist", uicb_clientlist },
|
||||
{"check_clist", uicb_checkclist },
|
||||
{"toggle_tagautohide", uicb_toggle_tagautohide },
|
||||
{"toggle_tag_expose", uicb_tag_toggle_expose},
|
||||
{NULL, NULL}
|
||||
};
|
||||
|
||||
@@ -157,7 +159,6 @@ conf_misc_section(void)
|
||||
|
||||
conf.font = fetch_opt_first(sec, "sans-9", "font").str;
|
||||
conf.raisefocus = fetch_opt_first(sec, "false", "raisefocus").bool;
|
||||
conf.raiseswitch = fetch_opt_first(sec, "false", "raiseswitch").bool;
|
||||
conf.focus_fmouse = fetch_opt_first(sec, "true", "focus_follow_mouse").bool;
|
||||
conf.focus_fmov = fetch_opt_first(sec, "false", "focus_follow_movement").bool;
|
||||
conf.focus_pclick = fetch_opt_first(sec, "true", "focus_pointer_click").bool;
|
||||
@@ -502,6 +503,8 @@ conf_tag_section(void)
|
||||
conf.border.tag = fetch_opt_first(sec, "false", "border").bool;
|
||||
conf.tagautohide = fetch_opt_first(sec, "false", "autohide").bool;
|
||||
conf.tagnamecount = fetch_opt_first(sec, "false", "name_count").bool;
|
||||
conf.tag_expose_name = fetch_opt_first(sec, "EXPOSE", "expose_name").str;
|
||||
conf.expose_layout = fetch_opt_first(sec, "tile_grid_vertical", "expose_layout").str;
|
||||
|
||||
def_tag = fetch_section_first(sec, "default_tag");
|
||||
|
||||
|
||||
@@ -51,10 +51,13 @@ arrange(int screen, Bool update_layout)
|
||||
client_hide(c);
|
||||
}
|
||||
|
||||
if(update_layout)
|
||||
tags[screen][seltag[screen]].layout.func(screen);
|
||||
if(tags[screen][seltag[screen]].layout.func)
|
||||
{
|
||||
if(update_layout)
|
||||
tags[screen][seltag[screen]].layout.func(screen);
|
||||
|
||||
infobar_draw(screen);
|
||||
infobar_draw(screen);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -381,7 +381,6 @@ typedef struct
|
||||
char *font;
|
||||
uint opacity;
|
||||
Bool raisefocus;
|
||||
Bool raiseswitch;
|
||||
Bool focus_fmouse;
|
||||
Bool focus_fmov;
|
||||
Bool focus_pclick;
|
||||
@@ -500,6 +499,8 @@ typedef struct
|
||||
Bool layout_system; /* Switch: False, Menu: True. */
|
||||
Bool layout_placement; /* Right (normal): False, Left: True. */
|
||||
Bool keep_layout_geo;
|
||||
char *tag_expose_name;
|
||||
char *expose_layout;
|
||||
char *selected_layout_symbol;
|
||||
/* Number of... */
|
||||
int nkeybind;
|
||||
|
||||
47
src/tag.c
47
src/tag.c
@@ -734,3 +734,50 @@ uicb_tag_rename(uicb_t cmd)
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
void
|
||||
uicb_tag_toggle_expose(uicb_t cmd)
|
||||
{
|
||||
(void)cmd;
|
||||
int i, j;
|
||||
|
||||
screen_get_sel();
|
||||
|
||||
for(i = 1; i <= conf.ntag[selscreen]; i++)
|
||||
{
|
||||
if(strcmp(tags[selscreen][i].name, conf.tag_expose_name) == 0)
|
||||
{
|
||||
if(clients && sel->tag)
|
||||
tag_set(sel->tag);
|
||||
|
||||
tag_delete(selscreen, i);
|
||||
|
||||
for(j = 0; j < conf.ntag[selscreen]; j++)
|
||||
tags[selscreen][j].request_update = True;
|
||||
|
||||
arrange(selscreen, True);
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
tag_new(selscreen, conf.tag_expose_name);
|
||||
|
||||
for(i = 0; i < conf.nlayout; ++i)
|
||||
{
|
||||
if(strcmp(conf.expose_layout, conf.layout[i].type) == 0)
|
||||
{
|
||||
tags[selscreen][conf.ntag[selscreen]].layout = conf.layout[i];
|
||||
}
|
||||
}
|
||||
|
||||
for(i = 1; i < conf.ntag[selscreen]; ++i)
|
||||
{
|
||||
tags[selscreen][conf.ntag[selscreen]].tagad ^= TagFlag(i);
|
||||
}
|
||||
|
||||
tags[selscreen][conf.ntag[selscreen]].request_update = True;
|
||||
arrange(selscreen, True);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -201,6 +201,7 @@ void uicb_ignore_next_client_rules(uicb_t cmd);
|
||||
void uicb_clientlist(uicb_t cmd);
|
||||
Bool uicb_checkclist(uicb_t);
|
||||
void uicb_client_ignore_tag(uicb_t);
|
||||
void uicb_client_set_master(uicb_t);
|
||||
|
||||
/* ewmh.c */
|
||||
void ewmh_init_hints(void);
|
||||
@@ -300,6 +301,7 @@ void uicb_tag_del(uicb_t);
|
||||
void uicb_tag_rename(uicb_t cmd);
|
||||
void uicb_tag_last(uicb_t cmd);
|
||||
void uicb_tag_stay_last(uicb_t cmd);
|
||||
void uicb_tag_toggle_expose(uicb_t cmd);
|
||||
|
||||
/* screen.c */
|
||||
int screen_count(void);
|
||||
|
||||
Reference in New Issue
Block a user