summaryrefslogtreecommitdiff
path: root/library
authorkergoth <kergoth>2002-06-06 23:31:00 (UTC)
committer kergoth <kergoth>2002-06-06 23:31:00 (UTC)
commitdfb9c76738bb68e235114c5ad43dbd26a59b98ab (patch) (side-by-side diff)
tree25ab1468116e8a092dc402f8aa96a9c6976ebdce /library
parent9d6af1137a96d63f71f8e4797fe3bf377d92a15a (diff)
downloadopie-dfb9c76738bb68e235114c5ad43dbd26a59b98ab.zip
opie-dfb9c76738bb68e235114c5ad43dbd26a59b98ab.tar.gz
opie-dfb9c76738bb68e235114c5ad43dbd26a59b98ab.tar.bz2
Initial revision
Diffstat (limited to 'library') (more/less context) (ignore whitespace changes)
-rw-r--r--library/custom-linux-sharp-g++.h147
-rw-r--r--library/qcopmessage_qws.h99
2 files changed, 246 insertions, 0 deletions
diff --git a/library/custom-linux-sharp-g++.h b/library/custom-linux-sharp-g++.h
new file mode 100644
index 0000000..f65d474
--- a/dev/null
+++ b/library/custom-linux-sharp-g++.h
@@ -0,0 +1,147 @@
+/**********************************************************************
+** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
+**
+** This file is part of the Qtopia Environment.
+**
+** 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.
+**
+** See http://www.trolltech.com/gpl/ for GPL licensing information.
+**
+** Contact info@trolltech.com if any conditions of this licensing are
+** not clear to you.
+**
+**********************************************************************/
+
+#define QPE_OWNAPM
+#define QPE_HAVE_TOGGLELIGHT
+#define QPE_NOCIBAUD
+#define QPE_STARTMENU
+#include <asm/sharp_apm.h>
+#ifndef APM_IOC_BATTERY_BACK_CHK
+#define APM_IOC_BATTERY_BACK_CHK _IO(APM_IOC_MAGIC, 32)
+#endif
+#ifndef APM_IOC_BATTERY_MAIN_CHK
+#define APM_IOC_BATTERY_MAIN_CHK _IO(APM_IOC_MAGIC, 33)
+#endif
+
+#include <unistd.h>
+#include <stdio.h>
+#include <signal.h>
+#include <fcntl.h>
+#include <sys/ioctl.h>
+
+#define SHARP_DEV_IOCTL_COMMAND_START 0x5680
+
+/* --- for SHARP_BUZZER device --- */
+#define SHARP_BUZZER_IOCTL_START (SHARP_DEV_IOCTL_COMMAND_START)
+#define SHARP_BUZZER_MAKESOUND (SHARP_BUZZER_IOCTL_START)
+#define SHARP_BUZZER_SETVOLUME (SHARP_BUZZER_IOCTL_START+1)
+#define SHARP_BUZZER_GETVOLUME (SHARP_BUZZER_IOCTL_START+2)
+#define SHARP_BUZZER_ISSUPPORTED (SHARP_BUZZER_IOCTL_START+3)
+#define SHARP_BUZZER_SETMUTE (SHARP_BUZZER_IOCTL_START+4)
+#define SHARP_BUZZER_STOPSOUND (SHARP_BUZZER_IOCTL_START+5)
+
+#define SHARP_BUZ_TOUCHSOUND 1 /* touch panel sound */
+#define SHARP_BUZ_KEYSOUND 2 /* key sound */
+#define SHARP_PDA_ILLCLICKSOUND 3 /* illegal click */
+#define SHARP_PDA_WARNSOUND 4 /* warning occurred */
+#define SHARP_PDA_ERRORSOUND 5 /* error occurred */
+#define SHARP_PDA_CRITICALSOUND 6 /* critical error occurred */
+#define SHARP_PDA_SYSSTARTSOUND 7 /* system start */
+#define SHARP_PDA_SYSTEMENDSOUND 8 /* system shutdown */
+#define SHARP_PDA_APPSTART 9 /* application start */
+#define SHARP_PDA_APPQUIT 10 /* application ends */
+#define SHARP_BUZ_SCHEDULE_ALARM 11 /* schedule alarm */
+#define SHARP_BUZ_DAILY_ALARM 12 /* daily alarm */
+#define SHARP_BUZ_GOT_PHONE_CALL 13 /* phone call sound */
+#define SHARP_BUZ_GOT_MAIL 14 /* mail sound */
+
+
+#define CUSTOM_BUZZER( sound ) \
+{ \
+ static int fd = open( "/dev/sharp_buz", O_RDWR|O_NONBLOCK ); \
+ ioctl( fd, SHARP_BUZZER_MAKESOUND, sound ); \
+}
+
+#define CUSTOM_SOUND_ALARM CUSTOM_BUZZER( SHARP_BUZ_SCHEDULE_ALARM )
+
+#include <sys/ioctl.h>
+#include <asm/sharp_char.h>
+
+// a bit awkward, as this value is defined in emailclient.cpp aswell...
+#define LED_MAIL 0
+#define SHARP_LED_MAIL 9
+
+#define CUSTOM_LEDS( led, status ) \
+{ \
+ if ( led == LED_MAIL ) \
+ led = SHARP_LED_MAIL; \
+ static int fd = open( "/dev/sharp_led", O_RDWR|O_NONBLOCK ); \
+ sharp_led_status leds; \
+ memset(&leds, 0, sizeof(leds)); \
+ leds.which = led; \
+ leds.status = status; \
+ ioctl( fd, SHARP_LED_SETSTATUS, (char*)&leds ); \
+}
+
+#define QPE_HAVE_MEMALERTER
+
+#define QPE_MEMALERTER_IMPL \
+static void sig_handler(int sig) \
+{ \
+ switch (sig) { \
+ case SIGHUP: \
+ memstate = VeryLow; \
+ break; \
+ case SIGUSR1: \
+ memstate = Normal; \
+ break; \
+ case SIGUSR2: \
+ memstate = Low; \
+ break; \
+ } \
+} \
+static void initMemalerter() \
+{ \
+ struct sigaction sa; \
+ memset(&sa, '\0', sizeof sa); \
+ sa.sa_handler = sig_handler; \
+ sa.sa_flags = SA_RESTART; \
+ if (sigaction(SIGHUP, &sa, NULL) < 0) { \
+ return; \
+ } \
+ if (sigaction(SIGUSR1, &sa, NULL) < 0) { \
+ return; \
+ } \
+ if (sigaction(SIGUSR2, &sa, NULL) < 0) { \
+ return; \
+ } \
+ FILE *fo = fopen("/proc/sys/vm/freepg_signal_proc", "w"); \
+ \
+ if (!fo) \
+ return; \
+ fprintf(fo, "qpe\n"); \
+ fclose(fo); \
+}
+
+#define QPE_INITIAL_NUMLOCK_STATE \
+{ \
+ bool numLock = FALSE; \
+ sharp_kbdctl_modifstat st; \
+ int dev = ::open("/dev/sharp_kbdctl", O_RDWR); \
+ if( dev >= 0 ) { \
+ memset(&st, 0, sizeof(st)); \
+ st.which = 3; \
+ int ret = ioctl(dev, SHARP_KBDCTL_GETMODIFSTAT, (char*)&st); \
+ if( !ret ) \
+ numLock = (bool)st.stat; \
+ ::close(dev); \
+ } \
+ return numLock; \
+}
diff --git a/library/qcopmessage_qws.h b/library/qcopmessage_qws.h
new file mode 100644
index 0000000..c19f57d
--- a/dev/null
+++ b/library/qcopmessage_qws.h
@@ -0,0 +1,99 @@
+/**********************************************************************
+** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
+**
+** This file is part of the Qtopia Environment.
+**
+** 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.
+**
+** See http://www.trolltech.com/gpl/ for GPL licensing information.
+**
+** Contact info@trolltech.com if any conditions of this licensing are
+** not clear to you.
+**
+**********************************************************************/
+
+#ifndef QCOP_MESSAGE_H
+#define QCOP_MESSAGE_H
+
+#include <qdatastream.h>
+#include <qbuffer.h>
+
+class QCopMessage : public QDataStream {
+ public:
+ QCopMessage();
+ QCopMessage(const QCString& channel, const QCString& message);
+ QCopMessage(const QCopMessage& orig);
+ ~QCopMessage();
+
+ void setChannel(QCString& channel) { m_Channel = channel; }
+ QCString channel() const { return m_Channel; }
+ void setMessage(QCString& message) { m_Message = message; }
+ QCString message() const { return m_Message; }
+ const QByteArray data() const;
+
+ QCopMessage& operator=(const QCopMessage& orig);
+
+ private:
+ QCString m_Channel;
+ QCString m_Message;
+};
+
+// ### No need to inline, just maintaining binary compatability
+inline QCopMessage::QCopMessage() : QDataStream(new QBuffer()) {
+ device()->open(IO_WriteOnly);
+}
+
+inline QCopMessage::QCopMessage(const QCString& channel, const QCString& message)
+ : QDataStream(new QBuffer()), m_Channel(channel), m_Message(message) {
+ device()->open(IO_WriteOnly);
+}
+
+inline QCopMessage::QCopMessage(const QCopMessage& orig) : QDataStream() {
+ // The QBuffer is going to share the byte array, so it will keep the
+ // data pointer even when this one goes out of scope.
+ QByteArray array(((QBuffer*)orig.device())->buffer());
+ array.detach();
+ setDevice(new QBuffer(array));
+ device()->open(IO_Append);
+
+ m_Channel = orig.channel();
+ m_Message = orig.message();
+}
+
+inline QCopMessage& QCopMessage::operator=(const QCopMessage& orig) {
+ if (device()) {
+ delete device();
+ unsetDevice();
+ }
+
+ // The QBuffer is going to share the byte array, so it will keep the
+ // data pointer even when this one goes out of scope.
+ QByteArray array(((QBuffer*)orig.device())->buffer());
+ array.detach();
+ setDevice(new QBuffer(array));
+ device()->open(IO_Append);
+
+ m_Channel = orig.channel();
+ m_Message = orig.message();
+
+ return *this;
+}
+
+inline const QByteArray QCopMessage::data() const {
+ return ((QBuffer*)device())->buffer();
+}
+
+inline QCopMessage::~QCopMessage() {
+ // If we still have our QBuffer, clean it up...
+ if (device())
+ delete device();
+ unsetDevice();
+}
+
+#endif