3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
7 * \author Jürgen Spitzmüller
9 * Full author contact details are available in file CREDITS.
14 #include "lengthcombo.h"
15 #include "qt_helpers.h"
17 #include "lengthcommon.h"
20 #include "support/lstrings.h"
21 #include "support/convert.h"
26 #include <qlineedit.h>
27 #include <qtextcodec.h>
35 using lyx::support::isStrDbl;
46 string makeFontName(string const & family, string const & foundry)
50 return family + " [" + foundry + ']';
54 pair<string, string> parseFontName(string const & name)
56 string::size_type const idx = name.find('[');
57 if (idx == string::npos || idx == 0)
58 return make_pair(name, string());
59 return make_pair(name.substr(0, idx - 1),
60 name.substr(idx + 1, name.size() - idx - 2));
64 string widgetsToLength(QLineEdit const * input, LengthCombo const * combo)
66 QString const length = input->text();
70 // Don't return unit-from-choice if the input(field) contains a unit
71 if (isValidGlueLength(fromqstr(length)))
72 return fromqstr(length);
74 LyXLength::UNIT const unit = combo->currentLengthItem();
76 return LyXLength(length.toDouble(), unit).asString();
80 LyXLength widgetsToLength(QLineEdit const * input, QComboBox const * combo)
82 QString const length = input->text();
86 // don't return unit-from-choice if the input(field) contains a unit
87 if (isValidGlueLength(fromqstr(length)))
88 return LyXLength(fromqstr(length));
90 LyXLength::UNIT const unit = unitFromString(fromqstr(combo->currentText()));
92 return LyXLength(length.toDouble(), unit);
96 void lengthToWidgets(QLineEdit * input, LengthCombo * combo,
97 string const & len, LyXLength::UNIT defaultUnit)
100 // no length (UNIT_NONE)
101 combo->setCurrentItem(defaultUnit);
103 } else if (!isValidLength(len) && !isStrDbl(len)) {
104 // use input field only for gluelengths
105 combo->setCurrentItem(defaultUnit);
106 input->setText(toqstr(len));
108 combo->setCurrentItem(LyXLength(len).unit());
109 input->setText(toqstr(convert<string>(LyXLength(len).value())));
114 void ucs4_to_qstring(lyx::docstring const & str, QString & s)
116 int i = static_cast<int>(str.size());
119 s[i] = ucs4_to_qchar(str[i]);
123 QString ucs4_to_qstring(lyx::docstring const & str)
126 ucs4_to_qstring(str, tmp);
131 QString const toqstr(docstring const & ucs4)
134 ucs4_to_qstring(ucs4, s);
139 docstring const qstring_to_ucs4(QString const & qstr)
141 int const ls = qstr.size();
143 for (int i = 0; i < ls; ++i)
144 ucs4 += static_cast<char_type>(qstr[i].unicode());
149 void qstring_to_ucs4(QString const & qstr, vector<char_type> & ucs4)
151 int const ls = qstr.size();
153 for (int i = 0; i < ls; ++i)
154 ucs4.push_back(static_cast<lyx::char_type>(qstr[i].unicode()));
158 QString const qt_(char const * str, const char *)
160 return toqstr(_(str));
164 QString const qt_(string const & str)
166 return toqstr(_(str));
170 string const fromqstr(QString const & str)
172 return str.isEmpty()? string(): string(str.toAscii());
176 docstring const formatted(docstring const & text, int w)
183 docstring::size_type curpos = 0;
187 docstring::size_type const nxtpos1 = text.find(' ', curpos);
188 docstring::size_type const nxtpos2 = text.find('\n', curpos);
189 docstring::size_type const nxtpos = std::min(nxtpos1, nxtpos2);
191 docstring const word =
192 nxtpos == docstring::npos ?
193 text.substr(curpos) :
194 text.substr(curpos, nxtpos - curpos);
196 bool const newline = (nxtpos2 != docstring::npos &&
199 docstring const line_plus_word =
200 line.empty() ? word : line + lyx::char_type(' ') + word;
202 // FIXME: make w be size_t
203 if (int(line_plus_word.length()) >= w) {
204 sout += line + lyx::char_type('\n');
206 sout += word + lyx::char_type('\n');
212 } else if (newline) {
213 sout += line_plus_word + lyx::char_type('\n');
218 line += lyx::char_type(' ');
222 if (nxtpos == docstring::npos) {