summaryrefslogtreecommitdiff
path: root/library
Side-by-side diff
Diffstat (limited to 'library') (more/less context) (ignore whitespace changes)
-rw-r--r--library/qpeapplication.cpp2294
-rw-r--r--library/styleinterface.h68
2 files changed, 1284 insertions, 1078 deletions
diff --git a/library/qpeapplication.cpp b/library/qpeapplication.cpp
index dff8235..187a7e2 100644
--- a/library/qpeapplication.cpp
+++ b/library/qpeapplication.cpp
@@ -60,3 +60,3 @@
-#define FBIOBLANK 0x4611
+#define FBIOBLANK 0x4611
@@ -66,2 +66,3 @@
#include "qpestyle.h"
+#include "styleinterface.h"
#if QT_VERSION >= 300
@@ -76,3 +77,2 @@
#include <qpe/qlibrary.h>
-#include <dlfcn.h>
#endif
@@ -107,118 +107,125 @@
-class QPEApplicationData {
+class QPEApplicationData
+{
public:
- QPEApplicationData() : presstimer(0), presswidget(0), rightpressed(FALSE),
- kbgrabber(0), kbregrab(FALSE), notbusysent(FALSE), preloaded(FALSE),
- forceshow(FALSE), nomaximize(FALSE), qpe_main_widget(0),
- keep_running(TRUE)
- {
- qcopq.setAutoDelete(TRUE);
- }
+ QPEApplicationData() : presstimer( 0 ), presswidget( 0 ), rightpressed( FALSE ),
+ kbgrabber( 0 ), kbregrab( FALSE ), notbusysent( FALSE ), preloaded( FALSE ),
+ forceshow( FALSE ), nomaximize( FALSE ), qpe_main_widget( 0 ),
+ keep_running( TRUE )
+ {
+ qcopq.setAutoDelete( TRUE );
+ }
- int presstimer;
- QWidget* presswidget;
- QPoint presspos;
- bool rightpressed;
- int kbgrabber;
- bool kbregrab;
- bool notbusysent;
- QString appName;
- struct QCopRec {
- QCopRec(const QCString &ch, const QCString &msg,
- const QByteArray &d) :
- channel(ch), message(msg), data(d) { }
-
- QCString channel;
- QCString message;
- QByteArray data;
- };
- bool preloaded;
- bool forceshow;
- bool nomaximize;
- QWidget* qpe_main_widget;
- bool keep_running;
- QList<QCopRec> qcopq;
-
- void enqueueQCop(const QCString &ch, const QCString &msg,
- const QByteArray &data)
- {
- qcopq.append(new QCopRec(ch,msg,data));
- }
- void sendQCopQ()
- {
- QCopRec* r;
- for (QListIterator<QCopRec> it(qcopq); (r=it.current()); ++it)
- QCopChannel::sendLocally(r->channel,r->message,r->data);
- qcopq.clear();
- }
+ int presstimer;
+ QWidget* presswidget;
+ QPoint presspos;
+ bool rightpressed;
+ int kbgrabber;
+ bool kbregrab;
+ bool notbusysent;
+ QString appName;
+ struct QCopRec
+ {
+ QCopRec( const QCString &ch, const QCString &msg,
+ const QByteArray &d ) :
+ channel( ch ), message( msg ), data( d )
+ { }
+
+ QCString channel;
+ QCString message;
+ QByteArray data;
+ };
+ bool preloaded;
+ bool forceshow;
+ bool nomaximize;
+ QWidget* qpe_main_widget;
+ bool keep_running;
+ QList<QCopRec> qcopq;
+
+ void enqueueQCop( const QCString &ch, const QCString &msg,
+ const QByteArray &data )
+ {
+ qcopq.append( new QCopRec( ch, msg, data ) );
+ }
+ void sendQCopQ()
+ {
+ QCopRec * r;
+ for ( QListIterator<QCopRec> it( qcopq ); ( r = it.current() ); ++it )
+ QCopChannel::sendLocally( r->channel, r->message, r->data );
+ qcopq.clear();
+ }
};
-class ResourceMimeFactory : public QMimeSourceFactory {
+class ResourceMimeFactory : public QMimeSourceFactory
+{
public:
- ResourceMimeFactory()
- {
- setFilePath( Global::helpPath() );
- setExtensionType("html","text/html;charset=UTF-8");
- }
+ ResourceMimeFactory()
+ {
+ setFilePath( Global::helpPath() );
+ setExtensionType( "html", "text/html;charset=UTF-8" );
+ }
- const QMimeSource* data(const QString& abs_name) const
- {
- const QMimeSource* r = QMimeSourceFactory::data(abs_name);
- if ( !r ) {
- int sl = abs_name.length();
- do {
- sl = abs_name.findRev('/',sl-1);
- QString name = sl>=0 ? abs_name.mid(sl+1) : abs_name;
- int dot = name.findRev('.');
- if ( dot >= 0 )
- name = name.left(dot);
- QImage img = Resource::loadImage(name);
- if ( !img.isNull() )
- r = new QImageDrag(img);
- } while (!r && sl>0);
- }
- return r;
- }
+ const QMimeSource* data( const QString& abs_name ) const
+ {
+ const QMimeSource * r = QMimeSourceFactory::data( abs_name );
+ if ( !r ) {
+ int sl = abs_name.length();
+ do {
+ sl = abs_name.findRev( '/', sl - 1 );
+ QString name = sl >= 0 ? abs_name.mid( sl + 1 ) : abs_name;
+ int dot = name.findRev( '.' );
+ if ( dot >= 0 )
+ name = name.left( dot );
+ QImage img = Resource::loadImage( name );
+ if ( !img.isNull() )
+ r = new QImageDrag( img );
+ }
+ while ( !r && sl > 0 );
+ }
+ return r;
+ }
};
-static int muted=0;
-static int micMuted=0;
+static int muted = 0;
+static int micMuted = 0;
-static void setVolume(int t=0, int percent=-1)
+static void setVolume( int t = 0, int percent = -1 )
{
- switch (t) {
- case 0: {
- Config cfg("qpe");
- cfg.setGroup("Volume");
- if ( percent < 0 )
- percent = cfg.readNumEntry("VolumePercent",50);
- int fd = 0;
- if ((fd = open("/dev/mixer", O_RDWR))>=0) {
- int vol = muted ? 0 : percent;
- // set both channels to same volume
- vol |= vol << 8;
- ioctl(fd, MIXER_WRITE(0), &vol);
- ::close(fd);
- }
- } break;
- }
+ switch ( t ) {
+ case 0: {
+ Config cfg( "qpe" );
+ cfg.setGroup( "Volume" );
+ if ( percent < 0 )
+ percent = cfg.readNumEntry( "VolumePercent", 50 );
+ int fd = 0;
+ if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) {
+ int vol = muted ? 0 : percent;
+ // set both channels to same volume
+ vol |= vol << 8;
+ ioctl( fd, MIXER_WRITE( 0 ), &vol );
+ ::close( fd );
+ }
+ }
+ break;
+ }
}
-static void setMic(int t=0, int percent=-1)
+static void setMic( int t = 0, int percent = -1 )
{
- switch (t) {
- case 0: {
- Config cfg("qpe");
- cfg.setGroup("Volume");
- if ( percent < 0 )
- percent = cfg.readNumEntry("Mic",50);
-
- int fd = 0;
- int mic = micMuted ? 0 : percent;
- if ((fd = open("/dev/mixer", O_RDWR))>=0) {
- ioctl(fd, MIXER_WRITE(SOUND_MIXER_MIC), &mic);
- ::close(fd);
- }
- } break;
- }
+ switch ( t ) {
+ case 0: {
+ Config cfg( "qpe" );
+ cfg.setGroup( "Volume" );
+ if ( percent < 0 )
+ percent = cfg.readNumEntry( "Mic", 50 );
+
+ int fd = 0;
+ int mic = micMuted ? 0 : percent;
+ if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) {
+ ioctl( fd, MIXER_WRITE( SOUND_MIXER_MIC ), &mic );
+ ::close( fd );
+ }
+ }
+ break;
+ }
}
@@ -228,7 +235,9 @@ int qpe_sysBrightnessSteps()
#if defined(QT_QWS_IPAQ)
- return 255;
+ return 255;
#elif defined(QT_QWS_EBX)
- return 4;
+
+ return 4;
#else
- return 255; // ?
+
+ return 255; // ?
#endif
@@ -237,10 +246,11 @@ int qpe_sysBrightnessSteps()
-static int& hack(int& i)
+static int& hack( int& i )
{
#if QT_VERSION <= 230 && defined(QT_NO_CODECS)
- // These should be created, but aren't in Qt 2.3.0
- (void)new QUtf8Codec;
- (void)new QUtf16Codec;
+ // These should be created, but aren't in Qt 2.3.0
+ ( void ) new QUtf8Codec;
+ ( void ) new QUtf16Codec;
#endif
- return i;
+
+ return i;
}
@@ -248,3 +258,3 @@ static int& hack(int& i)
static bool forced_off = FALSE;
-static int curbl=-1;
+static int curbl = -1;
@@ -252,56 +262,63 @@ static int backlight()
{
- if ( curbl == -1 ) {
- // Read from config
- Config config( "qpe" );
- config.setGroup( "Screensaver" );
- curbl = config.readNumEntry("Brightness",255);
- }
- return curbl;
+ if ( curbl == -1 ) {
+ // Read from config
+ Config config( "qpe" );
+ config.setGroup( "Screensaver" );
+ curbl = config.readNumEntry( "Brightness", 255 );
+ }
+ return curbl;
}
-static void setBacklight(int bright)
+static void setBacklight( int bright )
{
- if ( bright == -3 ) {
- // Forced on
- forced_off = FALSE;
- bright = -1;
- }
- if ( forced_off && bright != -2 )
- return;
- if ( bright == -2 ) {
- // Toggle between off and on
- bright = curbl ? 0 : -1;
- forced_off = !bright;
- }
- if ( bright == -1 ) {
- // Read from config
- Config config( "qpe" );
- config.setGroup( "Screensaver" );
- bright = config.readNumEntry("Brightness",255);
- }
+ if ( bright == -3 ) {
+ // Forced on
+ forced_off = FALSE;
+ bright = -1;
+ }
+ if ( forced_off && bright != -2 )
+ return ;
+ if ( bright == -2 ) {
+ // Toggle between off and on
+ bright = curbl ? 0 : -1;
+ forced_off = !bright;
+ }
+ if ( bright == -1 ) {
+ // Read from config
+ Config config( "qpe" );
+ config.setGroup( "Screensaver" );
+ bright = config.readNumEntry( "Brightness", 255 );
+ }
#if defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX)
- if ( QFile::exists("/usr/bin/bl") ) {
- QString cmd = "/usr/bin/bl 1 ";
- cmd += bright<=0 ? "0 " : "1 ";
- cmd += QString::number(bright);
- system(cmd.latin1());
+ if ( QFile::exists( "/usr/bin/bl" ) ) {
+ QString cmd = "/usr/bin/bl 1 ";
+ cmd += bright <= 0 ? "0 " : "1 ";
+ cmd += QString::number( bright );
+ system( cmd.latin1() );
#if defined(QT_QWS_EBX)
- } else if ( QFile::exists("/dev/fl") ) {
+
+ }
+ else if ( QFile::exists( "/dev/fl" ) ) {
#define FL_IOCTL_STEP_CONTRAST 100
- int fd = open("/dev/fl", O_WRONLY);
- if (fd >= 0 ) {
- int steps = qpe_sysBrightnessSteps();
- int bl = ( bright * steps + 127 ) / 255;
- if ( bright && !bl ) bl = 1;
- bl = ioctl(fd, FL_IOCTL_STEP_CONTRAST, bl);
- close(fd);
- }
- }
+ int fd = open( "/dev/fl", O_WRONLY );
+ if ( fd >= 0 ) {
+ int steps = qpe_sysBrightnessSteps();
+ int bl = ( bright * steps + 127 ) / 255;
+ if ( bright && !bl )
+ bl = 1;
+ bl = ioctl( fd, FL_IOCTL_STEP_CONTRAST, bl );
+ close( fd );
+ }
+ }
#elif defined(QT_QWS_IPAQ)
- } else if ( QFile::exists("/dev/ts") || QFile::exists("/dev/h3600_ts") ) {
- typedef struct {
- unsigned char mode;
- unsigned char pwr;
- unsigned char brightness;
- } FLITE_IN;
+
+ }
+ else if ( QFile::exists( "/dev/ts" ) || QFile::exists( "/dev/h3600_ts" ) )
+ {
+ typedef struct {
+ unsigned char mode;
+ unsigned char pwr;
+ unsigned char brightness;
+ }
+ FLITE_IN;
# ifndef FLITE_ON
@@ -312,22 +329,25 @@ static void setBacklight(int bright)
# endif
- int fd;
- if ( QFile::exists("/dev/ts") )
- fd = open("/dev/ts", O_WRONLY);
- else
- fd = open("/dev/h3600_ts", O_WRONLY);
- if (fd >= 0 ) {
- FLITE_IN bl;
- bl.mode = 1;
- bl.pwr = bright ? 1 : 0;
- bl.brightness = bright;
- ioctl(fd, FLITE_ON, &bl);
- close(fd);
- }
- }
+
+ int fd;
+ if ( QFile::exists( "/dev/ts" ) )
+ fd = open( "/dev/ts", O_WRONLY );
+ else
+ fd = open( "/dev/h3600_ts", O_WRONLY );
+ if ( fd >= 0 ) {
+ FLITE_IN bl;
+ bl.mode = 1;
+ bl.pwr = bright ? 1 : 0;
+ bl.brightness = bright;
+ ioctl( fd, FLITE_ON, &bl );
+ close( fd );
+ }
+ }
#endif
#endif
- curbl = bright;
+ curbl = bright;
}
-void qpe_setBacklight(int bright) { setBacklight(bright); }
+void qpe_setBacklight( int bright ) {
+ setBacklight( bright );
+}
@@ -339,3 +359,3 @@ static bool powerOnline()
{
- return PowerStatusManager::readStatus().acStatus() == PowerStatus::Online;
+ return PowerStatusManager::readStatus().acStatus() == PowerStatus::Online;
}
@@ -344,3 +364,3 @@ static bool networkOnline()
{
- return Network::networkOnline();
+ return Network::networkOnline();
}
@@ -350,103 +370,114 @@ class QPEScreenSaver : public QWSScreenSaver
private:
- int LcdOn;
+ int LcdOn;
public:
- QPEScreenSaver()
- {
- int fd;
-
- LcdOn = TRUE;
- // Make sure the LCD is in fact on, (if opie was killed while the LCD is off it would still be off)
- fd=open("/dev/fb0",O_RDWR);
- if (fd != -1) { ioctl(fd,FBIOBLANK,VESA_NO_BLANKING); close(fd); }
- }
- void restore()
- {
- if (!LcdOn) // We must have turned it off
- {
- int fd;
- fd=open("/dev/fb0",O_RDWR);
- if (fd != -1) { ioctl(fd,FBIOBLANK,VESA_NO_BLANKING); close(fd); }
- }
- setBacklight(-1);
- }
- bool save(int level)
- {
- int fd;
-
- switch ( level ) {
- case 0:
- if ( disable_suspend > 0 && dim_on ) {
- if (backlight() > 1)
- setBacklight(1); // lowest non-off
- }
- return TRUE;
- break;
- case 1:
- if ( disable_suspend > 1 && lightoff_on ) {
- setBacklight(0); // off
- }
- return TRUE;
- break;
- case 2:
- Config config( "qpe" );
- config.setGroup( "Screensaver" );
- if (config.readNumEntry("LcdOffOnly",0) != 0) // We're only turning off the LCD
- {
- fd=open("/dev/fb0",O_RDWR);
- if (fd != -1) { ioctl(fd,FBIOBLANK,VESA_POWERDOWN); close(fd); }
- LcdOn = FALSE;
- }
- else // We're going to suspend the whole machine
- {
- if ( disable_suspend > 2 && !powerOnline() && !networkOnline() ) {
- QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE );
- return TRUE;
- }
- }
- break;
- }
- return FALSE;
- }
+ QPEScreenSaver()
+ {
+ int fd;
+
+ LcdOn = TRUE;
+ // Make sure the LCD is in fact on, (if opie was killed while the LCD is off it would still be off)
+ fd = open( "/dev/fb0", O_RDWR );
+ if ( fd != -1 ) {
+ ioctl( fd, FBIOBLANK, VESA_NO_BLANKING );
+ close( fd );
+ }
+ }
+ void restore()
+ {
+ if ( !LcdOn ) // We must have turned it off
+ {
+ int fd;
+ fd = open( "/dev/fb0", O_RDWR );
+ if ( fd != -1 )
+ {
+ ioctl( fd, FBIOBLANK, VESA_NO_BLANKING );
+ close( fd );
+ }
+ }
+ setBacklight( -1 );
+ }
+ bool save( int level )
+ {
+ int fd;
+
+ switch ( level ) {
+ case 0:
+ if ( disable_suspend > 0 && dim_on ) {
+ if ( backlight() > 1 )
+ setBacklight( 1 ); // lowest non-off
+ }
+ return TRUE;
+ break;
+ case 1:
+ if ( disable_suspend > 1 && lightoff_on ) {
+ setBacklight( 0 ); // off
+ }
+ return TRUE;
+ break;
+ case 2:
+ Config config( "qpe" );
+ config.setGroup( "Screensaver" );
+ if ( config.readNumEntry( "LcdOffOnly", 0 ) != 0 ) // We're only turning off the LCD
+ {
+ fd = open( "/dev/fb0", O_RDWR );
+ if ( fd != -1 )
+ {
+ ioctl( fd, FBIOBLANK, VESA_POWERDOWN );
+ close( fd );
+ }
+ LcdOn = FALSE;
+ }
+ else // We're going to suspend the whole machine
+ {
+ if ( disable_suspend > 2 && !powerOnline() && !networkOnline() ) {
+ QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE );
+ return TRUE;
+ }
+ }
+ break;
+ }
+ return FALSE;
+ }
};
-static int ssi(int interval, Config &config, const QString &enable, const QString& value, int def)
+static int ssi( int interval, Config & config, const QString & enable, const QString & value, int def )
{
- if ( !enable.isEmpty() && config.readNumEntry(enable,0) == 0 )
- return 0;
+ if ( !enable.isEmpty() && config.readNumEntry( enable, 0 ) == 0 )
+ return 0;
- if ( interval < 0 ) {
- // Restore screen blanking and power saving state
- interval = config.readNumEntry( value, def );
- }
- return interval;
+ if ( interval < 0 ) {
+ // Restore screen blanking and power saving state
+ interval = config.readNumEntry( value, def );
+ }
+ return interval;
}
-static void setScreenSaverIntervals(int i1, int i2, int i3)
+static void setScreenSaverIntervals( int i1, int i2, int i3 )
{
- Config config( "qpe" );
- config.setGroup( "Screensaver" );
-
- int v[4];
- i1 = ssi(i1, config, "Dim","Interval_Dim", 30);
- i2 = ssi(i2, config, "LightOff","Interval_LightOff", 20);
- i3 = ssi(i3, config, "","Interval", 60);
-
- //qDebug("screen saver intervals: %d %d %d", i1, i2, i3);
-
- v[0] = QMAX( 1000*i1, 100);
- v[1] = QMAX( 1000*i2, 100);
- v[2] = QMAX( 1000*i3, 100);
- v[3] = 0;
- dim_on = ( (i1 != 0) ? config.readNumEntry("Dim",1) : FALSE );
- lightoff_on = ( (i2 != 0 ) ? config.readNumEntry("LightOff",1) : FALSE );
- if ( !i1 && !i2 && !i3 )
- QWSServer::setScreenSaverInterval(0);
- else
- QWSServer::setScreenSaverIntervals(v);
+ Config config( "qpe" );
+ config.setGroup( "Screensaver" );
+
+ int v[ 4 ];
+ i1 = ssi( i1, config, "Dim", "Interval_Dim", 30 );
+ i2 = ssi( i2, config, "LightOff", "Interval_LightOff", 20 );
+ i3 = ssi( i3, config, "", "Interval", 60 );
+
+ //qDebug("screen saver intervals: %d %d %d", i1, i2, i3);
+
+ v[ 0 ] = QMAX( 1000 * i1, 100 );
+ v[ 1 ] = QMAX( 1000 * i2, 100 );
+ v[ 2 ] = QMAX( 1000 * i3, 100 );
+ v[ 3 ] = 0;
+ dim_on = ( ( i1 != 0 ) ? config.readNumEntry( "Dim", 1 ) : FALSE );
+ lightoff_on = ( ( i2 != 0 ) ? config.readNumEntry( "LightOff", 1 ) : FALSE );
+ if ( !i1 && !i2 && !i3 )
+ QWSServer::setScreenSaverInterval( 0 );
+ else
+ QWSServer::setScreenSaverIntervals( v );
}
-static void setScreenSaverInterval(int interval)
+static void setScreenSaverInterval( int interval )
{
- setScreenSaverIntervals(-1,-1,interval);
+ setScreenSaverIntervals( -1, -1, interval );
}
@@ -458,3 +489,3 @@ static void setScreenSaverInterval(int interval)
that are available to all Qtopia applications.
-
+
Simply by using QPEApplication instead of QApplication, a plain Qt
@@ -468,3 +499,3 @@ static void setScreenSaverInterval(int interval)
\fn void QPEApplication::clientMoused()
-
+
\internal
@@ -474,3 +505,3 @@ static void setScreenSaverInterval(int interval)
\fn void QPEApplication::timeChanged();
-
+
This signal is emitted when the time jumps forward or backwards
@@ -481,3 +512,3 @@ static void setScreenSaverInterval(int interval)
\fn void QPEApplication::clockChanged( bool ampm );
-
+
This signal is emitted when the user changes the style
@@ -489,9 +520,9 @@ static void setScreenSaverInterval(int interval)
\fn void QPEApplication::appMessage( const QCString& msg, const QByteArray& data )
-
+
This signal is emitted when a message is received on the
QPE/Application/<i>appname</i> QCop channel for this application.
-
+
The slot to which you connect this signal uses \a msg and \a data
in the following way:
-
+
\code
@@ -509,3 +540,3 @@ static void setScreenSaverInterval(int interval)
\endcode
-
+
\sa qcop.html
@@ -517,70 +548,71 @@ static void setScreenSaverInterval(int interval)
*/
-QPEApplication::QPEApplication( int& argc, char **argv, Type t )
- : QApplication( hack(argc), argv, t )
+QPEApplication::QPEApplication( int & argc, char **argv, Type t )
+ : QApplication( hack( argc ), argv, t )
{
- int dw = desktop()->width();
- if ( dw < 200 ) {
-// setFont( QFont( "helvetica", 8 ) );
- AppLnk::setSmallIconSize(10);
- AppLnk::setBigIconSize(28);
- }
+ int dw = desktop() ->width();
+ if ( dw < 200 ) {
+ // setFont( QFont( "helvetica", 8 ) );
+ AppLnk::setSmallIconSize( 10 );
+ AppLnk::setBigIconSize( 28 );
+ }
- d = new QPEApplicationData;
- QMimeSourceFactory::setDefaultFactory(new ResourceMimeFactory);
+ d = new QPEApplicationData;
+ QMimeSourceFactory::setDefaultFactory( new ResourceMimeFactory );
- connect(this, SIGNAL(lastWindowClosed()), this, SLOT(hideOrQuit()));
+ connect( this, SIGNAL( lastWindowClosed() ), this, SLOT( hideOrQuit() ) );
#if defined(Q_WS_QWS) && !defined(QT_NO_COP)
- QString qcopfn("/tmp/qcop-msg-");
- qcopfn += QString(argv[0]); // append command name
-
- QFile f(qcopfn);
- if ( f.open(IO_ReadOnly) ) {
- flock(f.handle(), LOCK_EX);
- }
+ QString qcopfn( "/tmp/qcop-msg-" );
+ qcopfn += QString( argv[ 0 ] ); // append command name
- sysChannel = new QCopChannel( "QPE/System", this );
- connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)),
- this, SLOT(systemMessage( const QCString &, const QByteArray &)) );
-
- QCString channel = QCString(argv[0]);
- channel.replace(QRegExp(".*/"),"");
- d->appName = channel;
- channel = "QPE/Application/" + channel;
- pidChannel = new QCopChannel( channel, this);
- connect( pidChannel, SIGNAL(received(const QCString &, const QByteArray &)),
- this, SLOT(pidMessage(const QCString &, const QByteArray &)));
-
- if ( f.isOpen() ) {
- d->keep_running = FALSE;
- QDataStream ds(&f);
- QCString channel, message;
- QByteArray data;
- while(!ds.atEnd()) {
- ds >> channel >> message >> data;
- d->enqueueQCop(channel,message,data);
- }
+ QFile f( qcopfn );
+ if ( f.open( IO_ReadOnly ) ) {
+ flock( f.handle(), LOCK_EX );
+ }
- flock(f.handle(), LOCK_UN);
- f.close();
- f.remove();
- }
+ sysChannel = new QCopChannel( "QPE/System", this );
+ connect( sysChannel, SIGNAL( received( const QCString &, const QByteArray & ) ),
+ this, SLOT( systemMessage( const QCString &, const QByteArray & ) ) );
+
+ QCString channel = QCString( argv[ 0 ] );
+ channel.replace( QRegExp( ".*/" ), "" );
+ d->appName = channel;
+ channel = "QPE/Application/" + channel;
+ pidChannel = new QCopChannel( channel, this );
+ connect( pidChannel, SIGNAL( received( const QCString &, const QByteArray & ) ),
+ this, SLOT( pidMessage( const QCString &, const QByteArray & ) ) );
+
+ if ( f.isOpen() ) {
+ d->keep_running = FALSE;
+ QDataStream ds( &f );
+ QCString channel, message;
+ QByteArray data;
+ while ( !ds.atEnd() ) {
+ ds >> channel >> message >> data;
+ d->enqueueQCop( channel, message, data );
+ }
+
+ flock( f.handle(), LOCK_UN );
+ f.close();
+ f.remove();
+ }
- for (int a=0; a<argc; a++) {
- if ( qstrcmp(argv[a],"-preload")==0 ) {
- argv[a] = argv[a+1];
- a++;
- d->preloaded = TRUE;
- argc-=1;
- } else if ( qstrcmp(argv[a],"-preload-show")==0 ) {
- argv[a] = argv[a+1];
- a++;
- d->preloaded = TRUE;
- d->forceshow = TRUE;
- argc-=1;
- }
- }
+ for ( int a = 0; a < argc; a++ ) {
+ if ( qstrcmp( argv[ a ], "-preload" ) == 0 ) {
+ argv[ a ] = argv[ a + 1 ];
+ a++;
+ d->preloaded = TRUE;
+ argc -= 1;
+ }
+ else if ( qstrcmp( argv[ a ], "-preload-show" ) == 0 ) {
+ argv[ a ] = argv[ a + 1 ];
+ a++;
+ d->preloaded = TRUE;
+ d->forceshow = TRUE;
+ argc -= 1;
+ }
+ }
- /* overide stored arguments */
- setArgs(argc, argv);
+ /* overide stored arguments */
+ setArgs( argc, argv );
@@ -588,45 +620,46 @@ QPEApplication::QPEApplication( int& argc, char **argv, Type t )
- qwsSetDecoration( new QPEDecoration() );
+ qwsSetDecoration( new QPEDecoration() );
#ifndef QT_NO_TRANSLATION
- QStringList langs = Global::languageList();
- for (QStringList::ConstIterator it = langs.begin(); it!=langs.end(); ++it) {
- QString lang = *it;
-
- QTranslator * trans;
- QString tfn;
-
- trans = new QTranslator(this);
- tfn = qpeDir()+"/i18n/"+lang+"/libqpe.qm";
- if ( trans->load( tfn ))
- installTranslator( trans );
- else
- delete trans;
-
- trans = new QTranslator(this);
- tfn = qpeDir()+"/i18n/"+lang+"/"+d->appName+".qm";
- if ( trans->load( tfn ))
- installTranslator( trans );
- else
- delete trans;
-
- //###language/font hack; should look it up somewhere
- if ( lang == "ja" || lang == "zh_CN" || lang == "zh_TW" || lang == "ko" ) {
- QFont fn = FontManager::unicodeFont( FontManager::Proportional );
- setFont( fn );
- }
- else {
- Config config( "qpe" );
- config.setGroup( "Appearance" );
- QString familyStr = config.readEntry( "FontFamily", "helvetica" );
- QString styleStr = config.readEntry( "FontStyle", "Regular" );
- QString sizeStr = config.readEntry( "FontSize", "10" );
- QString charSetStr = config.readEntry( "FontCharSet", QString::null );
- bool ok;
- int i_size = sizeStr.toInt( &ok, 10 );
- FontDatabase fdb;
- QFont selectedFont = fdb.font( familyStr, styleStr, i_size, charSetStr );
- setFont( selectedFont );
- }
- }
+
+ QStringList langs = Global::languageList();
+ for ( QStringList::ConstIterator it = langs.begin(); it != langs.end(); ++it ) {
+ QString lang = *it;
+
+ QTranslator * trans;
+ QString tfn;
+
+ trans = new QTranslator( this );
+ tfn = qpeDir() + "/i18n/" + lang + "/libqpe.qm";
+ if ( trans->load( tfn ) )
+ installTranslator( trans );
+ else
+ delete trans;
+
+ trans = new QTranslator( this );
+ tfn = qpeDir() + "/i18n/" + lang + "/" + d->appName + ".qm";
+ if ( trans->load( tfn ) )
+ installTranslator( trans );
+ else
+ delete trans;
+
+ //###language/font hack; should look it up somewhere
+ if ( lang == "ja" || lang == "zh_CN" || lang == "zh_TW" || lang == "ko" ) {
+ QFont fn = FontManager::unicodeFont( FontManager::Proportional );
+ setFont( fn );
+ }
+ else {
+ Config config( "qpe" );
+ config.setGroup( "Appearance" );
+ QString familyStr = config.readEntry( "FontFamily", "helvetica" );
+ QString styleStr = config.readEntry( "FontStyle", "Regular" );
+ QString sizeStr = config.readEntry( "FontSize", "10" );
+ QString charSetStr = config.readEntry( "FontCharSet", QString::null );
+ bool ok;
+ int i_size = sizeStr.toInt( &ok, 10 );
+ FontDatabase fdb;
+ QFont selectedFont = fdb.font( familyStr, styleStr, i_size, charSetStr );
+ setFont( selectedFont );
+ }
+ }
@@ -634,17 +667,17 @@ QPEApplication::QPEApplication( int& argc, char **argv, Type t )
- applyStyle();
+ applyStyle();
- if ( type() == GuiServer ) {
- setScreenSaverInterval(-1);
- setVolume();
- QWSServer::setScreenSaver(new QPEScreenSaver);
- }
+ if ( type() == GuiServer ) {
+ setScreenSaverInterval( -1 );
+ setVolume();
+ QWSServer::setScreenSaver( new QPEScreenSaver );
+ }
- installEventFilter( this );
+ installEventFilter( this );
- QPEMenuToolFocusManager::initialize();
+ QPEMenuToolFocusManager::initialize();
#ifdef QT_NO_QWS_CURSOR
- // if we have no cursor, probably don't want tooltips
- QToolTip::setEnabled( FALSE );
+ // if we have no cursor, probably don't want tooltips
+ QToolTip::setEnabled( FALSE );
#endif
@@ -652,7 +685,7 @@ QPEApplication::QPEApplication( int& argc, char **argv, Type t )
-static QPtrDict<void>* inputMethodDict=0;
+static QPtrDict<void>* inputMethodDict = 0;
static void createInputMethodDict()
{
- if ( !inputMethodDict )
- inputMethodDict = new QPtrDict<void>;
+ if ( !inputMethodDict )
+ inputMethodDict = new QPtrDict<void>;
}
@@ -662,10 +695,10 @@ static void createInputMethodDict()
\a w has any use for text input methods.
-
+
\sa setInputMethodHint()
*/
-QPEApplication::InputMethodHint QPEApplication::inputMethodHint( QWidget* w )
+QPEApplication::InputMethodHint QPEApplication::inputMethodHint( QWidget * w )
{
- if ( inputMethodDict && w )
- return (InputMethodHint)(int)inputMethodDict->find(w);
- return Normal;
+ if ( inputMethodDict && w )
+ return ( InputMethodHint ) ( int ) inputMethodDict->find( w );
+ return Normal;
}
@@ -674,3 +707,3 @@ QPEApplication::InputMethodHint QPEApplication::inputMethodHint( QWidget* w )
\enum QPEApplication::InputMethodHint
-
+
\value Normal the application sometimes needs text input (the default).
@@ -683,13 +716,15 @@ QPEApplication::InputMethodHint QPEApplication::inputMethodHint( QWidget* w )
as specified by \a mode.
-
+
\sa inputMethodHint()
*/
-void QPEApplication::setInputMethodHint( QWidget* w, InputMethodHint mode )
+void QPEApplication::setInputMethodHint( QWidget * w, InputMethodHint mode )
{
- createInputMethodDict();
- if ( mode == Normal ) {
- inputMethodDict->remove(w);
- } else {
- inputMethodDict->insert(w,(void*)mode);
- }
+ createInputMethodDict();
+ if ( mode == Normal ) {
+ inputMethodDict->remove
+ ( w );
+ }
+ else {
+ inputMethodDict->insert( w, ( void* ) mode );
+ }
}
@@ -699,4 +734,10 @@ class HackDialog : public QDialog
public:
- void acceptIt() { accept(); }
- void rejectIt() { reject(); }
+ void acceptIt()
+ {
+ accept();
+ }
+ void rejectIt()
+ {
+ reject();
+ }
};
@@ -704,15 +745,15 @@ public:
-void QPEApplication::mapToDefaultAction( QWSKeyEvent *ke, int key )
+void QPEApplication::mapToDefaultAction( QWSKeyEvent * ke, int key )
{
- // specialised actions for certain widgets. May want to
- // add more stuff here.
- if ( activePopupWidget() && activePopupWidget()->inherits( "QListBox" )
- && activePopupWidget()->parentWidget()
- && activePopupWidget()->parentWidget()->inherits( "QComboBox" ) )
- key = Qt::Key_Return;
+ // specialised actions for certain widgets. May want to
+ // add more stuff here.
+ if ( activePopupWidget() && activePopupWidget() ->inherits( "QListBox" )
+ && activePopupWidget() ->parentWidget()
+ && activePopupWidget() ->parentWidget() ->inherits( "QComboBox" ) )
+ key = Qt::Key_Return;
- if ( activePopupWidget() && activePopupWidget()->inherits( "QPopupMenu" ) )
- key = Qt::Key_Return;
+ if ( activePopupWidget() && activePopupWidget() ->inherits( "QPopupMenu" ) )
+ key = Qt::Key_Return;
- ke->simpleData.keycode = key;
+ ke->simpleData.keycode = key;
}
@@ -722,4 +763,6 @@ class HackWidget : public QWidget
public:
- bool needsOk()
- { return (getWState() & WState_Reserved1 ); }
+ bool needsOk()
+ {
+ return ( getWState() & WState_Reserved1 );
+ }
};
@@ -729,109 +772,116 @@ public:
*/
-bool QPEApplication::qwsEventFilter( QWSEvent *e )
+bool QPEApplication::qwsEventFilter( QWSEvent * e )
{
- if ( !d->notbusysent && e->type == QWSEvent::Focus ) {
- if ( qApp->type() != QApplication::GuiServer ) {
- QCopEnvelope e("QPE/System", "notBusy(QString)" );
- e << d->appName;
- }
- d->notbusysent=TRUE;
- }
- if ( type() == GuiServer ) {
- switch ( e->type ) {
- case QWSEvent::Mouse:
- if ( e->asMouse()->simpleData.state && !QWidget::find(e->window()) )
- emit clientMoused();
- }
- }
- if ( e->type == QWSEvent::Key ) {
- if ( d->kbgrabber == 1 )
- return TRUE;
- QWSKeyEvent *ke = (QWSKeyEvent *)e;
- if ( ke->simpleData.keycode == Qt::Key_F33 ) {
- // Use special "OK" key to press "OK" on top level widgets
- QWidget *active = activeWindow();
- QWidget *popup = 0;
- if ( active && active->isPopup() ) {
- popup = active;
- active = active->parentWidget();
- }
- if ( active && (int)active->winId() == ke->simpleData.window &&
- !active->testWFlags( WStyle_Customize|WType_Popup|WType_Desktop )) {
- if ( ke->simpleData.is_press ) {
- if ( popup )
- popup->close();
- if ( active->inherits( "QDialog" ) ) {
- HackDialog *d = (HackDialog *)active;
- d->acceptIt();
- return TRUE;
- } else if ( ((HackWidget *)active)->needsOk() ) {
- QSignal s;
- s.connect( active, SLOT( accept() ) );
- s.activate();
- } else {
- // do the same as with the select key: Map to the default action of the widget:
- mapToDefaultAction( ke, Qt::Key_Return );
- }
- }
- }
- } else if ( ke->simpleData.keycode == Qt::Key_F30 ) {
- // Use special "select" key to do whatever default action a widget has
- mapToDefaultAction( ke, Qt::Key_Space );
- } else if ( ke->simpleData.keycode == Qt::Key_Escape &&
- ke->simpleData.is_press ) {
- // Escape key closes app if focus on toplevel
- QWidget *active = activeWindow();
- if ( active && active->testWFlags( WType_TopLevel ) &&
- (int)active->winId() == ke->simpleData.window &&
- !active->testWFlags( WStyle_Dialog|WStyle_Customize|WType_Popup|WType_Desktop )) {
- if ( active->inherits( "QDialog" ) ) {
- HackDialog *d = (HackDialog *)active;
- d->rejectIt();
- return TRUE;
- } else if ( strcmp( argv()[0], "embeddedkonsole") != 0 ) {
- active->close();
- }
- }
- }
+ if ( !d->notbusysent && e->type == QWSEvent::Focus ) {
+ if ( qApp->type() != QApplication::GuiServer ) {
+ QCopEnvelope e( "QPE/System", "notBusy(QString)" );
+ e << d->appName;
+ }
+ d->notbusysent = TRUE;
+ }
+ if ( type() == GuiServer ) {
+ switch ( e->type ) {
+ case QWSEvent::Mouse:
+ if ( e->asMouse() ->simpleData.state && !QWidget::find( e->window() ) )
+ emit clientMoused();
+ }
+ }
+ if ( e->type == QWSEvent::Key ) {
+ if ( d->kbgrabber == 1 )
+ return TRUE;
+ QWSKeyEvent *ke = ( QWSKeyEvent * ) e;
+ if ( ke->simpleData.keycode == Qt::Key_F33 ) {
+ // Use special "OK" key to press "OK" on top level widgets
+ QWidget * active = activeWindow();
+ QWidget *popup = 0;
+ if ( active && active->isPopup() ) {
+ popup = active;
+ active = active->parentWidget();
+ }
+ if ( active && ( int ) active->winId() == ke->simpleData.window &&
+ !active->testWFlags( WStyle_Customize | WType_Popup | WType_Desktop ) ) {
+ if ( ke->simpleData.is_press ) {
+ if ( popup )
+ popup->close();
+ if ( active->inherits( "QDialog" ) ) {
+ HackDialog * d = ( HackDialog * ) active;
+ d->acceptIt();
+ return TRUE;
+ }
+ else if ( ( ( HackWidget * ) active ) ->needsOk() ) {
+ QSignal s;
+ s.connect( active, SLOT( accept() ) );
+ s.activate();
+ }
+ else {
+ // do the same as with the select key: Map to the default action of the widget:
+ mapToDefaultAction( ke, Qt::Key_Return );
+ }
+ }
+ }
+ }
+ else if ( ke->simpleData.keycode == Qt::Key_F30 ) {
+ // Use special "select" key to do whatever default action a widget has
+ mapToDefaultAction( ke, Qt::Key_Space );
+ }
+ else if ( ke->simpleData.keycode == Qt::Key_Escape &&
+ ke->simpleData.is_press ) {
+ // Escape key closes app if focus on toplevel
+ QWidget * active = activeWindow();
+ if ( active && active->testWFlags( WType_TopLevel ) &&
+ ( int ) active->winId() == ke->simpleData.window &&
+ !active->testWFlags( WStyle_Dialog | WStyle_Customize | WType_Popup | WType_Desktop ) ) {
+ if ( active->inherits( "QDialog" ) ) {
+ HackDialog * d = ( HackDialog * ) active;
+ d->rejectIt();
+ return TRUE;
+ }
+ else if ( strcmp( argv() [ 0 ], "embeddedkonsole" ) != 0 ) {
+ active->close();
+ }
+ }
+ }
#if QT_VERSION < 231
- // Filter out the F4/Launcher key from apps
- // ### The launcher key may not always be F4 on all devices
- if ( ((QWSKeyEvent *)e)->simpleData.keycode == Qt::Key_F4 )
- return TRUE;
+ // Filter out the F4/Launcher key from apps
+ // ### The launcher key may not always be F4 on all devices
+ if ( ( ( QWSKeyEvent * ) e ) ->simpleData.keycode == Qt::Key_F4 )
+ return TRUE;
#endif
- }
- if ( e->type == QWSEvent::Focus ) {
- QWSFocusEvent *fe = (QWSFocusEvent*)e;
- QWidget* nfw = QWidget::find(e->window());
- if ( !fe->simpleData.get_focus ) {
- QWidget *active = activeWindow();
- while ( active && active->isPopup() ) {
- active->close();
- active = activeWindow();
- }
- if ( !nfw && d->kbgrabber == 2 ) {
- ungrabKeyboard();
- d->kbregrab = TRUE; // want kb back when we're active
- }
- } else {
- // make sure our modal widget is ALWAYS on top
- QWidget *topm = activeModalWidget();
- if ( topm ) {
- topm->raise();
- }
- if ( d->kbregrab ) {
- grabKeyboard();
- d->kbregrab = FALSE;
- }
- }
- if ( fe->simpleData.get_focus && inputMethodDict ) {
- InputMethodHint m = inputMethodHint( QWidget::find(e->window()) );
- if ( m == AlwaysOff )
- Global::hideInputMethod();
- if ( m == AlwaysOn )
- Global::showInputMethod();
- }
- }
- return QApplication::qwsEventFilter( e );
+
+ }
+ if ( e->type == QWSEvent::Focus ) {
+ QWSFocusEvent * fe = ( QWSFocusEvent* ) e;
+ QWidget* nfw = QWidget::find( e->window() );
+ if ( !fe->simpleData.get_focus ) {
+ QWidget * active = activeWindow();
+ while ( active && active->isPopup() ) {
+ active->close();
+ active = activeWindow();
+ }
+ if ( !nfw && d->kbgrabber == 2 ) {
+ ungrabKeyboard();
+ d->kbregrab = TRUE; // want kb back when we're active
+ }
+ }
+ else {
+ // make sure our modal widget is ALWAYS on top
+ QWidget *topm = activeModalWidget();
+ if ( topm ) {
+ topm->raise();
+ }
+ if ( d->kbregrab ) {
+ grabKeyboard();
+ d->kbregrab = FALSE;
+ }
+ }
+ if ( fe->simpleData.get_focus && inputMethodDict ) {
+ InputMethodHint m = inputMethodHint( QWidget::find( e->window() ) );
+ if ( m == AlwaysOff )
+ Global::hideInputMethod();
+ if ( m == AlwaysOn )
+ Global::showInputMethod();
+ }
+ }
+ return QApplication::qwsEventFilter( e );
}
@@ -843,10 +893,11 @@ QPEApplication::~QPEApplication()
{
- ungrabKeyboard();
+ ungrabKeyboard();
#if defined(Q_WS_QWS) && !defined(QT_NO_COP)
- // Need to delete QCopChannels early, since the display will
- // be gone by the time we get to ~QObject().
- delete sysChannel;
- delete pidChannel;
+ // Need to delete QCopChannels early, since the display will
+ // be gone by the time we get to ~QObject().
+ delete sysChannel;
+ delete pidChannel;
#endif
- delete d;
+
+ delete d;
}
@@ -858,7 +909,7 @@ QString QPEApplication::qpeDir()
{
- const char *base = getenv( "OPIEDIR" );
- if ( base )
- return QString( base ) + "/";
+ const char * base = getenv( "OPIEDIR" );
+ if ( base )
+ return QString( base ) + "/";
- return QString( "../" );
+ return QString( "../" );
}
@@ -870,10 +921,10 @@ QString QPEApplication::documentDir()
{
- const char *base = getenv( "HOME" );
- if ( base )
- return QString( base ) + "/Documents/";
+ const char * base = getenv( "HOME" );
+ if ( base )
+ return QString( base ) + "/Documents/";
- return QString( "../Documents/" );
+ return QString( "../Documents/" );
}
-static int deforient=-1;
+static int deforient = -1;
@@ -884,15 +935,18 @@ int QPEApplication::defaultRotation()
{
- if ( deforient < 0 ) {
- QString d = getenv("QWS_DISPLAY");
- if ( d.contains("Rot90") ) {
- deforient = 90;
- } else if ( d.contains("Rot180") ) {
- deforient = 180;
- } else if ( d.contains("Rot270") ) {
- deforient = 270;
- } else {
- deforient=0;
- }
- }
- return deforient;
+ if ( deforient < 0 ) {
+ QString d = getenv( "QWS_DISPLAY" );
+ if ( d.contains( "Rot90" ) ) {
+ deforient = 90;
+ }
+ else if ( d.contains( "Rot180" ) ) {
+ deforient = 180;
+ }
+ else if ( d.contains( "Rot270" ) ) {
+ deforient = 270;
+ }
+ else {
+ deforient = 0;
+ }
+ }
+ return deforient;
}
@@ -902,10 +956,11 @@ int QPEApplication::defaultRotation()
*/
-void QPEApplication::setDefaultRotation(int r)
+void QPEApplication::setDefaultRotation( int r )
{
- if ( qApp->type() == GuiServer ) {
- deforient = r;
- setenv("QWS_DISPLAY", QString("Transformed:Rot%1:0").arg(r).latin1(), 1);
- } else {
- QCopEnvelope("QPE/System", "setDefaultRotation(int)") << r;
- }
+ if ( qApp->type() == GuiServer ) {
+ deforient = r;
+ setenv( "QWS_DISPLAY", QString( "Transformed:Rot%1:0" ).arg( r ).latin1(), 1 );
+ }
+ else {
+ QCopEnvelope( "QPE/System", "setDefaultRotation(int)" ) << r;
+ }
}
@@ -917,171 +972,194 @@ void QPEApplication::applyStyle()
{
- Config config( "qpe" );
-
- config.setGroup( "Appearance" );
-
- // Widget style
- QString style = config.readEntry( "Style", "Light" );
- internalSetStyle( style );
-
- // Colors
- QColor bgcolor( config.readEntry( "Background", "#E5E1D5" ) );
- QColor btncolor( config.readEntry( "Button", "#D6CDBB" ) );
- QPalette pal( btncolor, bgcolor );
- QString color = config.readEntry( "Highlight", "#800000" );
- pal.setColor( QColorGroup::Highlight, QColor(color) );
- color = config.readEntry( "HighlightedText", "#FFFFFF" );
- pal.setColor( QColorGroup::HighlightedText, QColor(color) );
- color = config.readEntry( "Text", "#000000" );
- pal.setColor( QColorGroup::Text, QColor(color) );
- color = config.readEntry( "ButtonText", "#000000" );
- pal.setColor( QPalette::Active, QColorGroup::ButtonText, QColor(color) );
- color = config.readEntry( "Base", "#FFFFFF" );
- pal.setColor( QColorGroup::Base, QColor(color) );
-
- pal.setColor( QPalette::Disabled, QColorGroup::Text,
- pal.color(QPalette::Active, QColorGroup::Background).dark() );
-
- setPalette( pal, TRUE );
+ Config config( "qpe" );
+
+ config.setGroup( "Appearance" );
+
+ // Widget style
+ QString style = config.readEntry( "Style", "Light" );
+ internalSetStyle( style );
+
+ // Colors
+ QColor bgcolor( config.readEntry( "Background", "#E5E1D5" ) );
+ QColor btncolor( config.readEntry( "Button", "#D6CDBB" ) );
+ QPalette pal( btncolor, bgcolor );
+ QString color = config.readEntry( "Highlight", "#800000" );
+ pal.setColor( QColorGroup::Highlight, QColor( color ) );
+ color = config.readEntry( "HighlightedText", "#FFFFFF" );
+ pal.setColor( QColorGroup::HighlightedText, QColor( color ) );
+ color = config.readEntry( "Text", "#000000" );
+ pal.setColor( QColorGroup::Text, QColor( color ) );
+ color = config.readEntry( "ButtonText", "#000000" );
+ pal.setColor( QPalette::Active, QColorGroup::ButtonText, QColor( color ) );
+ color = config.readEntry( "Base", "#FFFFFF" );
+ pal.setColor( QColorGroup::Base, QColor( color ) );
+
+ pal.setColor( QPalette::Disabled, QColorGroup::Text,
+ pal.color( QPalette::Active, QColorGroup::Background ).dark() );
+
+ setPalette( pal, TRUE );
}
-void QPEApplication::systemMessage( const QCString &msg, const QByteArray &data)
+void QPEApplication::systemMessage( const QCString & msg, const QByteArray & data )
{
#ifdef Q_WS_QWS
- QDataStream stream( data, IO_ReadOnly );
- if ( msg == "applyStyle()" ) {
- applyStyle();
- } else if ( msg == "setScreenSaverInterval(int)" ) {
- if ( type() == GuiServer ) {
- int time;
- stream >> time;
- setScreenSaverInterval(time);
- }
- } else if ( msg == "setScreenSaverIntervals(int,int,int)" ) {
- if ( type() == GuiServer ) {
- int t1,t2,t3;
- stream >> t1 >> t2 >> t3;
- setScreenSaverIntervals(t1,t2,t3);
- }
- } else if ( msg == "setBacklight(int)" ) {
- if ( type() == GuiServer ) {
- int bright;
- stream >> bright;
- setBacklight(bright);
- }
- } else if ( msg == "setDefaultRotation(int)" ) {
- if ( type() == GuiServer ) {
- int r;
- stream >> r;
- setDefaultRotation(r);
- }
- } else if ( msg == "shutdown()" ) {
- if ( type() == GuiServer )
- shutdown();
- } else if ( msg == "quit()" ) {
- if ( type() != GuiServer )
- tryQuit();
- } else if ( msg == "forceQuit()" ) {
- if ( type() != GuiServer )
- quit();
- } else if ( msg == "restart()" ) {
- if ( type() == GuiServer )
- restart();
- } else if ( msg == "grabKeyboard(QString)" ) {
- QString who;
- stream >> who;
- if ( who.isEmpty() )
- d->kbgrabber = 0;
- else if ( who != d->appName )
- d->kbgrabber = 1;
- else
- d->kbgrabber = 2;
- } else if ( msg == "language(QString)" ) {
- if ( type() == GuiServer ) {
- QString l;
- stream >> l;
- QString cl = getenv("LANG");
- if ( cl != l ) {
- if ( l.isNull() )
- unsetenv( "LANG" );
- else
- setenv( "LANG", l.latin1(), 1 );
- restart();
- }
- }
- } else if ( msg == "timeChange(QString)" ) {
- QString t;
- stream >> t;
- if ( t.isNull() )
- unsetenv( "TZ" );
- else
- setenv( "TZ", t.latin1(), 1 );
- // emit the signal so everyone else knows...
- emit timeChanged();
- } else if ( msg == "execute(QString)" ) {
- if ( type() == GuiServer ) {
- QString t;
- stream >> t;
- Global::execute( t );
- }
- } else if ( msg == "execute(QString,QString)" ) {
- if ( type() == GuiServer ) {
- QString t,d;
- stream >> t >> d;
- Global::execute( t, d );
- }
- } else if ( msg == "addAlarm(QDateTime,QCString,QCString,int)" ) {
- if ( type() == GuiServer ) {
- QDateTime when;
- QCString channel, message;
- int data;
- stream >> when >> channel >> message >> data;
- AlarmServer::addAlarm( when, channel, message, data );
- }
- } else if ( msg == "deleteAlarm(QDateTime,QCString,QCString,int)" ) {
- if ( type() == GuiServer ) {
- QDateTime when;
- QCString channel, message;
- int data;
- stream >> when >> channel >> message >> data;
- AlarmServer::deleteAlarm( when, channel, message, data );
- }
- } else if ( msg == "clockChange(bool)" ) {
- int tmp;
- stream >> tmp;
- emit clockChanged( tmp );
- } else if ( msg == "weekChange(bool)" ) {
- int tmp;
- stream >> tmp;
- emit weekChanged( tmp );
- } else if ( msg == "setDateFormat(DateFormat)" ) {
- DateFormat tmp;
- stream >> tmp;
- emit dateFormatChanged( tmp );
- } else if ( msg == "setVolume(int,int)" ) {
- int t,v;
- stream >> t >> v;
- setVolume(t,v);
- emit volumeChanged( muted );
- } else if ( msg == "volumeChange(bool)" ) {
- stream >> muted;
- setVolume();
- emit volumeChanged( muted );
- } else if ( msg == "setMic(int,int)") { // Added: 2002-02-08 by Jeremy Cowgar <jc@cowgar.com>
- int t,v;
- stream >> t >> v;
- setMic(t,v);
- emit micChanged( micMuted );
- } else if ( msg == "micChange(bool)" ) { // Added: 2002-02-08 by Jeremy Cowgar <jc@cowgar.com>
- stream >> micMuted;
- setMic();
- emit micChanged( micMuted );
- } else if ( msg == "setScreenSaverMode(int)" ) {
- if ( type() == GuiServer ) {
- int old = disable_suspend;
- stream >> disable_suspend;
- //qDebug("setScreenSaverMode(%d)", disable_suspend );
- if ( disable_suspend > old )
- setScreenSaverInterval( -1 );
- }
- }
+ QDataStream stream( data, IO_ReadOnly );
+ if ( msg == "applyStyle()" ) {
+ applyStyle();
+ }
+ else if ( msg == "setScreenSaverInterval(int)" ) {
+ if ( type() == GuiServer ) {
+ int time;
+ stream >> time;
+ setScreenSaverInterval( time );
+ }
+ }
+ else if ( msg == "setScreenSaverIntervals(int,int,int)" ) {
+ if ( type() == GuiServer ) {
+ int t1, t2, t3;
+ stream >> t1 >> t2 >> t3;
+ setScreenSaverIntervals( t1, t2, t3 );
+ }
+ }
+ else if ( msg == "setBacklight(int)" ) {
+ if ( type() == GuiServer ) {
+ int bright;
+ stream >> bright;
+ setBacklight( bright );
+ }
+ }
+ else if ( msg == "setDefaultRotation(int)" ) {
+ if ( type() == GuiServer ) {
+ int r;
+ stream >> r;
+ setDefaultRotation( r );
+ }
+ }
+ else if ( msg == "shutdown()" ) {
+ if ( type() == GuiServer )
+ shutdown();
+ }
+ else if ( msg == "quit()" ) {
+ if ( type() != GuiServer )
+ tryQuit();
+ }
+ else if ( msg == "forceQuit()" ) {
+ if ( type() != GuiServer )
+ quit();
+ }
+ else if ( msg == "restart()" ) {
+ if ( type() == GuiServer )
+ restart();
+ }
+ else if ( msg == "grabKeyboard(QString)" ) {
+ QString who;
+ stream >> who;
+ if ( who.isEmpty() )
+ d->kbgrabber = 0;
+ else if ( who != d->appName )
+ d->kbgrabber = 1;
+ else
+ d->kbgrabber = 2;
+ }
+ else if ( msg == "language(QString)" ) {
+ if ( type() == GuiServer ) {
+ QString l;
+ stream >> l;
+ QString cl = getenv( "LANG" );
+ if ( cl != l ) {
+ if ( l.isNull() )
+ unsetenv( "LANG" );
+ else
+ setenv( "LANG", l.latin1(), 1 );
+ restart();
+ }
+ }
+ }
+ else if ( msg == "timeChange(QString)" ) {
+ QString t;
+ stream >> t;
+ if ( t.isNull() )
+ unsetenv( "TZ" );
+ else
+ setenv( "TZ", t.latin1(), 1 );
+ // emit the signal so everyone else knows...
+ emit timeChanged();
+ }
+ else if ( msg == "execute(QString)" ) {
+ if ( type() == GuiServer ) {
+ QString t;
+ stream >> t;
+ Global::execute( t );
+ }
+ }
+ else if ( msg == "execute(QString,QString)" ) {
+ if ( type() == GuiServer ) {
+ QString t, d;
+ stream >> t >> d;
+ Global::execute( t, d );
+ }
+ }
+ else if ( msg == "addAlarm(QDateTime,QCString,QCString,int)" ) {
+ if ( type() == GuiServer ) {
+ QDateTime when;
+ QCString channel, message;
+ int data;
+ stream >> when >> channel >> message >> data;
+ AlarmServer::addAlarm( when, channel, message, data );
+ }
+ }
+ else if ( msg == "deleteAlarm(QDateTime,QCString,QCString,int)" ) {
+ if ( type() == GuiServer ) {
+ QDateTime when;
+ QCString channel, message;
+ int data;
+ stream >> when >> channel >> message >> data;
+ AlarmServer::deleteAlarm( when, channel, message, data );
+ }
+ }
+ else if ( msg == "clockChange(bool)" ) {
+ int tmp;
+ stream >> tmp;
+ emit clockChanged( tmp );
+ }
+ else if ( msg == "weekChange(bool)" ) {
+ int tmp;
+ stream >> tmp;
+ emit weekChanged( tmp );
+ }
+ else if ( msg == "setDateFormat(DateFormat)" ) {
+ DateFormat tmp;
+ stream >> tmp;
+ emit dateFormatChanged( tmp );
+ }
+ else if ( msg == "setVolume(int,int)" ) {
+ int t, v;
+ stream >> t >> v;
+ setVolume( t, v );
+ emit volumeChanged( muted );
+ }
+ else if ( msg == "volumeChange(bool)" ) {
+ stream >> muted;
+ setVolume();
+ emit volumeChanged( muted );
+ }
+ else if ( msg == "setMic(int,int)" ) { // Added: 2002-02-08 by Jeremy Cowgar <jc@cowgar.com>
+ int t, v;
+ stream >> t >> v;
+ setMic( t, v );
+ emit micChanged( micMuted );
+ }
+ else if ( msg == "micChange(bool)" ) { // Added: 2002-02-08 by Jeremy Cowgar <jc@cowgar.com>
+ stream >> micMuted;
+ setMic();
+ emit micChanged( micMuted );
+ }
+ else if ( msg == "setScreenSaverMode(int)" ) {
+ if ( type() == GuiServer ) {
+ int old = disable_suspend;
+ stream >> disable_suspend;
+ //qDebug("setScreenSaverMode(%d)", disable_suspend );
+ if ( disable_suspend > old )
+ setScreenSaverInterval( -1 );
+ }
+ }
#endif
@@ -1094,30 +1172,33 @@ bool QPEApplication::raiseAppropriateWindow()
{
- bool r=FALSE;
- // ########## raise()ing main window should raise and set active
- // ########## it and then all childen. This belongs in Qt/Embedded
- QWidget *top = d->qpe_main_widget;
- if ( !top ) top =mainWidget();
- if ( top && d->keep_running ) {
- if ( top->isVisible() )
- r = TRUE;
+ bool r = FALSE;
+ // ########## raise()ing main window should raise and set active
+ // ########## it and then all childen. This belongs in Qt/Embedded
+ QWidget *top = d->qpe_main_widget;
+ if ( !top )
+ top = mainWidget();
+ if ( top && d->keep_running ) {
+ if ( top->isVisible() )
+ r = TRUE;
#ifdef Q_WS_QWS
- if ( !d->nomaximize )
- top->showMaximized();
- else
+
+ if ( !d->nomaximize )
+ top->showMaximized();
+ else
#endif
- top->show();
- top->raise();
- top->setActiveWindow();
- }
- QWidget *topm = activeModalWidget();
- if ( topm && topm != top ) {
- topm->show();
- topm->raise();
- topm->setActiveWindow();
- r = FALSE;
- }
- return r;
+
+ top->show();
+ top->raise();
+ top->setActiveWindow();
+ }
+ QWidget *topm = activeModalWidget();
+ if ( topm && topm != top ) {
+ topm->show();
+ topm->raise();
+ topm->setActiveWindow();
+ r = FALSE;
+ }
+ return r;
}
-void QPEApplication::pidMessage( const QCString &msg, const QByteArray & data)
+void QPEApplication::pidMessage( const QCString &msg, const QByteArray & data )
{
@@ -1125,44 +1206,54 @@ void QPEApplication::pidMessage( const QCString &msg, const QByteArray & data)
- if ( msg == "quit()" ) {
- tryQuit();
- } else if ( msg == "quitIfInvisible()" ) {
- if ( d->qpe_main_widget && !d->qpe_main_widget->isVisible() )
- quit();
- } else if ( msg == "close()" ) {
- hideOrQuit();
- } else if ( msg == "disablePreload()" ) {
- d->preloaded = FALSE;
- d->keep_running = TRUE;
- /* so that quit will quit */
- } else if ( msg == "enablePreload()" ) {
- d->preloaded = TRUE;
- d->keep_running = TRUE;
- /* so next quit won't quit */
- } else if ( msg == "raise()" ) {
- d->keep_running = TRUE;
- d->notbusysent = FALSE;
- raiseAppropriateWindow();
- } else if ( msg == "flush()" ) {
- emit flush();
- // we need to tell the desktop
- QCopEnvelope e( "QPE/Desktop", "flushDone(QString)" );
- e << d->appName;
- } else if ( msg == "reload()" ) {
- emit reload();
- } else if ( msg == "setDocument(QString)" ) {
- d->keep_running = TRUE;
- QDataStream stream( data, IO_ReadOnly );
- QString doc;
- stream >> doc;
- QWidget *mw = mainWidget();
- if ( !mw )
- mw = d->qpe_main_widget;
- if ( mw )
- Global::setDocument( mw, doc );
- } else if ( msg == "nextView()" ) {
- if ( raiseAppropriateWindow() )
- emit appMessage( msg, data);
- } else {
- emit appMessage( msg, data);
- }
+ if ( msg == "quit()" ) {
+ tryQuit();
+ }
+ else if ( msg == "quitIfInvisible()" ) {
+ if ( d->qpe_main_widget && !d->qpe_main_widget->isVisible() )
+ quit();
+ }
+ else if ( msg == "close()" ) {
+ hideOrQuit();
+ }
+ else if ( msg == "disablePreload()" ) {
+ d->preloaded = FALSE;
+ d->keep_running = TRUE;
+ /* so that quit will quit */
+ }
+ else if ( msg == "enablePreload()" ) {
+ d->preloaded = TRUE;
+ d->keep_running = TRUE;
+ /* so next quit won't quit */
+ }
+ else if ( msg == "raise()" ) {
+ d->keep_running = TRUE;
+ d->notbusysent = FALSE;
+ raiseAppropriateWindow();
+ }
+ else if ( msg == "flush()" ) {
+ emit flush();
+ // we need to tell the desktop
+ QCopEnvelope e( "QPE/Desktop", "flushDone(QString)" );
+ e << d->appName;
+ }
+ else if ( msg == "reload()" ) {
+ emit reload();
+ }
+ else if ( msg == "setDocument(QString)" ) {
+ d->keep_running = TRUE;
+ QDataStream stream( data, IO_ReadOnly );
+ QString doc;
+ stream >> doc;
+ QWidget *mw = mainWidget();
+ if ( !mw )
+ mw = d->qpe_main_widget;
+ if ( mw )
+ Global::setDocument( mw, doc );
+ }
+ else if ( msg == "nextView()" ) {
+ if ( raiseAppropriateWindow() )
+ emit appMessage( msg, data );
+ }
+ else {
+ emit appMessage( msg, data );
+ }
#endif
@@ -1173,21 +1264,21 @@ static bool setWidgetCaptionFromAppName( QWidget* /*mw*/, const QString& /*appNa
{
-/*
- // This works but disable it for now until it is safe to apply
- // What is does is scan the .desktop files of all the apps for
- // the applnk that has the corresponding argv[0] as this program
- // then it uses the name stored in the .desktop file as the caption
- // for the main widget. This saves duplicating translations for
- // the app name in the program and in the .desktop files.
-
- AppLnkSet apps( appsPath );
-
- QList<AppLnk> appsList = apps.children();
- for ( QListIterator<AppLnk> it(appsList); it.current(); ++it ) {
- if ( (*it)->exec() == appName ) {
- mw->setCaption( (*it)->name() );
- return TRUE;
- }
- }
-*/
- return FALSE;
+ /*
+ // This works but disable it for now until it is safe to apply
+ // What is does is scan the .desktop files of all the apps for
+ // the applnk that has the corresponding argv[0] as this program
+ // then it uses the name stored in the .desktop file as the caption
+ // for the main widget. This saves duplicating translations for
+ // the app name in the program and in the .desktop files.
+
+ AppLnkSet apps( appsPath );
+
+ QList<AppLnk> appsList = apps.children();
+ for ( QListIterator<AppLnk> it(appsList); it.current(); ++it ) {
+ if ( (*it)->exec() == appName ) {
+ mw->setCaption( (*it)->name() );
+ return TRUE;
+ }
+ }
+ */
+ return FALSE;
}
@@ -1198,3 +1289,3 @@ static bool setWidgetCaptionFromAppName( QWidget* /*mw*/, const QString& /*appNa
consider passing TRUE for \a nomaximize rather than the default FALSE.
-
+
\sa showMainDocumentWidget()
@@ -1203,24 +1294,27 @@ void QPEApplication::showMainWidget( QWidget* mw, bool nomaximize )
{
- setWidgetCaptionFromAppName( mw, d->appName, qpeDir() + "apps" );
+ setWidgetCaptionFromAppName( mw, d->appName, qpeDir() + "apps" );
- d->nomaximize = nomaximize;
- d->qpe_main_widget = mw;
- d->sendQCopQ();
- if ( d->preloaded ) {
- if(d->forceshow) {
+ d->nomaximize = nomaximize;
+ d->qpe_main_widget = mw;
+ d->sendQCopQ();
+ if ( d->preloaded ) {
+ if ( d->forceshow ) {
#ifdef Q_WS_QWS
- if ( !nomaximize )
- mw->showMaximized();
- else
+ if ( !nomaximize )
+ mw->showMaximized();
+ else
#endif
- mw->show();
- }
- } else if ( d->keep_running ) {
+
+ mw->show();
+ }
+ }
+ else if ( d->keep_running ) {
#ifdef Q_WS_QWS
- if ( !nomaximize )
- mw->showMaximized();
- else
+ if ( !nomaximize )
+ mw->showMaximized();
+ else
#endif
- mw->show();
- }
+
+ mw->show();
+ }
}
@@ -1230,8 +1324,8 @@ void QPEApplication::showMainWidget( QWidget* mw, bool nomaximize )
consider passing TRUE for \a nomaximize rather than the default FALSE.
-
+
This calls designates the application as
a \link docwidget.html document-oriented\endlink application.
-
+
The \a mw widget must have a slot: setDocument(const QString&).
-
+
\sa showMainWidget()
@@ -1240,26 +1334,29 @@ void QPEApplication::showMainDocumentWidget( QWidget* mw, bool nomaximize )
{
- setWidgetCaptionFromAppName( mw, d->appName, qpeDir() + "apps" );
-
- if ( mw && argc() == 2 )
- Global::setDocument( mw, QString::fromUtf8(argv()[1]) );
- d->nomaximize = nomaximize;
- d->qpe_main_widget = mw;
- d->sendQCopQ();
- if ( d->preloaded ) {
- if(d->forceshow) {
+ setWidgetCaptionFromAppName( mw, d->appName, qpeDir() + "apps" );
+
+ if ( mw && argc() == 2 )
+ Global::setDocument( mw, QString::fromUtf8( argv() [ 1 ] ) );
+ d->nomaximize = nomaximize;
+ d->qpe_main_widget = mw;
+ d->sendQCopQ();
+ if ( d->preloaded ) {
+ if ( d->forceshow ) {
#ifdef Q_WS_QWS
- if ( !nomaximize )
- mw->showMaximized();
- else
+ if ( !nomaximize )
+ mw->showMaximized();
+ else
#endif
- mw->show();
- }
- } else if ( d->keep_running ) {
+
+ mw->show();
+ }
+ }
+ else if ( d->keep_running ) {
#ifdef Q_WS_QWS
- if ( !nomaximize )
- mw->showMaximized();
- else
+ if ( !nomaximize )
+ mw->showMaximized();
+ else
#endif
- mw->show();
- }
+
+ mw->show();
+ }
}
@@ -1273,3 +1370,3 @@ void QPEApplication::showMainDocumentWidget( QWidget* mw, bool nomaximize )
will show and start proper once it has finished processing qcop messages.
-
+
\sa keepRunning()
@@ -1278,6 +1375,6 @@ void QPEApplication::setKeepRunning()
{
- if ( qApp && qApp->inherits( "QPEApplication" ) ) {
- QPEApplication *qpeApp = (QPEApplication*)qApp;
- qpeApp->d->keep_running = TRUE;
- }
+ if ( qApp && qApp->inherits( "QPEApplication" ) ) {
+ QPEApplication * qpeApp = ( QPEApplication* ) qApp;
+ qpeApp->d->keep_running = TRUE;
+ }
}
@@ -1287,3 +1384,3 @@ void QPEApplication::setKeepRunning()
list of qcop messages.
-
+
\sa setKeepRunning()
@@ -1292,3 +1389,3 @@ bool QPEApplication::keepRunning() const
{
- return d->keep_running;
+ return d->keep_running;
}
@@ -1301,30 +1398,34 @@ void QPEApplication::internalSetStyle( const QString &style )
#if QT_VERSION >= 300
- if ( style == "QPE" ) {
- setStyle( new QPEStyle );
- } else {
- QStyle *s = QStyleFactory::create(style);
- if ( s ) setStyle(s);
- }
+ if ( style == "QPE" ) {
+ setStyle( new QPEStyle );
+ }
+ else {
+ QStyle *s = QStyleFactory::create( style );
+ if ( s )
+ setStyle( s );
+ }
#else
- if ( style == "Windows" ) {
- setStyle( new QWindowsStyle );
- } else if ( style == "QPE" ) {
- setStyle( new QPEStyle );
- } else if ( style == "Light" ) {
- setStyle( new LightStyle );
- }
+ if ( style == "Windows" ) {
+ setStyle( new QWindowsStyle );
+ }
+ else if ( style == "QPE" ) {
+ setStyle( new QPEStyle );
+ }
+ else if ( style == "Light" ) {
+ setStyle( new LightStyle );
+ }
#ifndef QT_NO_STYLE_PLATINUM
- else if ( style == "Platinum" ) {
- setStyle( new QPlatinumStyle );
- }
+ else if ( style == "Platinum" ) {
+ setStyle( new QPlatinumStyle );
+ }
#endif
#ifndef QT_NO_STYLE_MOTIF
- else if ( style == "Motif" ) {
- setStyle( new QMotifStyle );
- }
+ else if ( style == "Motif" ) {
+ setStyle( new QMotifStyle );
+ }
#endif
#ifndef QT_NO_STYLE_MOTIFPLUS
- else if ( style == "MotifPlus" ) {
- setStyle( new QMotifPlusStyle );
- }
+ else if ( style == "MotifPlus" ) {
+ setStyle( new QMotifPlusStyle );
+ }
#endif
@@ -1333,4 +1434,41 @@ void QPEApplication::internalSetStyle( const QString &style )
else {
+ QStyle *sty = 0;
+ QString path = QPEApplication::qpeDir ( ) + "/plugins/styles/lib" + style. lower ( ) + ".so";
+
+ static QLibrary *lastlib = 0;
+ static StyleInterface *lastiface = 0;
+
+ QLibrary *lib = new QLibrary ( path );
+ StyleInterface *iface = 0;
+
+ if ( lib-> queryInterface ( IID_Style, ( QUnknownInterface ** ) &iface ) == QS_OK )
+ sty = iface-> create ( );
+
+ if ( sty ) {
+ setStyle ( sty );
+
+ qDebug ( "Got Style: %p -- iface: %p, lib: %p\n", sty, iface, lib );
+
+ if ( lastiface )
+ lastiface-> release ( );
+ lastiface = iface;
+
+
+ if ( lastlib ) {
+ lastlib-> unload ( );
+ delete lastlib;
+ }
+ lastlib = lib;
+ }
+ else {
+ if ( iface )
+ iface-> release ( );
+ delete lib;
+
+ setStyle ( new QPEStyle ( ));
+ }
+
+#if 0
// style == "Liquid Style (libliquid.so)" (or "Windows XP (libxp.so)"
-
+
int p2 = style. findRev ( ']' );
@@ -1338,4 +1476,4 @@ void QPEApplication::internalSetStyle( const QString &style )
QString style2;
-
- if (( p1 > 0 ) && ( p2 > 0 ) && (( p1 + 1 ) < p2 ))
+
+ if ( ( p1 > 0 ) && ( p2 > 0 ) && ( ( p1 + 1 ) < p2 ) )
style2 = "lib" + style. mid ( p1 + 1, p2 - p1 - 1 ). lower ( ) + ".so";
@@ -1343,5 +1481,4 @@ void QPEApplication::internalSetStyle( const QString &style )
style2 = "lib" + style. lower ( ) + ".so";
-
- // static QLibrary *currentlib = 0;
- static void *currentlib = 0;
+
+ static QLibrary *currentlib = 0;
@@ -1350,30 +1487,27 @@ void QPEApplication::internalSetStyle( const QString &style )
do { // try/catch simulation
- // QLibrary *lib = new QLibrary ( path, QLibrary::Immediately );
- void *lib = ::dlopen ( path. local8Bit ( ), RTLD_LAZY | RTLD_GLOBAL );
-
+ QLibrary *lib = new QLibrary ( path, QLibrary::Immediately );
+
if ( lib ) {
- //QStyle * (*fpa) ( ) = (QStyle * (*) ( )) lib-> resolve ( "allocate" );
- QStyle * (*fpa) ( ) = (QStyle * (*) ( )) ::dlsym ( lib, "allocate" );
+ QStyle * ( *fpa ) ( ) = ( QStyle * ( * ) ( ) ) lib-> resolve ( "allocate" );
if ( fpa ) {
- QStyle *sty = ( *fpa ) ( );
-
+ QStyle * sty = ( *fpa ) ( );
+
if ( sty ) {
setStyle ( sty );
-
- if ( currentlib ) {
- //delete currentlib;
- ::dlclose ( currentlib );
- }
+
+ if ( currentlib )
+ delete currentlib;
currentlib = lib;
-
+
break;
- }
+ }
}
- //delete lib;
- ::dlclose ( lib );
+ delete lib;
}
- } while ( false );
+ }
+ while ( false );
+ // HACK for Qt2 only
+#endif
}
- // HACK for Qt2 only
#endif
@@ -1384,21 +1518,22 @@ void QPEApplication::internalSetStyle( const QString &style )
*/
-void QPEApplication::prepareForTermination(bool willrestart)
+void QPEApplication::prepareForTermination( bool willrestart )
{
- if ( willrestart ) {
- // Draw a big wait icon, the image can be altered in later revisions
-// QWidget *d = QApplication::desktop();
- QImage img = Resource::loadImage( "launcher/new_wait" );
- QPixmap pix;
- pix.convertFromImage(img.smoothScale(1*img.width(), 1*img.height()));
- QLabel *lblWait = new QLabel(0, "wait hack!", QWidget::WStyle_Customize |
- QWidget::WStyle_NoBorder | QWidget::WStyle_Tool );
- lblWait->setPixmap( pix );
- lblWait->setAlignment( QWidget::AlignCenter );
- lblWait->show();
- lblWait->showMaximized();
- }
+ if ( willrestart ) {
+ // Draw a big wait icon, the image can be altered in later revisions
+ // QWidget *d = QApplication::desktop();
+ QImage img = Resource::loadImage( "launcher/new_wait" );
+ QPixmap pix;
+ pix.convertFromImage( img.smoothScale( 1 * img.width(), 1 * img.height() ) );
+ QLabel *lblWait = new QLabel( 0, "wait hack!", QWidget::WStyle_Customize |
+ QWidget::WStyle_NoBorder | QWidget::WStyle_Tool );
+ lblWait->setPixmap( pix );
+ lblWait->setAlignment( QWidget::AlignCenter );
+ lblWait->show();
+ lblWait->showMaximized();
+ }
#ifndef SINGLE_APP
- { QCopEnvelope envelope("QPE/System", "forceQuit()"); }
- processEvents(); // ensure the message goes out.
- sleep(1); // You have 1 second to comply.
+ { QCopEnvelope envelope( "QPE/System", "forceQuit()" );
+ }
+ processEvents(); // ensure the message goes out.
+ sleep( 1 ); // You have 1 second to comply.
#endif
@@ -1411,3 +1546,3 @@ void QPEApplication::shutdown()
{
- // Implement in server's QPEApplication subclass
+ // Implement in server's QPEApplication subclass
}
@@ -1419,10 +1554,10 @@ void QPEApplication::restart()
{
- // Implement in server's QPEApplication subclass
+ // Implement in server's QPEApplication subclass
}
-static QPtrDict<void>* stylusDict=0;
+static QPtrDict<void>* stylusDict = 0;
static void createDict()
{
- if ( !stylusDict )
- stylusDict = new QPtrDict<void>;
+ if ( !stylusDict )
+ stylusDict = new QPtrDict<void>;
}
@@ -1431,10 +1566,10 @@ static void createDict()
Returns the current StylusMode for \a w.
-
+
\sa setStylusOperation()
*/
-QPEApplication::StylusMode QPEApplication::stylusOperation( QWidget* w )
+QPEApplication::StylusMode QPEApplication::stylusOperation( QWidget * w )
{
- if ( stylusDict )
- return (StylusMode)(int)stylusDict->find(w);
- return LeftOnly;
+ if ( stylusDict )
+ return ( StylusMode ) ( int ) stylusDict->find( w );
+ return LeftOnly;
}
@@ -1443,3 +1578,3 @@ QPEApplication::StylusMode QPEApplication::stylusOperation( QWidget* w )
\enum QPEApplication::StylusMode
-
+
\value LeftOnly the stylus only generates LeftButton
@@ -1448,3 +1583,3 @@ QPEApplication::StylusMode QPEApplication::stylusOperation( QWidget* w )
if the user uses the press-and-hold gesture.
-
+
See setStylusOperation().
@@ -1454,16 +1589,18 @@ QPEApplication::StylusMode QPEApplication::stylusOperation( QWidget* w )
Causes \a w to receive mouse events according to \a mode.
-
+
\sa stylusOperation()
*/
-void QPEApplication::setStylusOperation( QWidget* w, StylusMode mode )
+void QPEApplication::setStylusOperation( QWidget * w, StylusMode mode )
{
- createDict();
- if ( mode == LeftOnly ) {
- stylusDict->remove(w);
- w->removeEventFilter(qApp);
- } else {
- stylusDict->insert(w,(void*)mode);
- connect(w,SIGNAL(destroyed()),qApp,SLOT(removeSenderFromStylusDict()));
- w->installEventFilter(qApp);
- }
+ createDict();
+ if ( mode == LeftOnly ) {
+ stylusDict->remove
+ ( w );
+ w->removeEventFilter( qApp );
+ }
+ else {
+ stylusDict->insert( w, ( void* ) mode );
+ connect( w, SIGNAL( destroyed() ), qApp, SLOT( removeSenderFromStylusDict() ) );
+ w->installEventFilter( qApp );
+ }
}
@@ -1476,56 +1613,57 @@ bool QPEApplication::eventFilter( QObject *o, QEvent *e )
{
- if ( stylusDict && e->type() >= QEvent::MouseButtonPress && e->type() <= QEvent::MouseMove ) {
- QMouseEvent* me = (QMouseEvent*)e;
- if ( me->button() == LeftButton ) {
- StylusMode mode = (StylusMode)(int)stylusDict->find(o);
- switch (mode) {
- case RightOnHold:
- switch ( me->type() ) {
- case QEvent::MouseButtonPress:
- d->presstimer = startTimer(500); // #### pref.
- d->presswidget = (QWidget*)o;
- d->presspos = me->pos();
- d->rightpressed = FALSE;
- break;
- case QEvent::MouseButtonRelease:
- if ( d->presstimer ) {
- killTimer(d->presstimer);
- d->presstimer = 0;
- }
- if ( d->rightpressed && d->presswidget ) {
- // Right released
- postEvent( d->presswidget,
- new QMouseEvent( QEvent::MouseButtonRelease, me->pos(),
- RightButton, LeftButton+RightButton ) );
- // Left released, off-widget
- postEvent( d->presswidget,
- new QMouseEvent( QEvent::MouseMove, QPoint(-1,-1),
- LeftButton, LeftButton ) );
- postEvent( d->presswidget,
- new QMouseEvent( QEvent::MouseButtonRelease, QPoint(-1,-1),
- LeftButton, LeftButton ) );
- d->rightpressed = FALSE;
- return TRUE; // don't send the real Left release
- }
- break;
- default:
- break;
- }
- break;
- default:
- ;
- }
- }
- } else if ( e->type() == QEvent::KeyPress || e->type() == QEvent::KeyRelease ) {
- QKeyEvent *ke = (QKeyEvent *)e;
- if ( ke->key() == Key_Enter ) {
- if ( o->isA( "QRadioButton" ) || o->isA( "QCheckBox" ) ) {
- postEvent( o, new QKeyEvent( e->type(), Key_Space, ' ',
- ke->state(), " ", ke->isAutoRepeat(), ke->count() ) );
- return TRUE;
- }
- }
- }
+ if ( stylusDict && e->type() >= QEvent::MouseButtonPress && e->type() <= QEvent::MouseMove ) {
+ QMouseEvent * me = ( QMouseEvent* ) e;
+ if ( me->button() == LeftButton ) {
+ StylusMode mode = ( StylusMode ) ( int ) stylusDict->find( o );
+ switch ( mode ) {
+ case RightOnHold:
+ switch ( me->type() ) {
+ case QEvent::MouseButtonPress:
+ d->presstimer = startTimer( 500 ); // #### pref.
+ d->presswidget = ( QWidget* ) o;
+ d->presspos = me->pos();
+ d->rightpressed = FALSE;
+ break;
+ case QEvent::MouseButtonRelease:
+ if ( d->presstimer ) {
+ killTimer( d->presstimer );
+ d->presstimer = 0;
+ }
+ if ( d->rightpressed && d->presswidget ) {
+ // Right released
+ postEvent( d->presswidget,
+ new QMouseEvent( QEvent::MouseButtonRelease, me->pos(),
+ RightButton, LeftButton + RightButton ) );
+ // Left released, off-widget
+ postEvent( d->presswidget,
+ new QMouseEvent( QEvent::MouseMove, QPoint( -1, -1 ),
+ LeftButton, LeftButton ) );
+ postEvent( d->presswidget,
+ new QMouseEvent( QEvent::MouseButtonRelease, QPoint( -1, -1 ),
+ LeftButton, LeftButton ) );
+ d->rightpressed = FALSE;
+ return TRUE; // don't send the real Left release
+ }
+ break;
+ default:
+ break;
+ }
+ break;
+ default:
+ ;
+ }
+ }
+ }
+ else if ( e->type() == QEvent::KeyPress || e->type() == QEvent::KeyRelease ) {
+ QKeyEvent * ke = ( QKeyEvent * ) e;
+ if ( ke->key() == Key_Enter ) {
+ if ( o->isA( "QRadioButton" ) || o->isA( "QCheckBox" ) ) {
+ postEvent( o, new QKeyEvent( e->type(), Key_Space, ' ',
+ ke->state(), " ", ke->isAutoRepeat(), ke->count() ) );
+ return TRUE;
+ }
+ }
+ }
- return FALSE;
+ return FALSE;
}
@@ -1537,11 +1675,11 @@ void QPEApplication::timerEvent( QTimerEvent *e )
{
- if ( e->timerId() == d->presstimer && d->presswidget ) {
- // Right pressed
- postEvent( d->presswidget,
- new QMouseEvent( QEvent::MouseButtonPress, d->presspos,
- RightButton, LeftButton ) );
- killTimer( d->presstimer );
- d->presstimer = 0;
- d->rightpressed = TRUE;
- }
+ if ( e->timerId() == d->presstimer && d->presswidget ) {
+ // Right pressed
+ postEvent( d->presswidget,
+ new QMouseEvent( QEvent::MouseButtonPress, d->presspos,
+ RightButton, LeftButton ) );
+ killTimer( d->presstimer );
+ d->presstimer = 0;
+ d->rightpressed = TRUE;
+ }
}
@@ -1550,5 +1688,6 @@ void QPEApplication::removeSenderFromStylusDict()
{
- stylusDict->remove((void*)sender());
- if ( d->presswidget == sender() )
- d->presswidget = 0;
+ stylusDict->remove
+ ( ( void* ) sender() );
+ if ( d->presswidget == sender() )
+ d->presswidget = 0;
}
@@ -1560,3 +1699,3 @@ bool QPEApplication::keyboardGrabbed() const
{
- return d->kbgrabber;
+ return d->kbgrabber;
}
@@ -1570,9 +1709,9 @@ void QPEApplication::ungrabKeyboard()
{
- QPEApplicationData* d = ((QPEApplication*)qApp)->d;
- if ( d->kbgrabber == 2 ) {
- QCopEnvelope e("QPE/System", "grabKeyboard(QString)" );
- e << QString::null;
- d->kbregrab = FALSE;
- d->kbgrabber = 0;
- }
+ QPEApplicationData * d = ( ( QPEApplication* ) qApp ) ->d;
+ if ( d->kbgrabber == 2 ) {
+ QCopEnvelope e( "QPE/System", "grabKeyboard(QString)" );
+ e << QString::null;
+ d->kbregrab = FALSE;
+ d->kbgrabber = 0;
+ }
}
@@ -1583,3 +1722,3 @@ void QPEApplication::ungrabKeyboard()
application.
-
+
\sa ungrabKeyboard()
@@ -1588,10 +1727,10 @@ void QPEApplication::grabKeyboard()
{
- QPEApplicationData* d = ((QPEApplication*)qApp)->d;
- if ( qApp->type() == QApplication::GuiServer )
- d->kbgrabber = 0;
- else {
- QCopEnvelope e("QPE/System", "grabKeyboard(QString)" );
- e << d->appName;
- d->kbgrabber = 2; // me
- }
+ QPEApplicationData * d = ( ( QPEApplication* ) qApp ) ->d;
+ if ( qApp->type() == QApplication::GuiServer )
+ d->kbgrabber = 0;
+ else {
+ QCopEnvelope e( "QPE/System", "grabKeyboard(QString)" );
+ e << d->appName;
+ d->kbgrabber = 2; // me
+ }
}
@@ -1603,13 +1742,13 @@ int QPEApplication::exec()
{
- d->sendQCopQ();
- if ( d->keep_running)
- //|| d->qpe_main_widget && d->qpe_main_widget->isVisible() )
- return QApplication::exec();
-
- {
- QCopEnvelope e("QPE/System", "closing(QString)" );
- e << d->appName;
- }
- processEvents();
- return 0;
+ d->sendQCopQ();
+ if ( d->keep_running )
+ //|| d->qpe_main_widget && d->qpe_main_widget->isVisible() )
+ return QApplication::exec();
+
+ {
+ QCopEnvelope e( "QPE/System", "closing(QString)" );
+ e << d->appName;
+ }
+ processEvents();
+ return 0;
}
@@ -1623,11 +1762,11 @@ void QPEApplication::tryQuit()
{
- if ( activeModalWidget() || strcmp( argv()[0], "embeddedkonsole") == 0 )
- return; // Inside modal loop or konsole. Too hard to save state.
- {
- QCopEnvelope e("QPE/System", "closing(QString)" );
- e << d->appName;
- }
- processEvents();
+ if ( activeModalWidget() || strcmp( argv() [ 0 ], "embeddedkonsole" ) == 0 )
+ return ; // Inside modal loop or konsole. Too hard to save state.
+ {
+ QCopEnvelope e( "QPE/System", "closing(QString)" );
+ e << d->appName;
+ }
+ processEvents();
- quit();
+ quit();
}
@@ -1642,12 +1781,12 @@ void QPEApplication::hideOrQuit()
{
- // notify of our demise :)
- {
- QCopEnvelope e("QPE/System", "closing(QString)" );
- e << d->appName;
- }
- processEvents();
- if ( d->preloaded && d->qpe_main_widget )
- d->qpe_main_widget->hide();
- else
- quit();
+ // notify of our demise :)
+ {
+ QCopEnvelope e( "QPE/System", "closing(QString)" );
+ e << d->appName;
+ }
+ processEvents();
+ if ( d->preloaded && d->qpe_main_widget )
+ d->qpe_main_widget->hide();
+ else
+ quit();
}
@@ -1661,30 +1800,30 @@ void QPEApplication::hideOrQuit()
-void* operator new[](size_t size)
+void* operator new[] ( size_t size )
{
- return malloc(size);
+ return malloc( size );
}
-void* operator new(size_t size)
+void* operator new( size_t size )
{
- return malloc(size);
+ return malloc( size );
}
-void operator delete[](void* p)
+void operator delete[] ( void* p )
{
- free(p);
+ free( p );
}
-void operator delete[](void* p, size_t /*size*/)
+void operator delete[] ( void* p, size_t /*size*/ )
{
- free(p);
+ free( p );
}
-void operator delete(void* p)
+void operator delete( void* p )
{
- free(p);
+ free( p );
}
-void operator delete(void* p, size_t /*size*/)
+void operator delete( void* p, size_t /*size*/ )
{
- free(p);
+ free( p );
}
@@ -1697,19 +1836,18 @@ void operator delete(void* p, size_t /*size*/)
extern QRect qt_maxWindowRect;
-void qt_setMaxWindowRect(const QRect& r)
+void qt_setMaxWindowRect( const QRect & r )
{
- qt_maxWindowRect = qt_screen->mapFromDevice(r,
- qt_screen->mapToDevice(QSize(qt_screen->width(),qt_screen->height())));
- // Re-resize any maximized windows
- QWidgetList* l = QApplication::topLevelWidgets();
- if ( l ) {
- QWidget *w = l->first();
- while ( w ) {
- if ( w->isVisible() && w->isMaximized() )
- {
- w->showMaximized();
- }
- w = l->next();
- }
- delete l;
- }
+ qt_maxWindowRect = qt_screen->mapFromDevice( r,
+ qt_screen->mapToDevice( QSize( qt_screen->width(), qt_screen->height() ) ) );
+ // Re-resize any maximized windows
+ QWidgetList* l = QApplication::topLevelWidgets();
+ if ( l ) {
+ QWidget * w = l->first();
+ while ( w ) {
+ if ( w->isVisible() && w->isMaximized() ) {
+ w->showMaximized();
+ }
+ w = l->next();
+ }
+ delete l;
+ }
}
diff --git a/library/styleinterface.h b/library/styleinterface.h
new file mode 100644
index 0000000..9fea636
--- a/dev/null
+++ b/library/styleinterface.h
@@ -0,0 +1,68 @@
+/**********************************************************************
+** Copyright (C) 2002 Robert Griebl. All rights reserved.
+**
+** This file is part of OPIE (http://www.opie.info).
+**
+** This file may be distributed and/or modified under the terms of the
+** GNU General Public License version 2 as published by the Free Software
+** Foundation and appearing in the file LICENSE.GPL included in the
+** packaging of this file.
+**
+** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
+** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
+**
+**********************************************************************/
+
+#ifndef STYLEINTERFACE_H
+#define STYLEINTERFACE_H
+
+#include <qpe/qcom.h>
+
+#ifndef QT_NO_COMPONENT
+
+// {6C33B4F9-D529-453A-8FB3-DA42B21872BD}
+# ifndef IID_Style
+# define IID_Style QUuid( 0x6c33b4f9, 0xd529, 0x453a, 0x8f, 0xb3, 0xda, 0x42, 0xb2, 0x18, 0x72, 0xbd)
+#endif
+
+// {9757A252-3FD4-438F-A756-80BE4A9FB8DC}
+# ifndef IID_StyleSettings
+# define IID_StyleSettings QUuid( 0x9757a252, 0x3fd4, 0x438f, 0xa7, 0x56, 0x80, 0xbe, 0x4a, 0x9f, 0xb8, 0xdc)
+# endif
+
+#endif
+
+class QWidget;
+class QStyle;
+
+struct StyleInterface : public QUnknownInterface
+{
+ //! Return a new style.
+ virtual QStyle *create ( ) = 0;
+
+ //! Return a (longer) description for the style.
+ virtual QString description ( ) = 0;
+
+ //! Return a short name for the style.
+ virtual QString name ( ) = 0;
+
+ //! Return the library basename (libliquid.so => liquid)
+ virtual QCString key ( ) = 0;
+
+ //! QT_VERSION like 1.2.3 == 123
+ virtual unsigned int version ( ) = 0;
+};
+
+struct StyleSettingsInterface : public QUnknownInterface
+{
+ //! Return a new settings page.
+ virtual QWidget *create ( QWidget *parent, const char *name = 0 ) = 0;
+
+ //! Callback for appearance app when OK is clicked (return true when style has to re-applied).
+ virtual bool accept ( ) = 0;
+
+ //! Callback for appeaeance app when Cancel is clicked.
+ virtual void reject ( ) = 0;
+};
+
+#endif