Correctly define standard XA_FOO atoms

This commit is contained in:
Lars Knoll 2011-05-22 23:50:32 +02:00
parent 1b1142b305
commit 28ab03741e
4 changed files with 24 additions and 22 deletions

View File

@ -583,12 +583,9 @@ static const char * xcb_atomnames = {
"_NET_ACTIVE_WINDOW\0" "_NET_ACTIVE_WINDOW\0"
// Property formats // Property formats
"XA_STRING\0"
"COMPOUND_TEXT\0" "COMPOUND_TEXT\0"
"TEXT\0" "TEXT\0"
"UTF8_STRING\0" "UTF8_STRING\0"
"XA_PIXMAP\0"
"XA_BITMAP\0"
// xdnd // xdnd
"XdndEnter\0" "XdndEnter\0"

View File

@ -57,6 +57,12 @@ class QXcbWindow;
typedef QHash<xcb_window_t, QXcbWindow *> WindowMapper; typedef QHash<xcb_window_t, QXcbWindow *> WindowMapper;
namespace QXcbAtom { namespace QXcbAtom {
static const xcb_atom_t XA_PRIMARY = 1;
static const xcb_atom_t XA_SECONDARY = 2;
static const xcb_atom_t XA_PIXMAP = 20;
static const xcb_atom_t XA_BITMAP = 5;
static const xcb_atom_t XA_STRING = 32;
enum Atom { enum Atom {
// window-manager <-> client protocols // window-manager <-> client protocols
WM_PROTOCOLS, WM_PROTOCOLS,
@ -164,12 +170,9 @@ namespace QXcbAtom {
_NET_ACTIVE_WINDOW, _NET_ACTIVE_WINDOW,
// Property formats // Property formats
XA_STRING,
COMPOUND_TEXT, COMPOUND_TEXT,
TEXT, TEXT,
UTF8_STRING, UTF8_STRING,
XA_PIXMAP,
XA_BITMAP,
// Xdnd // Xdnd
XdndEnter, XdndEnter,

View File

@ -66,14 +66,14 @@ QString QXcbMime::mimeAtomToString(QXcbConnection *connection, xcb_atom_t a)
return 0; return 0;
// special cases for string type // special cases for string type
if (a == connection->atom(QXcbAtom::XA_STRING) if (a == QXcbAtom::XA_STRING
|| a == connection->atom(QXcbAtom::UTF8_STRING) || a == connection->atom(QXcbAtom::UTF8_STRING)
|| a == connection->atom(QXcbAtom::TEXT) || a == connection->atom(QXcbAtom::TEXT)
|| a == connection->atom(QXcbAtom::COMPOUND_TEXT)) || a == connection->atom(QXcbAtom::COMPOUND_TEXT))
return QLatin1String("text/plain"); return QLatin1String("text/plain");
// special case for images // special case for images
if (a == connection->atom(QXcbAtom::XA_PIXMAP)) if (a == QXcbAtom::XA_PIXMAP)
return QLatin1String("image/ppm"); return QLatin1String("image/ppm");
QByteArray atomName = connection->atomName(a); QByteArray atomName = connection->atomName(a);
@ -96,14 +96,14 @@ bool QXcbMime::mimeDataForAtom(QXcbConnection *connection, xcb_atom_t a, QMimeDa
*dataFormat = 8; *dataFormat = 8;
if ((a == connection->atom(QXcbAtom::UTF8_STRING) if ((a == connection->atom(QXcbAtom::UTF8_STRING)
|| a == connection->atom(QXcbAtom::XA_STRING) || a == QXcbAtom::XA_STRING
|| a == connection->atom(QXcbAtom::TEXT) || a == connection->atom(QXcbAtom::TEXT)
|| a == connection->atom(QXcbAtom::COMPOUND_TEXT)) || a == connection->atom(QXcbAtom::COMPOUND_TEXT))
&& QInternalMimeData::hasFormatHelper(QLatin1String("text/plain"), mimeData)) { && QInternalMimeData::hasFormatHelper(QLatin1String("text/plain"), mimeData)) {
if (a == connection->atom(QXcbAtom::UTF8_STRING)){ if (a == connection->atom(QXcbAtom::UTF8_STRING)){
*data = QInternalMimeData::renderDataHelper(QLatin1String("text/plain"), mimeData); *data = QInternalMimeData::renderDataHelper(QLatin1String("text/plain"), mimeData);
ret = true; ret = true;
} else if (a == connection->atom(QXcbAtom::XA_STRING)) { } else if (a == QXcbAtom::XA_STRING) {
*data = QString::fromUtf8(QInternalMimeData::renderDataHelper( *data = QString::fromUtf8(QInternalMimeData::renderDataHelper(
QLatin1String("text/plain"), mimeData)).toLocal8Bit(); QLatin1String("text/plain"), mimeData)).toLocal8Bit();
ret = true; ret = true;
@ -145,7 +145,7 @@ bool QXcbMime::mimeDataForAtom(QXcbConnection *connection, xcb_atom_t a, QMimeDa
mozUri += QLatin1Char('\n'); mozUri += QLatin1Char('\n');
*data = QByteArray(reinterpret_cast<const char *>(mozUri.utf16()), mozUri.length() * 2); *data = QByteArray(reinterpret_cast<const char *>(mozUri.utf16()), mozUri.length() * 2);
ret = true; ret = true;
} else if ((a == connection->atom(QXcbAtom::XA_PIXMAP) || a == connection->atom(QXcbAtom::XA_BITMAP)) && mimeData->hasImage()) { } else if ((a == QXcbAtom::XA_PIXMAP || a == QXcbAtom::XA_BITMAP) && mimeData->hasImage()) {
ret = true; ret = true;
} }
return ret; return ret;
@ -159,7 +159,7 @@ QList<xcb_atom_t> QXcbMime::mimeAtomsForFormat(QXcbConnection *connection, const
// special cases for strings // special cases for strings
if (format == QLatin1String("text/plain")) { if (format == QLatin1String("text/plain")) {
atoms.append(connection->atom(QXcbAtom::UTF8_STRING)); atoms.append(connection->atom(QXcbAtom::UTF8_STRING));
atoms.append(connection->atom(QXcbAtom::XA_STRING)); atoms.append(QXcbAtom::XA_STRING);
atoms.append(connection->atom(QXcbAtom::TEXT)); atoms.append(connection->atom(QXcbAtom::TEXT));
atoms.append(connection->atom(QXcbAtom::COMPOUND_TEXT)); atoms.append(connection->atom(QXcbAtom::COMPOUND_TEXT));
} }
@ -170,9 +170,9 @@ QList<xcb_atom_t> QXcbMime::mimeAtomsForFormat(QXcbConnection *connection, const
//special cases for images //special cases for images
if (format == QLatin1String("image/ppm")) if (format == QLatin1String("image/ppm"))
atoms.append(connection->atom(QXcbAtom::XA_PIXMAP)); atoms.append(QXcbAtom::XA_PIXMAP);
if (format == QLatin1String("image/pbm")) if (format == QLatin1String("image/pbm"))
atoms.append(connection->atom(QXcbAtom::XA_BITMAP)); atoms.append(QXcbAtom::XA_BITMAP);
return atoms; return atoms;
} }
@ -200,7 +200,7 @@ QVariant QXcbMime::mimeConvertToFormat(QXcbConnection *connection, xcb_atom_t a,
if (format == QLatin1String("text/plain")) { if (format == QLatin1String("text/plain")) {
if (a == connection->atom(QXcbAtom::UTF8_STRING)) if (a == connection->atom(QXcbAtom::UTF8_STRING))
return QString::fromUtf8(data); return QString::fromUtf8(data);
if (a == connection->atom(QXcbAtom::XA_STRING)) if (a == QXcbAtom::XA_STRING)
return QString::fromLatin1(data); return QString::fromLatin1(data);
if (a == connection->atom(QXcbAtom::TEXT) if (a == connection->atom(QXcbAtom::TEXT)
|| a == connection->atom(QXcbAtom::COMPOUND_TEXT)) || a == connection->atom(QXcbAtom::COMPOUND_TEXT))
@ -267,8 +267,8 @@ xcb_atom_t QXcbMime::mimeAtomForFormat(QXcbConnection *connection, const QString
return connection->atom(QXcbAtom::COMPOUND_TEXT); return connection->atom(QXcbAtom::COMPOUND_TEXT);
if (atoms.contains(connection->atom(QXcbAtom::TEXT))) if (atoms.contains(connection->atom(QXcbAtom::TEXT)))
return connection->atom(QXcbAtom::TEXT); return connection->atom(QXcbAtom::TEXT);
if (atoms.contains(connection->atom(QXcbAtom::XA_STRING))) if (atoms.contains(QXcbAtom::XA_STRING))
return connection->atom(QXcbAtom::XA_STRING); return QXcbAtom::XA_STRING;
} }
// find matches for uri types // find matches for uri types
@ -283,8 +283,8 @@ xcb_atom_t QXcbMime::mimeAtomForFormat(QXcbConnection *connection, const QString
// find match for image // find match for image
if (format == QLatin1String("image/ppm")) { if (format == QLatin1String("image/ppm")) {
if (atoms.contains(connection->atom(QXcbAtom::XA_PIXMAP))) if (atoms.contains(QXcbAtom::XA_PIXMAP))
return connection->atom(QXcbAtom::XA_PIXMAP); return QXcbAtom::XA_PIXMAP;
} }
// for string/text requests try to use a format with a well-defined charset // for string/text requests try to use a format with a well-defined charset

View File

@ -6,6 +6,7 @@ QTDIR_build:DESTDIR = $$QT_BUILD_TREE/plugins/platforms
QT += core-private gui-private QT += core-private gui-private
SOURCES = \ SOURCES = \
# qxcbclipboard.cpp \
qxcbconnection.cpp \ qxcbconnection.cpp \
qxcbintegration.cpp \ qxcbintegration.cpp \
qxcbkeyboard.cpp \ qxcbkeyboard.cpp \
@ -17,6 +18,7 @@ SOURCES = \
qxcbnativeinterface.cpp qxcbnativeinterface.cpp
HEADERS = \ HEADERS = \
# qxcbclipboard.h \
qxcbconnection.h \ qxcbconnection.h \
qxcbintegration.h \ qxcbintegration.h \
qxcbkeyboard.h \ qxcbkeyboard.h \