forked from qt-creator/qt-creator
TextEditor: Factor out codec chooser
Change-Id: I664f7ba484f379b8d2b8254d4f880c0d37d70ff8 Reviewed-by: hjk <hjk@qt.io> Reviewed-by: David Schulz <david.schulz@qt.io>
This commit is contained in:
committed by
Orgad Shaneh
parent
4edb238073
commit
eb33d26090
@@ -40,6 +40,7 @@ add_qtc_plugin(TextEditor
|
|||||||
codeassist/runner.cpp codeassist/runner.h
|
codeassist/runner.cpp codeassist/runner.h
|
||||||
codeassist/textdocumentmanipulator.cpp codeassist/textdocumentmanipulator.h
|
codeassist/textdocumentmanipulator.cpp codeassist/textdocumentmanipulator.h
|
||||||
codeassist/textdocumentmanipulatorinterface.h
|
codeassist/textdocumentmanipulatorinterface.h
|
||||||
|
codecchooser.cpp codecchooser.h
|
||||||
codestyleeditor.cpp codestyleeditor.h
|
codestyleeditor.cpp codestyleeditor.h
|
||||||
codestylepool.cpp codestylepool.h
|
codestylepool.cpp codestylepool.h
|
||||||
codestyleselectorwidget.cpp codestyleselectorwidget.h
|
codestyleselectorwidget.cpp codestyleselectorwidget.h
|
||||||
|
@@ -25,17 +25,17 @@
|
|||||||
|
|
||||||
#include "behaviorsettingswidget.h"
|
#include "behaviorsettingswidget.h"
|
||||||
|
|
||||||
|
#include "behaviorsettings.h"
|
||||||
|
#include "codecchooser.h"
|
||||||
|
#include "extraencodingsettings.h"
|
||||||
|
#include "simplecodestylepreferenceswidget.h"
|
||||||
|
#include "storagesettings.h"
|
||||||
#include "tabsettingswidget.h"
|
#include "tabsettingswidget.h"
|
||||||
|
#include "typingsettings.h"
|
||||||
|
|
||||||
#include <coreplugin/coreconstants.h>
|
#include <coreplugin/coreconstants.h>
|
||||||
#include <coreplugin/icore.h>
|
#include <coreplugin/icore.h>
|
||||||
|
|
||||||
#include <texteditor/typingsettings.h>
|
|
||||||
#include <texteditor/storagesettings.h>
|
|
||||||
#include <texteditor/behaviorsettings.h>
|
|
||||||
#include <texteditor/extraencodingsettings.h>
|
|
||||||
#include <texteditor/simplecodestylepreferenceswidget.h>
|
|
||||||
|
|
||||||
#include <utils/algorithm.h>
|
#include <utils/algorithm.h>
|
||||||
#include <utils/hostosinfo.h>
|
#include <utils/hostosinfo.h>
|
||||||
#include <utils/layoutbuilder.h>
|
#include <utils/layoutbuilder.h>
|
||||||
@@ -54,7 +54,6 @@ namespace TextEditor {
|
|||||||
|
|
||||||
struct BehaviorSettingsWidgetPrivate
|
struct BehaviorSettingsWidgetPrivate
|
||||||
{
|
{
|
||||||
QList<QTextCodec *> m_codecs;
|
|
||||||
|
|
||||||
SimpleCodeStylePreferencesWidget *tabPreferencesWidget;
|
SimpleCodeStylePreferencesWidget *tabPreferencesWidget;
|
||||||
QComboBox *tabKeyBehavior;
|
QComboBox *tabKeyBehavior;
|
||||||
@@ -70,7 +69,7 @@ struct BehaviorSettingsWidgetPrivate
|
|||||||
QCheckBox *cleanIndentation;
|
QCheckBox *cleanIndentation;
|
||||||
QCheckBox *inEntireDocument;
|
QCheckBox *inEntireDocument;
|
||||||
QGroupBox *groupBoxEncodings;
|
QGroupBox *groupBoxEncodings;
|
||||||
QComboBox *encodingBox;
|
CodecChooser *encodingBox;
|
||||||
QComboBox *utf8BomBox;
|
QComboBox *utf8BomBox;
|
||||||
QLabel *defaultLineEndingsLabel;
|
QLabel *defaultLineEndingsLabel;
|
||||||
QComboBox *defaultLineEndings;
|
QComboBox *defaultLineEndings;
|
||||||
@@ -145,7 +144,7 @@ BehaviorSettingsWidget::BehaviorSettingsWidget(QWidget *parent)
|
|||||||
d->inEntireDocument->setEnabled(false);
|
d->inEntireDocument->setEnabled(false);
|
||||||
d->inEntireDocument->setToolTip(tr("Cleans whitespace in entire document instead of only for changed parts."));
|
d->inEntireDocument->setToolTip(tr("Cleans whitespace in entire document instead of only for changed parts."));
|
||||||
|
|
||||||
d->encodingBox = new QComboBox;
|
d->encodingBox = new CodecChooser;
|
||||||
d->encodingBox->setSizeAdjustPolicy(QComboBox::AdjustToMinimumContentsLengthWithIcon);
|
d->encodingBox->setSizeAdjustPolicy(QComboBox::AdjustToMinimumContentsLengthWithIcon);
|
||||||
d->encodingBox->setMinimumContentsLength(20);
|
d->encodingBox->setMinimumContentsLength(20);
|
||||||
|
|
||||||
@@ -188,32 +187,6 @@ BehaviorSettingsWidget::BehaviorSettingsWidget(QWidget *parent)
|
|||||||
|
|
||||||
d->groupBoxMouse = new QGroupBox(tr("Mouse and Keyboard"));
|
d->groupBoxMouse = new QGroupBox(tr("Mouse and Keyboard"));
|
||||||
|
|
||||||
QList<int> mibs = QTextCodec::availableMibs();
|
|
||||||
Utils::sort(mibs);
|
|
||||||
QList<int>::iterator firstNonNegative =
|
|
||||||
std::find_if(mibs.begin(), mibs.end(), [](int n) { return n >=0; });
|
|
||||||
if (firstNonNegative != mibs.end())
|
|
||||||
std::rotate(mibs.begin(), firstNonNegative, mibs.end());
|
|
||||||
for (int mib : qAsConst(mibs)) {
|
|
||||||
if (QTextCodec *codec = QTextCodec::codecForMib(mib)) {
|
|
||||||
QString compoundName = QLatin1String(codec->name());
|
|
||||||
const QList<QByteArray> aliases = codec->aliases();
|
|
||||||
for (const QByteArray &alias : aliases) {
|
|
||||||
compoundName += QLatin1String(" / ");
|
|
||||||
compoundName += QString::fromLatin1(alias);
|
|
||||||
}
|
|
||||||
d->encodingBox->addItem(compoundName);
|
|
||||||
d->m_codecs.append(codec);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Qt5 doesn't list the system locale (QTBUG-34283), so add it manually
|
|
||||||
const QString system(QLatin1String("System"));
|
|
||||||
if (d->encodingBox->findText(system) == -1) {
|
|
||||||
d->encodingBox->insertItem(0, system);
|
|
||||||
d->m_codecs.prepend(QTextCodec::codecForLocale());
|
|
||||||
}
|
|
||||||
|
|
||||||
using namespace Utils::Layouting;
|
using namespace Utils::Layouting;
|
||||||
|
|
||||||
const auto indent = [](QWidget *inner) { return Row { Space(30), inner }; };
|
const auto indent = [](QWidget *inner) { return Row { Space(30), inner }; };
|
||||||
@@ -293,8 +266,8 @@ BehaviorSettingsWidget::BehaviorSettingsWidget(QWidget *parent)
|
|||||||
this, &BehaviorSettingsWidget::slotBehaviorSettingsChanged);
|
this, &BehaviorSettingsWidget::slotBehaviorSettingsChanged);
|
||||||
connect(d->utf8BomBox, &QComboBox::currentIndexChanged,
|
connect(d->utf8BomBox, &QComboBox::currentIndexChanged,
|
||||||
this, &BehaviorSettingsWidget::slotExtraEncodingChanged);
|
this, &BehaviorSettingsWidget::slotExtraEncodingChanged);
|
||||||
connect(d->encodingBox, &QComboBox::currentIndexChanged,
|
connect(d->encodingBox, &CodecChooser::codecChanged,
|
||||||
this, &BehaviorSettingsWidget::slotEncodingBoxChanged);
|
this, &BehaviorSettingsWidget::textCodecChanged);
|
||||||
connect(d->constrainTooltipsBox, &QComboBox::currentIndexChanged,
|
connect(d->constrainTooltipsBox, &QComboBox::currentIndexChanged,
|
||||||
this, &BehaviorSettingsWidget::slotBehaviorSettingsChanged);
|
this, &BehaviorSettingsWidget::slotBehaviorSettingsChanged);
|
||||||
connect(d->keyboardTooltips, &QAbstractButton::clicked,
|
connect(d->keyboardTooltips, &QAbstractButton::clicked,
|
||||||
@@ -323,28 +296,12 @@ void BehaviorSettingsWidget::setAssignedCodec(QTextCodec *codec)
|
|||||||
{
|
{
|
||||||
const QString codecName = Core::ICore::settings()->value(
|
const QString codecName = Core::ICore::settings()->value(
|
||||||
Core::Constants::SETTINGS_DEFAULTTEXTENCODING).toString();
|
Core::Constants::SETTINGS_DEFAULTTEXTENCODING).toString();
|
||||||
|
d->encodingBox->setAssignedCodec(codec, codecName);
|
||||||
int rememberedSystemPosition = -1;
|
|
||||||
for (int i = 0; i < d->m_codecs.size(); ++i) {
|
|
||||||
if (codec == d->m_codecs.at(i)) {
|
|
||||||
if (d->encodingBox->itemText(i) == codecName) {
|
|
||||||
d->encodingBox->setCurrentIndex(i);
|
|
||||||
return;
|
|
||||||
} else { // we've got System matching encoding - but have explicitly set the codec
|
|
||||||
rememberedSystemPosition = i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (rememberedSystemPosition != -1)
|
|
||||||
d->encodingBox->setCurrentIndex(rememberedSystemPosition);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QByteArray BehaviorSettingsWidget::assignedCodecName() const
|
QByteArray BehaviorSettingsWidget::assignedCodecName() const
|
||||||
{
|
{
|
||||||
return d->encodingBox->currentIndex() == 0
|
return d->encodingBox->assignedCodecName();
|
||||||
? QByteArray("System") // we prepend System to the available codecs
|
|
||||||
: d->m_codecs.at(d->encodingBox->currentIndex())->name();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void BehaviorSettingsWidget::setCodeStyle(ICodeStylePreferences *preferences)
|
void BehaviorSettingsWidget::setCodeStyle(ICodeStylePreferences *preferences)
|
||||||
@@ -488,9 +445,4 @@ void BehaviorSettingsWidget::slotExtraEncodingChanged()
|
|||||||
emit extraEncodingSettingsChanged(settings);
|
emit extraEncodingSettingsChanged(settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
void BehaviorSettingsWidget::slotEncodingBoxChanged(int index)
|
|
||||||
{
|
|
||||||
emit textCodecChanged(d->m_codecs.at(index));
|
|
||||||
}
|
|
||||||
|
|
||||||
} // TextEditor
|
} // TextEditor
|
||||||
|
@@ -88,7 +88,6 @@ private:
|
|||||||
void slotStorageSettingsChanged();
|
void slotStorageSettingsChanged();
|
||||||
void slotBehaviorSettingsChanged();
|
void slotBehaviorSettingsChanged();
|
||||||
void slotExtraEncodingChanged();
|
void slotExtraEncodingChanged();
|
||||||
void slotEncodingBoxChanged(int index);
|
|
||||||
void updateConstrainTooltipsBoxTooltip() const;
|
void updateConstrainTooltipsBoxTooltip() const;
|
||||||
|
|
||||||
BehaviorSettingsWidgetPrivate *d;
|
BehaviorSettingsWidgetPrivate *d;
|
||||||
|
95
src/plugins/texteditor/codecchooser.cpp
Normal file
95
src/plugins/texteditor/codecchooser.cpp
Normal file
@@ -0,0 +1,95 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** Copyright (C) 2022 The Qt Company Ltd.
|
||||||
|
** Contact: https://www.qt.io/licensing/
|
||||||
|
**
|
||||||
|
** This file is part of Qt Creator.
|
||||||
|
**
|
||||||
|
** Commercial License Usage
|
||||||
|
** Licensees holding valid commercial Qt licenses may use this file in
|
||||||
|
** accordance with the commercial license agreement provided with the
|
||||||
|
** Software or, alternatively, in accordance with the terms contained in
|
||||||
|
** a written agreement between you and The Qt Company. For licensing terms
|
||||||
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||||
|
** information use the contact form at https://www.qt.io/contact-us.
|
||||||
|
**
|
||||||
|
** GNU General Public License Usage
|
||||||
|
** Alternatively, this file may be used under the terms of the GNU
|
||||||
|
** General Public License version 3 as published by the Free Software
|
||||||
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
||||||
|
** included in the packaging of this file. Please review the following
|
||||||
|
** information to ensure the GNU General Public License requirements will
|
||||||
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
||||||
|
**
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include "codecchooser.h"
|
||||||
|
|
||||||
|
#include <utils/algorithm.h>
|
||||||
|
|
||||||
|
#include <QTextCodec>
|
||||||
|
|
||||||
|
namespace TextEditor {
|
||||||
|
|
||||||
|
CodecChooser::CodecChooser()
|
||||||
|
{
|
||||||
|
QList<int> mibs = QTextCodec::availableMibs();
|
||||||
|
Utils::sort(mibs);
|
||||||
|
QList<int>::iterator firstNonNegative =
|
||||||
|
std::find_if(mibs.begin(), mibs.end(), [](int n) { return n >=0; });
|
||||||
|
if (firstNonNegative != mibs.end())
|
||||||
|
std::rotate(mibs.begin(), firstNonNegative, mibs.end());
|
||||||
|
for (int mib : qAsConst(mibs)) {
|
||||||
|
if (QTextCodec *codec = QTextCodec::codecForMib(mib)) {
|
||||||
|
QString compoundName = QLatin1String(codec->name());
|
||||||
|
const QList<QByteArray> aliases = codec->aliases();
|
||||||
|
for (const QByteArray &alias : aliases) {
|
||||||
|
compoundName += QLatin1String(" / ");
|
||||||
|
compoundName += QString::fromLatin1(alias);
|
||||||
|
}
|
||||||
|
addItem(compoundName);
|
||||||
|
m_codecs.append(codec);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
connect(this, &QComboBox::currentIndexChanged,
|
||||||
|
this, [this](int index) { emit codecChanged(m_codecs.at(index)); });
|
||||||
|
}
|
||||||
|
|
||||||
|
QTextCodec *CodecChooser::currentCodec() const
|
||||||
|
{
|
||||||
|
return codecAt(currentIndex());
|
||||||
|
}
|
||||||
|
|
||||||
|
QTextCodec *CodecChooser::codecAt(int index) const
|
||||||
|
{
|
||||||
|
if (index < 0)
|
||||||
|
index = 0;
|
||||||
|
return m_codecs[index];
|
||||||
|
}
|
||||||
|
|
||||||
|
void CodecChooser::setAssignedCodec(QTextCodec *codec, const QString &name)
|
||||||
|
{
|
||||||
|
int rememberedSystemPosition = -1;
|
||||||
|
for (int i = 0, total = m_codecs.size(); i < total; ++i) {
|
||||||
|
if (codec != m_codecs.at(i))
|
||||||
|
continue;
|
||||||
|
if (itemText(i) == name) {
|
||||||
|
setCurrentIndex(i);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// we've got System matching encoding - but have explicitly set the codec
|
||||||
|
rememberedSystemPosition = i;
|
||||||
|
}
|
||||||
|
if (rememberedSystemPosition != -1)
|
||||||
|
setCurrentIndex(rememberedSystemPosition);
|
||||||
|
}
|
||||||
|
|
||||||
|
QByteArray CodecChooser::assignedCodecName() const
|
||||||
|
{
|
||||||
|
const int index = currentIndex();
|
||||||
|
return index == 0
|
||||||
|
? QByteArray("System") // we prepend System to the available codecs
|
||||||
|
: m_codecs.at(index)->name();
|
||||||
|
}
|
||||||
|
|
||||||
|
} // TextEditor
|
56
src/plugins/texteditor/codecchooser.h
Normal file
56
src/plugins/texteditor/codecchooser.h
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** Copyright (C) 2022 The Qt Company Ltd.
|
||||||
|
** Contact: https://www.qt.io/licensing/
|
||||||
|
**
|
||||||
|
** This file is part of Qt Creator.
|
||||||
|
**
|
||||||
|
** Commercial License Usage
|
||||||
|
** Licensees holding valid commercial Qt licenses may use this file in
|
||||||
|
** accordance with the commercial license agreement provided with the
|
||||||
|
** Software or, alternatively, in accordance with the terms contained in
|
||||||
|
** a written agreement between you and The Qt Company. For licensing terms
|
||||||
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||||
|
** information use the contact form at https://www.qt.io/contact-us.
|
||||||
|
**
|
||||||
|
** GNU General Public License Usage
|
||||||
|
** Alternatively, this file may be used under the terms of the GNU
|
||||||
|
** General Public License version 3 as published by the Free Software
|
||||||
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
||||||
|
** included in the packaging of this file. Please review the following
|
||||||
|
** information to ensure the GNU General Public License requirements will
|
||||||
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
||||||
|
**
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "texteditor_global.h"
|
||||||
|
|
||||||
|
#include <QComboBox>
|
||||||
|
|
||||||
|
QT_BEGIN_NAMESPACE
|
||||||
|
class QTextCodec;
|
||||||
|
QT_END_NAMESPACE
|
||||||
|
|
||||||
|
namespace TextEditor {
|
||||||
|
|
||||||
|
class TEXTEDITOR_EXPORT CodecChooser : public QComboBox
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
CodecChooser();
|
||||||
|
QTextCodec *currentCodec() const;
|
||||||
|
QTextCodec *codecAt(int index) const;
|
||||||
|
void setAssignedCodec(QTextCodec *codec, const QString &name);
|
||||||
|
QByteArray assignedCodecName() const;
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void codecChanged(QTextCodec *codec);
|
||||||
|
|
||||||
|
private:
|
||||||
|
QList<QTextCodec *> m_codecs;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace TextEditor
|
@@ -37,6 +37,8 @@ Project {
|
|||||||
"circularclipboard.h",
|
"circularclipboard.h",
|
||||||
"circularclipboardassist.cpp",
|
"circularclipboardassist.cpp",
|
||||||
"circularclipboardassist.h",
|
"circularclipboardassist.h",
|
||||||
|
"codecchooser.cpp",
|
||||||
|
"codecchooser.h",
|
||||||
"codestyleeditor.cpp",
|
"codestyleeditor.cpp",
|
||||||
"codestyleeditor.h",
|
"codestyleeditor.h",
|
||||||
"codestylepool.cpp",
|
"codestylepool.cpp",
|
||||||
|
Reference in New Issue
Block a user