summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/tools/quicklauncher/dropins.h9
-rw-r--r--core/tools/quicklauncher/main.cpp10
2 files changed, 11 insertions, 8 deletions
diff --git a/core/tools/quicklauncher/dropins.h b/core/tools/quicklauncher/dropins.h
index 7acace9..a9664f8 100644
--- a/core/tools/quicklauncher/dropins.h
+++ b/core/tools/quicklauncher/dropins.h
@@ -1,27 +1,30 @@
1/* OPIE */
2#include <opie2/owait.h>
3using namespace Opie::Ui;
1 4
2#include <qstring.h>
3#include <qtopia/qcom.h> 5#include <qtopia/qcom.h>
4#include <qtopia/qlibrary.h> 6#include <qtopia/qlibrary.h>
7#include <qtopia/qpeapplication.h>
5#include <qtopia/applicationinterface.h> 8#include <qtopia/applicationinterface.h>
6#include <qtopia/resource.h> 9#include <qtopia/resource.h>
7 10
8#include <opie2/owait.h> 11/* QT */
9
10#include <qmetaobject.h> 12#include <qmetaobject.h>
11#include <qmap.h> 13#include <qmap.h>
14#include <qstring.h>
12 15
13namespace QuickPrivate { 16namespace QuickPrivate {
14 17
15 struct PluginLoader { 18 struct PluginLoader {
16 PluginLoader( const char* ) { 19 PluginLoader( const char* ) {
17 } 20 }
18 21
19 QRESULT queryInterface( const QString& app, const QUuid&, QUnknownInterface** ); 22 QRESULT queryInterface( const QString& app, const QUuid&, QUnknownInterface** );
20 void releaseInterface( QUnknownInterface* ); 23 void releaseInterface( QUnknownInterface* );
21 QMap<QUnknownInterface*, QLibrary*> libs; 24 QMap<QUnknownInterface*, QLibrary*> libs;
22 }; 25 };
23 26
24 /* 27 /*
25 * We can skip installing a Translator here because Opies QPEApplication 28 * We can skip installing a Translator here because Opies QPEApplication
26 * will do that in initApp for us as well 29 * will do that in initApp for us as well
27 */ 30 */
diff --git a/core/tools/quicklauncher/main.cpp b/core/tools/quicklauncher/main.cpp
index c2467fb..b1befce 100644
--- a/core/tools/quicklauncher/main.cpp
+++ b/core/tools/quicklauncher/main.cpp
@@ -5,76 +5,76 @@
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21#define QTOPIA_INTERNAL_INITAPP
21#include "dropins.h" 22#include "dropins.h"
22 23
23/* OPIE */ 24/* OPIE */
24#include <opie2/odebug.h> 25#include <opie2/odebug.h>
26using namespace Opie::Core;
25 27
26/* QT */ 28/* QT */
27#include <qpainter.h> 29#include <qpainter.h>
28#include <qstrlist.h> 30#include <qstrlist.h>
29#include <qtimer.h> 31#include <qtimer.h>
30#include <qguardedptr.h> 32#include <qguardedptr.h>
31#include <qcopchannel_qws.h> 33#include <qcopchannel_qws.h>
32#define QTOPIA_INTERNAL_INITAPP
33 34
34#ifdef private 35#ifdef private
35# undef private 36# undef private
36#endif 37#endif
37#define private public 38#define private public
38#include <qtopia/qpeapplication.h> 39#include <qtopia/qpeapplication.h>
39#undef private 40#undef private
40 41
41/* STD */ 42/* STD */
42#include <stdio.h> 43#include <stdio.h>
43#include <stdlib.h> 44#include <stdlib.h>
44#include <sys/types.h> 45#include <sys/types.h>
45#include <sys/stat.h> 46#include <sys/stat.h>
46#include <unistd.h> 47#include <unistd.h>
47 48
48 49
49using QuickPrivate::PluginLoader; 50using QuickPrivate::PluginLoader;
50 51
51static QPEApplication *app = 0; 52static QPEApplication *app = 0;
52static PluginLoader *loader = 0; 53static PluginLoader *loader = 0;
53static ApplicationInterface *appIface = 0; 54static ApplicationInterface *appIface = 0;
54static QGuardedPtr<QWidget> mainWindow; 55static QGuardedPtr<QWidget> mainWindow;
55 56
56#ifdef _OS_LINUX_ 57#ifdef _OS_LINUX_
57static char **argv0 = 0; 58static char **argv0 = 0;
58static int argv_lth; 59static int argv_lth;
59extern char **environ; 60extern char **environ;
60#ifndef SPT_BUFSIZE 61#ifndef SPT_BUFSIZE
61#define SPT_BUFSIZE 2048 62#define SPT_BUFSIZE 2048
62#endif 63#endif
63#include <stdarg.h> 64#include <stdarg.h>
64using namespace Opie::Ui;
65void setproctitle (const char *fmt,...) { 65void setproctitle (const char *fmt,...) {
66 int i; 66 int i;
67 char buf[SPT_BUFSIZE]; 67 char buf[SPT_BUFSIZE];
68 va_list ap; 68 va_list ap;
69 69
70 if (!argv0) 70 if (!argv0)
71 return; 71 return;
72 72
73 va_start(ap, fmt); 73 va_start(ap, fmt);
74 (void) vsnprintf(buf, SPT_BUFSIZE, fmt, ap); 74 (void) vsnprintf(buf, SPT_BUFSIZE, fmt, ap);
75 va_end(ap); 75 va_end(ap);
76 76
77 i = strlen (buf); 77 i = strlen (buf);
78 if (i > argv_lth - 2) { 78 if (i > argv_lth - 2) {
79 i = argv_lth - 2; 79 i = argv_lth - 2;
80 buf[i] = '\0'; 80 buf[i] = '\0';
@@ -120,41 +120,41 @@ public:
120 } else { 120 } else {
121 owarn << "Could not create application main window" << oendl; 121 owarn << "Could not create application main window" << oendl;
122 exit(-1); 122 exit(-1);
123 } 123 }
124 } 124 }
125 125
126private slots: 126private slots:
127 void message(const QCString &msg, const QByteArray & data) 127 void message(const QCString &msg, const QByteArray & data)
128 { 128 {
129 QStrList argList; 129 QStrList argList;
130 130
131 if ( msg == "execute(QStrList)" ) { 131 if ( msg == "execute(QStrList)" ) {
132 delete qlChannel; 132 delete qlChannel;
133 QDataStream stream( data, IO_ReadOnly ); 133 QDataStream stream( data, IO_ReadOnly );
134 QStrList argList; 134 QStrList argList;
135 stream >> argList; 135 stream >> argList;
136 odebug << "QuickLauncher execute: " << argList.at(0) << "" << oendl; 136 odebug << "QuickLauncher execute: " << argList.at(0) << oendl;
137 doQuickLaunch( argList ); 137 doQuickLaunch( argList );
138 delete this; 138 delete this;
139 } else if ( msg == "execute(QString)" ) { 139 } else if ( msg == "execute(QString)" ) {
140 delete qlChannel; 140 delete qlChannel;
141 QDataStream stream( data, IO_ReadOnly ); 141 QDataStream stream( data, IO_ReadOnly );
142 QString arg; 142 QString arg;
143 stream >> arg; 143 stream >> arg;
144 odebug << "QuickLauncher execute: " << arg << "" << oendl; 144 odebug << "QuickLauncher execute: " << arg << oendl;
145 QStrList argList; 145 QStrList argList;
146 argList.append( arg.utf8() ); 146 argList.append( arg.utf8() );
147 doQuickLaunch( argList ); 147 doQuickLaunch( argList );
148 delete this; 148 delete this;
149 } 149 }
150 } 150 }
151 151
152private: 152private:
153 void doQuickLaunch( QStrList &argList ) 153 void doQuickLaunch( QStrList &argList )
154 { 154 {
155 static int myargc = argList.count(); 155 static int myargc = argList.count();
156 static char **myargv = new char *[myargc + 1]; 156 static char **myargv = new char *[myargc + 1];
157 for ( int j = 0; j < myargc; j++ ) { 157 for ( int j = 0; j < myargc; j++ ) {
158 myargv[j] = new char [strlen(argList.at(j))+1]; 158 myargv[j] = new char [strlen(argList.at(j))+1];
159 strcpy( myargv[j], argList.at(j) ); 159 strcpy( myargv[j], argList.at(j) );
160 } 160 }
@@ -174,33 +174,33 @@ private:
174 QCopChannel *qlChannel; 174 QCopChannel *qlChannel;
175}; 175};
176 176
177int main( int argc, char** argv ) 177int main( int argc, char** argv )
178{ 178{
179 app = new QPEApplication( argc, argv ); 179 app = new QPEApplication( argc, argv );
180 180
181 loader = new PluginLoader( "application" ); 181 loader = new PluginLoader( "application" );
182 182
183 unsetenv( "LD_BIND_NOW" ); 183 unsetenv( "LD_BIND_NOW" );
184 184
185 QCString arg0 = argv[0]; 185 QCString arg0 = argv[0];
186 int sep = arg0.findRev( '/' ); 186 int sep = arg0.findRev( '/' );
187 if ( sep > 0 ) 187 if ( sep > 0 )
188 arg0 = arg0.mid( sep+1 ); 188 arg0 = arg0.mid( sep+1 );
189 if ( arg0 != "quicklauncher" ) { 189 if ( arg0 != "quicklauncher" ) {
190 odebug << "QuickLauncher invoked as: " << arg0.data() << "" << oendl; 190 odebug << "QuickLauncher invoked as: " << arg0.data() << oendl;
191 QuickLauncher::exec( argc, argv ); 191 QuickLauncher::exec( argc, argv );
192 } else { 192 } else {
193#ifdef _OS_LINUX_ 193#ifdef _OS_LINUX_
194 // Setup to change proc title 194 // Setup to change proc title
195 int i; 195 int i;
196 char **envp = environ; 196 char **envp = environ;
197 /* Move the environment so we can reuse the memory. 197 /* Move the environment so we can reuse the memory.
198 * (Code borrowed from sendmail.) */ 198 * (Code borrowed from sendmail.) */
199 for (i = 0; envp[i] != NULL; i++) 199 for (i = 0; envp[i] != NULL; i++)
200 continue; 200 continue;
201 environ = (char **) malloc(sizeof(char *) * (i + 1)); 201 environ = (char **) malloc(sizeof(char *) * (i + 1));
202 if (environ == NULL) 202 if (environ == NULL)
203 return -1; 203 return -1;
204 for (i = 0; envp[i] != NULL; i++) 204 for (i = 0; envp[i] != NULL; i++)
205 if ((environ[i] = strdup(envp[i])) == NULL) 205 if ((environ[i] = strdup(envp[i])) == NULL)
206 return -1; 206 return -1;