all repos — openbox @ 53309da211ec1a11c5eb452eb78bfb640d1701a1

openbox fork - make it a bit more like ryudo

put back the check for the window type when restoring the session. if you only have 1 firefox window in the saved session, the check for duplicates won't help
Dana Jansens danakj@orodu.net
commit

53309da211ec1a11c5eb452eb78bfb640d1701a1

parent

3cf852d5ac30c14dd72c5f1731675bb23cb0d6be

2 files changed, 15 insertions(+), 1 deletions(-)

jump to
M openbox/session.copenbox/session.c

@@ -515,6 +515,8 @@ t = g_markup_escape_text(c->role, -1);

fprintf(f, "\t<role>%s</role>\n", t); g_free(t); + fprintf(f, "\t<windowtype>%d</windowtype>\n", c->type); + fprintf(f, "\t<desktop>%d</desktop>\n", c->desktop); fprintf(f, "\t<x>%d</x>\n", prex); fprintf(f, "\t<y>%d</y>\n", prey);

@@ -578,12 +580,14 @@ ob_debug_type(OB_DEBUG_SM, " client id: %s \n", c->sm_client_id);

ob_debug_type(OB_DEBUG_SM, " client name: %s \n", c->name); ob_debug_type(OB_DEBUG_SM, " client class: %s \n", c->class); ob_debug_type(OB_DEBUG_SM, " client role: %s \n", c->role); + ob_debug_type(OB_DEBUG_SM, " client type: %s \n", c->type); ob_debug_type(OB_DEBUG_SM, " client command: %s \n", c->wm_command ? c->wm_command : "(null)"); ob_debug_type(OB_DEBUG_SM, " state id: %s \n", s->id); ob_debug_type(OB_DEBUG_SM, " state name: %s \n", s->name); ob_debug_type(OB_DEBUG_SM, " state class: %s \n", s->class); ob_debug_type(OB_DEBUG_SM, " state role: %s \n", s->role); + ob_debug_type(OB_DEBUG_SM, " state type: %s \n", s->type); ob_debug_type(OB_DEBUG_SM, " state command: %s \n", s->command ? s->command : "(null)");

@@ -592,7 +596,13 @@ (c->wm_command && s->command && !strcmp(c->wm_command, s->command)))

{ return (!strcmp(s->name, c->name) && !strcmp(s->class, c->class) && - !strcmp(s->role, c->role)); + !strcmp(s->role, c->role) && + /* the check for type is to catch broken clients, like + firefox, which open a different window on startup + with the same info as the one we saved. only do this + check for old windows that dont use xsmp, others should + know better ! */ + (!s->command || c->type == s->type)); } return FALSE; }

@@ -642,6 +652,9 @@ state->class = parse_string(doc, n);

if (!(n = parse_find_node("role", node->children))) goto session_load_bail; state->role = parse_string(doc, n); + if (!(n = parse_find_node("windowtype", node->children))) + goto session_load_bail; + state->type = parse_int(doc, n); if (!(n = parse_find_node("desktop", node->children))) goto session_load_bail; state->desktop = parse_int(doc, n);
M openbox/session.hopenbox/session.h

@@ -27,6 +27,7 @@ typedef struct _ObSessionState ObSessionState;

struct _ObSessionState { gchar *id, *command, *name, *class, *role; + ObClientType type; guint desktop; gint x, y, w, h; gboolean shaded, iconic, skip_pager, skip_taskbar, fullscreen;