mirror of
https://github.com/gryf/wmaker.git
synced 2025-12-20 12:58:08 +01:00
Remove XSMP_ENABLED constructs
The code was never used and the !XSMP_ENABLED code seems to work well enough for all these years.
This commit is contained in:
20
src/main.c
20
src/main.c
@@ -271,9 +271,6 @@ static int initWVisualID(const char *user_str)
|
||||
|
||||
void Exit(int status)
|
||||
{
|
||||
#ifdef XSMP_ENABLED
|
||||
wSessionDisconnectManager();
|
||||
#endif
|
||||
if (dpy)
|
||||
XCloseDisplay(dpy);
|
||||
|
||||
@@ -296,9 +293,6 @@ void Restart(char *manager, Bool abortOnFailure)
|
||||
}
|
||||
}
|
||||
if (dpy) {
|
||||
#ifdef XSMP_ENABLED
|
||||
wSessionDisconnectManager();
|
||||
#endif
|
||||
XCloseDisplay(dpy);
|
||||
dpy = NULL;
|
||||
}
|
||||
@@ -734,16 +728,7 @@ static int real_main(int argc, char **argv)
|
||||
exit(0);
|
||||
}
|
||||
} else if (strcmp(argv[i], "-static") == 0 || strcmp(argv[i], "--static") == 0) {
|
||||
|
||||
wPreferences.flags.noupdates = 1;
|
||||
#ifdef XSMP_ENABLED
|
||||
} else if (strcmp(argv[i], "-clientid") == 0 || strcmp(argv[i], "-restore") == 0) {
|
||||
i++;
|
||||
if (i >= argc) {
|
||||
wwarning(_("too few arguments for %s"), argv[i - 1]);
|
||||
exit(0);
|
||||
}
|
||||
#endif
|
||||
} else if (strcmp(argv[i], "--help") == 0) {
|
||||
print_help();
|
||||
exit(0);
|
||||
@@ -842,11 +827,6 @@ static int real_main(int argc, char **argv)
|
||||
#endif
|
||||
|
||||
wXModifierInitialize();
|
||||
|
||||
#ifdef XSMP_ENABLED
|
||||
wSessionConnectManager(argv, argc);
|
||||
#endif
|
||||
|
||||
StartUp(!multiHead);
|
||||
|
||||
if (wScreenCount == 1)
|
||||
|
||||
@@ -39,10 +39,6 @@ extern Atom _XA_WM_CLIENT_LEADER;
|
||||
extern Atom _XA_WM_TAKE_FOCUS;
|
||||
extern Atom _XA_WM_DELETE_WINDOW;
|
||||
extern Atom _XA_WM_SAVE_YOURSELF;
|
||||
#ifdef XSMP_ENABLED
|
||||
extern Atom _XA_WM_WINDOW_ROLE;
|
||||
extern Atom _XA_SM_CLIENT_ID;
|
||||
#endif
|
||||
|
||||
extern Atom _XA_GNUSTEP_WM_ATTR;
|
||||
extern Atom _XA_GNUSTEP_WM_MINIATURIZE_WINDOW;
|
||||
@@ -251,52 +247,6 @@ Window PropGetClientLeader(Window window)
|
||||
return leader;
|
||||
}
|
||||
|
||||
#ifdef XSMP_ENABLED
|
||||
char *PropGetClientID(Window window)
|
||||
{
|
||||
XTextProperty txprop;
|
||||
|
||||
txprop.value = NULL;
|
||||
|
||||
if (XGetTextProperty(dpy, window, &txprop, _XA_SM_CLIENT_ID) != Success) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
if (txprop.encoding == XA_STRING && txprop.format == 8 && txprop.nitems > 0) {
|
||||
|
||||
return (char *)txprop.value;
|
||||
} else {
|
||||
|
||||
if (txprop.value)
|
||||
XFree(txprop.value);
|
||||
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
char *PropGetWindowRole(Window window)
|
||||
{
|
||||
XTextProperty txprop;
|
||||
|
||||
txprop.value = NULL;
|
||||
|
||||
if (XGetTextProperty(dpy, window, &txprop, _XA_WM_WINDOW_ROLE) != Success) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
if (txprop.encoding == XA_STRING && txprop.format == 8 && txprop.nitems > 0) {
|
||||
|
||||
return (char *)txprop.value;
|
||||
} else {
|
||||
|
||||
if (txprop.value)
|
||||
XFree(txprop.value);
|
||||
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
#endif /* XSMP_ENABLED */
|
||||
|
||||
void PropWriteGNUstepWMAttr(Window window, GNUstepWMAttributes * attr)
|
||||
{
|
||||
unsigned long data[9];
|
||||
@@ -334,8 +284,6 @@ int PropGetWindowState(Window window)
|
||||
void PropCleanUp(Window root)
|
||||
{
|
||||
XDeleteProperty(dpy, root, _XA_WINDOWMAKER_WM_PROTOCOLS);
|
||||
|
||||
XDeleteProperty(dpy, root, _XA_WINDOWMAKER_NOTICEBOARD);
|
||||
|
||||
XDeleteProperty(dpy, root, XA_WM_ICON_SIZE);
|
||||
}
|
||||
|
||||
@@ -42,9 +42,4 @@ void PropSetIconTileHint(WScreen *scr, RImage *image);
|
||||
|
||||
Window PropGetClientLeader(Window window);
|
||||
|
||||
#ifdef XSMP_ENABLED
|
||||
char *PropGetClientID(Window window);
|
||||
#endif
|
||||
|
||||
|
||||
#endif
|
||||
|
||||
@@ -222,21 +222,6 @@ static void shutdownCommand(WMenu * menu, WMenuEntry * entry)
|
||||
if ((long)entry->clientdata == M_QUICK)
|
||||
result = R_CLOSE;
|
||||
else {
|
||||
#ifdef XSMP_ENABLED
|
||||
if (wSessionIsManaged()) {
|
||||
int r;
|
||||
|
||||
r = wMessageDialog(menu->frame->screen_ptr,
|
||||
_("Close X session"),
|
||||
_("Close Window System session?\n"
|
||||
"Kill might close applications with unsaved data."),
|
||||
_("Close"), _("Kill"), _("Cancel"));
|
||||
if (r == WAPRDefault)
|
||||
result = R_CLOSE;
|
||||
else if (r == WAPRAlternate)
|
||||
result = R_KILL;
|
||||
} else
|
||||
#endif
|
||||
{
|
||||
int r, oldSaveSessionFlag;
|
||||
|
||||
@@ -257,11 +242,6 @@ static void shutdownCommand(WMenu * menu, WMenuEntry * entry)
|
||||
}
|
||||
|
||||
if (result != R_CANCEL) {
|
||||
#ifdef XSMP_ENABLED
|
||||
if (result == R_CLOSE) {
|
||||
Shutdown(WSLogoutMode);
|
||||
} else
|
||||
#endif /* XSMP_ENABLED */
|
||||
{
|
||||
Shutdown(WSKillMode);
|
||||
}
|
||||
|
||||
658
src/session.c
658
src/session.c
@@ -63,10 +63,6 @@
|
||||
#include <X11/Xlib.h>
|
||||
#include <X11/Xutil.h>
|
||||
|
||||
#ifdef XSMP_ENABLED
|
||||
#include <X11/SM/SMlib.h>
|
||||
#endif
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
@@ -85,7 +81,6 @@
|
||||
#include "properties.h"
|
||||
#include "application.h"
|
||||
#include "appicon.h"
|
||||
|
||||
#include "dock.h"
|
||||
|
||||
#include <WINGs/WUtil.h>
|
||||
@@ -96,21 +91,6 @@ extern Atom _XA_WM_SAVE_YOURSELF;
|
||||
|
||||
extern Time LastTimestamp;
|
||||
|
||||
#ifdef XSMP_ENABLED
|
||||
|
||||
extern int wScreenCount;
|
||||
|
||||
/* requested for SaveYourselfPhase2 */
|
||||
static Bool sWaitingPhase2 = False;
|
||||
|
||||
static SmcConn sSMCConn = NULL;
|
||||
|
||||
static WMHandlerID sSMInputHandler = NULL;
|
||||
|
||||
/* our SM client ID */
|
||||
static char *sClientID = NULL;
|
||||
#endif
|
||||
|
||||
static WMPropList *sApplications = NULL;
|
||||
static WMPropList *sCommand;
|
||||
static WMPropList *sName;
|
||||
@@ -123,7 +103,6 @@ static WMPropList *sGeometry;
|
||||
static WMPropList *sShortcutMask;
|
||||
|
||||
static WMPropList *sDock;
|
||||
|
||||
static WMPropList *sYes, *sNo;
|
||||
|
||||
static void make_keys()
|
||||
@@ -650,640 +629,3 @@ void wSessionSendSaveYourself(WScreen * scr)
|
||||
XUngrabKeyboard(dpy, CurrentTime);
|
||||
XFlush(dpy);
|
||||
}
|
||||
|
||||
#ifdef XSMP_ENABLED
|
||||
/*
|
||||
* With full session management support, the part of WMState
|
||||
* that store client window state will become obsolete (maybe we can reuse
|
||||
* the old code too),
|
||||
* but we still need to store state info like the dock and workspaces.
|
||||
* It is better to keep dock/wspace info in WMState because the user
|
||||
* might want to keep the dock configuration while not wanting to
|
||||
* resume a previously saved session.
|
||||
* So, wmaker specific state info can be saved in
|
||||
* ~/GNUstep/Library/WindowMaker/statename.state
|
||||
* Its better to not put it in the defaults directory because:
|
||||
* - its not a defaults file (having domain names like wmaker0089504baa
|
||||
* in the defaults directory wouldn't be very neat)
|
||||
* - this state file is not meant to be edited by users
|
||||
*
|
||||
* The old session code will become obsolete. When wmaker is
|
||||
* compiled with R6 sm support compiled in, it'll be better to
|
||||
* use a totally rewritten state saving code, but we can keep
|
||||
* the current code for when XSMP_ENABLED is not compiled in.
|
||||
*
|
||||
* This will be confusing to old users (well get lots of "SAVE_SESSION broke!"
|
||||
* messages), but it'll be better.
|
||||
*
|
||||
* -readme
|
||||
*/
|
||||
|
||||
static char *getWindowRole(Window window)
|
||||
{
|
||||
XTextProperty prop;
|
||||
static Atom atom = 0;
|
||||
|
||||
if (!atom)
|
||||
atom = XInternAtom(dpy, "WM_WINDOW_ROLE", False);
|
||||
|
||||
if (XGetTextProperty(dpy, window, &prop, atom)) {
|
||||
if (prop.encoding == XA_STRING && prop.format == 8 && prop.nitems > 0)
|
||||
return prop.value;
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/*
|
||||
*
|
||||
* Saved Info:
|
||||
*
|
||||
* WM_WINDOW_ROLE
|
||||
*
|
||||
* WM_CLASS.instance
|
||||
* WM_CLASS.class
|
||||
* WM_NAME
|
||||
* WM_COMMAND
|
||||
*
|
||||
* geometry
|
||||
* state = (miniaturized, shaded, etc)
|
||||
* attribute
|
||||
* workspace #
|
||||
* app state = (which dock, hidden)
|
||||
* window shortcut #
|
||||
*/
|
||||
|
||||
static WMPropList *makeAppState(WWindow * wwin)
|
||||
{
|
||||
WApplication *wapp;
|
||||
WMPropList *state;
|
||||
WScreen *scr = wwin->screen_ptr;
|
||||
|
||||
state = WMCreatePLArray(NULL, NULL);
|
||||
|
||||
wapp = wApplicationOf(wwin->main_window);
|
||||
|
||||
if (wapp) {
|
||||
if (wapp->app_icon && wapp->app_icon->dock) {
|
||||
|
||||
if (wapp->app_icon->dock == scr->dock) {
|
||||
WMAddToPLArray(state, WMCreatePLString("Dock"));
|
||||
} else {
|
||||
int i;
|
||||
|
||||
for (i = 0; i < scr->workspace_count; i++)
|
||||
if (scr->workspaces[i]->clip == wapp->app_icon->dock)
|
||||
break;
|
||||
|
||||
assert(i < scr->workspace_count);
|
||||
|
||||
WMAddToPLArray(state, WMCreatePLString(scr->workspaces[i]->name));
|
||||
}
|
||||
}
|
||||
|
||||
WMAddToPLArray(state, WMCreatePLString(wapp->hidden ? "1" : "0"));
|
||||
}
|
||||
|
||||
return state;
|
||||
}
|
||||
|
||||
Bool wSessionGetStateFor(WWindow * wwin, WSessionData * state)
|
||||
{
|
||||
char *str;
|
||||
WMPropList *slist;
|
||||
WMPropList *elem;
|
||||
WMPropList *value;
|
||||
int index = 0;
|
||||
|
||||
index = 3;
|
||||
|
||||
/* geometry */
|
||||
value = WMGetFromPLArray(slist, index++);
|
||||
str = WMGetFromPLString(value);
|
||||
|
||||
sscanf(str, "%i %i %i %i %i %i", &state->x, &state->y,
|
||||
&state->width, &state->height, &state->user_changed_width, &state->user_changed_height);
|
||||
|
||||
/* state */
|
||||
value = WMGetFromPLArray(slist, index++);
|
||||
str = WMGetFromPLString(value);
|
||||
|
||||
sscanf(str, "%i %i %i", &state->miniaturized, &state->shaded, &state->maximized);
|
||||
|
||||
/* attributes */
|
||||
value = WMGetFromPLArray(slist, index++);
|
||||
str = WMGetFromPLString(value);
|
||||
|
||||
getAttributeState(str, &state->mflags, &state->flags);
|
||||
|
||||
/* workspace */
|
||||
value = WMGetFromPLArray(slist, index++);
|
||||
str = WMGetFromPLString(value);
|
||||
|
||||
sscanf(str, "%i", &state->workspace);
|
||||
|
||||
/* app state (repeated for all windows of the app) */
|
||||
value = WMGetFromPLArray(slist, index++);
|
||||
str = WMGetFromPLString(value);
|
||||
|
||||
/* ???? */
|
||||
|
||||
/* shortcuts */
|
||||
value = WMGetFromPLArray(slist, index++);
|
||||
str = WMGetFromPLString(value);
|
||||
|
||||
sscanf(str, "%i", &state->shortcuts);
|
||||
}
|
||||
|
||||
static WMPropList *makeAttributeState(WWindow * wwin)
|
||||
{
|
||||
unsigned int data1, data2;
|
||||
char buffer[256];
|
||||
|
||||
#define W_FLAG(wwin, FLAG) ((wwin)->defined_user_flags.FLAG \
|
||||
? (wwin)->user_flags.FLAG : -1)
|
||||
|
||||
snprintf(buffer, sizeof(buffer),
|
||||
"%i %i %i %i %i %i %i %i %i %i %i %i %i %i %i %i %i %i %i %i %i %i %i %i",
|
||||
W_FLAG(no_titlebar),
|
||||
W_FLAG(no_resizable),
|
||||
W_FLAG(no_closable),
|
||||
W_FLAG(no_miniaturizable),
|
||||
W_FLAG(no_resizebar), W_FLAG(no_close_button), W_FLAG(no_miniaturize_button),
|
||||
/*
|
||||
W_FLAG(broken_close),
|
||||
W_FLAG(kill_close),
|
||||
*/
|
||||
W_FLAG(no_shadeable),
|
||||
W_FLAG(omnipresent),
|
||||
W_FLAG(skip_window_list),
|
||||
W_FLAG(floating),
|
||||
W_FLAG(sunken),
|
||||
W_FLAG(no_bind_keys),
|
||||
W_FLAG(no_bind_mouse),
|
||||
W_FLAG(no_hide_others),
|
||||
W_FLAG(no_appicon),
|
||||
W_FLAG(dont_move_off),
|
||||
W_FLAG(no_focusable),
|
||||
W_FLAG(always_user_icon),
|
||||
W_FLAG(start_miniaturized),
|
||||
W_FLAG(start_hidden),
|
||||
W_FLAG(start_maximized),
|
||||
W_FLAG(dont_save_session), W_FLAG(dont_focus_across_wksp), W_FLAG(emulate_appicon));
|
||||
|
||||
return WMCreatePLString(buffer);
|
||||
}
|
||||
|
||||
static void appendStringInArray(WMPropList * array, char *str)
|
||||
{
|
||||
WMPropList *val;
|
||||
|
||||
val = WMCreatePLString(str);
|
||||
WMAddToPLArray(array, val);
|
||||
WMReleasePropList(val);
|
||||
}
|
||||
|
||||
static WMPropList *makeClientState(WWindow * wwin)
|
||||
{
|
||||
WMPropList *state;
|
||||
WMPropList *tmp;
|
||||
char *str;
|
||||
char buffer[512];
|
||||
int i;
|
||||
unsigned shortcuts;
|
||||
|
||||
state = WMCreatePLArray(NULL, NULL);
|
||||
|
||||
/* WM_WINDOW_ROLE */
|
||||
str = getWindowRole(wwin->client_win);
|
||||
if (!str)
|
||||
appendStringInArray(state, "");
|
||||
else {
|
||||
appendStringInArray(state, str);
|
||||
XFree(str);
|
||||
}
|
||||
|
||||
/* WM_CLASS.instance */
|
||||
appendStringInArray(state, wwin->wm_instance);
|
||||
|
||||
/* WM_CLASS.class */
|
||||
appendStringInArray(state, wwin->wm_class);
|
||||
|
||||
/* WM_NAME */
|
||||
if (wwin->flags.wm_name_changed)
|
||||
appendStringInArray(state, "");
|
||||
else
|
||||
appendStringInArray(state, wwin->frame->name);
|
||||
|
||||
/* geometry */
|
||||
snprintf(buffer, sizeof(buffer), "%i %i %i %i %i %i", wwin->frame_x, wwin->frame_y,
|
||||
wwin->client.width, wwin->client.height,
|
||||
wwin->flags.user_changed_width, wwin->flags.user_changed_height);
|
||||
appendStringInArray(state, buffer);
|
||||
|
||||
/* state */
|
||||
snprintf(buffer, sizeof(buffer), "%i %i %i", wwin->flags.miniaturized,
|
||||
wwin->flags.shaded, wwin->flags.maximized);
|
||||
appendStringInArray(state, buffer);
|
||||
|
||||
/* attributes */
|
||||
tmp = makeAttributeState(wwin);
|
||||
WMAddToPLArray(state, tmp);
|
||||
WMReleasePropList(tmp);
|
||||
|
||||
/* workspace */
|
||||
snprintf(buffer, sizeof(buffer), "%i", wwin->frame->workspace);
|
||||
appendStringInArray(state, buffer);
|
||||
|
||||
/* app state (repeated for all windows of the app) */
|
||||
tmp = makeAppState(wwin);
|
||||
WMAddToPLArray(state, tmp);
|
||||
WMReleasePropList(tmp);
|
||||
|
||||
/* shortcuts */
|
||||
shortcuts = 0;
|
||||
for (i = 0; i < MAX_WINDOW_SHORTCUTS; i++) {
|
||||
if (scr->shortcutWindow[i] == wwin) {
|
||||
shortcuts |= 1 << i;
|
||||
}
|
||||
}
|
||||
snprintf(buffer, sizeof(buffer), "%ui", shortcuts);
|
||||
appendStringInArray(tmp, buffer);
|
||||
|
||||
return state;
|
||||
}
|
||||
|
||||
static void smSaveYourselfPhase2Proc(SmcConn smc_conn, SmPointer client_data)
|
||||
{
|
||||
SmProp props[4];
|
||||
SmPropValue prop1val, prop2val, prop3val, prop4val;
|
||||
char **argv = (char **)client_data;
|
||||
int argc;
|
||||
int i, j;
|
||||
Bool ok = False;
|
||||
char *statefile = NULL;
|
||||
char *prefix;
|
||||
Bool gsPrefix = False;
|
||||
char *discardCmd = NULL;
|
||||
time_t t;
|
||||
WMPropList *state, *plState;
|
||||
int len;
|
||||
|
||||
#ifdef DEBUG1
|
||||
puts("received SaveYourselfPhase2 SM message");
|
||||
#endif
|
||||
|
||||
/* save session state */
|
||||
|
||||
/* the file that will contain the state */
|
||||
prefix = getenv("SM_SAVE_DIR");
|
||||
if (!prefix) {
|
||||
prefix = wusergnusteppath();
|
||||
if (prefix)
|
||||
gsPrefix = True;
|
||||
}
|
||||
if (!prefix) {
|
||||
prefix = getenv("HOME");
|
||||
}
|
||||
if (!prefix)
|
||||
prefix = ".";
|
||||
|
||||
len = strlen(prefix) + 64;
|
||||
statefile = malloc(len);
|
||||
if (!statefile) {
|
||||
wwarning(_("out of memory while saving session state"));
|
||||
goto fail;
|
||||
}
|
||||
|
||||
t = time();
|
||||
i = 0;
|
||||
do {
|
||||
if (gsPrefix)
|
||||
snprintf(statefile, len, "%s/Library/WindowMaker/wmaker.%l%i.state", prefix, t, i);
|
||||
else
|
||||
snprintf(statefile, len, "%s/wmaker.%l%i.state", prefix, t, i);
|
||||
i++;
|
||||
} while (access(F_OK, statefile) != -1);
|
||||
|
||||
/* save the states of all windows we're managing */
|
||||
state = WMCreatePLArray(NULL, NULL);
|
||||
|
||||
/*
|
||||
* Format:
|
||||
*
|
||||
* state_file ::= dictionary with version_info ; state
|
||||
* version_info ::= 'version' = '1';
|
||||
* state ::= 'state' = array of screen_info
|
||||
* screen_info ::= array of (screen number, window_info, window_info, ...)
|
||||
* window_info ::=
|
||||
*/
|
||||
for (i = 0; i < wScreenCount; i++) {
|
||||
WScreen *scr;
|
||||
WWindow *wwin;
|
||||
char buf[32];
|
||||
WMPropList *pscreen;
|
||||
|
||||
scr = wScreenWithNumber(i);
|
||||
|
||||
snprintf(buf, sizeof(buf), "%i", scr->screen);
|
||||
pscreen = WMCreatePLArray(WMCreatePLString(buf), NULL);
|
||||
|
||||
wwin = scr->focused_window;
|
||||
while (wwin) {
|
||||
WMPropList *pwindow;
|
||||
|
||||
pwindow = makeClientState(wwin);
|
||||
WMAddToPLArray(pscreen, pwindow);
|
||||
|
||||
wwin = wwin->prev;
|
||||
}
|
||||
|
||||
WMAddToPLArray(state, pscreen);
|
||||
}
|
||||
|
||||
plState = WMCreatePLDictionary(WMCreatePLString("Version"),
|
||||
WMCreatePLString("1.0"), WMCreatePLString("Screens"), state, NULL);
|
||||
|
||||
if (!WMWritePropListToFile(plState, statefile, True)) {
|
||||
wwarning(_("error while saving session state"));
|
||||
WMReleasePropList(plState);
|
||||
goto fail;
|
||||
}
|
||||
|
||||
WMReleasePropList(plState);
|
||||
|
||||
/* set the remaining properties that we didn't set at
|
||||
* startup time */
|
||||
|
||||
for (argc = 0, i = 0; argv[i] != NULL; i++) {
|
||||
if (strcmp(argv[i], "-clientid") == 0 || strcmp(argv[i], "-restore") == 0) {
|
||||
i++;
|
||||
} else {
|
||||
argc++;
|
||||
}
|
||||
}
|
||||
|
||||
prop[0].name = SmRestartCommand;
|
||||
prop[0].type = SmLISTofARRAY8;
|
||||
prop[0].vals = malloc(sizeof(SmPropValue) * (argc + 4));
|
||||
prop[0].num_vals = argc + 4;
|
||||
|
||||
prop[1].name = SmCloneCommand;
|
||||
prop[1].type = SmLISTofARRAY8;
|
||||
prop[1].vals = malloc(sizeof(SmPropValue) * (argc));
|
||||
prop[1].num_vals = argc;
|
||||
|
||||
if (!prop[0].vals || !prop[1].vals) {
|
||||
wwarning(_("end of memory while saving session state"));
|
||||
goto fail;
|
||||
}
|
||||
|
||||
for (j = 0, i = 0; i < argc + 4; i++) {
|
||||
if (strcmp(argv[i], "-clientid") == 0 || strcmp(argv[i], "-restore") == 0) {
|
||||
i++;
|
||||
} else {
|
||||
prop[0].vals[j].value = argv[i];
|
||||
prop[0].vals[j].length = strlen(argv[i]);
|
||||
prop[1].vals[j].value = argv[i];
|
||||
prop[1].vals[j].length = strlen(argv[i]);
|
||||
j++;
|
||||
}
|
||||
}
|
||||
prop[0].vals[j].value = "-clientid";
|
||||
prop[0].vals[j].length = 9;
|
||||
j++;
|
||||
prop[0].vals[j].value = sClientID;
|
||||
prop[0].vals[j].length = strlen(sClientID);
|
||||
j++;
|
||||
prop[0].vals[j].value = "-restore";
|
||||
prop[0].vals[j].length = 11;
|
||||
j++;
|
||||
prop[0].vals[j].value = statefile;
|
||||
prop[0].vals[j].length = strlen(statefile);
|
||||
|
||||
{
|
||||
int len = strlen(statefile) + 8;
|
||||
|
||||
discardCmd = malloc(len);
|
||||
if (!discardCmd)
|
||||
goto fail;
|
||||
snprintf(discardCmd, len, "rm %s", statefile);
|
||||
}
|
||||
prop[2].name = SmDiscardCommand;
|
||||
prop[2].type = SmARRAY8;
|
||||
prop[2].vals[0] = discardCmd;
|
||||
prop[2].num_vals = 1;
|
||||
|
||||
SmcSetProperties(sSMCConn, 3, prop);
|
||||
|
||||
ok = True;
|
||||
fail:
|
||||
SmcSaveYourselfDone(smc_conn, ok);
|
||||
|
||||
if (prop[0].vals)
|
||||
wfree(prop[0].vals);
|
||||
if (prop[1].vals)
|
||||
wfree(prop[1].vals);
|
||||
if (discardCmd)
|
||||
wfree(discardCmd);
|
||||
|
||||
if (!ok) {
|
||||
remove(statefile);
|
||||
}
|
||||
if (statefile)
|
||||
wfree(statefile);
|
||||
}
|
||||
|
||||
static void
|
||||
smSaveYourselfProc(SmcConn smc_conn, SmPointer client_data, int save_type,
|
||||
Bool shutdown, int interact_style, Bool fast)
|
||||
{
|
||||
#ifdef DEBUG1
|
||||
puts("received SaveYourself SM message");
|
||||
#endif
|
||||
|
||||
if (!SmcRequestSaveYourselfPhase2(smc_conn, smSaveYourselfPhase2Proc, client_data)) {
|
||||
|
||||
SmcSaveYourselfDone(smc_conn, False);
|
||||
sWaitingPhase2 = False;
|
||||
} else {
|
||||
#ifdef DEBUG1
|
||||
puts("successfull request of SYS phase 2");
|
||||
#endif
|
||||
sWaitingPhase2 = True;
|
||||
}
|
||||
}
|
||||
|
||||
static void smDieProc(SmcConn smc_conn, SmPointer client_data)
|
||||
{
|
||||
#ifdef DEBUG1
|
||||
puts("received Die SM message");
|
||||
#endif
|
||||
|
||||
wSessionDisconnectManager();
|
||||
|
||||
Shutdown(WSExitMode, True);
|
||||
}
|
||||
|
||||
static void smSaveCompleteProc(SmcConn smc_conn)
|
||||
{
|
||||
/* it means that we can resume doing things that can change our state */
|
||||
#ifdef DEBUG1
|
||||
puts("received SaveComplete SM message");
|
||||
#endif
|
||||
}
|
||||
|
||||
static void smShutdownCancelledProc(SmcConn smc_conn, SmPointer client_data)
|
||||
{
|
||||
if (sWaitingPhase2) {
|
||||
|
||||
sWaitingPhase2 = False;
|
||||
|
||||
SmcSaveYourselfDone(smc_conn, False);
|
||||
}
|
||||
}
|
||||
|
||||
static void iceMessageProc(int fd, int mask, void *clientData)
|
||||
{
|
||||
IceConn iceConn = (IceConn) clientData;
|
||||
|
||||
IceProcessMessages(iceConn, NULL, NULL);
|
||||
}
|
||||
|
||||
static void iceIOErrorHandler(IceConnection ice_conn)
|
||||
{
|
||||
/* This is not fatal but can mean the session manager exited.
|
||||
* If the session manager exited normally we would get a
|
||||
* Die message, so this probably means an abnormal exit.
|
||||
* If the sm was the last client of session, then we'll die
|
||||
* anyway, otherwise we can continue doing our stuff.
|
||||
*/
|
||||
wwarning(_("connection to the session manager was lost"));
|
||||
wSessionDisconnectManager();
|
||||
}
|
||||
|
||||
void wSessionConnectManager(char **argv, int argc)
|
||||
{
|
||||
IceConn iceConn;
|
||||
char *previous_id = NULL;
|
||||
char buffer[256];
|
||||
SmcCallbacks callbacks;
|
||||
unsigned long mask;
|
||||
char uid[32];
|
||||
char pid[32];
|
||||
SmProp props[4];
|
||||
SmPropValue prop1val, prop2val, prop3val, prop4val;
|
||||
char restartStyle;
|
||||
int i;
|
||||
|
||||
mask = SmcSaveYourselfProcMask | SmcDieProcMask | SmcSaveCompleteProcMask | SmcShutdownCancelledProcMask;
|
||||
|
||||
callbacks.save_yourself.callback = smSaveYourselfProc;
|
||||
callbacks.save_yourself.client_data = argv;
|
||||
|
||||
callbacks.die.callback = smDieProc;
|
||||
callbacks.die.client_data = NULL;
|
||||
|
||||
callbacks.save_complete.callback = smSaveCompleteProc;
|
||||
callbacks.save_complete.client_data = NULL;
|
||||
|
||||
callbacks.shutdown_cancelled.callback = smShutdownCancelledProc;
|
||||
callbacks.shutdown_cancelled.client_data = NULL;
|
||||
|
||||
for (i = 0; i < argc; i++) {
|
||||
if (strcmp(argv[i], "-clientid") == 0) {
|
||||
previous_id = argv[i + 1];
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* connect to the session manager */
|
||||
sSMCConn = SmcOpenConnection(NULL, NULL, SmProtoMajor, SmProtoMinor,
|
||||
mask, &callbacks, previous_id, &sClientID, 255, buffer);
|
||||
if (!sSMCConn) {
|
||||
return;
|
||||
}
|
||||
#ifdef DEBUG1
|
||||
puts("connected to the session manager");
|
||||
#endif
|
||||
|
||||
/* IceSetIOErrorHandler(iceIOErrorHandler); */
|
||||
|
||||
/* check for session manager clients */
|
||||
iceConn = SmcGetIceConnection(smcConn);
|
||||
|
||||
if (fcntl(IceConnectionNumber(iceConn), F_SETFD, FD_CLOEXEC) < 0) {
|
||||
wsyserror("error setting close-on-exec flag for ICE connection");
|
||||
}
|
||||
|
||||
sSMInputHandler = WMAddInputHandler(IceConnectionNumber(iceConn), WIReadMask, iceMessageProc, iceConn);
|
||||
|
||||
/* setup information about ourselves */
|
||||
|
||||
/* program name */
|
||||
prop1val.value = argv[0];
|
||||
prop1val.length = strlen(argv[0]);
|
||||
prop[0].name = SmProgram;
|
||||
prop[0].type = SmARRAY8;
|
||||
prop[0].num_vals = 1;
|
||||
prop[0].vals = &prop1val;
|
||||
|
||||
/* The XSMP doc from X11R6.1 says it contains the user name,
|
||||
* but every client implementation I saw places the uid # */
|
||||
snprintf(uid, sizeof(uid), "%i", getuid());
|
||||
prop2val.value = uid;
|
||||
prop2val.length = strlen(uid);
|
||||
prop[1].name = SmUserID;
|
||||
prop[1].type = SmARRAY8;
|
||||
prop[1].num_vals = 1;
|
||||
prop[1].vals = &prop2val;
|
||||
|
||||
/* Restart style. We should restart only if we were running when
|
||||
* the previous session finished. */
|
||||
restartStyle = SmRestartIfRunning;
|
||||
prop3val.value = &restartStyle;
|
||||
prop3val.length = 1;
|
||||
prop[2].name = SmRestartStyleHint;
|
||||
prop[2].type = SmCARD8;
|
||||
prop[2].num_vals = 1;
|
||||
prop[2].vals = &prop3val;
|
||||
|
||||
/* Our PID. Not required but might be usefull */
|
||||
snprintf(pid, sizeof(pid), "%i", getpid());
|
||||
prop4val.value = pid;
|
||||
prop4val.length = strlen(pid);
|
||||
prop[3].name = SmProcessID;
|
||||
prop[3].type = SmARRAY8;
|
||||
prop[3].num_vals = 1;
|
||||
prop[3].vals = &prop4val;
|
||||
|
||||
/* we'll set the rest of the hints later */
|
||||
|
||||
SmcSetProperties(sSMCConn, 4, props);
|
||||
|
||||
}
|
||||
|
||||
void wSessionDisconnectManager(void)
|
||||
{
|
||||
if (sSMCConn) {
|
||||
WMDeleteInputHandler(sSMInputHandler);
|
||||
sSMInputHandler = NULL;
|
||||
|
||||
SmcCloseConnection(sSMCConn, 0, NULL);
|
||||
sSMCConn = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
void wSessionRequestShutdown(void)
|
||||
{
|
||||
/* request a shutdown to the session manager */
|
||||
if (sSMCConn)
|
||||
SmcRequestSaveYourself(sSMCConn, SmSaveBoth, True, SmInteractStyleAny, False, True);
|
||||
}
|
||||
|
||||
Bool wSessionIsManaged(void)
|
||||
{
|
||||
return sSMCConn != NULL;
|
||||
}
|
||||
|
||||
#endif /* !XSMP_ENABLED */
|
||||
|
||||
@@ -57,17 +57,6 @@ void wSessionRestoreState(WScreen *scr);
|
||||
|
||||
void wSessionRestoreLastWorkspace(WScreen *scr);
|
||||
|
||||
#ifdef XSMP_ENABLED
|
||||
void wSessionConnectManager(char **argv, int argc);
|
||||
|
||||
void wSessionDisconnectManager(void);
|
||||
|
||||
void wSessionRequestShutdown(void);
|
||||
|
||||
Bool wSessionIsManaged(void);
|
||||
|
||||
#endif
|
||||
|
||||
Bool wSessionGetStateFor(WWindow *wwin, WSessionData *state);
|
||||
|
||||
#endif
|
||||
|
||||
@@ -60,29 +60,10 @@ void Shutdown(WShutdownMode mode)
|
||||
|
||||
switch (mode) {
|
||||
case WSLogoutMode:
|
||||
#ifdef XSMP_ENABLED
|
||||
wSessionRequestShutdown();
|
||||
break;
|
||||
#else
|
||||
/* fall through */
|
||||
#endif
|
||||
case WSKillMode:
|
||||
case WSExitMode:
|
||||
/* if there is no session manager, send SAVE_YOURSELF to
|
||||
* the clients */
|
||||
#if 0
|
||||
#ifdef XSMP_ENABLED
|
||||
if (!wSessionIsManaged())
|
||||
#endif
|
||||
for (i = 0; i < wScreenCount; i++) {
|
||||
WScreen *scr;
|
||||
|
||||
scr = wScreenWithNumber(i);
|
||||
if (scr) {
|
||||
wSessionSendSaveYourself(scr);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
close(inotifyFD);
|
||||
for (i = 0; i < wScreenCount; i++) {
|
||||
WScreen *scr;
|
||||
@@ -93,9 +74,6 @@ void Shutdown(WShutdownMode mode)
|
||||
kill(scr->helper_pid, SIGKILL);
|
||||
|
||||
/* if the session is not being managed, save restart info */
|
||||
#ifdef XSMP_ENABLED
|
||||
if (!wSessionIsManaged())
|
||||
#endif
|
||||
wSessionSaveClients(scr);
|
||||
|
||||
wScreenSaveState(scr);
|
||||
|
||||
Reference in New Issue
Block a user