Added some unicode escaping routines for later
This commit is contained in:
parent
fb956d9141
commit
1f7d6a9f3a
@ -1,5 +1,7 @@
|
|||||||
#include "TransmitTextEdit.h"
|
#include "TransmitTextEdit.h"
|
||||||
|
|
||||||
|
#include "varicode.h"
|
||||||
|
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
|
|
||||||
@ -243,9 +245,14 @@ void TransmitTextEdit::on_textContentsChanged(int /*pos*/, int rem, int add){
|
|||||||
}
|
}
|
||||||
|
|
||||||
QString normalized = text.normalized(QString::NormalizationForm_KD);
|
QString normalized = text.normalized(QString::NormalizationForm_KD);
|
||||||
|
|
||||||
QString result;
|
QString result;
|
||||||
std::copy_if(normalized.begin(), normalized.end(), std::back_inserter(result), [](QChar& c) {
|
std::copy_if(normalized.begin(), normalized.end(), std::back_inserter(result), [](QChar& c) {
|
||||||
|
#if JS8_ALLOW_UNICODE
|
||||||
|
return (c == 10 || c == 0x1A || (c > 31 && c < 128)) || c.isPrint());
|
||||||
|
#else
|
||||||
return c.toLatin1() != 0 && (c == 10 || c == 0x1A || (c > 31 && c < 128));
|
return c.toLatin1() != 0 && (c == 10 || c == 0x1A || (c > 31 && c < 128));
|
||||||
|
#endif
|
||||||
});
|
});
|
||||||
|
|
||||||
if(result != text){
|
if(result != text){
|
||||||
|
37
varicode.cpp
37
varicode.cpp
@ -336,13 +336,42 @@ int dbmTomwatts(int dbm){
|
|||||||
}
|
}
|
||||||
|
|
||||||
QString Varicode::escape(const QString &text){
|
QString Varicode::escape(const QString &text){
|
||||||
// TODO: support different escapes?
|
static const int size = 6;
|
||||||
return text;
|
QString escaped;
|
||||||
|
escaped.reserve(size * text.size());
|
||||||
|
for(QString::const_iterator it = text.begin(); it != text.end(); ++it){
|
||||||
|
QChar ch = *it;
|
||||||
|
ushort code = ch.unicode();
|
||||||
|
if (code < 0x80) {
|
||||||
|
escaped += ch;
|
||||||
|
} else {
|
||||||
|
#if JS8_USE_ESCAPE_SUB_CHAR
|
||||||
|
//escaped += "\x1A"; // substitute char
|
||||||
|
#else
|
||||||
|
escaped += "\\U"; // "U+"; // substitute char
|
||||||
|
#endif
|
||||||
|
escaped += QString::number(code, 16).rightJustified(4, '0');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return escaped;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString Varicode::unescape(const QString &text){
|
QString Varicode::unescape(const QString &text){
|
||||||
// TODO: support different escapes?
|
QString unescaped(text);
|
||||||
return text;
|
#if JS8_USE_ESCAPE_SUB_CHAR
|
||||||
|
static const int size = 5;
|
||||||
|
QRegExp r("([\\x1A][0-9a-fA-F]{4})");
|
||||||
|
#else
|
||||||
|
static const int size = 6;
|
||||||
|
QRegExp r("(([uU][+]|\\\\[uU])[0-9a-fA-F]{4})");
|
||||||
|
#endif
|
||||||
|
int pos = 0;
|
||||||
|
while ((pos = r.indexIn(unescaped, pos)) != -1) {
|
||||||
|
unescaped.replace(pos++, size, QChar(r.cap(1).right(4).toUShort(0, 16)));
|
||||||
|
}
|
||||||
|
|
||||||
|
return unescaped;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString Varicode::rstrip(const QString& str) {
|
QString Varicode::rstrip(const QString& str) {
|
||||||
|
Loading…
Reference in New Issue
Block a user