mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-11-14 15:05:56 +00:00
897436efbb
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@18550 a592a061-630c-0410-9148-cb99ea01b6c8
203 lines
4.0 KiB
C++
203 lines
4.0 KiB
C++
/**
|
|
* \file QKeySymbol.cpp
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author Asger and Jürgen
|
|
* \author John Levon
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#include <config.h>
|
|
|
|
#include "QKeySymbol.h"
|
|
#include "qlkey.h"
|
|
#include "qt_helpers.h"
|
|
|
|
|
|
#include "debug.h"
|
|
|
|
#include <QKeyEvent>
|
|
#include <QKeySequence>
|
|
#include <QEvent>
|
|
#include <QTextCodec>
|
|
|
|
#include <map>
|
|
#include "support/lstrings.h"
|
|
#include "support/environment.h"
|
|
#include "support/unicode.h"
|
|
|
|
#include "Encoding.h"
|
|
#include "Language.h"
|
|
|
|
|
|
namespace lyx {
|
|
|
|
using std::endl;
|
|
using std::string;
|
|
using std::map;
|
|
using lyx::support::contains;
|
|
using lyx::support::getEnv;
|
|
|
|
|
|
namespace {
|
|
|
|
typedef map<string, QTextCodec *> EncodingMap;
|
|
EncodingMap encoding_map;
|
|
|
|
char const encode(string const & encoding, QString const & str)
|
|
{
|
|
QTextCodec * codec = 0;
|
|
|
|
EncodingMap::const_iterator cit = encoding_map.find(encoding);
|
|
if (cit == encoding_map.end()) {
|
|
LYXERR(Debug::KEY) << "Unrecognised encoding '" << encoding
|
|
<< "'." << endl;
|
|
codec = encoding_map.find("")->second;
|
|
} else {
|
|
codec = cit->second;
|
|
}
|
|
|
|
if (!codec) {
|
|
LYXERR(Debug::KEY) << "No codec for encoding '" << encoding
|
|
<< "' found." << endl;
|
|
return 0;
|
|
}
|
|
|
|
LYXERR(Debug::KEY) << "Using codec " << fromqstr(codec->name()) << endl;
|
|
|
|
if (!codec->canEncode(str)) {
|
|
LYXERR(Debug::KEY) << "Oof. Can't encode the text !" << endl;
|
|
return 0;
|
|
}
|
|
|
|
return codec->fromUnicode(str).data()[0];
|
|
}
|
|
|
|
}
|
|
|
|
|
|
QKeySymbol::QKeySymbol()
|
|
: KeySymbol(), key_(0)
|
|
{
|
|
}
|
|
|
|
|
|
void QKeySymbol::set(QKeyEvent * ev)
|
|
{
|
|
key_ = ev->key();
|
|
if (ev->text().isNull()) {
|
|
LYXERR(Debug::KEY) << "keyevent has isNull() text !" << endl;
|
|
text_ = "";
|
|
return;
|
|
}
|
|
text_ = ev->text();
|
|
LYXERR(Debug::KEY) << "Setting key to " << key_ << ", " << fromqstr(text_) << endl;
|
|
}
|
|
|
|
|
|
void QKeySymbol::init(string const & symbolname)
|
|
{
|
|
key_ = string_to_qkey(symbolname);
|
|
text_ = toqstr(symbolname);
|
|
LYXERR(Debug::KEY) << "Init key to " << key_ << ", " << fromqstr(text_) << endl;
|
|
}
|
|
|
|
|
|
bool QKeySymbol::isOK() const
|
|
{
|
|
bool const ok(!(text_.isEmpty() && key_ == Qt::Key_unknown));
|
|
LYXERR(Debug::KEY) << "isOK is " << ok << endl;
|
|
return ok;
|
|
}
|
|
|
|
|
|
bool QKeySymbol::isModifier() const
|
|
{
|
|
bool const mod(q_is_modifier(key_));
|
|
LYXERR(Debug::KEY) << "isMod is " << mod << endl;
|
|
return mod;
|
|
}
|
|
|
|
|
|
string QKeySymbol::getSymbolName() const
|
|
{
|
|
string sym(qkey_to_string(key_));
|
|
|
|
// e.g. A-Za-z, and others
|
|
if (sym.empty())
|
|
sym = fromqstr(text_);
|
|
|
|
return sym;
|
|
}
|
|
|
|
|
|
char_type QKeySymbol::getUCSEncoded() const
|
|
{
|
|
if (text_.isEmpty())
|
|
return 0;
|
|
|
|
// UTF16 has a maximum of two characters.
|
|
BOOST_ASSERT(text_.size() <= 2);
|
|
|
|
if (lyxerr.debugging() && text_.size() > 1) {
|
|
// We don't know yet how well support the full ucs4 range.
|
|
LYXERR(Debug::KEY) << "QKeySymbol::getUCSEncoded()" << endl;
|
|
for (int i = 0; i < text_.size(); ++i) {
|
|
LYXERR(Debug::KEY) << "char " << i << ": "
|
|
<< text_[i].unicode() << endl;
|
|
}
|
|
}
|
|
|
|
// Only one UCS4 character at the end.
|
|
docstring ucs4_text = qstring_to_ucs4(text_);
|
|
return ucs4_text[0];
|
|
}
|
|
|
|
|
|
docstring const QKeySymbol::print(key_modifier::state mod, bool forgui) const
|
|
{
|
|
int tmpkey = key_;
|
|
|
|
if (mod & key_modifier::shift)
|
|
tmpkey += Qt::SHIFT;
|
|
if (mod & key_modifier::ctrl)
|
|
tmpkey += Qt::CTRL;
|
|
if (mod & key_modifier::alt)
|
|
tmpkey += Qt::ALT;
|
|
|
|
QKeySequence seq(tmpkey);
|
|
|
|
return qstring_to_ucs4(seq.toString(forgui ? QKeySequence::NativeText
|
|
: QKeySequence::PortableText));
|
|
}
|
|
|
|
|
|
bool QKeySymbol::isText() const
|
|
{
|
|
if (text_.isEmpty()) {
|
|
LYXERR(Debug::KEY) << "text_ empty, isText() == false" << endl;
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
|
|
bool QKeySymbol::operator==(KeySymbol const & ks) const
|
|
{
|
|
QKeySymbol const & qks = static_cast<QKeySymbol const &>(ks);
|
|
|
|
// we do not have enough info for a fair comparison, so return
|
|
// false. This works out OK because unknown text from Qt will
|
|
// get inserted anyway after the isText() check
|
|
if (key_ == Qt::Key_unknown || qks.key_ == Qt::Key_unknown)
|
|
return false;
|
|
|
|
return key_ == qks.key_;
|
|
}
|
|
|
|
|
|
} // namespace lyx
|