author | alwin <alwin> | 2004-08-01 21:26:02 (UTC) |
---|---|---|
committer | alwin <alwin> | 2004-08-01 21:26:02 (UTC) |
commit | cd26bd549ac20b73039bab11662d627895f37c1a (patch) (side-by-side diff) | |
tree | a1840bf1e13ca4ff1b43572db8194eacdcbe091d /noncore/apps | |
parent | 9084969d2d4fa39d4d2c185695f0c88739a0f95c (diff) | |
download | opie-cd26bd549ac20b73039bab11662d627895f37c1a.zip opie-cd26bd549ac20b73039bab11662d627895f37c1a.tar.gz opie-cd26bd549ac20b73039bab11662d627895f37c1a.tar.bz2 |
reorganized zkbapplet for easier packaging within OE
-rw-r--r-- | noncore/apps/keyz-cfg/.cvsignore | 16 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/cfgdlg.cpp | 132 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/cfgdlg.h | 39 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/cfgfile.cpp | 349 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/cfgfile.h | 106 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/config.in | 4 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/keyz-cfg.pro | 24 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/main.cpp | 22 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/zkb.cpp | 592 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/zkb.h | 205 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/zkbcfg.cpp | 231 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/zkbcfg.h | 69 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/zkbnames.cpp | 446 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/zkbnames.h | 23 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/zkbxml.cpp | 573 | ||||
-rw-r--r-- | noncore/apps/keyz-cfg/zkbxml.h | 68 |
16 files changed, 0 insertions, 2899 deletions
diff --git a/noncore/apps/keyz-cfg/.cvsignore b/noncore/apps/keyz-cfg/.cvsignore deleted file mode 100644 index a8916d5..0000000 --- a/noncore/apps/keyz-cfg/.cvsignore +++ b/dev/null @@ -1,16 +0,0 @@ -.moc -categorydialog.cpp -categorydialog.h -infoform.cpp -infoform.h -newdialog.cpp -newdialog.h -passworddialog.cpp -passworddialog.h -searchdialog.cpp -searchdialog.h -wait.cpp -wait.h -Makefile -Makefile.in -moc* diff --git a/noncore/apps/keyz-cfg/cfgdlg.cpp b/noncore/apps/keyz-cfg/cfgdlg.cpp deleted file mode 100644 index 8d868d4..0000000 --- a/noncore/apps/keyz-cfg/cfgdlg.cpp +++ b/dev/null @@ -1,132 +0,0 @@ - -#include <qdir.h> -#include <qpe/qpeapplication.h> -#include <qpe/qcopenvelope_qws.h> -#include <unistd.h> -#include "cfgdlg.h" - -CfgDlg::CfgDlg(QWidget* parent, CfgFile* cf, QApplication* app, bool mod): - QDialog(parent, "CfgDlg", mod), cfile(cf), application(app) { - - setCaption(tr("keyz configurator")); - - QGridLayout* gl = new QGridLayout(this, 7, 5, 5, 5); - - QLabel* flabel = new QLabel("Available Keymaps", this); - files = new QListBox(this); - QPushButton* addButton = new QPushButton(">>", this); //add->setText("Add"); - connect(addButton, SIGNAL(clicked()), this, SLOT(add())); - QLabel* klabel = new QLabel("Selected Keymaps", this); - keymaps = new QListBox(this); - connect(keymaps, SIGNAL(highlighted(const QString&)), this, SLOT(keymapHighlighted(const QString&))); - QPushButton* delButton = new QPushButton("<<", this); //del->setText("Delete"); - connect(delButton, SIGNAL(clicked()), this, SLOT(del())); - QPushButton* slabelButton = new QPushButton("Set Label", this); //apply->setText("Apply"); - connect(slabelButton, SIGNAL(clicked()), this, SLOT(setLabel())); - QLabel* l = new QLabel("Label", this); - label = new QLineEdit(this); - QLabel* adlabel = new QLabel("Auto Repeat Delay (ms)", this); - QLabel* aplabel = new QLabel("Auto Repeat Period (ms)", this); - ad = new QSpinBox(50, 5000, 5, this); - ap = new QSpinBox(0, 5000, 5, this); - -// QLabel* adms = new QLabel("ms", this); -// QLabel* apms = new QLabel("ms", this); - -// QCheckBox* enable = new QCheckBox("Enable", t); - - gl->setColStretch(0, 1); - gl->setColStretch(1, 1); - gl->setColStretch(3, 1); - gl->setColStretch(4, 1); - gl->setRowStretch(3, 1); - gl->addMultiCellWidget(flabel, 0, 0, 0, 1); - gl->addMultiCellWidget(klabel, 0, 0, 3, 4); - gl->addMultiCellWidget(files, 1, 3, 0, 1); - gl->addMultiCellWidget(keymaps, 1, 3, 3, 4); - gl->addWidget(addButton, 1, 2); - gl->addWidget(delButton, 2, 2); - - gl->addWidget(l, 4, 0); - gl->addWidget(label, 4, 1); - gl->addMultiCellWidget(slabelButton, 4, 4, 3, 4); - - gl->addMultiCellWidget(adlabel, 5, 5, 0, 2); - gl->addMultiCellWidget(ad, 5, 5, 3, 4); -// gl->addWidget(adms, 5, 3); - - gl->addMultiCellWidget(aplabel, 6, 6, 0, 2); - gl->addMultiCellWidget(ap, 6, 6, 3, 4); - -// gl->addWidget(apms, 6, 3); - - QList<CfgEntry>& e = cfile->getEntries(); - - for(uint i = 0; i < e.count(); i++) { - CfgEntry* entry = e.at(i); - keymaps->insertItem(entry->getFile()); - m.insert(entry->getFile(), entry->getLabel()); - } - - QDir dir(QPEApplication::qpeDir()+"/share/zkb", "*.xml"); - QStringList flist = dir.entryList(); - QStringList::Iterator sit; - for(sit = flist.begin(); sit != flist.end(); ++sit) { - if (*sit != "common.xml" && *sit != "zkb.xml" && m.find(*sit) == m.end()) { - files->insertItem(*sit); - } - } - - ad->setValue(cfile->getAutorepeatDelay()); - ap->setValue(cfile->getAutorepeatPeriod()); - -// gl->addMultiCellWidget(enable, 7, 7, 0, 4); -} - -CfgDlg::~CfgDlg() { -} - -void CfgDlg::add() { - if (!files->currentText().isEmpty()) { - QString t = files->currentText(); - files->removeItem(files->currentItem()); - keymaps->insertItem(t); - cfile->replaceEntry(t, ""); - m.replace(t, ""); - } -} - -void CfgDlg::del() { - if (!keymaps->currentText().isEmpty()) { - QString t = keymaps->currentText(); - keymaps->removeItem(keymaps->currentItem()); - cfile->deleteEntry(t); - files->insertItem(t); - m.remove(files->currentText()); - } -} - -void CfgDlg::setLabel() { - if (!keymaps->currentText().isEmpty()) { - cfile->replaceEntry(keymaps->currentText(), - label->text()); - m.replace(keymaps->currentText(), label->text()); - } -} - -void CfgDlg::keymapHighlighted(const QString&text) { - label->setText(*m.find(text)); -} - - -void CfgDlg::accept() { - cfile->setAutorepeatDelay(ad->value()); - cfile->setAutorepeatPeriod(ap->value()); - - CfgParser p; - p.save(QPEApplication::qpeDir()+"/share/zkb/zkb.xml", *cfile); - QCopEnvelope("QPE/zkb", "reload()"); - - QDialog::accept(); -} - diff --git a/noncore/apps/keyz-cfg/cfgdlg.h b/noncore/apps/keyz-cfg/cfgdlg.h deleted file mode 100644 index cbefdf1..0000000 --- a/noncore/apps/keyz-cfg/cfgdlg.h +++ b/dev/null @@ -1,39 +0,0 @@ -#include <qlabel.h> -#include <qlistbox.h> -#include <qpushbutton.h> -#include <qlineedit.h> -#include <qlayout.h> -#include <qcheckbox.h> -#include <qspinbox.h> -#include <qdialog.h> -#include <qapplication.h> - -#include "cfgfile.h" - -class CfgDlg : public QDialog { -Q_OBJECT - -public: - CfgDlg(QWidget* parent, CfgFile* cfile, QApplication *, bool b = false); - virtual ~CfgDlg(); - -protected: - CfgFile* cfile; - QApplication* application; - - QMap<QString, QString> m; - - QListBox* files; - QListBox* keymaps; - QLineEdit* label; - QSpinBox* ap; - QSpinBox* ad; - - virtual void accept(); - -protected slots: - void add(); - void del(); - void setLabel(); - void keymapHighlighted(const QString&); -}; diff --git a/noncore/apps/keyz-cfg/cfgfile.cpp b/noncore/apps/keyz-cfg/cfgfile.cpp deleted file mode 100644 index be7150e..0000000 --- a/noncore/apps/keyz-cfg/cfgfile.cpp +++ b/dev/null @@ -1,349 +0,0 @@ -#include "cfgfile.h" - -/* OPIE */ -#include <opie2/odebug.h> -using namespace Opie::Core; - -/* QT */ -#include <qmessagebox.h> - -// CfgEntry implementation -CfgEntry::CfgEntry() { -} - -CfgEntry::CfgEntry(const QString& f, const QString& l): - file(f), label(l) { -} - -const QString& CfgEntry::getFile() const { - return file; -} - -void CfgEntry::setFile(const QString& f) { - file = f; -} - -const QString& CfgEntry::getLabel() const { - return label; -} - -void CfgEntry::setLabel(const QString& f) { - label = f; -} - -// CfgFile implementation -CfgFile::CfgFile():ardelay(400), arperiod(80) { -} - -CfgFile::~CfgFile() { -} - -QList<CfgEntry>& CfgFile::getEntries() { - return entries; -} - -bool CfgFile::replaceEntry(const QString& file, const QString& label, int index) { - deleteEntry(file); - - CfgEntry* entry = new CfgEntry(file, label); - if (index >= 0) { - entries.insert(index, entry); - } else { - entries.append(entry); - } - - return true; -} - -bool CfgFile::deleteEntry(const QString& file) { - for(int i = 0; i < (int) entries.count(); i++) { - CfgEntry* entry = entries.at(i); - if (entry->getFile() == file) { - entries.remove(i); - return true; - } - } - return false; -} - -int CfgFile::getAutorepeatDelay() const { - return ardelay; -} - -void CfgFile::setAutorepeatDelay(int n) { - ardelay = n; -} - -int CfgFile::getAutorepeatPeriod() const { - return arperiod; -} - -void CfgFile::setAutorepeatPeriod(int n) { - arperiod = n; -} - -// CfgParser implementation -CfgParser::CfgParser() { -} - -bool CfgParser::load(QString file, CfgFile& cfg) { - QFile f(file); - QXmlInputSource is(f); - QXmlSimpleReader reader; - CfgHandler p(*this); - - reader.setErrorHandler(this); - reader.setContentHandler(&p); - - err = ""; - ardelay = -1; - arperiod = -1; - reader.parse(is); - - if (!err.isEmpty()) { - odebug << err << oendl; - return false; - } - - QMap<QString, QString>::Iterator fit, lit; - for(uint i = 0; i < includeList.count(); i++) { - QString file = *includeList.at(i); - fit = includes.find(file); - QString prefix = fit.data(); - QString label = ""; - - odebug << "include: file=" + fit.key() + ", prefix=" + fit.data() << oendl; - lit = labels.find(prefix+":*"); - if (lit != labels.end()) { - label = lit.data(); - } - - cfg.replaceEntry(file, label); - } - - if (ardelay != -1) { - cfg.setAutorepeatDelay(ardelay); - } - - if (arperiod != -1) { - cfg.setAutorepeatPeriod(arperiod); - } - - return true; -} - -bool CfgParser::save(QString file, CfgFile& cfg) { - FILE* f = fopen((const char*) file.local8Bit(), "w"); - if (!f) { - oerr << "Could not write config file!" << oendl; - return false; - } - - fprintf(f, "<keymap autorepeat-delay=\"%d\" autorepeat-period=\"%d\" " - "author=\"keyzcfg\">\n", cfg.getAutorepeatDelay(), - cfg.getAutorepeatPeriod()); - - QList<CfgEntry>& entries = cfg.getEntries(); - int n; - - for(n=0; n < (int) entries.count(); n++) { - CfgEntry* entry = entries.at(n); - QString l = entry->getLabel(); - if (l.isEmpty()) { - l = entry->getFile(); - } - fprintf(f, "\t<label name=\"%s\" state=\"km%d:*\"/>\n", - (const char*) l.utf8(), n); - } - - for(n=0; n < (int) entries.count(); n++) { - CfgEntry* entry = entries.at(n); - fprintf(f, "\t<include file=\"%s\" prefix=\"km%d\"/>\n", - (const char*) entry->getFile().utf8(), n); - } - - int k = n-1; - char* states[] = { "LShift", "LShift-Caps", "LShift-Num", - "LShift-Num-Caps", 0}; - - for(n=0; n < (int) entries.count(); n++) { - QString nstate = "km" + QString::number(n+1); - if (n == k) { - nstate = "km" + QString::number(0); - } - - for(int i = 0; states[i] != 0; i++) { - fprintf(f, "\t<state name=\"km%d:%s\">\n", - n, states[i]); - fprintf(f, "\t\t<map keycode=\"Middle\" pressed=\"true\">\n"); - fprintf(f, "\t\t\t<next-state name=\"%s:%s\"/>\n", - (const char*) nstate.utf8(), states[i]); - fprintf(f, "\t\t</map>\n\t</state>\n\n"); - } - } - - fprintf(f, "\t<state name=\"km0:Normal\" default=\"true\"/>\n"); - - fprintf(f, "</keymap>"); - fclose(f); - return true; -} - -CfgParser::~CfgParser() { -} - -int CfgParser::getAutorepeatDelay() const { - return ardelay; -} - -void CfgParser::setAutorepeatDelay(int n) { - ardelay = n; -} - -int CfgParser::getAutorepeatPeriod() const { - return arperiod; -} - -void CfgParser::setAutorepeatPeriod(int n) { - arperiod = n; -} - -void CfgParser::addLabel(const QString& name, const QString& state) { - labels.insert(state, name); - labelList.append(&labels.find(state).data()); -} - -void CfgParser::addFile(const QString& file, const QString& prefix) { - includes.insert(file, prefix); - includeList.append(&includes.find(file).key()); -} - -QString CfgParser::errorString() { - return err; -} - -bool CfgParser::warning(const QXmlParseException& e) { - QString tmp; - - tmp.sprintf("%d: warning: %s\n", e.lineNumber(), - (const char*) e.message().utf8()); - - err += tmp; - - return true; -} - -bool CfgParser::error(const QXmlParseException& e) { - QString tmp; - - tmp.sprintf("%d: error: %s\n", e.lineNumber(), - (const char*) e.message().utf8()); - - err += tmp; - - return true; -} - -bool CfgParser::fatalError(const QXmlParseException& e) { - QString tmp; - - tmp.sprintf("%d: fatal error: %s\n", e.lineNumber(), - (const char*) e.message().utf8()); - - err += tmp; - - return false; -} - -// CfgHandler implementation -CfgHandler::CfgHandler(CfgParser& c):cfg(c) { -} - -CfgHandler::~CfgHandler() { -} - -bool CfgHandler::startKeymapElement(int ard, int arp, const QString& author) { - if (author != "keyzcfg") { - bool ret; - ret = QMessageBox::warning(0, "keyz configurator", - "Your zkb.xml doesn't seem created by keyz configurator.\n" - "By using keyz configurator you may loose your current " - "configuration\n Do you want to continue\n\n", - "Yes", "No", 0, 0, 1); - - if (ret != 0) { - err = "cancelled by user"; - return false; - } - } - - if (ard != -1) { - cfg.setAutorepeatDelay(ard); - } - - if (arp != -1) { - cfg.setAutorepeatPeriod(arp); - } - - return true; -} - -bool CfgHandler::startIncludeElement(const QString& file, - const QString& pref) { - - cfg.addFile(file, pref); - return true; -} - -bool CfgHandler::startLabelElement(const QString& label, - const QString& state) { - - cfg.addLabel(label, state); - return true; -} - -bool CfgHandler::startStateElement(const QString&, const QString&, bool) { - - return true; -} - -bool CfgHandler::startMapElement(int, bool) { - return true; -} - -bool CfgHandler::startEventElement(int, int, int, bool, bool) { - return true; -} - -bool CfgHandler::startNextStateElement(const QString&) { - return true; -} - - -bool CfgHandler::endKeymapElement() { - return true; -} - -bool CfgHandler::endIncludeElement() { - return true; -} - -bool CfgHandler::endLabelElement() { - return true; -} - -bool CfgHandler::endStateElement() { - return true; -} - -bool CfgHandler::endMapElement() { - return true; -} - -bool CfgHandler::endEventElement() { - return true; -} - -bool CfgHandler::endNextStateElement() { - return true; -} diff --git a/noncore/apps/keyz-cfg/cfgfile.h b/noncore/apps/keyz-cfg/cfgfile.h deleted file mode 100644 index 9759900..0000000 --- a/noncore/apps/keyz-cfg/cfgfile.h +++ b/dev/null @@ -1,106 +0,0 @@ -#ifndef CFGFILE_H -#define CFGFILE_H - -#include <qlist.h> -#include "zkbxml.h" - -class CfgEntry { -public: - CfgEntry(); - CfgEntry(const QString& file, const QString& label); - - const QString& getFile() const; - void setFile(const QString& f); - const QString& getLabel() const; - void setLabel(const QString& l); - -protected: - QString file; - QString label; -}; - -class CfgFile { -public: - CfgFile(); - ~CfgFile(); - - QList<CfgEntry>& getEntries(); - bool replaceEntry(const QString& file, const QString& label, - int index = -1); - bool deleteEntry(const QString& file); - - int getAutorepeatDelay() const; - void setAutorepeatDelay(int); - int getAutorepeatPeriod() const; - void setAutorepeatPeriod(int); - -protected: - QList<CfgEntry> entries; - int ardelay; - int arperiod; -}; - -class CfgParser : public QXmlErrorHandler { -public: - CfgParser(); - virtual ~CfgParser(); - - bool load(QString file, CfgFile& cfg); - bool save(QString file, CfgFile& cfg); - - void addLabel(const QString& name, const QString& state); - void addFile(const QString& file, const QString& prefix); - - int getAutorepeatDelay() const; - void setAutorepeatDelay(int); - int getAutorepeatPeriod() const; - void setAutorepeatPeriod(int); - - virtual bool warning(const QXmlParseException& e); - virtual bool error(const QXmlParseException& e); - virtual bool fatalError(const QXmlParseException& e); - virtual QString errorString(); - - QString getError(); - -protected: - QString err; - QMap<QString, QString> labels; - QMap<QString, QString> includes; - QList<QString> labelList; - QList<QString> includeList; - int ardelay; - int arperiod; -}; - -class CfgHandler : public ZkbXmlHandler { -public: - CfgHandler(CfgParser &); - virtual ~CfgHandler(); - -protected: - CfgParser& cfg; - - virtual bool startKeymapElement(int ardelay, int arperiod, - const QString& author); - virtual bool startIncludeElement(const QString& file, - const QString& prfix); - virtual bool startLabelElement(const QString& label, - const QString& state); - virtual bool startStateElement(const QString& name, - const QString& parent, bool dflt); - virtual bool startMapElement(int key, bool pressed); - virtual bool startEventElement(int keycode, int unicode, int modifiers, - bool pressed, bool autorepeat); - virtual bool startNextStateElement(const QString& state); - - virtual bool endKeymapElement(); - virtual bool endIncludeElement(); - virtual bool endLabelElement(); - virtual bool endStateElement(); - virtual bool endMapElement(); - virtual bool endEventElement(); - virtual bool endNextStateElement(); -}; - -#endif diff --git a/noncore/apps/keyz-cfg/config.in b/noncore/apps/keyz-cfg/config.in deleted file mode 100644 index 8e1be2d..0000000 --- a/noncore/apps/keyz-cfg/config.in +++ b/dev/null @@ -1,4 +0,0 @@ - config KEYZCFG - boolean "keyz-cfg (configuration tool for keyz applet)" - default "n" - depends ( LIBQPE || LIBQPE-X11 ) && LIBOPIE2CORE diff --git a/noncore/apps/keyz-cfg/keyz-cfg.pro b/noncore/apps/keyz-cfg/keyz-cfg.pro deleted file mode 100644 index 7ac604b..0000000 --- a/noncore/apps/keyz-cfg/keyz-cfg.pro +++ b/dev/null @@ -1,24 +0,0 @@ -TEMPLATE = app -DESTDIR = $(OPIEDIR)/bin -CONFIG = qt warn_on -HEADERS = zkb.h \ - zkbcfg.h \ - zkbnames.h \ - zkbxml.h \ - cfgdlg.h \ - cfgfile.h - -SOURCES = main.cpp \ - cfgdlg.cpp \ - cfgfile.cpp \ - zkb.cpp \ - zkbcfg.cpp \ - zkbnames.cpp \ - zkbxml.cpp - -INCLUDEPATH += $(OPIEDIR)/include -DEPENDPATH += $(OPIEDIR)/include -LIBS += -lqpe -lopiecore2 -TARGET = keyz-cfg - -include ( $(OPIEDIR)/include.pro ) diff --git a/noncore/apps/keyz-cfg/main.cpp b/noncore/apps/keyz-cfg/main.cpp deleted file mode 100644 index 4615562..0000000 --- a/noncore/apps/keyz-cfg/main.cpp +++ b/dev/null @@ -1,22 +0,0 @@ -#include <stdio.h> -#include <qpe/qpeapplication.h> -#include <qlayout.h> -#include <qmainwindow.h> - -#include "cfgdlg.h" - -int main( int argc, char **argv ) { - QPEApplication app(argc, argv); - CfgFile cfile; - CfgParser cp; - cp.load(QPEApplication::qpeDir()+"/share/zkb/zkb.xml", cfile); - - - CfgDlg c(0, &cfile, &app, true); - - - app.showMainWidget(&c); - int ret = QPEApplication::execDialog(&c); - - return ret; -} diff --git a/noncore/apps/keyz-cfg/zkb.cpp b/noncore/apps/keyz-cfg/zkb.cpp deleted file mode 100644 index a357b88..0000000 --- a/noncore/apps/keyz-cfg/zkb.cpp +++ b/dev/null @@ -1,592 +0,0 @@ -#include "zkb.h" - -/* OPIE */ -#include <opie2/odebug.h> -#include <opie2/okeyfilter.h> - -#include <stdio.h> - -// Implementation of Action class -Action::Action():state(0), keycode(0), unicode(0), flags(0) { -} - -Action::Action(State* s, ushort kc, ushort uni, int f): - state(s), keycode(kc), unicode(uni), flags(f) { -} - -Action::~Action() { -} - -State* Action::getState() const { - return state; -} - -void Action::setState(State* s) { - state = s; - setDefined(true); -} - -bool Action::hasEvent() const { - return flags & Event; -} - -void Action::setEvent(bool e) { - flags = (flags & ~Event) | ((e) ? Event : 0); - - if (e) { - setDefined(true); - } else { - if (state == 0) { - setDefined(false); - } - } -} - -bool Action::isDefined() const { - return flags & Defined; -} - -void Action::setDefined(bool d) { - flags = (flags & ~Defined) | ((d) ? Defined : 0); -} - -int Action::getKeycode() const { - return keycode; -} - -void Action::setKeycode(int c) { - keycode = (ushort) c; - setEvent(true); -} - -int Action::getUnicode() const { - return unicode; -} - -void Action::setUnicode(int u) { - unicode = (ushort) u; - setEvent(true); -} - -int Action::getModifiers() const { - int ret = 0; - if (flags & Shift_Mod) { - ret |= Qt::ShiftButton; - } - - if (flags & Ctrl_Mod) { - ret |= Qt::ControlButton; - } - - if (flags & Alt_Mod) { - ret |= Qt::AltButton; - } - - if (flags & Keypad_Mod) { - ret |= Qt::Keypad; - } - - return ret; -} - -void Action::setModifiers(int m) { - int n = 0; - - if (m & Qt::ShiftButton) { - n |= Shift_Mod; - } - - if (m & Qt::ControlButton) { - n |= Ctrl_Mod; - } - - if (m & Qt::AltButton) { - n |= Alt_Mod; - } - - if (m & Qt::Keypad) { - n |= Keypad_Mod; - } - - flags = flags & ~Mod_Bits | n; - setEvent(true); -} - -bool Action::isPressed() const { - return (flags & Press) != 0; -} - -void Action::setPressed(bool p) { - flags = (flags & ~Press) | ((p) ? Press : 0); - setEvent(true); -} - -bool Action::isAutorepeat() const { - return (flags & Autorepeat) != 0; -} - -void Action::setAutorepeat(bool p) { - flags = (flags & ~Autorepeat) | ((p) ? Autorepeat : 0); - setEvent(true); -} - -// Implementation of State class -const short State::x1[] = { /* from 0x20 to 0x5f */ - 31, 0, 28, 3, 5, 6, 9, 28, /* 0x20 - 0x27 */ - 11, 26, 10, 13, 26, 1, 29, 27, /* 0x28 - 0x2f */ - 15, 16, 22, 4, 17, 19, 24, 20, /* 0x30 - 0x37 */ - 8, 14, 29, 26, 29, 12, 32, 27, /* 0x38 - 0x3f */ - 18, 0, 1, 2, 3, 4, 5, 6, /* 0x40 - 0x47 */ - 7, 8, 9, 10, 11, 12, 13, 14, /* 0x48 - 0x4f */ - 15, 16, 17, 18, 19, 20, 21, 22, /* 0x50 - 0x57 */ - 23, 24, 25, 30, -1, 26, 28, 7, /* 0x58 - 0x5f */ - 31, -1, -1, -1, -1, -1, -1, -1, /* 0x60 - 0x67 */ - -1, -1, -1, -1, -1, -1, -1, -1, /* 0x68 - 0x6f */ - -1, -1, -1, -1, -1, -1, -1, -1, /* 0x70 - 0x77 */ - -1, -1, -1, 29, 31, 32, 32, 28, /* 0x78 - 0x7f */ -}; - -const short State::x2[] = { /* from 0x1000 to 0x1057*/ - 42, 36, -1, 30, 32, -1, -1, -1, /* 0x1000 - 0x1007 */ - -1, -1, -1, -1, -1, -1, -1, -1, /* 0x1008 - 0x100f */ - -1, -1, 44, 45, 46, 47, -1, -1, /* 0x1010 - 0x1017 */ - -1, -1, -1, -1, -1, -1, -1, -1, /* 0x1018 - 0x101f */ - 33, 35, 34, -1, 36, 27, -1, -1, /* 0x1020 - 0x1027 */ - -1, -1, -1, -1, -1, -1, -1, -1, /* 0x1028 - 0x102f */ - -1, -1, -1, -1, -1, -1, -1, -1, /* 0x1030 - 0x1037 */ - 37, 38, 40, 39, 41, -1, -1, -1, /* 0x1038 - 0x103f */ - -1, -1, -1, -1, -1, 35, -1, -1, /* 0x1040 - 0x1047 */ - -1, -1, -1, -1, -1, 48, -1, -1, /* 0x1048 - 0x104f */ - 43, 49, 50, -1, -1, -1, -1, -1, /* 0x1050 - 0x1057 */ -}; - -State::State(State* p):parent(p), keys(0) { - keys = new Action[Key_Max * 2 + 1]; -} - -State::State(const State& s) { - parent = s.parent; - keys = new Action[Key_Max * 2 + 1]; - memcpy(keys, s.keys, sizeof(Action) * (Key_Max * 2 + 1)); -} - -State::~State() { - if (keys!=0) { - delete [] keys; - } -} - -Action* State::get(int keycode, bool pressed, bool follow) const { - Action* ret = 0; - int n = translateKeycode(keycode); - - if (n != -1 && keys != 0) { - if (pressed) { - n += Key_Max; - } - ret = &keys[n]; - } - - if (ret==0 || !ret->isDefined()) { - if (follow && parent!=0) { - ret = parent->get(keycode, pressed, follow); - } - } - - return ret; -} - -bool State::set(int keycode, bool pressed, Action& action) { - int n = translateKeycode(keycode); - - if (n==-1 || keys==0) { - return false; - } - - if (pressed) { - n += Key_Max + 1; - } - - keys[n] = action; - return true; -} - -State* State::getParent() const { - return parent; -} - -void State::setParent(State* s) { - parent = s; -} - -int State::translateKeycode(int keycode) const { - if (keycode < 0x20) { - return -1; - } - - if (keycode < 0x80) { - return x1[keycode - 0x20]; - } - - if (keycode < 0x1000) { - return -1; - } - - if (keycode < 0x1057) { - return x2[keycode - 0x1000]; - } - - return -1; -} - -// Implementation of Keymap class -Keymap::Keymap():enabled(true), currentState(0), autoRepeatAction(0), repeater(this) { - repeatDelay=400; - repeatPeriod=80; - connect(&repeater, SIGNAL(timeout()), this, SLOT(autoRepeat())); -} - -Keymap::~Keymap() { - odebug << "removing keyboard filter for zkb"<<oendl; - Opie::Core::OKeyFilter::inst()->remHandler(this); - QMap<QString, State*>::Iterator it; - for(it = states.begin(); it != states.end(); ++it) { - delete it.data(); - } - states.clear(); -} - -bool Keymap::filter(int unicode, int keycode, int modifiers, - bool isPress, bool autoRepeat) { - - odebug << "filter: >>> unicode=" << unicode << ", keycode=" << keycode - << ", modifiers=" << modifiers << ", ispressed=" << isPress << oendl; - - if (!enabled) { - return false; - } - - // the second check is workaround to make suspend work if - // the user pressed it right after he did resume. for some - // reason the event sent by qt has autoRepeat true in this - // case - if (autoRepeat && keycode != 4177) { - return true; - } - - (void) unicode; (void) modifiers; - - Action* action = currentState->get(keycode, isPress, true); - if (action==0 || !action->isDefined()) { - return true; - } - - if (action->hasEvent()) { - odebug << "filter:<<< unicode=" << action->getUnicode() << ", keycode=" << action->getKeycode() - << ", modifiers=" << action->getModifiers() << ", ispressed=" << action->isPressed() << oendl; - - QWSServer::sendKeyEvent(action->getUnicode(), - action->getKeycode(), action->getModifiers(), - action->isPressed(), false); - } - - if (action->isAutorepeat()) { - autoRepeatAction = action; - repeater.start(repeatDelay, TRUE); - } else { - autoRepeatAction = 0; - } - - State* nstate = action->getState(); - if (nstate != 0) { - setCurrentState(nstate); - QString lbl = getCurrentLabel(); - if (!lbl.isEmpty()) { - emit stateChanged(lbl); - } - } - - - return true; -} - -void Keymap::enable() { - enabled = true; -} - -void Keymap::disable() { - enabled = false; -} - -QStringList Keymap::listStates() { - QStringList ret; - - QMap<QString, State*>::Iterator it; - for(it = states.begin(); it != states.end(); ++it) { - ret.append(it.key()); - } - - return ret; -} - -State* Keymap::getStateByName(const QString& name) { - QMap<QString, State*>::Iterator it = states.find(name); - - if (it == states.end()) { - return 0; - } - - return it.data(); -} - -QStringList Keymap::listLabels() { - QStringList ret; - - for(uint i = 0; i < labelList.count(); i++) { - ret.append(*labelList.at(i)); - } - - return ret; -} - -State* Keymap::getStateByLabel(const QString& label) { - QMap<QString, QString>::Iterator lit = labels.find(label); - State* state = 0; - - if (lit == labels.end()) { - return 0; - } - - QString name = lit.data(); - - int n = name.find(":*"); - if (n>=0 && n==(int)(name.length()-2)) { - name=name.left(name.length() - 1); - - n = currentStateName.findRev(":"); - if (n >= 0) { - name += currentStateName.mid(n+1); - } - } - -// odebug << "look for: " << name.utf8() << "\n" << oendl; - QMap<QString, State*>::Iterator sit = states.find(name); - if (sit != states.end()) { - state = sit.data(); - } - - return state; -} - -bool Keymap::addState(const QString& name, State* state) { - if (states.find(name) != states.end()) { - return false; - } - - states.insert(name, state); - lsmapInSync = false; - - if (currentState == 0) { - setCurrentState(state); - } - - return true; -} - -State* Keymap::getCurrentState() const { - return currentState; -} - -QString Keymap::getCurrentLabel() { - return currentLabel; -} - -bool Keymap::setCurrentState(State* state) { - QMap<QString, State*>::Iterator it; - for(it = states.begin(); it != states.end(); ++it) { - State* s = it.data(); - if (s == state) { - currentState = s; - currentStateName = it.key(); - - odebug << "state changed: " << (const char*)currentStateName.utf8() << oendl; - - if (!lsmapInSync) { - generateLabelStateMaps(); - } - - QMap<State*, QString>::Iterator tit; - tit = stateLabelMap.find(state); - if (tit != stateLabelMap.end()) { - currentLabel = tit.data(); - } else { -// odebug << "no label for: " + currentStateName + "\n" << oendl; - currentLabel = ""; - } - - return true; - } - } - - return false; -} - -bool Keymap::removeState(const QString& name, bool force) { - QMap<QString, State*>::Iterator it = states.find(name); - - if (it == states.end()) { - return false; - } - - State* state = it.data(); - QList<Action> acts = findStateUsage(state); - - if (!acts.isEmpty()) { - if (!force) { - return false; - } else { - for(Action* a = acts.first(); a != 0; a = acts.next()) { - a->setState(0); - } - } - } - - if (state == currentState) { - if (states.begin() != states.end()) { - setCurrentState(states.begin().data()); - } - } - - states.remove(it); - delete state; - - lsmapInSync = false; - - return true; -} - -void Keymap::autoRepeat() { - if (autoRepeatAction != 0) { - odebug << "filter:<<< unicode=" << autoRepeatAction->getUnicode() - << ", keycode=" << autoRepeatAction->getKeycode() - << ", modifiers=" << autoRepeatAction->getModifiers() - << "ispressed=" << autoRepeatAction->isPressed() << oendl; - - QWSServer::sendKeyEvent(autoRepeatAction->getUnicode(), - autoRepeatAction->getKeycode(), - autoRepeatAction->getModifiers(), - autoRepeatAction->isPressed(), true); - } - - repeater.start(repeatPeriod, TRUE); -} - -bool Keymap::addLabel(const QString& label, const QString& state, int index) { - if (labels.find(label) != labels.end()) { - return false; - } - - labels.insert(label, state); - const QString& l = labels.find(label).key(); - if (index == -1) { - labelList.append(l); - } else { - labelList.insert(labelList.at(index), l); - } - - lsmapInSync = false; - - return true; -} - -bool Keymap::removeLabel(const QString& label) { - - if (labels.find(label) == labels.end()) { - return false; - } - - labels.remove(label); - labelList.remove(label); - lsmapInSync = false; - - if (label == currentLabel) { - currentLabel = ""; - } - - return true; -} - -int Keymap::getAutorepeatDelay() const { - return repeatDelay; -} - -void Keymap::setAutorepeatDelay(int n) { - repeatDelay = n; -} - -int Keymap::getAutorepeatPeriod() const { - return repeatPeriod; -} - -void Keymap::setAutorepeatPeriod(int n) { - repeatPeriod = n; -} - -QList<Action> Keymap::findStateUsage(State* s) { - QList<Action> ret; - - QMap<QString, State*>::Iterator it; - for(it = states.begin(); it != states.end(); ++it) { - State* state = it.data(); - - for(int i = 0; i < 0x1100; i++) { - Action* action = state->get(i, false); - if (action!=0 && action->getState()==s) { - ret.append(action); - } - - action = state->get(i, true); - if (action!=0 && action->getState()==s) { - ret.append(action); - } - } - } - - return ret; -} - -void Keymap::generateLabelStateMaps() { - stateLabelMap.clear(); - - QMap<QString, QString>::Iterator lit; - for(lit = labels.begin(); lit != labels.end(); ++lit) { - QString label = lit.key(); - QString name = lit.data(); - - bool wc = false; - int n = name.find("*"); - if (n>=0 && n==(int)(name.length()-1)) { - name=name.left(name.length() - 1); - wc = true; - } - - QMap<QString, State*>::Iterator sit; - for(sit = states.begin(); sit != states.end(); ++sit) { - QString sname = sit.key(); - State* state = sit.data(); - - if (sname.length() < name.length()) { - continue; - } - - if (sname.left(name.length()) == name) { - if (wc || sname.length()==name.length()) { - stateLabelMap.insert(state, label); - } - - } - } - } - - lsmapInSync = true; -} diff --git a/noncore/apps/keyz-cfg/zkb.h b/noncore/apps/keyz-cfg/zkb.h deleted file mode 100644 index deff869..0000000 --- a/noncore/apps/keyz-cfg/zkb.h +++ b/dev/null @@ -1,205 +0,0 @@ -#ifndef ZKB_H -#define ZKB_H - -#include <qstring.h> -#include <qstringlist.h> -#include <qmap.h> -#include <qwindowsystem_qws.h> -#include <qkeyboard_qws.h> -#include <qtimer.h> -#include <stdio.h> - -class State; - -class Action { -protected: - State* state; - ushort keycode; - ushort unicode; - int flags; - - enum { - Shift_Mod = 1, - Ctrl_Mod = 2, - Alt_Mod = 4, - Keypad_Mod = 8, - Mod_Bits = 15, - Press = 16, - Autorepeat = 32, - Event = 64, - Defined = 128, - }; - - void setDefined(bool); - -public: - Action(); - Action(State*, ushort, ushort, int); - ~Action(); - - State* getState() const; - void setState(State*); - - bool hasEvent() const; - void setEvent(bool); - - bool isDefined() const; - - int getKeycode() const; - void setKeycode(int); - - int getUnicode() const; - void setUnicode(int); - - int getModifiers() const; - void setModifiers(int m); - - bool isPressed() const; - void setPressed(bool); - - bool isAutorepeat() const; - void setAutorepeat(bool); -}; - -class State { -protected: - State* parent; - Action* keys; - - enum { - Key_a=0, - Key_b=1, - Key_c=2, - Key_d=3, - Key_e=4, - Key_f=5, - Key_g=6, - Key_h=7, - Key_i=8, - Key_j=9, - Key_k=10, - Key_l=11, - Key_m=12, - Key_n=13, - Key_o=14, - Key_p=15, - Key_q=16, - Key_r=17, - Key_s=18, - Key_t=19, - Key_u=20, - Key_v=21, - Key_w=22, - Key_x=23, - Key_y=24, - Key_z=25, - Key_Comma=26, - Key_Slash=27, - Key_Quote=28, - Key_Dot=29, - Key_Backspace=30, - Key_Space=31, - Key_Enter=32, - Key_LeftShift=33, - Key_RightShift=34, - Key_Fn=35, - Key_Tab=36, - Key_Calendar=37, - Key_Addressbook=38, - Key_Home=39, - Key_Menu=40, - Key_Mail=41, - Key_Cancel=42, - Key_OK=43, - Key_Left=44, - Key_Up=45, - Key_Right=46, - Key_Down=47, - Key_Middle=48, - Key_Off=49, - Key_Light=50, - - Key_Max=51 - }; - - static const short x1[]; - static const short x2[]; - - int translateKeycode(int keycode) const; - -public: - State(State* parent=0); - State(const State&); - ~State(); - - Action* get(int keycode, bool pressed, bool follow = false) const; - bool set(int keycode, bool pressed, Action& action); - - State* getParent() const; - void setParent(State*); -}; - -class Keymap : public QObject, public QWSServer::KeyboardFilter { -Q_OBJECT - -public: - Keymap(); - virtual ~Keymap(); - - virtual bool filter(int unicode, int keycode, int modifiers, - bool isPress, bool autoRepeat); - - void enable(); - void disable(); - - QStringList listStates(); - State* getStateByName(const QString& name); - - QStringList listLabels(); - State* getStateByLabel(const QString& label); - - bool addState(const QString& name, State* state); - bool removeState(const QString& name, bool force = false); - bool setCurrentState(State*); - State* getCurrentState() const; - QString getCurrentLabel(); - - bool addLabel(const QString& label, const QString& state, - int index=-1); - bool removeLabel(const QString& label); - - int getAutorepeatDelay() const; - void setAutorepeatDelay(int); - - int getAutorepeatPeriod() const; - void setAutorepeatPeriod(int); - -signals: - void stateChanged(const QString& name); - -protected slots: - void autoRepeat(); - -protected: - QMap<QString, State*> states; - QMap<QString, QString> labels; - QStringList labelList; - - QMap<State*,QString> stateLabelMap; - bool lsmapInSync; - - bool enabled; - State* currentState; - QString currentStateName; - QString currentLabel; - Action* autoRepeatAction; - - int repeatDelay; - int repeatPeriod; - QTimer repeater; - - QList<Action> findStateUsage(State* s); - void generateLabelStateMaps(); -}; - -#endif diff --git a/noncore/apps/keyz-cfg/zkbcfg.cpp b/noncore/apps/keyz-cfg/zkbcfg.cpp deleted file mode 100644 index 24bd897..0000000 --- a/noncore/apps/keyz-cfg/zkbcfg.cpp +++ b/dev/null @@ -1,231 +0,0 @@ -#include "zkbcfg.h" - -/* OPIE */ -#include <opie2/odebug.h> -using namespace Opie::Core; - -/* QT */ -#include <qfileinfo.h> - -// Implementation of XkbConfig class -ZkbConfig::ZkbConfig(const QString& dir):path(dir) { -} - -ZkbConfig::~ZkbConfig() { -} - -bool ZkbConfig::load(const QString& file, Keymap& keymap, const QString& prefix) { - bool ret; - QFile f(path+"/"+file); - QFileInfo fi(f); - - odebug << "start loading file=" << file.utf8() << "\n" << oendl; - if (includedFiles.find(fi.absFilePath()) != includedFiles.end()) { - return false; - } - - includedFiles.insert(fi.absFilePath(), 1); - QXmlInputSource is(f); - QXmlSimpleReader reader; - ZkbHandler h(*this, keymap, prefix); - - reader.setContentHandler(&h); - reader.setErrorHandler(this); - ret = reader.parse(is); - includedFiles.remove(fi.absFilePath()); - - odebug << "end loading file=" << file.utf8() << ": status=" << err.utf8() << oendl; - return ret; -} - -bool ZkbConfig::warning(const QXmlParseException& e) { - QString tmp; - - tmp.sprintf("%d: warning: %s\n", e.lineNumber(), - (const char*) e.message().utf8()); - - err += tmp; - - return true; -} - -bool ZkbConfig::error(const QXmlParseException& e) { - QString tmp; - - tmp.sprintf("%d: error: %s\n", e.lineNumber(), - (const char*) e.message().utf8()); - - err += tmp; - - return true; -} - -bool ZkbConfig::fatalError(const QXmlParseException& e) { - QString tmp; - - tmp.sprintf("%d: fatal error: %s\n", e.lineNumber(), - (const char*) e.message().utf8()); - - err += tmp; - - return false; -} - -QString ZkbConfig::errorString() { - return err; -} - -// Implementation of ZkbHandler -ZkbHandler::ZkbHandler(ZkbConfig& z, Keymap& k, const QString& p):zkc(z), keymap(k), - prefix(p), ardelay(-1), arperiod(-1), currentState(0), currentAction(0) { -} - -ZkbHandler::~ZkbHandler() { -} - -bool ZkbHandler::startKeymapElement(int ard, int arp, const QString&) { - ardelay = ard; - arperiod = arp; - - return true; -} - -bool ZkbHandler::startIncludeElement(const QString& file, - const QString& pref) { - - QString p = prefix; - - if (!pref.isNull()) { - p += pref + ":"; - } - - - bool ret = zkc.load(file, keymap, p); - if (!ret) { - setError("Error including file: " + file); - } - - return ret; -} - -bool ZkbHandler::startLabelElement(const QString& label, - const QString& state) { - - if (!keymap.addLabel(label, prefix + state)) { - err = "label " + label + " already defined"; - return false; - } - - return true; -} - -bool ZkbHandler::startStateElement(const QString& name, - const QString& parentName, bool dflt) { - - currentStateName = prefix + name; - currentState = keymap.getStateByName(currentStateName); - -// odebug << "state name=" << currentStateName.utf8() << "\n" << oendl; - - State* parent = 0; - if (!parentName.isEmpty()) { - QString pn = prefix + parentName; - parent = keymap.getStateByName(pn); - if (parent == 0) { - err = currentStateName + - ": undefined parent state: " + pn; - return false; - } - } - - if (currentState == 0) { - currentState = new State(parent); - keymap.addState(currentStateName, currentState); - } else { - if (parent!=0) { - currentState->setParent(parent); - } - } - - if (dflt) { - keymap.setCurrentState(currentState); - } - - return true; -} - -bool ZkbHandler::startMapElement(int keycode, bool pressed) { - currentAction = currentState->get(keycode, pressed); - if (currentAction == 0) { - setError("keycode " + QString::number(keycode) + " not supported"); - return false; - } - - currentAction->setEvent(false); - currentAction->setState(0); - - return true; -} - -bool ZkbHandler::startEventElement(int keycode, int unicode, int modifiers, - bool pressed, bool autorepeat) { - - currentAction->setEvent(true); - currentAction->setKeycode(keycode); - currentAction->setUnicode(unicode); - currentAction->setModifiers(modifiers); - currentAction->setPressed(pressed); - currentAction->setAutorepeat(autorepeat); - - return true; -} - -bool ZkbHandler::startNextStateElement(const QString& state) { - State* s = keymap.getStateByName(prefix + state); - if (s == 0) { - setError("undefine state: " + prefix + state); - return false; - } - - currentAction->setState(s); - return true; -} - - -bool ZkbHandler::endKeymapElement() { - if (ardelay > 0) { - keymap.setAutorepeatDelay(ardelay); - } - - if (arperiod > 0) { - keymap.setAutorepeatPeriod(arperiod); - } - - return true; -} - -bool ZkbHandler::endIncludeElement() { - return true; -} - -bool ZkbHandler::endLabelElement() { - return true; -} - -bool ZkbHandler::endStateElement() { - currentState = 0; - return true; -} - -bool ZkbHandler::endMapElement() { - currentAction = 0; - return true; -} - -bool ZkbHandler::endEventElement() { - return true; -} - -bool ZkbHandler::endNextStateElement() { - return true; -} diff --git a/noncore/apps/keyz-cfg/zkbcfg.h b/noncore/apps/keyz-cfg/zkbcfg.h deleted file mode 100644 index dc1ac07..0000000 --- a/noncore/apps/keyz-cfg/zkbcfg.h +++ b/dev/null @@ -1,69 +0,0 @@ -#ifndef ZKBCFG_H -#define ZKBCFG_H - -#include <qxml.h> -#include "zkb.h" -#include "zkbxml.h" - -class ZkbConfig : public QXmlErrorHandler { -public: - ZkbConfig(const QString& dir); - virtual ~ZkbConfig(); - - bool load(const QString& file, Keymap& keymap, const QString& prefix); - - virtual bool warning(const QXmlParseException& e); - virtual bool error(const QXmlParseException& e); - virtual bool fatalError(const QXmlParseException& e); - virtual QString errorString(); - -protected: - QString path; - QMap<QString, int> includedFiles; - QString err; -}; - -class ZkbHandler : public ZkbXmlHandler { -public: - ZkbHandler(ZkbConfig& zkc, Keymap& keymap, const QString& prefix); - virtual ~ZkbHandler(); - -protected: - ZkbConfig& zkc; - Keymap& keymap; - QString prefix; - - // stuff for keymap tag - int ardelay; - int arperiod; - - // stuff for state tag - QString currentStateName; - State* currentState; - - // stuff for map tag - Action* currentAction; - - virtual bool startKeymapElement(int ardelay, int arperiod, - const QString& author); - virtual bool startIncludeElement(const QString& file, - const QString& prfix); - virtual bool startLabelElement(const QString& label, - const QString& state); - virtual bool startStateElement(const QString& name, - const QString& parent, bool dflt); - virtual bool startMapElement(int key, bool pressed); - virtual bool startEventElement(int keycode, int unicode, int modifiers, - bool pressed, bool autorepeat); - virtual bool startNextStateElement(const QString& state); - - virtual bool endKeymapElement(); - virtual bool endIncludeElement(); - virtual bool endLabelElement(); - virtual bool endStateElement(); - virtual bool endMapElement(); - virtual bool endEventElement(); - virtual bool endNextStateElement(); -}; - -#endif diff --git a/noncore/apps/keyz-cfg/zkbnames.cpp b/noncore/apps/keyz-cfg/zkbnames.cpp deleted file mode 100644 index b2180ba..0000000 --- a/noncore/apps/keyz-cfg/zkbnames.cpp +++ b/dev/null @@ -1,446 +0,0 @@ -#include <qmap.h> - -#include "zkbnames.h" - -QString Null_String((const char*) 0); - -// Implementation of KeyNames -static struct { - int key; - char *name; -} Key_Names[] = { - { 32, "Space" }, - { 39, "Apostrophe" }, - { 44, "Comma" }, - { 46, "Period" }, - { 47, "Slash" }, - { 65, "A" }, - { 66, "B" }, - { 67, "C" }, - { 68, "D" }, - { 69, "E" }, - { 70, "F" }, - { 71, "G" }, - { 72, "H" }, - { 73, "I" }, - { 74, "J" }, - { 75, "K" }, - { 76, "L" }, - { 77, "M" }, - { 78, "N" }, - { 79, "O" }, - { 80, "P" }, - { 81, "Q" }, - { 82, "R" }, - { 83, "S" }, - { 84, "T" }, - { 85, "U" }, - { 86, "V" }, - { 87, "W" }, - { 88, "X" }, - { 89, "Y" }, - { 90, "Z" }, - { 4096, "Cancel" }, - { 4097, "Tab" }, - { 4099, "Backspace" }, - { 4100, "Enter" }, - { 4114, "Left" }, - { 4115, "Up" }, - { 4116, "Right" }, - { 4117, "Down" }, - { 4128, "Left Shift" }, - { 4130, "Right Shift" }, - { 4152, "Calendar" }, - { 4153, "Addressbook" }, - { 4154, "Menu" }, - { 4155, "Home" }, - { 4156, "Mail" }, - { 4165, "Fn" }, - { 4173, "Middle" }, - { 4176, "OK" }, - { 4177, "Off" }, - { 4178, "Light" }, - { 0, 0 } -}; - -static QMap<QString, int> kn_map; -static QMap<int, QString> kn_rmap; - -void init_kn_maps() { - int i = 0; - while (Key_Names[i].name != 0) { - int key = Key_Names[i].key; - QString name(Key_Names[i].name); - - kn_map.insert(name, key); - kn_rmap.insert(key, name); - i++; - } -} - -int KeyNames::find(const QString& key) { - if (kn_map.isEmpty()) { - init_kn_maps(); - } - - QMap<QString, int>::Iterator it = kn_map.find(key); - if (it == kn_map.end()) { - return -1; - } else { - return it.data(); - } -} - -const QString& KeyNames::find(int k) { - if (kn_map.isEmpty()) { - init_kn_maps(); - } - - QMap<int, QString>::Iterator it = kn_rmap.find(k); - if (it == kn_rmap.end()) { - return Null_String; - } else { - return it.data(); - } -} - -// Implementation of ModifierNames -struct { - int value; - char* name; -} Modifier_Names[] = { - { 8, "Shift" }, - { 16, "Control" }, - { 32, "Alt" }, - { 0x4000, "Keypad" }, - { 0, 0 } -}; - -static QMap<QString, int> mn_map; -static QMap<int, QString> mn_rmap; - -void init_mn_maps() { - int i = 0; - while (Modifier_Names[i].name != 0) { - int value = Modifier_Names[i].value; - QString name(Modifier_Names[i].name); - - mn_map.insert(name, value); - mn_rmap.insert(value, name); - i++; - } -} - -int ModifierNames::find(const QString& key) { - if (mn_map.isEmpty()) { - init_mn_maps(); - } - - QMap<QString, int>::Iterator it = mn_map.find(key); - if (it == mn_map.end()) { - return -1; - } else { - return it.data(); - } -} - -const QString& ModifierNames::find(int k) { - if (mn_map.isEmpty()) { - init_mn_maps(); - } - - QMap<int, QString>::Iterator it = mn_rmap.find(k); - if (it == mn_rmap.end()) { - return Null_String; - } else { - return it.data(); - } -} - -// Implementation of KeycodeNames - -struct { - char* name; - int keycode; -} Keycode_Names[] = { - { "Escape", 0x1000 }, - { "Tab", 0x1001 }, - { "Backtab", 0x1002 }, - { "Backspace", 0x1003 }, - { "BackSpace", 0x1003 }, - { "Return", 0x1004 }, - { "Enter", 0x1005 }, - { "Insert", 0x1006 }, - { "Delete", 0x1007 }, - { "Pause", 0x1008 }, - { "Print", 0x1009 }, - { "SysReq", 0x100a }, - { "Home", 0x1010 }, - { "End", 0x1011 }, - { "Left", 0x1012 }, - { "Up", 0x1013 }, - { "Right", 0x1014 }, - { "Down", 0x1015 }, - { "Prior", 0x1016 }, - { "PageUp", 0x1016 }, - { "Next", 0x1017 }, - { "PageDown", 0x1017 }, - { "Shift", 0x1020 }, - { "Control", 0x1021 }, - { "Meta", 0x1022 }, - { "Alt", 0x1023 }, - { "CapsLock", 0x1024 }, - { "NumLock", 0x1025 }, - { "ScrollLock", 0x1026 }, - { "F1", 0x1030 }, - { "F2", 0x1031 }, - { "F3", 0x1032 }, - { "F4", 0x1033 }, - { "F5", 0x1034 }, - { "F6", 0x1035 }, - { "F7", 0x1036 }, - { "F8", 0x1037 }, - { "F9", 0x1038 }, - { "F10", 0x1039 }, - { "F11", 0x103a }, - { "F12", 0x103b }, - { "F13", 0x103c }, - { "F14", 0x103d }, - { "F15", 0x103e }, - { "F16", 0x103f }, - { "F17", 0x1040 }, - { "F18", 0x1041 }, - { "F19", 0x1042 }, - { "F20", 0x1043 }, - { "F21", 0x1044 }, - { "F22", 0x1045 }, - { "F23", 0x1046 }, - { "F24", 0x1047 }, - { "F25", 0x1048 }, - { "F26", 0x1049 }, - { "F27", 0x104a }, - { "F28", 0x104b }, - { "F29", 0x104c }, - { "F30", 0x104d }, - { "F31", 0x104e }, - { "F32", 0x104f }, - { "F33", 0x1050 }, - { "F34", 0x1051 }, - { "F35", 0x1052 }, - { "Super_L", 0x1053 }, - { "Super_R", 0x1054 }, - { "Menu", 0x1055 }, - { "Hyper_L", 0x1056 }, - { "Hyper_R", 0x1057 }, - { "Help", 0x1058 }, - { "Space", 0x20 }, - { "Any", 0x20 }, - { "Exclam", 0x21 }, - { "QuoteDbl", 0x22 }, - { "NumberSign", 0x23 }, - { "Dollar", 0x24 }, - { "Percent", 0x25 }, - { "Ampersand", 0x26 }, - { "Apostrophe", 0x27 }, - { "ParenLeft", 0x28 }, - { "ParenRight", 0x29 }, - { "Asterisk", 0x2a }, - { "Plus", 0x2b }, - { "Comma", 0x2c }, - { "Minus", 0x2d }, - { "Period", 0x2e }, - { "Slash", 0x2f }, - { "0", 0x30 }, - { "1", 0x31 }, - { "2", 0x32 }, - { "3", 0x33 }, - { "4", 0x34 }, - { "5", 0x35 }, - { "6", 0x36 }, - { "7", 0x37 }, - { "8", 0x38 }, - { "9", 0x39 }, - { "Colon", 0x3a }, - { "Semicolon", 0x3b }, - { "Less", 0x3c }, - { "Equal", 0x3d }, - { "Greater", 0x3e }, - { "Question", 0x3f }, - { "At", 0x40 }, - { "A", 0x41 }, - { "B", 0x42 }, - { "C", 0x43 }, - { "D", 0x44 }, - { "E", 0x45 }, - { "F", 0x46 }, - { "G", 0x47 }, - { "H", 0x48 }, - { "I", 0x49 }, - { "J", 0x4a }, - { "K", 0x4b }, - { "L", 0x4c }, - { "M", 0x4d }, - { "N", 0x4e }, - { "O", 0x4f }, - { "P", 0x50 }, - { "Q", 0x51 }, - { "R", 0x52 }, - { "S", 0x53 }, - { "T", 0x54 }, - { "U", 0x55 }, - { "V", 0x56 }, - { "W", 0x57 }, - { "X", 0x58 }, - { "Y", 0x59 }, - { "Z", 0x5a }, - { "BracketLeft", 0x5b }, - { "Backslash", 0x5c }, - { "BracketRight", 0x5d }, - { "AsciiCircum", 0x5e }, - { "Underscore", 0x5f }, - { "QuoteLeft", 0x60 }, - { "BraceLeft", 0x7b }, - { "Bar", 0x7c }, - { "BraceRight", 0x7d }, - { "AsciiTilde", 0x7e }, - { "nobreakspace", 0x0a0 }, - { "exclamdown", 0x0a1 }, - { "cent", 0x0a2 }, - { "sterling", 0x0a3 }, - { "currency", 0x0a4 }, - { "yen", 0x0a5 }, - { "brokenbar", 0x0a6 }, - { "section", 0x0a7 }, - { "diaeresis", 0x0a8 }, - { "copyright", 0x0a9 }, - { "ordfeminine", 0x0aa }, - { "guillemotleft", 0x0ab }, - { "notsign", 0x0ac }, - { "hyphen", 0x0ad }, - { "registered", 0x0ae }, - { "macron", 0x0af }, - { "degree", 0x0b0 }, - { "plusminus", 0x0b1 }, - { "twosuperior", 0x0b2 }, - { "threesuperior", 0x0b3 }, - { "acute", 0x0b4 }, - { "mu", 0x0b5 }, - { "paragraph", 0x0b6 }, - { "periodcentered", 0x0b7 }, - { "cedilla", 0x0b8 }, - { "onesuperior", 0x0b9 }, - { "masculine", 0x0ba }, - { "guillemotright", 0x0bb }, - { "onequarter", 0x0bc }, - { "onehalf", 0x0bd }, - { "threequarters", 0x0be }, - { "questiondown", 0x0bf }, - { "Agrave", 0x0c0 }, - { "Aacute", 0x0c1 }, - { "Acircumflex", 0x0c2 }, - { "Atilde", 0x0c3 }, - { "Adiaeresis", 0x0c4 }, - { "Aring", 0x0c5 }, - { "AE", 0x0c6 }, - { "Ccedilla", 0x0c7 }, - { "Egrave", 0x0c8 }, - { "Eacute", 0x0c9 }, - { "Ecircumflex", 0x0ca }, - { "Ediaeresis", 0x0cb }, - { "Igrave", 0x0cc }, - { "Iacute", 0x0cd }, - { "Icircumflex", 0x0ce }, - { "Idiaeresis", 0x0cf }, - { "ETH", 0x0d0 }, - { "Ntilde", 0x0d1 }, - { "Ograve", 0x0d2 }, - { "Oacute", 0x0d3 }, - { "Ocircumflex", 0x0d4 }, - { "Otilde", 0x0d5 }, - { "Odiaeresis", 0x0d6 }, - { "multiply", 0x0d7 }, - { "Ooblique", 0x0d8 }, - { "Ugrave", 0x0d9 }, - { "Uacute", 0x0da }, - { "Ucircumflex", 0x0db }, - { "Udiaeresis", 0x0dc }, - { "Yacute", 0x0dd }, - { "THORN", 0x0de }, - { "ssharp", 0x0df }, - { "agrave", 0x0e0 }, - { "aacute", 0x0e1 }, - { "acircumflex", 0x0e2 }, - { "atilde", 0x0e3 }, - { "adiaeresis", 0x0e4 }, - { "aring", 0x0e5 }, - { "ae", 0x0e6 }, - { "ccedilla", 0x0e7 }, - { "egrave", 0x0e8 }, - { "eacute", 0x0e9 }, - { "ecircumflex", 0x0ea }, - { "ediaeresis", 0x0eb }, - { "igrave", 0x0ec }, - { "iacute", 0x0ed }, - { "icircumflex", 0x0ee }, - { "idiaeresis", 0x0ef }, - { "eth", 0x0f0 }, - { "ntilde", 0x0f1 }, - { "ograve", 0x0f2 }, - { "oacute", 0x0f3 }, - { "ocircumflex", 0x0f4 }, - { "otilde", 0x0f5 }, - { "odiaeresis", 0x0f6 }, - { "division", 0x0f7 }, - { "oslash", 0x0f8 }, - { "ugrave", 0x0f9 }, - { "uacute", 0x0fa }, - { "ucircumflex", 0x0fb }, - { "udiaeresis", 0x0fc }, - { "yacute", 0x0fd }, - { "thorn", 0x0fe }, - { "ydiaeresis", 0x0ff }, - { "unknown", 0xffff }, - { 0, 0} -}; - -static QMap<QString, int> kcn_map; -static QMap<int, QString> kcn_rmap; - -void init_kcn_maps() { - int i = 0; - while (Keycode_Names[i].name != 0) { - int keycode = Keycode_Names[i].keycode; - QString name(Keycode_Names[i].name); - - kcn_map.insert(name, keycode); - kcn_rmap.insert(keycode, name); - i++; - } -} - -int KeycodeNames::find(const QString& key) { - if (kcn_map.isEmpty()) { - init_kcn_maps(); - } - - QMap<QString, int>::Iterator it = kcn_map.find(key); - if (it == kcn_map.end()) { - return -1; - } else { - return it.data(); - } -} - -const QString& KeycodeNames::find(int k) { - if (kcn_map.isEmpty()) { - init_kcn_maps(); - } - - QMap<int, QString>::Iterator it = kcn_rmap.find(k); - if (it == kcn_rmap.end()) { - return Null_String; - } else { - return it.data(); - } -} - diff --git a/noncore/apps/keyz-cfg/zkbnames.h b/noncore/apps/keyz-cfg/zkbnames.h deleted file mode 100644 index 0d1e7f5..0000000 --- a/noncore/apps/keyz-cfg/zkbnames.h +++ b/dev/null @@ -1,23 +0,0 @@ -#ifndef ZKBNAMES_H -#define ZKBNAMES_H - -#include <qstring.h> - -class KeyNames { -public: - static int find(const QString& key); - static const QString& find(int); -}; - -class KeycodeNames { -public: - static int find(const QString& key); - static const QString& find(int); -}; - -class ModifierNames { -public: - static int find(const QString& key); - static const QString& find(int); -}; -#endif diff --git a/noncore/apps/keyz-cfg/zkbxml.cpp b/noncore/apps/keyz-cfg/zkbxml.cpp deleted file mode 100644 index 5b0084c..0000000 --- a/noncore/apps/keyz-cfg/zkbxml.cpp +++ b/dev/null @@ -1,573 +0,0 @@ -#include "zkbxml.h" -#include "zkbnames.h" - -static QString Keymap_Tag("keymap"); -static QString Include_Tag("include"); -static QString Label_Tag("label"); -static QString State_Tag("state"); -static QString Map_Tag("map"); -static QString Event_Tag("event"); -static QString NextState_Tag("next-state"); - -ZkbXmlHandler::ZkbXmlHandler() { -} - -ZkbXmlHandler::~ZkbXmlHandler() { -} - -bool ZkbXmlHandler::startElement(const QString&, const QString&, - const QString& name, const QXmlAttributes& attr) { - - bool ret = false; - - if (name == Keymap_Tag) { - ret = start_keymap(attr); - } else if (name == Include_Tag) { - ret = start_include(attr); - } else if (name == Label_Tag) { - ret = start_label(attr); - } else if (name == State_Tag) { - ret = start_state(attr); - } else if (name == Map_Tag) { - ret = start_map(attr); - } else if (name == Event_Tag) { - ret = start_event(attr); - } else if (name == NextState_Tag) { - ret = start_next_state(attr); - } - - elements.prepend(name); - - return ret; -} - -bool ZkbXmlHandler::endElement(const QString&, const QString&, - const QString& name) { - - bool ret = false; - - elements.remove(elements.begin()); - - if (name == Keymap_Tag) { - ret = end_keymap(); - } else if (name == Include_Tag) { - ret = end_include(); - } else if (name == Label_Tag) { - ret = end_label(); - } else if (name == State_Tag) { - ret = end_state(); - } else if (name == Map_Tag) { - ret = end_map(); - } else if (name == Event_Tag) { - ret = end_event(); - } else if (name == NextState_Tag) { - ret = end_next_state(); - } - - return ret; -} - -QString ZkbXmlHandler::errorString() { - return err; -} - -bool ZkbXmlHandler::startKeymapElement(int ardelay, int arperiod, const QString& author) { - return false; -} - -bool ZkbXmlHandler::startIncludeElement(const QString& file, - const QString& prefix) { - - return false; -} - -bool ZkbXmlHandler::startLabelElement(const QString& label, - const QString& state) { - - return false; -} - -bool ZkbXmlHandler::startStateElement(const QString& name, - const QString& parent, bool dflt) { - - return false; -} - -bool ZkbXmlHandler::startMapElement(int keycode, bool pressed) { - return false; -} - -bool ZkbXmlHandler::startEventElement(int keycode, int unicode, int modifiers, - bool pressed, bool autorepeat) { - - return false; -} - -bool ZkbXmlHandler::startNextStateElement(const QString& state) { - return false; -} - - -bool ZkbXmlHandler::endKeymapElement() { - return false; -} - -bool ZkbXmlHandler::endIncludeElement() { - return false; -} - -bool ZkbXmlHandler::endLabelElement() { - return false; -} - -bool ZkbXmlHandler::endStateElement() { - return false; -} - -bool ZkbXmlHandler::endMapElement() { - return false; -} - -bool ZkbXmlHandler::endEventElement() { - return false; -} - -bool ZkbXmlHandler::endNextStateElement() { - return false; -} - - -bool ZkbXmlHandler::start_keymap(const QXmlAttributes& attr) { - int nattr = 0; - int didx = attr.index("autorepeat-delay"); - int pidx = attr.index("autorepeat-period"); - int aidx = attr.index("author"); - int ard = -1; - int arp = -1; - QString author; - - if (!elements.isEmpty()) { - setError("keymap element should be top-level element"); - return false; - } - - if (didx >= 0) { - QString s = attr.value(didx); - bool ok; - - ard = s.toInt(&ok); - if (!ok) { - setError("Invalid autorepeat-delay value: " + s); - return false; - } - - nattr++; - } - - if (pidx >= 0) { - QString s = attr.value(pidx); - bool ok; - - arp = s.toInt(&ok); - if (!ok) { - setError("Invalid autorepeat-period value: " + s); - return false; - } - - nattr++; - } - - if (aidx >= 0) { - author = attr.value(aidx); - nattr++; - } - - if (attr.length() > nattr) { - setError("Unsupported attributes"); - return false; - } - - return startKeymapElement(ard, arp, author); -} - -bool ZkbXmlHandler::start_include(const QXmlAttributes& attr) { - int nattr = 0; - int fidx = attr.index("file"); - int pidx = attr.index("prefix"); - QString file; - QString prefix((const char*) 0); - - if (elements.first() != Keymap_Tag) { - setError("include element should be used only " - "within keymap element"); - return false; - } - - if (fidx >= 0) { - file = attr.value(fidx); - nattr++; - } else { - setError("Missing file attribute"); - return false; - } - - if (pidx >= 0) { - prefix = attr.value(pidx); - nattr++; - } - - if (attr.length() > nattr) { - setError("Unsupported attributes"); - return false; - } - - return startIncludeElement(file, prefix); -} - -bool ZkbXmlHandler::start_label(const QXmlAttributes& attr) { - int nattr = 0; - int nidx = attr.index("name"); - int sidx = attr.index("state"); - QString name; - QString state; - - if (elements.first() != Keymap_Tag) { - setError("label element should be used only " - "within keymap element"); - return false; - } - - if (nidx >= 0) { - name = attr.value(nidx); - nattr++; - } else { - setError("Missing name attribute"); - return false; - } - - if (sidx >= 0) { - state = attr.value(sidx); - nattr++; - } else { - setError("Missing name attribute"); - return false; - } - - if (attr.length() > nattr) { - setError("Unsupported attributes"); - return false; - } - - return startLabelElement(name, state); -} - -bool ZkbXmlHandler::start_state(const QXmlAttributes& attr) { - int nattr = 0; - int nidx = attr.index("name"); - int pidx = attr.index("parent"); - int didx = attr.index("default"); - QString name; - QString parent((const char*) 0); - bool dflt = false; - - if (elements.first() != Keymap_Tag) { - setError("state element should be used only " - "within keymap element"); - return false; - } - - if (nidx >= 0) { - name = attr.value(nidx); - nattr++; - } else { - setError("Missing name attribute"); - return false; - } - - if (pidx >= 0) { - parent = attr.value(pidx); - nattr++; - } - - if (didx >= 0) { - dflt = str2bool(attr.value(didx)); - if (!err.isEmpty()) { - return false; - } - - nattr++; - } - - if (attr.length() > nattr) { - setError("Unsupported attributes"); - return false; - } - - return startStateElement(name, parent, dflt); -} - -bool ZkbXmlHandler::start_map(const QXmlAttributes& attr) { - int nattr = 0; - int kidx = attr.index("keycode"); - int pidx = attr.index("pressed"); - int key; - bool pressed; - - if (elements.first() != State_Tag) { - setError("map element should be used only " - "within state element"); - return false; - } - - if (kidx >= 0) { - key = str2key(attr.value(kidx)); - if (!err.isEmpty()) { - return false; - } - nattr++; - } else { - setError("Missing keycode attribute"); - return false; - } - - if (pidx >= 0) { - pressed = str2bool(attr.value(pidx)); - if (!err.isEmpty()) { - return false; - } - nattr++; - } else { - setError("Missing pressed attribute"); - return false; - } - - if (attr.length() > nattr) { - setError("Unsupported attributes"); - return false; - } - - return startMapElement(key, pressed); -} - -bool ZkbXmlHandler::start_event(const QXmlAttributes& attr) { - int nattr = 0; - int kidx = attr.index("keycode"); - int pidx = attr.index("pressed"); - int uidx = attr.index("unicode"); - int midx = attr.index("modifiers"); - int aidx = attr.index("autorepeat"); - - int keycode; - int unicode; - int modifiers = 0; - bool pressed; - bool autorepeat = false; - - if (elements.first() != Map_Tag) { - setError("event element should be used only " - "within map element"); - return false; - } - - if (kidx >= 0) { - keycode = str2keycode(attr.value(kidx)); - if (!err.isEmpty()) { - return false; - } - nattr++; - } else { - setError("Missing keycode attribute"); - return false; - } - - if (uidx >= 0) { - unicode = str2unicode(attr.value(uidx)); - if (!err.isEmpty()) { - return false; - } - nattr++; - } else { - setError("Missing unicode attribute"); - return false; - } - - if (midx >= 0) { - modifiers = str2modifier(attr.value(midx)); - if (!err.isEmpty()) { - return false; - } - nattr++; - } - - if (pidx >= 0) { - pressed = str2bool(attr.value(pidx)); - if (!err.isEmpty()) { - return false; - } - nattr++; - } else { - setError("Missing pressed attribute"); - return false; - } - - if (aidx >= 0) { - autorepeat = str2bool(attr.value(aidx)); - if (!err.isEmpty()) { - return false; - } - nattr++; - } - - if (attr.length() > nattr) { - setError("Unsupported attributes"); - return false; - } - - return startEventElement(keycode, unicode, modifiers, pressed, - autorepeat); -} - -bool ZkbXmlHandler::start_next_state(const QXmlAttributes& attr) { - int nattr = 0; - int nidx = attr.index("name"); - QString name; - - if (elements.first() != Map_Tag) { - setError("next-state element should be used only " - "within map element"); - return false; - } - - if (nidx >= 0) { - name = attr.value(nidx); - nattr++; - } else { - setError("Missing name attribute"); - return false; - } - - if (attr.length() > nattr) { - setError("Unsupported attributes"); - return false; - } - - return startNextStateElement(name); -} - -bool ZkbXmlHandler::end_keymap() { - return endKeymapElement(); -} - -bool ZkbXmlHandler::end_include() { - return endIncludeElement(); -} - -bool ZkbXmlHandler::end_label() { - return endLabelElement(); -} - -bool ZkbXmlHandler::end_state() { - return endStateElement(); -} - -bool ZkbXmlHandler::end_map() { - return endMapElement(); -} - -bool ZkbXmlHandler::end_event() { - return endEventElement(); -} - -bool ZkbXmlHandler::end_next_state() { - return endNextStateElement(); -} - -void ZkbXmlHandler::setError(const QString& e) { - err = e; -} - -int ZkbXmlHandler::str2key(const QString& s) { - int ret; - - ret = KeyNames::find(s); - if (ret == -1) { - setError("Invalid value: " + s); - } - - return ret; -} - -int ZkbXmlHandler::str2modifier(const QString& val) { - int ret; - - int n, i; - ret = 0; - n = 0; - do { - i = val.find('|', n); - if (i < 0) { - i = val.length(); - } - - QString s = val.mid(n, i - n); - int v = ModifierNames::find(s.stripWhiteSpace()); - - if (v == -1) { - setError("Invalid value: " + val); - return -1; - } - - ret |= v; - n = i + 1; - } while (n < val.length()); - - return ret; -} - -bool ZkbXmlHandler::str2bool(const QString& s) { - if (s == "true") { - return true; - } else { - return false; - } -} - -int ZkbXmlHandler::str2unicode(const QString& s) { - return str2uint(s); -} - -int ZkbXmlHandler::str2keycode(const QString& s) { - int ret; - - ret = KeycodeNames::find(s); - if (ret == -1) { - setError("Invalid value: " + s); - } - - return ret; -} - -int ZkbXmlHandler::str2uint(const QString& s) { - int ret; - bool ok; - QString val = s; - int r; - - if (val.left(2) == "0x") { - val = s.mid(2); - r = 16; - } else if (val.left(1) == "0") { - val = s.mid(1); - r = 8; - } else { - r = 10; - } - - ret = val.toInt(&ok, r); - if (!ok) { - setError("Invalid value: " + s); - ret = -1; - } - - return ret; -} diff --git a/noncore/apps/keyz-cfg/zkbxml.h b/noncore/apps/keyz-cfg/zkbxml.h deleted file mode 100644 index 2b15cbb..0000000 --- a/noncore/apps/keyz-cfg/zkbxml.h +++ b/dev/null @@ -1,68 +0,0 @@ -#ifndef ZKBXML_H -#define ZKBXML_H - -#include <qxml.h> - -class ZkbXmlHandler : public QXmlDefaultHandler { -public: - ZkbXmlHandler(); - virtual ~ZkbXmlHandler(); - - virtual bool startElement(const QString&, const QString&, - const QString& name, const QXmlAttributes& attr); - - virtual bool endElement(const QString&, const QString&, - const QString& name); - - virtual QString errorString(); - -protected: - QString err; - QStringList elements; - - virtual bool startKeymapElement(int ardelay, int arperiod, - const QString& author); - virtual bool startIncludeElement(const QString& file, - const QString& prfix); - virtual bool startLabelElement(const QString& label, - const QString& state); - virtual bool startStateElement(const QString& name, - const QString& parent, bool dflt); - virtual bool startMapElement(int key, bool pressed); - virtual bool startEventElement(int keycode, int unicode, int modifiers, - bool pressed, bool autorepeat); - virtual bool startNextStateElement(const QString& state); - - virtual bool endKeymapElement(); - virtual bool endIncludeElement(); - virtual bool endLabelElement(); - virtual bool endStateElement(); - virtual bool endMapElement(); - virtual bool endEventElement(); - virtual bool endNextStateElement(); - - bool start_keymap(const QXmlAttributes&); - bool start_include(const QXmlAttributes&); - bool start_label(const QXmlAttributes&); - bool start_state(const QXmlAttributes&); - bool start_map(const QXmlAttributes&); - bool start_event(const QXmlAttributes&); - bool start_next_state(const QXmlAttributes&); - bool end_keymap(); - bool end_include(); - bool end_label(); - bool end_state(); - bool end_map(); - bool end_event(); - bool end_next_state(); - - void setError(const QString&); - int str2key(const QString&); - int str2modifier(const QString&); - bool str2bool(const QString&); - int str2unicode(const QString&); - int str2keycode(const QString&); - int str2uint(const QString&); -}; - -#endif |