diff options
author | Ken Moore <moorekou@gmail.com> | 2016-04-26 09:44:23 -0400 |
---|---|---|
committer | Ken Moore <moorekou@gmail.com> | 2016-04-26 09:44:23 -0400 |
commit | 1cece69cdba961c2d568a77d3144e070f0e26a9b (patch) | |
tree | 7b4cf1293d8a9f96e38b40a0ee00288639547413 | |
parent | Add the beginnings of a new "lumina-session" wrapper utility for the sequentu... (diff) | |
download | lumina-1cece69cdba961c2d568a77d3144e070f0e26a9b.tar.gz lumina-1cece69cdba961c2d568a77d3144e070f0e26a9b.tar.bz2 lumina-1cece69cdba961c2d568a77d3144e070f0e26a9b.zip |
Oops - forgot to "git add" the new lumina-session files.
-rw-r--r-- | desktop-utilities/desktop-utilities.pro | 3 | ||||
-rw-r--r-- | src-qt5/core/lumina-session/lumina-session.pro | 17 | ||||
-rw-r--r-- | src-qt5/core/lumina-session/main.cpp | 54 | ||||
-rw-r--r-- | src-qt5/core/lumina-session/session.h | 81 | ||||
-rw-r--r-- | src-qt5/desktop-utils/lumina-fm/Insight-FileManager.png | bin | 0 -> 2829 bytes |
5 files changed, 152 insertions, 3 deletions
diff --git a/desktop-utilities/desktop-utilities.pro b/desktop-utilities/desktop-utilities.pro deleted file mode 100644 index 8d6c5f46..00000000 --- a/desktop-utilities/desktop-utilities.pro +++ /dev/null @@ -1,3 +0,0 @@ -TEMPLATE = subdirs - -SUBDIRS+= lumina-terminal diff --git a/src-qt5/core/lumina-session/lumina-session.pro b/src-qt5/core/lumina-session/lumina-session.pro new file mode 100644 index 00000000..e9a6c319 --- /dev/null +++ b/src-qt5/core/lumina-session/lumina-session.pro @@ -0,0 +1,17 @@ +include($${PWD}/../../OS-detect.pri) + +QT += core widgets x11extras + + +TARGET = start-lumina-desktop +target.path = $${L_BINDIR} + + +LIBS += -lLuminaUtils -lxcb -lxcb-damage +DEPENDPATH += ../libLumina + +SOURCES += main.cpp + +HEADERS += session.h + +INSTALLS += target diff --git a/src-qt5/core/lumina-session/main.cpp b/src-qt5/core/lumina-session/main.cpp new file mode 100644 index 00000000..0ed3067a --- /dev/null +++ b/src-qt5/core/lumina-session/main.cpp @@ -0,0 +1,54 @@ +//=========================================== +// Lumina-DE source code +// Copyright (c) 2016, Ken Moore +// Available under the 3-clause BSD license +// See the LICENSE file for full details +//=========================================== +#include <QDebug> +#include <QCoreApplication> +#include <QProcess> +#include <QString> + + + + +#include "session.h" +#include <LuminaUtils.h> +#include <LuminaOS.h> +#include <LuminaThemes.h> +#include <LuminaXDG.h> + +#define DEBUG 0 + +int main(int argc, char ** argv) +{ + if (argc > 1) { + if (QString(argv[1]) == QString("--version")){ + qDebug() << LUtils::LuminaDesktopVersion(); + return 0; + } + } + if(!QFile::exists(LOS::LuminaShare())){ + qDebug() << "Lumina does not appear to be installed correctly. Cannot find: " << LOS::LuminaShare(); + return 1; + } + //Setup any initialization values + LTHEME::LoadCustomEnvSettings(); + LXDG::setEnvironmentVars(); + setenv("DESKTOP_SESSION","Lumina",1); + setenv("XDG_CURRENT_DESKTOP","Lumina",1); + unsetenv("QT_QPA_PLATFORMTHEME"); //causes issues with Lumina themes - not many people have this by default... + //Check for any missing user config files + + //Start X11 if needed + + //Configure X11 monitors if needed + + //Startup the session + QCoreApplication a(argc, argv); + LSession sess; + sess.start(); + int retCode = a.exec(); + qDebug() << "Finished Closing Down Lumina"; + return retCode; +} diff --git a/src-qt5/core/lumina-session/session.h b/src-qt5/core/lumina-session/session.h new file mode 100644 index 00000000..7e5f1deb --- /dev/null +++ b/src-qt5/core/lumina-session/session.h @@ -0,0 +1,81 @@ +//=========================================== +// Lumina-DE source code +// Copyright (c) 2016, Ken Moore +// Available under the 3-clause BSD license +// See the LICENSE file for full details +//=========================================== +#include <QObject> +#include <QProcess> +#include <QProcessEnvironment> + +#include <LuminaUtils.h> + +class LSession : public QObject{ +private: + QList<QProcess*> PROCS; + bool stopping; + + void startProcess(QString ID, QString command){ + QString logfile = QDir::homePath()+"/.lumina/logs/"+ID+".log"; + if(QFile::exists(logfile+".old")){ QFile::remove(logfile+".old"); } + if(QFile::exists(logfile)){ QFile::rename(logfile,logfile+".old"); } + QProcess *proc = new QProcess(); + proc->setProcessChannelMode(QProcess::MergedChannels); + proc->setProcessEnvironment( QProcessEnvironment::systemEnvironment() ); + proc->setStandardOutputFile(logfile); + proc->start(command, QIODevice::ReadOnly); + connect(proc, SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(procFinished()) ); + PROCS << proc; + } + +private slots: + void stopall(){ + stopping = true; + for(int i=0; i<PROCS.length(); i++){ + if(PROCS[i]->state()!=QProcess::NotRunning){ PROCS[i]->kill(); } + } + } + + void procFinished(){ + //Go through and check the status on all the procs to determine which one finished + int stopped = 0; + for(int i=0; i<PROCS.length(); i++){ + if(PROCS[i]->state()==QProcess::NotRunning){ + stopped++; + if(!stopping){ + //See if this process is the main desktop binary + if(PROCS[i]->program().section("/",-1) == "Lumina-DE"){ stopall(); } //start closing down everything + //else{ PROCS[i]->start(QIODevice::ReadOnly); } //restart the process + break; + } + } + } + if(stopping && stopped==PROCS.length()){ + QCoreApplication::exit(0); + } + } + +public: + LSession(){ + stopping = false; + } + ~LSession(){ } + + void start(){ + //First check for a valid installation + if( !LUtils::isValidBinary("fluxbox") || !LUtils::isValidBinary("Lumina-DE") ){ + exit(1); + } + //Window Manager First + // FLUXBOX BUG BYPASS: if the ~/.fluxbox dir does not exist, it will ignore the given config file + //if(!QFile::exists(QDir::homePath()+"/.fluxbox")){ QDir dir; dir.mkpath(QDir::homePath()+"/.fluxbox"); } + //startProcess("wm", "fluxbox -rc "+QDir::homePath()+"/.lumina/fluxbox-init -no-slit -no-toolbar"); + //Desktop Next + startProcess("runtime","Lumina-DE"); + //ScreenSaver + if(LUtils::isValidBinary("xscreensaver")){ startProcess("screensaver","xscreensaver -no-splash"); } + //Compositing manager + if(LUtils::isValidBinary("xcompmgr")){ startProcess("compositing","xcompmgr"); } + } + +}; diff --git a/src-qt5/desktop-utils/lumina-fm/Insight-FileManager.png b/src-qt5/desktop-utils/lumina-fm/Insight-FileManager.png Binary files differnew file mode 100644 index 00000000..46cfaad7 --- /dev/null +++ b/src-qt5/desktop-utils/lumina-fm/Insight-FileManager.png |