2006-03-05 17:24:44 +00:00
|
|
|
// -*- C++ -*-
|
|
|
|
/**
|
|
|
|
* \file qt_helpers.h
|
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
* Licence details can be found in the file COPYING.
|
|
|
|
*
|
|
|
|
* \author Dekel Tsur
|
|
|
|
*
|
|
|
|
* Full author contact details are available in file CREDITS.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef QTHELPERS_H
|
|
|
|
#define QTHELPERS_H
|
|
|
|
|
|
|
|
#include "lyxlength.h"
|
2006-09-13 21:13:49 +00:00
|
|
|
#include "support/docstring.h"
|
2006-08-30 14:59:07 +00:00
|
|
|
|
2006-10-07 16:30:26 +00:00
|
|
|
#include <QChar>
|
2006-10-22 19:33:37 +00:00
|
|
|
#include <QString>
|
2006-10-07 16:30:26 +00:00
|
|
|
|
2006-08-30 14:59:07 +00:00
|
|
|
#include <vector>
|
2006-10-21 00:16:43 +00:00
|
|
|
#include <utility>
|
2006-12-02 21:25:24 +00:00
|
|
|
#include <boost/assert.hpp>
|
2006-08-30 14:59:07 +00:00
|
|
|
|
2006-03-05 17:24:44 +00:00
|
|
|
class QComboBox;
|
|
|
|
class QLineEdit;
|
|
|
|
|
2006-10-21 00:16:43 +00:00
|
|
|
class LengthCombo;
|
|
|
|
|
|
|
|
namespace lyx {
|
|
|
|
|
2006-03-05 17:24:44 +00:00
|
|
|
std::string makeFontName(std::string const & family, std::string const & foundry);
|
|
|
|
|
|
|
|
std::pair<std::string,std::string> parseFontName(std::string const & name);
|
|
|
|
|
|
|
|
/// method to get a LyXLength from widgets (LengthCombo)
|
|
|
|
std::string widgetsToLength(QLineEdit const * input, LengthCombo const * combo);
|
|
|
|
/// method to get a LyXLength from widgets (QComboBox)
|
|
|
|
LyXLength widgetsToLength(QLineEdit const * input, QComboBox const * combo);
|
|
|
|
|
|
|
|
/// method to set widgets from a LyXLength
|
|
|
|
void lengthToWidgets(QLineEdit * input, LengthCombo * combo,
|
|
|
|
std::string const & len, LyXLength::UNIT default_unit);
|
|
|
|
|
|
|
|
/// format a string to the given width
|
2006-10-21 00:16:43 +00:00
|
|
|
docstring const formatted(docstring const & text, int w = 80);
|
2006-03-05 17:24:44 +00:00
|
|
|
|
2006-12-08 08:57:57 +00:00
|
|
|
|
2006-03-05 17:24:44 +00:00
|
|
|
/**
|
2006-12-08 08:57:57 +00:00
|
|
|
* toqstr - convert a UTF8 encoded char * into a QString
|
2006-03-05 17:24:44 +00:00
|
|
|
*
|
2006-12-08 08:57:57 +00:00
|
|
|
* This should not be used, since all possibly non-ASCII stuff should be
|
|
|
|
* stored in a docstring.
|
2006-03-05 17:24:44 +00:00
|
|
|
*/
|
2006-10-22 19:33:37 +00:00
|
|
|
inline QString const toqstr(char const * str)
|
|
|
|
{
|
|
|
|
return QString::fromUtf8(str);
|
|
|
|
}
|
2006-03-05 17:24:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
2006-12-08 08:57:57 +00:00
|
|
|
* toqstr - convert a UTF8 encoded std::string into a QString
|
2006-03-05 17:24:44 +00:00
|
|
|
*
|
2006-12-08 08:57:57 +00:00
|
|
|
* This should not be used, since all possibly non-ASCII stuff should be
|
|
|
|
* stored in a docstring.
|
2006-03-05 17:24:44 +00:00
|
|
|
*/
|
2006-10-22 19:33:37 +00:00
|
|
|
inline QString const toqstr(std::string const & str)
|
|
|
|
{
|
|
|
|
return toqstr(str.c_str());
|
|
|
|
}
|
2006-03-05 17:24:44 +00:00
|
|
|
|
|
|
|
|
2006-08-30 14:59:07 +00:00
|
|
|
/**
|
2006-12-08 08:57:57 +00:00
|
|
|
* Convert a QChar into a UCS4 character.
|
|
|
|
* This is a hack (it does only make sense for the common part of the UCS4
|
|
|
|
* and UTF16 encodings) and should not be used.
|
|
|
|
* This does only exist because of performance reasons (a real conversion
|
|
|
|
* using iconv is too slow on windows).
|
2006-08-30 14:59:07 +00:00
|
|
|
*/
|
2006-12-08 08:57:57 +00:00
|
|
|
inline char_type const qchar_to_ucs4(QChar const & qchar)
|
|
|
|
{
|
2006-10-22 19:33:37 +00:00
|
|
|
return static_cast<char_type>(qchar.unicode());
|
|
|
|
}
|
2006-08-30 14:59:07 +00:00
|
|
|
|
2006-12-08 08:57:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert a UCS4 character into a QChar.
|
|
|
|
* This is a hack (it does only make sense for the common part of the UCS4
|
|
|
|
* and UTF16 encodings) and should not be used.
|
|
|
|
* This does only exist because of performance reasons (a real conversion
|
|
|
|
* using iconv is too slow on windows).
|
|
|
|
*/
|
|
|
|
inline QChar const ucs4_to_qchar(char_type const ucs4)
|
|
|
|
{
|
2006-12-02 15:54:49 +00:00
|
|
|
// FIXME: The following cast is not a real conversion but it work
|
|
|
|
// for the ucs2 subrange of unicode. Instead of an assertion we should
|
|
|
|
// return some special characters that indicates that its display is
|
|
|
|
// not supported.
|
|
|
|
BOOST_ASSERT(ucs4 < 65536);
|
2006-10-22 19:33:37 +00:00
|
|
|
return QChar(static_cast<unsigned short>(ucs4));
|
|
|
|
}
|
|
|
|
|
2006-12-04 13:50:46 +00:00
|
|
|
|
2006-12-08 08:57:57 +00:00
|
|
|
/**
|
|
|
|
* toqstr - convert a UCS4 encoded docstring into a QString
|
|
|
|
*
|
|
|
|
* This is the preferred method of converting anything that possibly
|
|
|
|
* contains non-ASCII stuff to QString.
|
|
|
|
*/
|
2006-12-04 13:50:46 +00:00
|
|
|
#if QT_VERSION >= 0x040200
|
|
|
|
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());
|
|
|
|
}
|
|
|
|
#else
|
2006-10-22 19:33:37 +00:00
|
|
|
QString const toqstr(docstring const & ucs4);
|
2006-12-04 13:50:46 +00:00
|
|
|
#endif
|
2006-08-30 14:59:07 +00:00
|
|
|
|
2006-10-09 12:07:05 +00:00
|
|
|
|
2006-12-08 08:57:57 +00:00
|
|
|
/**
|
|
|
|
* ucs4_to_qstring - convert a UCS4 encoded char_type * into a QString
|
|
|
|
*
|
|
|
|
* This is a hack for the painter and font metrics and should not be used
|
|
|
|
* elsewhere. Since it uses ucs4_to_qchar it has the same limitations.
|
|
|
|
*/
|
2006-10-22 19:33:37 +00:00
|
|
|
inline void ucs4_to_qstring(char_type const * str, size_t ls, QString & s)
|
|
|
|
{
|
2006-11-29 22:57:34 +00:00
|
|
|
int i = static_cast<int>(ls);
|
|
|
|
s.resize(i);
|
2006-12-02 17:32:15 +00:00
|
|
|
for (; --i >= 0;)
|
2006-10-22 19:33:37 +00:00
|
|
|
s[i] = ucs4_to_qchar(str[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-12-08 08:57:57 +00:00
|
|
|
/**
|
|
|
|
* qstring_to_ucs4 - convert a QString into a UCS4 encoded docstring
|
|
|
|
*
|
|
|
|
* This is the preferred method of converting anything that possibly
|
|
|
|
* contains non-ASCII stuff to docstring.
|
|
|
|
*/
|
2006-10-21 00:16:43 +00:00
|
|
|
docstring const qstring_to_ucs4(QString const & qstr);
|
2006-08-30 14:59:07 +00:00
|
|
|
|
|
|
|
|
2006-03-05 17:24:44 +00:00
|
|
|
/**
|
2006-12-08 08:57:57 +00:00
|
|
|
* qt_ - i18nize string and convert to QString
|
2006-03-05 17:24:44 +00:00
|
|
|
*
|
2006-12-03 00:28:14 +00:00
|
|
|
* Use this in qt4/ instead of _()
|
2006-03-05 17:24:44 +00:00
|
|
|
*/
|
2006-12-03 01:09:09 +00:00
|
|
|
QString const qt_(char const * str, const char * comment = 0);
|
2006-03-05 17:24:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
2006-12-08 08:57:57 +00:00
|
|
|
* qt_ - i18nize string and convert to QString
|
2006-03-05 17:24:44 +00:00
|
|
|
*
|
2006-12-03 00:28:14 +00:00
|
|
|
* Use this in qt4/ instead of _()
|
2006-03-05 17:24:44 +00:00
|
|
|
*/
|
|
|
|
QString const qt_(std::string const & str);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2006-12-08 08:57:57 +00:00
|
|
|
* fromqstr - convert a QString into a UTF8 encoded std::string
|
2006-03-05 17:24:44 +00:00
|
|
|
*
|
2006-12-08 08:57:57 +00:00
|
|
|
* This should not be used except for output to lyxerr, since all possibly
|
|
|
|
* non-ASCII stuff should be stored in a docstring.
|
2006-03-05 17:24:44 +00:00
|
|
|
*/
|
|
|
|
std::string const fromqstr(QString const & str);
|
|
|
|
|
2006-10-21 00:16:43 +00:00
|
|
|
} // namespace lyx
|
|
|
|
|
2006-03-05 17:24:44 +00:00
|
|
|
#endif // QTHELPERS_H
|