2006-03-05 17:24:44 +00:00
|
|
|
|
/**
|
|
|
|
|
* \file qt_helpers.C
|
|
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
|
* Licence details can be found in the file COPYING.
|
|
|
|
|
*
|
|
|
|
|
* \author Dekel Tsur
|
|
|
|
|
* \author J<EFBFBD>rgen Spitzm<EFBFBD>ller
|
|
|
|
|
*
|
|
|
|
|
* Full author contact details are available in file CREDITS.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
|
|
#include "lengthcombo.h"
|
|
|
|
|
#include "qt_helpers.h"
|
|
|
|
|
|
|
|
|
|
#include "lengthcommon.h"
|
|
|
|
|
#include "gettext.h"
|
|
|
|
|
|
|
|
|
|
#include "support/lstrings.h"
|
|
|
|
|
#include "support/convert.h"
|
|
|
|
|
|
2006-08-30 14:59:07 +00:00
|
|
|
|
#include "debug.h"
|
|
|
|
|
|
2006-03-05 17:24:44 +00:00
|
|
|
|
#include <QComboBox>
|
|
|
|
|
#include <qlineedit.h>
|
|
|
|
|
#include <qtextcodec.h>
|
|
|
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
using lyx::support::isStrDbl;
|
2006-08-30 14:59:07 +00:00
|
|
|
|
using lyx::char_type;
|
2006-09-03 07:02:38 +00:00
|
|
|
|
using lyx::docstring;
|
2006-03-05 17:24:44 +00:00
|
|
|
|
|
2006-08-30 14:59:07 +00:00
|
|
|
|
using std::vector;
|
2006-03-05 17:24:44 +00:00
|
|
|
|
using std::make_pair;
|
|
|
|
|
using std::string;
|
|
|
|
|
using std::pair;
|
2006-08-30 14:59:07 +00:00
|
|
|
|
using std::endl;
|
2006-03-05 17:24:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
string makeFontName(string const & family, string const & foundry)
|
|
|
|
|
{
|
|
|
|
|
if (foundry.empty())
|
|
|
|
|
return family;
|
|
|
|
|
return family + " [" + foundry + ']';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
pair<string,string> parseFontName(string const & name)
|
|
|
|
|
{
|
|
|
|
|
string::size_type const idx = name.find('[');
|
|
|
|
|
if (idx == string::npos || idx == 0)
|
|
|
|
|
return make_pair(name, string());
|
|
|
|
|
return make_pair(name.substr(0, idx - 1),
|
|
|
|
|
name.substr(idx + 1, name.size() - idx - 2));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
string widgetsToLength(QLineEdit const * input, LengthCombo const * combo)
|
|
|
|
|
{
|
|
|
|
|
QString length = input->text();
|
|
|
|
|
if (length.isEmpty())
|
|
|
|
|
return string();
|
|
|
|
|
|
|
|
|
|
// don't return unit-from-choice if the input(field) contains a unit
|
|
|
|
|
if (isValidGlueLength(fromqstr(length)))
|
|
|
|
|
return fromqstr(length);
|
|
|
|
|
|
|
|
|
|
LyXLength::UNIT unit = combo->currentLengthItem();
|
|
|
|
|
|
|
|
|
|
return LyXLength(length.toDouble(), unit).asString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
LyXLength widgetsToLength(QLineEdit const * input, QComboBox const * combo)
|
|
|
|
|
{
|
|
|
|
|
QString length = input->text();
|
|
|
|
|
if (length.isEmpty())
|
|
|
|
|
return LyXLength();
|
|
|
|
|
|
|
|
|
|
// don't return unit-from-choice if the input(field) contains a unit
|
|
|
|
|
if (isValidGlueLength(fromqstr(length)))
|
|
|
|
|
return LyXLength(fromqstr(length));
|
|
|
|
|
|
|
|
|
|
LyXLength::UNIT unit = unitFromString(fromqstr(combo->currentText()));
|
|
|
|
|
|
|
|
|
|
return LyXLength(length.toDouble(), unit);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void lengthToWidgets(QLineEdit * input, LengthCombo * combo,
|
|
|
|
|
string const & len, LyXLength::UNIT defaultUnit)
|
|
|
|
|
{
|
|
|
|
|
if (len.empty()) {
|
|
|
|
|
// no length (UNIT_NONE)
|
|
|
|
|
combo->setCurrentItem(defaultUnit);
|
|
|
|
|
input->setText("");
|
|
|
|
|
} else if (!isValidLength(len) && !isStrDbl(len)) {
|
|
|
|
|
// use input field only for gluelengths
|
|
|
|
|
combo->setCurrentItem(defaultUnit);
|
|
|
|
|
input->setText(toqstr(len));
|
|
|
|
|
} else {
|
|
|
|
|
combo->setCurrentItem(LyXLength(len).unit());
|
|
|
|
|
input->setText(toqstr(convert<string>(LyXLength(len).value())));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
QString const toqstr(char const * str)
|
|
|
|
|
{
|
|
|
|
|
return QString::fromAscii(str);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
QString const toqstr(string const & str)
|
|
|
|
|
{
|
|
|
|
|
return toqstr(str.c_str());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2006-08-30 14:59:07 +00:00
|
|
|
|
QString const ucs4_to_qstring(char_type const * str, size_t ls)
|
|
|
|
|
{
|
|
|
|
|
QString s;
|
|
|
|
|
|
|
|
|
|
for (size_t i = 0; i < ls; ++i)
|
|
|
|
|
s.append(ucs4_to_qchar(str[i]));
|
|
|
|
|
|
|
|
|
|
return s;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2006-09-03 07:02:38 +00:00
|
|
|
|
QString const toqstr(docstring const & ucs4)
|
2006-08-30 14:59:07 +00:00
|
|
|
|
{
|
|
|
|
|
QString s;
|
|
|
|
|
size_t const ls = ucs4.size();
|
|
|
|
|
|
|
|
|
|
for (size_t i = 0; i < ls; ++i)
|
|
|
|
|
s.append(ucs4_to_qchar(ucs4[i]));
|
|
|
|
|
|
|
|
|
|
return s;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2006-09-03 07:02:38 +00:00
|
|
|
|
docstring const qstring_to_ucs4(QString const & qstr)
|
2006-08-30 14:59:07 +00:00
|
|
|
|
{
|
2006-08-31 20:36:07 +00:00
|
|
|
|
int ls = qstr.size();
|
2006-09-03 07:02:38 +00:00
|
|
|
|
docstring ucs4;
|
2006-08-31 20:36:07 +00:00
|
|
|
|
for (int i = 0; i < ls; ++i)
|
2006-09-03 07:02:38 +00:00
|
|
|
|
ucs4 += static_cast<char_type>(qstr[i].unicode());
|
2006-08-30 14:59:07 +00:00
|
|
|
|
|
|
|
|
|
return ucs4;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void qstring_to_ucs4(QString const & qstr, vector<char_type> & ucs4)
|
|
|
|
|
{
|
2006-08-31 20:36:07 +00:00
|
|
|
|
int ls = qstr.size();
|
2006-08-30 14:59:07 +00:00
|
|
|
|
ucs4.clear();
|
2006-08-31 20:36:07 +00:00
|
|
|
|
for (int i = 0; i < ls; ++i)
|
2006-08-30 14:59:07 +00:00
|
|
|
|
ucs4.push_back(static_cast<boost::uint32_t>(qstr[i].unicode()));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
char_type const qchar_to_ucs4(QChar const & qchar)
|
|
|
|
|
{
|
|
|
|
|
return static_cast<boost::uint32_t>(qchar.unicode());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
QChar const ucs4_to_qchar(char_type const & ucs4)
|
|
|
|
|
{
|
|
|
|
|
return QChar(static_cast<unsigned short>(ucs4));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2006-03-05 17:24:44 +00:00
|
|
|
|
QString const qt_(char const * str)
|
|
|
|
|
{
|
2006-09-09 15:27:44 +00:00
|
|
|
|
return toqstr(lyx::to_utf8(_(str)));
|
2006-03-05 17:24:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
QString const qt_(string const & str)
|
|
|
|
|
{
|
2006-09-09 15:27:44 +00:00
|
|
|
|
return toqstr(lyx::to_utf8(_(str)));
|
2006-03-05 17:24:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
string const fromqstr(QString const & str)
|
|
|
|
|
{
|
2006-08-17 09:00:36 +00:00
|
|
|
|
return str.isEmpty()? string(): string(str.toAscii());
|
2006-03-05 17:24:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
string const formatted(string const & text, int w)
|
|
|
|
|
{
|
|
|
|
|
string sout;
|
|
|
|
|
|
|
|
|
|
if (text.empty())
|
|
|
|
|
return sout;
|
|
|
|
|
|
|
|
|
|
string::size_type curpos = 0;
|
|
|
|
|
string line;
|
|
|
|
|
|
|
|
|
|
for (;;) {
|
|
|
|
|
string::size_type const nxtpos1 = text.find(' ', curpos);
|
|
|
|
|
string::size_type const nxtpos2 = text.find('\n', curpos);
|
|
|
|
|
string::size_type const nxtpos = std::min(nxtpos1, nxtpos2);
|
|
|
|
|
|
|
|
|
|
string const word = nxtpos == string::npos ?
|
|
|
|
|
text.substr(curpos) : text.substr(curpos, nxtpos-curpos);
|
|
|
|
|
|
|
|
|
|
bool const newline = (nxtpos2 != string::npos &&
|
|
|
|
|
nxtpos2 < nxtpos1);
|
|
|
|
|
|
|
|
|
|
string const line_plus_word =
|
|
|
|
|
line.empty() ? word : line + ' ' + word;
|
|
|
|
|
|
|
|
|
|
// FIXME: make w be size_t
|
|
|
|
|
if (int(line_plus_word.length()) >= w) {
|
|
|
|
|
sout += line + '\n';
|
|
|
|
|
if (newline) {
|
|
|
|
|
sout += word + '\n';
|
|
|
|
|
line.erase();
|
|
|
|
|
} else {
|
|
|
|
|
line = word;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} else if (newline) {
|
|
|
|
|
sout += line_plus_word + '\n';
|
|
|
|
|
line.erase();
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
if (!line.empty())
|
|
|
|
|
line += ' ';
|
|
|
|
|
line += word;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (nxtpos == string::npos) {
|
|
|
|
|
if (!line.empty())
|
|
|
|
|
sout += line;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
curpos = nxtpos + 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return sout;
|
|
|
|
|
}
|