Terminate kwin manager unless a TDE or failsafe session was selected

This closes Bug 824
(cherry picked from commit a305c08326)
v3.5.13-sru
Timothy Pearson 13 years ago committed by Slávek Banko
parent a8862198d1
commit b2dacef1e9

@ -257,6 +257,7 @@ kg_main( const char *argv0 )
XSetIOErrorHandler( xIOErr );
TQString login_user;
TQString login_session_wm;
Display *dpy = qt_xdisplay();
@ -409,6 +410,7 @@ kg_main( const char *argv0 )
Debug( "left event loop\n" );
login_user = static_cast<KGreeter*>(dialog)->curUser;
login_session_wm = static_cast<KGreeter*>(dialog)->curWMSession;
if (rslt != ex_greet) {
delete dialog;
@ -451,8 +453,13 @@ kg_main( const char *argv0 )
delete comp;
}
if (kwin) {
kwin->closeStdin();
kwin->detach();
if (login_session_wm.endsWith("/startkde") || (login_session_wm == "failsafe")) {
kwin->closeStdin();
kwin->detach();
}
else {
kwin->kill();
}
delete kwin;
}
delete proc;

@ -842,10 +842,12 @@ KGreeter::verifyOk()
GSendInt( G_PutDmrc );
GSendStr( "Session" );
GSendStr( sessionTypes[curSel].type.utf8() );
curWMSession = sessionTypes[curSel].type.utf8();
} else if (!prevValid) {
GSendInt( G_PutDmrc );
GSendStr( "Session" );
GSendStr( "default" );
curWMSession = sessionTypes[curSel].type.utf8();
}
GSendInt( G_Ready );
closingDown = true;

@ -75,7 +75,7 @@ class KGreeter : public KGDialog, public KGVerifyHandler {
void handleInputPipe();
public:
TQString curUser, dName;
TQString curUser, curWMSession, dName;
protected:
void readFacesList();

Loading…
Cancel
Save