mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-11-12 06:03:36 +00:00
be624b3de0
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23552 a592a061-630c-0410-9148-cb99ea01b6c8
306 lines
6.8 KiB
C++
306 lines
6.8 KiB
C++
/**
|
|
* \file qt_helpers.cpp
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author Dekel Tsur
|
|
* \author Jürgen Spitzmüller
|
|
* \author Richard Heck
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#include <config.h>
|
|
|
|
#include "qt_helpers.h"
|
|
|
|
#include "FileDialog.h"
|
|
#include "LengthCombo.h"
|
|
|
|
#include "frontends/alert.h"
|
|
|
|
#include "Language.h"
|
|
#include "Length.h"
|
|
|
|
#include "support/debug.h"
|
|
#include "support/filetools.h"
|
|
#include "support/foreach.h"
|
|
#include "support/gettext.h"
|
|
#include "support/lstrings.h"
|
|
#include "support/lyxalgo.h"
|
|
#include "support/os.h"
|
|
#include "support/Package.h"
|
|
#include "support/Path.h"
|
|
#include "support/Systemcall.h"
|
|
|
|
#include <QCheckBox>
|
|
#include <QComboBox>
|
|
#include <QLineEdit>
|
|
#include <QPalette>
|
|
#include <QSet>
|
|
|
|
#include <algorithm>
|
|
#include <fstream>
|
|
#include <locale>
|
|
|
|
using namespace std;
|
|
using namespace lyx::support;
|
|
|
|
namespace lyx {
|
|
|
|
FileName libFileSearch(QString const & dir, QString const & name,
|
|
QString const & ext)
|
|
{
|
|
return support::libFileSearch(fromqstr(dir), fromqstr(name), fromqstr(ext));
|
|
}
|
|
|
|
namespace frontend {
|
|
|
|
string widgetsToLength(QLineEdit const * input, LengthCombo const * combo)
|
|
{
|
|
QString const 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);
|
|
|
|
Length::UNIT const unit = combo->currentLengthItem();
|
|
|
|
return Length(length.toDouble(), unit).asString();
|
|
}
|
|
|
|
|
|
Length widgetsToLength(QLineEdit const * input, QComboBox const * combo)
|
|
{
|
|
QString const length = input->text();
|
|
if (length.isEmpty())
|
|
return Length();
|
|
|
|
// don't return unit-from-choice if the input(field) contains a unit
|
|
if (isValidGlueLength(fromqstr(length)))
|
|
return Length(fromqstr(length));
|
|
|
|
Length::UNIT const unit = unitFromString(fromqstr(combo->currentText()));
|
|
|
|
return Length(length.toDouble(), unit);
|
|
}
|
|
|
|
|
|
void lengthToWidgets(QLineEdit * input, LengthCombo * combo,
|
|
Length const & len, Length::UNIT /*defaultUnit*/)
|
|
{
|
|
combo->setCurrentItem(len.unit());
|
|
input->setText(QString::number(Length(len).value()));
|
|
}
|
|
|
|
|
|
void lengthToWidgets(QLineEdit * input, LengthCombo * combo,
|
|
string const & len, Length::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 {
|
|
lengthToWidgets(input, combo, Length(len), defaultUnit);
|
|
}
|
|
}
|
|
|
|
|
|
void lengthAutoToWidgets(QLineEdit * input, LengthCombo * combo,
|
|
Length const & len, Length::UNIT defaultUnit)
|
|
{
|
|
if (len.value() == 0)
|
|
lengthToWidgets(input, combo, "auto", defaultUnit);
|
|
else
|
|
lengthToWidgets(input, combo, len, defaultUnit);
|
|
}
|
|
|
|
|
|
void setValid(QWidget * widget, bool valid)
|
|
{
|
|
if (valid) {
|
|
widget->setPalette(QPalette());
|
|
} else {
|
|
QPalette pal = widget->palette();
|
|
pal.setColor(QPalette::Active, QPalette::Foreground, QColor(255, 0, 0));
|
|
widget->setPalette(pal);
|
|
}
|
|
}
|
|
|
|
} // namespace frontend
|
|
|
|
QString const qt_(char const * str, const char *)
|
|
{
|
|
return toqstr(_(str));
|
|
}
|
|
|
|
|
|
QString const qt_(string const & str)
|
|
{
|
|
return toqstr(_(str));
|
|
}
|
|
|
|
namespace {
|
|
|
|
class Sorter
|
|
{
|
|
public:
|
|
#if !defined(USE_WCHAR_T) && defined(__GNUC__)
|
|
bool operator()(LanguagePair const & lhs, LanguagePair const & rhs) const
|
|
{
|
|
return lhs.first < rhs.first;
|
|
}
|
|
#else
|
|
Sorter() : loc_ok(true)
|
|
{
|
|
try {
|
|
loc_ = locale("");
|
|
} catch (...) {
|
|
loc_ok = false;
|
|
}
|
|
}
|
|
|
|
bool operator()(LanguagePair const & lhs, LanguagePair const & rhs) const
|
|
{
|
|
// FIXME: would that be "QString::localeAwareCompare()"?
|
|
if (loc_ok)
|
|
return loc_(fromqstr(lhs.first), fromqstr(rhs.first));
|
|
else
|
|
return lhs.first < rhs.first;
|
|
}
|
|
private:
|
|
locale loc_;
|
|
bool loc_ok;
|
|
#endif
|
|
};
|
|
|
|
|
|
} // namespace anon
|
|
|
|
|
|
QList<LanguagePair> languageData(bool character_dlg)
|
|
{
|
|
size_t const offset = character_dlg ? 2 : 0;
|
|
vector<LanguagePair> langs(languages.size() + offset);
|
|
|
|
if (character_dlg) {
|
|
langs[0].first = qt_("No change");
|
|
langs[0].second = "ignore";
|
|
langs[1].first = qt_("Reset");
|
|
langs[1].second = "reset";
|
|
}
|
|
|
|
Languages::const_iterator it = languages.begin();
|
|
for (size_t i = 0; i != languages.size(); ++i, ++it) {
|
|
langs[i + offset].first = qt_(it->second.display());
|
|
langs[i + offset].second = toqstr(it->second.lang());
|
|
}
|
|
|
|
// Don't sort "ignore" and "reset"
|
|
vector<LanguagePair>::iterator begin = langs.begin() + offset;
|
|
sort(begin, langs.end(), Sorter());
|
|
|
|
QList<LanguagePair> list;
|
|
foreach (LanguagePair const & l, langs)
|
|
list.append(l);
|
|
return list;
|
|
}
|
|
|
|
|
|
void rescanTexStyles()
|
|
{
|
|
// Run rescan in user lyx directory
|
|
PathChanger p(package().user_support());
|
|
FileName const command = libFileSearch("scripts", "TeXFiles.py");
|
|
Systemcall one;
|
|
int const status = one.startscript(Systemcall::Wait,
|
|
os::python() + ' ' +
|
|
quoteName(command.toFilesystemEncoding()));
|
|
if (status == 0)
|
|
return;
|
|
// FIXME UNICODE
|
|
frontend::Alert::error(_("Could not update TeX information"),
|
|
bformat(_("The script `%s' failed."), from_utf8(command.absFilename())));
|
|
}
|
|
|
|
|
|
QStringList texFileList(QString const & filename)
|
|
{
|
|
QStringList list;
|
|
FileName const file = libFileSearch(QString(), filename);
|
|
if (file.empty())
|
|
return list;
|
|
|
|
// FIXME Unicode.
|
|
vector<docstring> doclist =
|
|
getVectorFromString(file.fileContents("UTF-8"), from_ascii("\n"));
|
|
|
|
// Normalise paths like /foo//bar ==> /foo/bar
|
|
QSet<QString> set;
|
|
for (size_t i = 0; i != doclist.size(); ++i) {
|
|
QString file = toqstr(doclist[i]);
|
|
while (file.contains("//"))
|
|
file.replace("//", "/");
|
|
if (!file.isEmpty())
|
|
set.insert(file);
|
|
}
|
|
|
|
// remove duplicates
|
|
return QList<QString>::fromSet(set);
|
|
}
|
|
|
|
|
|
QString internalPath(const QString & str)
|
|
{
|
|
return toqstr(os::internal_path(fromqstr(str)));
|
|
}
|
|
|
|
|
|
QString onlyFilename(const QString & str)
|
|
{
|
|
return toqstr(support::onlyFilename(fromqstr(str)));
|
|
}
|
|
|
|
|
|
QString onlyPath(const QString & str)
|
|
{
|
|
return toqstr(support::onlyPath(fromqstr(str)));
|
|
}
|
|
|
|
|
|
QString changeExtension(QString const & oldname, QString const & ext)
|
|
{
|
|
return toqstr(support::changeExtension(fromqstr(oldname), fromqstr(ext)));
|
|
}
|
|
|
|
/// Remove the extension from \p name
|
|
QString removeExtension(QString const & name)
|
|
{
|
|
return toqstr(support::removeExtension(fromqstr(name)));
|
|
}
|
|
|
|
/** Add the extension \p ext to \p name.
|
|
Use this instead of changeExtension if you know that \p name is without
|
|
extension, because changeExtension would wrongly interpret \p name if it
|
|
contains a dot.
|
|
*/
|
|
QString addExtension(QString const & name, QString const & ext)
|
|
{
|
|
return toqstr(support::addExtension(fromqstr(name), fromqstr(ext)));
|
|
}
|
|
|
|
/// Return the extension of the file (not including the .)
|
|
QString getExtension(QString const & name)
|
|
{
|
|
return toqstr(support::getExtension(fromqstr(name)));
|
|
}
|
|
|
|
} // namespace lyx
|