]> git.lyx.org Git - lyx.git/blobdiff - src/support/qstring_helpers.h
RefChanger
[lyx.git] / src / support / qstring_helpers.h
index 9028fad7075ef3d7e3d37fde9904cb12f34e8921..9c28092811ed9c980ff04f89c18ec0531a5a2efa 100644 (file)
 #ifndef QSTRING_HELPERS_H
 #define QSTRING_HELPERS_H
 
-#include "support/docstring.h"
+#include "support/strfwd.h"
 
-#include <QString>
-#include <QVector>
+class QString;
 
 namespace lyx {
 
+class LyXErr;
+
+LyXErr & operator<<(LyXErr &, QString const &);
+
 /**
  * toqstr - convert a UTF8 encoded char * into a QString
  *
  * This should not be used, since all possibly non-ASCII stuff should be
  * stored in a docstring.
  */
-inline QString const toqstr(char const * str)
-{
-       return QString::fromUtf8(str);
-}
+QString toqstr(char const * str);
 
 
 /**
@@ -37,14 +37,11 @@ inline QString const toqstr(char const * str)
  * This should not be used, since all possibly non-ASCII stuff should be
  * stored in a docstring.
  */
-inline QString const toqstr(std::string const & str)
-{
-       return toqstr(str.c_str());
-}
+QString toqstr(std::string const & str);
 
 
 /// Is \p c a valid utf16 char?
-inline bool is_utf16(char_type c)
+inline bool is_utf16(unsigned int c)
 {
        // 0xd800 ... 0xdfff is the range of surrogate pairs.
        return c < 0xd800 || (c > 0xdfff && c < 0x10000);
@@ -57,12 +54,7 @@ inline bool is_utf16(char_type c)
  * This is the preferred method of converting anything that possibly
  * contains non-ASCII stuff to QString.
  */
-inline QString const toqstr(docstring const & ucs4)
-{
-       // If possible we let qt do the work, since this version does not
-       // need to be superfast.
-       return QString::fromUcs4(reinterpret_cast<uint const *>(ucs4.data()), ucs4.length());
-}
+QString toqstr(docstring const & ucs4);
 
 /**
  * toqstr - convert a UCS4 encoded character into a QString
@@ -70,10 +62,7 @@ inline QString const toqstr(docstring const & ucs4)
  * This is the preferred method of converting anything that possibly
  * contains non-ASCII stuff to QString.
  */
-inline QString const toqstr(char_type ucs4)
-{
-       return QString::fromUcs4(reinterpret_cast<uint const *>(&ucs4), 1);
-}
+QString toqstr(char_type ucs4);
 
 /**
  * qstring_to_ucs4 - convert a QString into a UCS4 encoded docstring
@@ -81,13 +70,7 @@ inline QString const toqstr(char_type ucs4)
  * This is the preferred method of converting anything that possibly
  * contains non-ASCII stuff to docstring.
  */
-inline docstring const qstring_to_ucs4(QString const & qstr)
-{
-       if (qstr.isEmpty())
-               return docstring();
-       QVector<uint> const ucs4 = qstr.toUcs4();
-       return docstring((char_type const *)(ucs4.constData()), ucs4.size());
-}
+docstring qstring_to_ucs4(QString const & qstr);
 
 /**
  * fromqstr - convert a QString into a UTF8 encoded std::string
@@ -95,10 +78,7 @@ inline docstring const qstring_to_ucs4(QString const & qstr)
  * This should not be used except for output to lyxerr, since all possibly
  * non-ASCII stuff should be stored in a docstring.
  */
-inline std::string const fromqstr(QString const & str)
-{
-       return str.isEmpty() ? std::string() : std::string(str.toUtf8());
-}
+std::string fromqstr(QString const & str);
 
 } // namespace lyx