summaryrefslogtreecommitdiff
path: root/openbox
diff options
context:
space:
mode:
authorMikael Magnusson <mikachu@gmail.com>2013-08-19 03:25:40 +0200
committerMikael Magnusson <mikachu@gmail.com>2013-08-19 21:35:45 +0200
commit0a7ff45e4930a72968911325a019f0ea64b62a43 (patch)
tree770ff490ea4c85e78173b700985b5679ab31c4dc /openbox
parent1d1fe5e6cc7afd8db05be7d4938ca87ba621dc94 (diff)
Add window type to If as well
This one required some extra helpers so is separate commit
Diffstat (limited to 'openbox')
-rw-r--r--openbox/actions/if.c9
-rw-r--r--openbox/client.c30
-rw-r--r--openbox/client.h3
3 files changed, 29 insertions, 13 deletions
diff --git a/openbox/actions/if.c b/openbox/actions/if.c
index 3d9f0e7f..a083d485 100644
--- a/openbox/actions/if.c
+++ b/openbox/actions/if.c
@@ -75,6 +75,7 @@ typedef struct {
TypedMatch class;
TypedMatch name;
TypedMatch role;
+ TypedMatch type;
} Query;
typedef struct {
@@ -153,7 +154,7 @@ static void free_typed_match(TypedMatch *tm)
}
}
-static gboolean check_typed_match(TypedMatch *tm, gchar *s)
+static gboolean check_typed_match(TypedMatch *tm, const gchar *s)
{
switch (tm->type) {
case MATCH_TYPE_PATTERN:
@@ -212,6 +213,9 @@ static void setup_query(Options* o, xmlNodePtr node, QueryTarget target) {
if ((n = obt_xml_find_node(node, "role"))) {
setup_typed_match(&q->role, n);
}
+ if ((n = obt_xml_find_node(node, "type"))) {
+ setup_typed_match(&q->type, n);
+ }
if ((n = obt_xml_find_node(node, "monitor"))) {
q->client_monitor = obt_xml_node_int(n);
}
@@ -283,6 +287,7 @@ static void free_func(gpointer options)
free_typed_match(&q->class);
free_typed_match(&q->name);
free_typed_match(&q->role);
+ free_typed_match(&q->type);
g_slice_free(Query, q);
}
@@ -398,6 +403,8 @@ static gboolean run_func_if(ObActionsData *data, gpointer options)
is_true &= check_typed_match(&q->class, query_target->class);
is_true &= check_typed_match(&q->name, query_target->name);
is_true &= check_typed_match(&q->role, query_target->role);
+ is_true &= check_typed_match(&q->type,
+ client_type_to_string(query_target));
if (q->client_monitor)
is_true &= client_monitor(query_target) == q->client_monitor - 1;
diff --git a/openbox/client.c b/openbox/client.c
index b6cc4a87..88b08f9f 100644
--- a/openbox/client.c
+++ b/openbox/client.c
@@ -2458,20 +2458,10 @@ static void client_get_session_ids(ObClient *self)
}
}
-/*! Save the properties used for app matching rules, as seen by Openbox when
- the window mapped, so that users can still access them later if the app
- changes them */
-static void client_save_app_rule_values(ObClient *self)
+const gchar *client_type_to_string(ObClient *self)
{
const gchar *type;
- OBT_PROP_SETS(self->window, OB_APP_ROLE, self->role);
- OBT_PROP_SETS(self->window, OB_APP_NAME, self->name);
- OBT_PROP_SETS(self->window, OB_APP_CLASS, self->class);
- OBT_PROP_SETS(self->window, OB_APP_GROUP_NAME, self->group_name);
- OBT_PROP_SETS(self->window, OB_APP_GROUP_CLASS, self->group_class);
- OBT_PROP_SETS(self->window, OB_APP_TITLE, self->original_title);
-
switch (self->type) {
case OB_CLIENT_TYPE_NORMAL:
type = "normal"; break;
@@ -2490,7 +2480,23 @@ static void client_save_app_rule_values(ObClient *self)
case OB_CLIENT_TYPE_DOCK:
type = "dock"; break;
}
- OBT_PROP_SETS(self->window, OB_APP_TYPE, type);
+
+ return type;
+}
+
+/*! Save the properties used for app matching rules, as seen by Openbox when
+ the window mapped, so that users can still access them later if the app
+ changes them */
+static void client_save_app_rule_values(ObClient *self)
+{
+ OBT_PROP_SETS(self->window, OB_APP_ROLE, self->role);
+ OBT_PROP_SETS(self->window, OB_APP_NAME, self->name);
+ OBT_PROP_SETS(self->window, OB_APP_CLASS, self->class);
+ OBT_PROP_SETS(self->window, OB_APP_GROUP_NAME, self->group_name);
+ OBT_PROP_SETS(self->window, OB_APP_GROUP_CLASS, self->group_class);
+ OBT_PROP_SETS(self->window, OB_APP_TITLE, self->original_title);
+
+ OBT_PROP_SETS(self->window, OB_APP_TYPE, client_type_to_string(self));
}
static void client_change_wm_state(ObClient *self)
diff --git a/openbox/client.h b/openbox/client.h
index d68d3035..5ae2d3d2 100644
--- a/openbox/client.h
+++ b/openbox/client.h
@@ -645,6 +645,9 @@ void client_update_icons(ObClient *self);
/*! Updates the window's icon geometry (where to iconify to/from) */
void client_update_icon_geometry(ObClient *self);
+/*! Helper function to convert the ->type member to string representation */
+const gchar *client_type_to_string(ObClient *self);
+
/*! Set up what decor should be shown on the window and what functions should
be allowed (ObClient::decorations and ObClient::functions).
This also updates the NET_WM_ALLOWED_ACTIONS hint.