refactoring qad widgets part 2
c++ cast, nullptr, forward declaration, agregate ui, connect to member functions, order and clear includes
This commit is contained in:
@@ -1,5 +1,12 @@
|
||||
#include "propertyeditor.h"
|
||||
#include "colorbutton.h"
|
||||
#include "qpointedit.h"
|
||||
#include "qrectedit.h"
|
||||
#include "clineedit.h"
|
||||
#include <QPainter>
|
||||
#include <QCheckBox>
|
||||
#include <QSpinBox>
|
||||
#include <QApplication>
|
||||
|
||||
|
||||
QWidget * Delegate::widgetForProperty(QWidget * parent, const QModelIndex & index) const {
|
||||
@@ -10,7 +17,6 @@ QWidget * Delegate::widgetForProperty(QWidget * parent, const QModelIndex & inde
|
||||
if (index.data(Qt::UserRole + 1).toString() == "__flag") {
|
||||
qulonglong key = index.data(Qt::UserRole).toULongLong();
|
||||
value = index.parent().data(Qt::UserRole);
|
||||
//QMetaProperty prop = index.parent().data(Qt::UserRole + 1).value<QMetaProperty>();
|
||||
w = new QCheckBox(parent); type = 14; ((QCheckBox*)w)->setChecked(((value.toULongLong() & key) == key && key != 0) || (value.toULongLong() == 0 && key == 0));
|
||||
((QCheckBox*)w)->setText("0x" + QString::number(key, 16).toUpper());
|
||||
connect((QCheckBox*)w, SIGNAL(clicked(bool)), this, SLOT(changedFlag()));
|
||||
|
||||
@@ -22,6 +22,7 @@
|
||||
#include "loader_3ds.h"
|
||||
#include "loader_obj.h"
|
||||
#include "loader_dae.h"
|
||||
#include "qad_types.h"
|
||||
#include <QGraphicsRectItem>
|
||||
#include <QImageReader>
|
||||
#include <QMessageBox>
|
||||
|
||||
@@ -85,7 +85,7 @@ void ImageView::clear() {
|
||||
}
|
||||
|
||||
|
||||
void ImageView::mouseDoubleClickEvent(QMouseEvent * e) {
|
||||
void ImageView::mouseDoubleClickEvent(QMouseEvent *) {
|
||||
autofit();
|
||||
}
|
||||
|
||||
@@ -121,7 +121,7 @@ bool ImageView::eventFilter(QObject * o, QEvent * e) {
|
||||
break;
|
||||
case QEvent::MouseMove:
|
||||
if (me->buttons().testFlag(Qt::RightButton) && !autofit_ && viewInteractive()) {
|
||||
QPointF dp = QPointF(me->pos() - prev_pos);
|
||||
QPoint dp = QPoint(me->pos() - prev_pos);
|
||||
horizontalScrollBar()->setValue(horizontalScrollBar()->value() - dp.x());
|
||||
verticalScrollBar()->setValue(verticalScrollBar()->value() - dp.y());
|
||||
prev_pos = me->pos();
|
||||
|
||||
@@ -52,7 +52,7 @@ signals:
|
||||
void clicked(QPointF, Qt::MouseButtons);
|
||||
|
||||
private:
|
||||
void mouseDoubleClickEvent(QMouseEvent * e) override;
|
||||
void mouseDoubleClickEvent(QMouseEvent *) override;
|
||||
void mousePressEvent(QMouseEvent * e) override;
|
||||
void wheelEvent(QWheelEvent * e) override;
|
||||
bool eventFilter(QObject * o, QEvent * e) override;
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
#include "mathmatrixedit.h"
|
||||
#include "qvariantedit_custom.h"
|
||||
#include "matrixedit.h"
|
||||
#include "qvariantedit_custom.h"
|
||||
#include "qad_types.h"
|
||||
#include <QBoxLayout>
|
||||
|
||||
|
||||
@@ -43,7 +44,7 @@ void MathMatrixEdit::setReadOnly(bool yes) {
|
||||
class MathMatrixEditFactory: public QVariantEditorFactoryBase {
|
||||
public:
|
||||
MathMatrixEditFactory() {}
|
||||
virtual QWidget * createEditor() {return new MathMatrixEdit();}
|
||||
QWidget * createEditor() override {return new MathMatrixEdit();}
|
||||
};
|
||||
|
||||
|
||||
|
||||
@@ -20,9 +20,9 @@
|
||||
#ifndef MATH_MATRIX_EDIT_H
|
||||
#define MATH_MATRIX_EDIT_H
|
||||
|
||||
#include <QWidget>
|
||||
#include "qad_types.h"
|
||||
#include "qad_widgets_export.h"
|
||||
#include <QWidget>
|
||||
#include <QVariant>
|
||||
|
||||
|
||||
class MatrixEdit;
|
||||
@@ -33,15 +33,12 @@ class QAD_WIDGETS_EXPORT MathMatrixEdit: public QWidget {
|
||||
Q_PROPERTY(QVariant value READ value WRITE setValue NOTIFY valueChanged)
|
||||
Q_PROPERTY(bool readOnly READ isReadOnly WRITE setReadOnly)
|
||||
public:
|
||||
explicit MathMatrixEdit(QWidget * parent = 0);
|
||||
~MathMatrixEdit();
|
||||
explicit MathMatrixEdit(QWidget * parent = nullptr);
|
||||
~MathMatrixEdit() override;
|
||||
|
||||
QVariant value() const;
|
||||
bool isReadOnly() const;
|
||||
|
||||
private:
|
||||
MatrixEdit * edit;
|
||||
|
||||
public slots:
|
||||
void setValue(const QVariant & v);
|
||||
void setReadOnly(bool yes);
|
||||
@@ -49,6 +46,8 @@ public slots:
|
||||
signals:
|
||||
void valueChanged();
|
||||
|
||||
private:
|
||||
MatrixEdit * edit;
|
||||
};
|
||||
|
||||
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
#include "mathvectoredit.h"
|
||||
#include "qvariantedit_custom.h"
|
||||
#include "qad_types.h"
|
||||
#include "matrixedit.h"
|
||||
#include <QBoxLayout>
|
||||
|
||||
@@ -43,11 +44,10 @@ void MathVectorEdit::setReadOnly(bool yes) {
|
||||
class MathVectorEditFactory: public QVariantEditorFactoryBase {
|
||||
public:
|
||||
MathVectorEditFactory() {}
|
||||
virtual QWidget * createEditor() {return new MathVectorEdit();}
|
||||
virtual QWidget * createEditor() override {return new MathVectorEdit();}
|
||||
};
|
||||
|
||||
|
||||
__MathVectorEditRegistrator__::__MathVectorEditRegistrator__() {
|
||||
QVariantEditorFactories::registerEditorFactory(qMetaTypeId<QAD::MathVector>(), new MathVectorEditFactory());
|
||||
//__QADTypesRegistrator__::instance()->toString_funcs.insert(qMetaTypeId<QAD::IODevice>(), &QAD_IODevice_toString);
|
||||
}
|
||||
|
||||
@@ -20,9 +20,9 @@
|
||||
#ifndef MATH_VECTOR_EDIT_H
|
||||
#define MATH_VECTOR_EDIT_H
|
||||
|
||||
#include <QWidget>
|
||||
#include "qad_types.h"
|
||||
#include "qad_widgets_export.h"
|
||||
#include <QWidget>
|
||||
#include <QVariant>
|
||||
|
||||
|
||||
class MatrixEdit;
|
||||
@@ -33,15 +33,12 @@ class QAD_WIDGETS_EXPORT MathVectorEdit: public QWidget {
|
||||
Q_PROPERTY(QVariant value READ value WRITE setValue NOTIFY valueChanged)
|
||||
Q_PROPERTY(bool readOnly READ isReadOnly WRITE setReadOnly)
|
||||
public:
|
||||
explicit MathVectorEdit(QWidget * parent = 0);
|
||||
~MathVectorEdit();
|
||||
explicit MathVectorEdit(QWidget * parent = nullptr);
|
||||
~MathVectorEdit() override;
|
||||
|
||||
QVariant value() const;
|
||||
bool isReadOnly() const;
|
||||
|
||||
private:
|
||||
MatrixEdit * edit;
|
||||
|
||||
public slots:
|
||||
void setValue(const QVariant & v);
|
||||
void setReadOnly(bool yes);
|
||||
@@ -49,6 +46,8 @@ public slots:
|
||||
signals:
|
||||
void valueChanged();
|
||||
|
||||
private:
|
||||
MatrixEdit * edit;
|
||||
};
|
||||
|
||||
|
||||
|
||||
@@ -26,13 +26,14 @@ bool MatrixEdit::isReadOnly() const {
|
||||
|
||||
void MatrixEdit::setReadOnly(bool yes) {
|
||||
ro = yes;
|
||||
/// TODO
|
||||
/// TODO : readonly not implemented
|
||||
}
|
||||
|
||||
|
||||
void MatrixEdit::setVectorMode(bool yes) {
|
||||
if (yes)
|
||||
if (yes) {
|
||||
ui->spinCols->setValue(1);
|
||||
}
|
||||
ui->labelCols->setHidden(yes);
|
||||
ui->spinCols->setHidden(yes);
|
||||
ui->buttonIdentity->setHidden(yes);
|
||||
@@ -74,7 +75,9 @@ QVector<double> MatrixEdit::vector() const {
|
||||
ret.fill(0.);
|
||||
for (int r = 0; r < ret.size(); ++r) {
|
||||
QTableWidgetItem * i = ui->table->item(r, 0);
|
||||
if (!i) continue;
|
||||
if (!i) {
|
||||
continue;
|
||||
}
|
||||
ret[r] = i->text().toDouble();
|
||||
}
|
||||
return ret;
|
||||
@@ -91,7 +94,9 @@ QVector<QVector<double> > MatrixEdit::matrix() const {
|
||||
ret[r].fill(0.);
|
||||
for (int c = 0; c < cc; ++c) {
|
||||
QTableWidgetItem * i = ui->table->item(r, c);
|
||||
if (!i) continue;
|
||||
if (!i) {
|
||||
continue;
|
||||
}
|
||||
ret[r][c] = i->text().toDouble();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -20,8 +20,8 @@
|
||||
#ifndef MATRIXEDIT_H
|
||||
#define MATRIXEDIT_H
|
||||
|
||||
#include <QWidget>
|
||||
#include "qad_widgets_export.h"
|
||||
#include <QWidget>
|
||||
|
||||
|
||||
namespace Ui {
|
||||
@@ -32,8 +32,8 @@ namespace Ui {
|
||||
class QAD_WIDGETS_EXPORT MatrixEdit: public QWidget {
|
||||
Q_OBJECT
|
||||
public:
|
||||
explicit MatrixEdit(QWidget * parent = 0);
|
||||
~MatrixEdit();
|
||||
explicit MatrixEdit(QWidget * parent = nullptr);
|
||||
~MatrixEdit() override;
|
||||
|
||||
bool isReadOnly() const;
|
||||
void setReadOnly(bool yes);
|
||||
@@ -43,14 +43,6 @@ public:
|
||||
void setVector(const QVector<double> & v);
|
||||
void setMatrix(const QVector<QVector<double> > & v);
|
||||
|
||||
private:
|
||||
void setVectorMode(bool yes);
|
||||
void clear(bool ident = false);
|
||||
void changeEvent(QEvent * e);
|
||||
|
||||
Ui::MatrixEdit * ui;
|
||||
bool ro;
|
||||
|
||||
private slots:
|
||||
void on_spinRows_valueChanged(int cnt);
|
||||
void on_spinCols_valueChanged(int cnt);
|
||||
@@ -60,6 +52,13 @@ private slots:
|
||||
signals:
|
||||
void changed();
|
||||
|
||||
private:
|
||||
void setVectorMode(bool yes);
|
||||
void clear(bool ident = false);
|
||||
void changeEvent(QEvent * e) override;
|
||||
|
||||
Ui::MatrixEdit * ui;
|
||||
bool ro;
|
||||
};
|
||||
|
||||
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
#include "propertystorage_editor.h"
|
||||
#include "propertystorage.h"
|
||||
#include "qvariantedit.h"
|
||||
#include <QGridLayout>
|
||||
#include <QToolButton>
|
||||
@@ -7,7 +8,7 @@
|
||||
PropertyStorageEditor::PropertyStorageEditor(QWidget * parent): QWidget(parent) {
|
||||
setLayout(new QGridLayout());
|
||||
layout()->setContentsMargins(0, 0, 0, 0);
|
||||
storage = 0;
|
||||
storage = nullptr;
|
||||
}
|
||||
|
||||
|
||||
@@ -23,7 +24,7 @@ void PropertyStorageEditor::clear() {
|
||||
|
||||
|
||||
bool PropertyStorageEditor::isEmpty() const {
|
||||
return ((QGridLayout*)layout())->count() == 0;
|
||||
return static_cast<QGridLayout*>(layout())->count() == 0;
|
||||
}
|
||||
|
||||
|
||||
@@ -32,13 +33,13 @@ void PropertyStorageEditor::setStorage(PropertyStorage * s) {
|
||||
storage = s;
|
||||
if (!storage) return;
|
||||
int r = 0;
|
||||
QGridLayout * layoutProps = (QGridLayout*)layout();
|
||||
foreach (const PropertyStorage::Property & p, *storage) {
|
||||
QLabel * lbl = new QLabel(p.name);
|
||||
auto layoutProps = static_cast<QGridLayout*>(layout());
|
||||
for (const PropertyStorage::Property & p : *storage) {
|
||||
auto lbl = new QLabel(p.name);
|
||||
_widgets << lbl;
|
||||
lbl->setAlignment(Qt::AlignVCenter | Qt::AlignRight);
|
||||
layoutProps->addWidget(lbl, r, 0);
|
||||
QVariantEdit * ve = new QVariantEdit();
|
||||
auto ve = new QVariantEdit();
|
||||
ve->setValue(p.value);
|
||||
ve->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred);
|
||||
ve->setMinimumWidth(50);
|
||||
@@ -54,12 +55,16 @@ void PropertyStorageEditor::setStorage(PropertyStorage * s) {
|
||||
void PropertyStorageEditor::applyProperties() {
|
||||
if (!storage) return;
|
||||
QList<PropertyStorage::Property> & props(storage->properties());
|
||||
QGridLayout * layoutProps = (QGridLayout*)layout();
|
||||
auto layoutProps = static_cast<QGridLayout*>(layout());
|
||||
for (int r = 0; r < layoutProps->rowCount(); ++r) {
|
||||
if (layoutProps->itemAtPosition(r, 0) == 0 || layoutProps->itemAtPosition(r, 1) == 0) continue;
|
||||
if (layoutProps->itemAtPosition(r, 0) == nullptr || layoutProps->itemAtPosition(r, 1) == nullptr) {
|
||||
continue;
|
||||
}
|
||||
QLabel * lbl = qobject_cast<QLabel * >(layoutProps->itemAtPosition(r, 0)->widget());
|
||||
QVariantEdit * ve = qobject_cast<QVariantEdit * >(layoutProps->itemAtPosition(r, 1)->widget());
|
||||
if (lbl == 0 || ve == 0) continue;
|
||||
if (lbl == nullptr || ve == nullptr) {
|
||||
continue;
|
||||
}
|
||||
QString pn = lbl->text();
|
||||
for (int i = 0; i < props.size(); ++i) {
|
||||
PropertyStorage::Property & p(props[i]);
|
||||
|
||||
@@ -21,29 +21,30 @@
|
||||
#define PROPERTYSTORAGEEDITOR_H
|
||||
|
||||
#include <QWidget>
|
||||
#include "propertystorage.h"
|
||||
#include "qad_widgets_export.h"
|
||||
|
||||
|
||||
class PropertyStorage;
|
||||
|
||||
|
||||
class QAD_WIDGETS_EXPORT PropertyStorageEditor: public QWidget {
|
||||
Q_OBJECT
|
||||
public:
|
||||
explicit PropertyStorageEditor(QWidget * parent = 0);
|
||||
~PropertyStorageEditor();
|
||||
explicit PropertyStorageEditor(QWidget * parent = nullptr);
|
||||
~PropertyStorageEditor() override;
|
||||
|
||||
void clear();
|
||||
bool isEmpty() const;
|
||||
void setStorage(PropertyStorage * s);
|
||||
void applyProperties();
|
||||
|
||||
private:
|
||||
QList<QWidget*> _widgets;
|
||||
PropertyStorage * storage;
|
||||
|
||||
signals:
|
||||
void resetStorageRequest(PropertyStorage * );
|
||||
void changed();
|
||||
|
||||
private:
|
||||
QList<QWidget*> _widgets;
|
||||
PropertyStorage * storage;
|
||||
};
|
||||
|
||||
#endif // PROPERTYSTORAGEEDITOR_H
|
||||
|
||||
@@ -1,5 +1,9 @@
|
||||
#include "qcodeedit.h"
|
||||
#include "ui_qcodeedit.h"
|
||||
#include "qcodeedit_completer_p.h"
|
||||
#include "ecombobox.h"
|
||||
#include "qad_types.h"
|
||||
#include "iconedlabel.h"
|
||||
#include <QLayout>
|
||||
#include <QBoxLayout>
|
||||
#include <QScrollBar>
|
||||
@@ -13,12 +17,10 @@
|
||||
#include <QApplication>
|
||||
#include <QDesktopServices>
|
||||
#include <QPainter>
|
||||
#include <QPlainTextEdit>
|
||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 0, 0)
|
||||
# include <QWindow>
|
||||
#endif
|
||||
#include "ecombobox.h"
|
||||
#include "qad_types.h"
|
||||
#include "ui_qcodeedit.h"
|
||||
|
||||
Q_DECLARE_METATYPE(QTextCursor)
|
||||
Q_DECLARE_METATYPE(QCodeEdit::ACEntry)
|
||||
@@ -29,10 +31,9 @@ public:
|
||||
_QCE_Viewport(QWidget * p = nullptr): QWidget(p) {
|
||||
setObjectName("__qcodeedit_viewport__");
|
||||
setMouseTracking(true);
|
||||
//setCursor(Qt::IBeamCursor);
|
||||
}
|
||||
|
||||
void paintEvent(QPaintEvent * e) override {
|
||||
void paintEvent(QPaintEvent *) override {
|
||||
if (!isEnabled()) return;
|
||||
ce->drawCursor();
|
||||
}
|
||||
@@ -42,8 +43,8 @@ public:
|
||||
};
|
||||
|
||||
|
||||
QCodeEdit::QCodeEdit(QWidget * parent): QWidget(parent) {
|
||||
overlay = 0;
|
||||
QCodeEdit::QCodeEdit(QWidget * parent): QWidget(parent), ui(new Ui::QCodeEdit) {
|
||||
overlay = nullptr;
|
||||
prev_lc = auto_comp_pl = cur_search_ind = pos_press = pos_el_press = -1;
|
||||
timer_parse = 0;
|
||||
_ignore_focus_out = _destructor = _replacing = cursor_state = block_sel_state = false;
|
||||
@@ -51,7 +52,6 @@ QCodeEdit::QCodeEdit(QWidget * parent): QWidget(parent) {
|
||||
comment_text = "//";
|
||||
qRegisterMetaType<QTextCursor>();
|
||||
qRegisterMetaType<QCodeEdit::ACEntry>();
|
||||
ui = new Ui::QCodeEdit();
|
||||
ui->setupUi(this);
|
||||
overlay = new _QCE_Viewport(ui->textCode->viewport());
|
||||
overlay->ce = this;
|
||||
@@ -127,9 +127,6 @@ QCodeEdit::QCodeEdit(QWidget * parent): QWidget(parent) {
|
||||
QTextOption to = ui->textLines->document()->defaultTextOption();
|
||||
to.setAlignment(Qt::AlignTop | Qt::AlignRight);
|
||||
ui->textLines->document()->setDefaultTextOption(to);
|
||||
/*to = ui->textCode->document()->defaultTextOption();
|
||||
to.setFlags(QTextOption::SuppressColors);
|
||||
ui->textCode->document()->setDefaultTextOption(to);*/
|
||||
setShowSpaces(true);
|
||||
|
||||
a = new QAction(this);
|
||||
@@ -138,12 +135,6 @@ QCodeEdit::QCodeEdit(QWidget * parent): QWidget(parent) {
|
||||
connect(a, SIGNAL(triggered(bool)), this, SLOT(search_triggered()));
|
||||
addAction(a);
|
||||
|
||||
/*a = new QAction(this);
|
||||
a->setShortcut(QKeySequence("Esc"));
|
||||
a->setShortcutContext(Qt::WidgetWithChildrenShortcut);
|
||||
connect(a, SIGNAL(triggered(bool)), this, SLOT(hideSearch()));
|
||||
addAction(a);*/
|
||||
|
||||
connect(completer, SIGNAL(itemDoubleClicked(QTreeWidgetItem * ,int)), this, SLOT(commitCompletition()));
|
||||
connect(completer, SIGNAL(commit()), this, SLOT(commitCompletition()));
|
||||
connect(completer, SIGNAL(gotoHRef(QCodeEdit::ACEntry)), this, SLOT(gotoHelpHRef(QCodeEdit::ACEntry)));
|
||||
@@ -159,7 +150,7 @@ QCodeEdit::QCodeEdit(QWidget * parent): QWidget(parent) {
|
||||
connect(ui->comboSearch->lineEdit(), SIGNAL(returnPressed()), this, SLOT(searchNext()));
|
||||
connect(ui->comboReplace->lineEdit(), SIGNAL(returnPressed()), this, SLOT(on_buttonReplaceSearch_clicked()));
|
||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 0, 0)
|
||||
connect(qApp, &QGuiApplication::focusWindowChanged, this, [this](QWindow*w){if (w == 0) {hideHelp(); completer->hide();}});
|
||||
connect(qApp, &QGuiApplication::focusWindowChanged, this, [this](QWindow*w){if (w == nullptr) {hideHelp(); completer->hide();}});
|
||||
#endif
|
||||
updateLines();
|
||||
timer_blink = startTimer(QApplication::cursorFlashTime() / 2);
|
||||
@@ -171,10 +162,8 @@ QCodeEdit::QCodeEdit(QWidget * parent): QWidget(parent) {
|
||||
QCodeEdit::~QCodeEdit() {
|
||||
_destructor = true;
|
||||
delete completer;
|
||||
//for (int i = 0; i < 2; ++i)
|
||||
// delete lbl_help[i];
|
||||
delete widget_help;
|
||||
//delete ui;
|
||||
delete ui;
|
||||
}
|
||||
|
||||
|
||||
@@ -198,8 +187,8 @@ void QCodeEdit::setDocument(QTextDocument * doc) {
|
||||
ui->textLines->setEnabled(doc);
|
||||
documentUnset();
|
||||
if (!doc) {
|
||||
ui->textCode->setDocument(0);
|
||||
documentChanged(0);
|
||||
ui->textCode->setDocument(nullptr);
|
||||
documentChanged(nullptr);
|
||||
return;
|
||||
}
|
||||
if (!qobject_cast<QPlainTextDocumentLayout*>(doc->documentLayout()))
|
||||
@@ -207,7 +196,6 @@ void QCodeEdit::setDocument(QTextDocument * doc) {
|
||||
ui->textCode->setDocument(doc);
|
||||
cursor_width = qMax<int>(qRound(fontHeight(this) / 10.), 1);
|
||||
ui->textCode->setCursorWidth(0);
|
||||
//ui->textCode->setCursorWidth(qMax<int>(qRound(fontHeight() / 10.), 1));
|
||||
setShowSpaces(spaces_);
|
||||
if (doc->property("_cursor").isValid()) {
|
||||
setTextCursor(doc->property("_cursor").value<QTextCursor>());
|
||||
@@ -388,46 +376,41 @@ bool QCodeEdit::eventFilter(QObject * o, QEvent * e) {
|
||||
return QWidget::eventFilter(o, e);
|
||||
}
|
||||
if (ui->textLines) {
|
||||
if (o == ui->textLines->viewport()) {/*
|
||||
if (e->type() == QEvent::MouseButtonPress || e->type() == QEvent::MouseButtonRelease ||
|
||||
e->type() == QEvent::MouseMove || e->type() == QEvent::MouseButtonDblClick) {
|
||||
#if (QT_VERSION < 0x050000)
|
||||
const_cast<QPoint&>(((QMouseEvent*)e)->pos()) = QPoint(0, ((QMouseEvent*)e)->pos().y());
|
||||
#else
|
||||
const_cast<QPointF&>(((QMouseEvent*)e)->localPos()) = QPointF(0, ((QMouseEvent*)e)->localPos().y());
|
||||
#endif
|
||||
QApplication::sendEvent(ui->textCode->viewport(), e);
|
||||
return true;
|
||||
}*/
|
||||
if (o == ui->textLines->viewport()) {
|
||||
QTextCursor tc;
|
||||
int tcpos = 0;
|
||||
switch (e->type()) {
|
||||
case QEvent::MouseButtonPress:
|
||||
if (!isEnabled()) break;
|
||||
tc = ui->textCode->cursorForPosition(((QMouseEvent*)e)->pos());
|
||||
if (!isEnabled()) {
|
||||
break;
|
||||
}
|
||||
tc = ui->textCode->cursorForPosition(static_cast<QMouseEvent*>(e)->pos());
|
||||
tc.movePosition(QTextCursor::EndOfLine);
|
||||
pos_el_press = tc.anchor();
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
pos_press = tc.anchor();
|
||||
if (!tc.movePosition(QTextCursor::Down, QTextCursor::KeepAnchor))
|
||||
if (!tc.movePosition(QTextCursor::Down, QTextCursor::KeepAnchor)) {
|
||||
tc.movePosition(QTextCursor::EndOfLine, QTextCursor::KeepAnchor);
|
||||
}
|
||||
ui->textCode->setFocus();
|
||||
ui->textCode->setTextCursor(tc);
|
||||
return true;
|
||||
case QEvent::MouseMove:
|
||||
if (!isEnabled()) break;
|
||||
tc = ui->textCode->cursorForPosition(((QMouseEvent*)e)->pos());
|
||||
tc = ui->textCode->cursorForPosition(static_cast<QMouseEvent*>(e)->pos());
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
if (pos_press == tc.anchor()) {
|
||||
if (!tc.movePosition(QTextCursor::Down, QTextCursor::KeepAnchor))
|
||||
if (!tc.movePosition(QTextCursor::Down, QTextCursor::KeepAnchor)) {
|
||||
tc.movePosition(QTextCursor::EndOfLine, QTextCursor::KeepAnchor);
|
||||
}
|
||||
ui->textCode->setTextCursor(tc);
|
||||
return true;
|
||||
}
|
||||
if (pos_press < tc.anchor()) {
|
||||
if (!tc.movePosition(QTextCursor::Down, QTextCursor::KeepAnchor))
|
||||
if (!tc.movePosition(QTextCursor::Down, QTextCursor::KeepAnchor)) {
|
||||
tc.movePosition(QTextCursor::EndOfLine, QTextCursor::KeepAnchor);
|
||||
}
|
||||
}
|
||||
tcpos = tc.position();
|
||||
tc.setPosition(pos_press < tc.anchor() ? pos_press : pos_el_press);
|
||||
tc.setPosition(tcpos, QTextCursor::KeepAnchor);
|
||||
@@ -451,7 +434,7 @@ bool QCodeEdit::eventFilter(QObject * o, QEvent * e) {
|
||||
if (o == ui->comboSearch || o == ui->comboReplace) {
|
||||
//qDebug() << o << e;
|
||||
if (e->type() == QEvent::KeyPress) {
|
||||
if (((QKeyEvent * )e)->key() == Qt::Key_Escape) {
|
||||
if (static_cast<QKeyEvent*>(e)->key() == Qt::Key_Escape) {
|
||||
hideHelp();
|
||||
if (completer->isVisible())
|
||||
completer->hide();
|
||||
@@ -469,14 +452,14 @@ bool QCodeEdit::eventFilter(QObject * o, QEvent * e) {
|
||||
cancelBlockSelection();
|
||||
completer->hide();
|
||||
hideHelp();
|
||||
QMouseEvent * me = (QMouseEvent*)e;
|
||||
auto me = static_cast<QMouseEvent*>(e);
|
||||
if (me->modifiers().testFlag(Qt::ControlModifier) && (me->button() == Qt::LeftButton))
|
||||
if (!hasBlockSelection() && !ui->textCode->textCursor().hasSelection())
|
||||
gotoLink();
|
||||
} break;
|
||||
case QEvent::MouseMove: {
|
||||
if (!completer->isHidden()) break;
|
||||
QMouseEvent * me = (QMouseEvent*)e;
|
||||
auto me = static_cast<QMouseEvent*>(e);
|
||||
if (me->buttons() != 0)
|
||||
switchBlockSelection();
|
||||
if (me->modifiers().testFlag(Qt::ControlModifier))
|
||||
@@ -490,9 +473,9 @@ bool QCodeEdit::eventFilter(QObject * o, QEvent * e) {
|
||||
if (!isEnabled()) break;
|
||||
drag_cursor = ui->textCode->cursorForPosition(
|
||||
#if QT_VERSION_MAJOR <= 5
|
||||
((QDragMoveEvent*)e)->pos()
|
||||
static_cast<QDragMoveEvent*>(e)->pos()
|
||||
#else
|
||||
((QDragMoveEvent*)e)->position().toPoint()
|
||||
static_cast<QDragMoveEvent*>(e)->position().toPoint()
|
||||
#endif
|
||||
);
|
||||
repaintCursor();
|
||||
@@ -512,14 +495,14 @@ bool QCodeEdit::eventFilter(QObject * o, QEvent * e) {
|
||||
switch (e->type()) {
|
||||
case QEvent::ToolTip:
|
||||
if (completer->isHidden()) {
|
||||
QTextCursor tc = ui->textCode->cursorForPosition(((QHelpEvent*)e)->pos());
|
||||
QTextCursor tc = ui->textCode->cursorForPosition(static_cast<QHelpEvent*>(e)->pos());
|
||||
tc.select(QTextCursor::WordUnderCursor);
|
||||
raiseHelp(tc);
|
||||
}
|
||||
break;
|
||||
case QEvent::KeyPress:
|
||||
//qDebug() << "key" << ke;
|
||||
if (codeKeyEvent((QKeyEvent * )e))
|
||||
if (codeKeyEvent(static_cast<QKeyEvent*>(e)))
|
||||
return true;
|
||||
break;
|
||||
case QEvent::KeyRelease:
|
||||
@@ -608,10 +591,11 @@ bool QCodeEdit::codeKeyEvent(QKeyEvent * ke) {
|
||||
break;
|
||||
case Qt::Key_Escape:
|
||||
hideHelp();
|
||||
if (completer->isVisible())
|
||||
if (completer->isVisible()) {
|
||||
completer->hide();
|
||||
else
|
||||
} else {
|
||||
hideSearch();
|
||||
}
|
||||
break;
|
||||
case Qt::Key_Up:
|
||||
switchBlockSelection(ke);
|
||||
@@ -622,10 +606,11 @@ bool QCodeEdit::codeKeyEvent(QKeyEvent * ke) {
|
||||
completer->hide();
|
||||
hideHelp();
|
||||
if (ke->modifiers().testFlag(Qt::AltModifier)) {
|
||||
if (ke->modifiers().testFlag(Qt::ShiftModifier))
|
||||
if (ke->modifiers().testFlag(Qt::ShiftModifier)) {
|
||||
return false;
|
||||
else
|
||||
} else {
|
||||
copyLineUp();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
if (ke->modifiers().testFlag(Qt::ControlModifier) && ke->modifiers().testFlag(Qt::ShiftModifier)) {
|
||||
@@ -642,10 +627,11 @@ bool QCodeEdit::codeKeyEvent(QKeyEvent * ke) {
|
||||
completer->hide();
|
||||
hideHelp();
|
||||
if (ke->modifiers().testFlag(Qt::AltModifier)) {
|
||||
if (ke->modifiers().testFlag(Qt::ShiftModifier))
|
||||
if (ke->modifiers().testFlag(Qt::ShiftModifier)) {
|
||||
return false;
|
||||
else
|
||||
} else {
|
||||
copyLineDown();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
if (ke->modifiers().testFlag(Qt::ControlModifier) && ke->modifiers().testFlag(Qt::ShiftModifier)) {
|
||||
@@ -666,13 +652,17 @@ bool QCodeEdit::codeKeyEvent(QKeyEvent * ke) {
|
||||
case Qt::Key_Left:
|
||||
case Qt::Key_Right:
|
||||
switchBlockSelection(ke);
|
||||
if (hasBlockSelection()) break;
|
||||
if (hasBlockSelection()) {
|
||||
break;
|
||||
}
|
||||
case Qt::Key_Backspace:
|
||||
case Qt::Key_Delete:
|
||||
if (completer->isVisible())
|
||||
if (completer->isVisible()) {
|
||||
QMetaObject::invokeMethod(this, "invokeAutoCompletition", Qt::QueuedConnection, Q_ARG(bool, false));
|
||||
if (removeBlockSelection(ke->key() == Qt::Key_Delete))
|
||||
}
|
||||
if (removeBlockSelection(ke->key() == Qt::Key_Delete)) {
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case Qt::Key_Return:
|
||||
if (hasBlockSelection()) {
|
||||
@@ -684,15 +674,17 @@ bool QCodeEdit::codeKeyEvent(QKeyEvent * ke) {
|
||||
completer->hide();
|
||||
return true;
|
||||
}
|
||||
if (ui->textCode->textCursor().selectedText().isEmpty())
|
||||
if (ui->textCode->textCursor().selectedText().isEmpty()) {
|
||||
QMetaObject::invokeMethod(this, "autoIndent", Qt::QueuedConnection);
|
||||
}
|
||||
break;
|
||||
case Qt::Key_Tab:
|
||||
if (!ui->textCode->textCursor().selectedText().isEmpty()) {
|
||||
if (ke->modifiers().testFlag(Qt::ShiftModifier))
|
||||
if (ke->modifiers().testFlag(Qt::ShiftModifier)) {
|
||||
deindent();
|
||||
else
|
||||
} else {
|
||||
indent();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
@@ -703,12 +695,14 @@ bool QCodeEdit::codeKeyEvent(QKeyEvent * ke) {
|
||||
}
|
||||
break;
|
||||
case Qt::Key_Control:
|
||||
if (!hasBlockSelection() && !ui->textCode->textCursor().hasSelection())
|
||||
if (!hasBlockSelection() && !ui->textCode->textCursor().hasSelection()) {
|
||||
showLink();
|
||||
}
|
||||
break;
|
||||
case Qt::Key_F1:
|
||||
if (widget_help->isVisible())
|
||||
if (widget_help->isVisible()) {
|
||||
gotoHelpHRef(help_entry);
|
||||
}
|
||||
break;
|
||||
default: break;
|
||||
}
|
||||
@@ -723,9 +717,10 @@ bool QCodeEdit::codeKeyEvent(QKeyEvent * ke) {
|
||||
completer->hide();
|
||||
QMetaObject::invokeMethod(this, "invokeAutoCompletition", Qt::QueuedConnection, Q_ARG(bool, false));
|
||||
} else {
|
||||
if ((kc.isLetterOrNumber() || kc.toLatin1() == '_') && completer->isVisible())
|
||||
if ((kc.isLetterOrNumber() || kc.toLatin1() == '_') && completer->isVisible()) {
|
||||
QMetaObject::invokeMethod(this, "invokeAutoCompletition", Qt::QueuedConnection, Q_ARG(bool, false));
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@@ -733,14 +728,21 @@ bool QCodeEdit::codeKeyEvent(QKeyEvent * ke) {
|
||||
void QCodeEdit::toggleComment() {
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
tc.beginEditBlock();
|
||||
int ss = tc.selectionStart(), ss_ = ss, se = tc.selectionEnd(), se_ = se;
|
||||
int ss = tc.selectionStart();
|
||||
int ss_ = ss;
|
||||
int se = tc.selectionEnd();
|
||||
QString st_ = tc.selection().toPlainText();
|
||||
if (st_.endsWith("\n")) {
|
||||
st_.chop(1);
|
||||
se--; se_--;
|
||||
se--;
|
||||
}
|
||||
tc.setPosition(ss); tc.movePosition(QTextCursor::StartOfLine); ss = tc.position();
|
||||
tc.setPosition(se); tc.movePosition(QTextCursor::EndOfLine ); se = tc.position();
|
||||
int se_ = se;
|
||||
tc.setPosition(ss);
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
ss = tc.position();
|
||||
tc.setPosition(se);
|
||||
tc.movePosition(QTextCursor::EndOfLine );
|
||||
se = tc.position();
|
||||
tc.setPosition(ss);
|
||||
bool need_comment = false;
|
||||
QMap<int, bool> comms;
|
||||
@@ -754,12 +756,14 @@ void QCodeEdit::toggleComment() {
|
||||
need_comment = true;
|
||||
comms[line] = false;
|
||||
}
|
||||
} else
|
||||
} else {
|
||||
comms[line] = false;
|
||||
}
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
if (!tc.movePosition(QTextCursor::Down))
|
||||
if (!tc.movePosition(QTextCursor::Down)) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
tc.setPosition(ss);
|
||||
bool first = true;
|
||||
while (tc.position() <= se_) {
|
||||
@@ -780,9 +784,10 @@ void QCodeEdit::toggleComment() {
|
||||
}
|
||||
first = false;
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
if (!tc.movePosition(QTextCursor::Down))
|
||||
if (!tc.movePosition(QTextCursor::Down)) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
tc.setPosition(ss_);
|
||||
tc.setPosition(se_, QTextCursor::KeepAnchor);
|
||||
ui->textCode->setTextCursor(tc);
|
||||
@@ -822,7 +827,8 @@ void QCodeEdit::highlightBrackets() {
|
||||
es.cursor = tc;
|
||||
es_brackets << es;
|
||||
QTextCursor ftc = tc;
|
||||
int bcnt = 1; char fch = antiBracket(ch);
|
||||
int bcnt = 1;
|
||||
char fch = antiBracket(ch);
|
||||
while (bcnt > 0) {
|
||||
ftc.setPosition(ftc.position());
|
||||
if (!ftc.movePosition(mop[d], QTextCursor::KeepAnchor)) break;
|
||||
@@ -836,12 +842,13 @@ void QCodeEdit::highlightBrackets() {
|
||||
es_brackets << es;
|
||||
es.format = es_range.format;
|
||||
es.cursor.setPosition(tc.position(), QTextCursor::KeepAnchor);
|
||||
if (!es.cursor.selection().isEmpty())
|
||||
if (!es.cursor.selection().isEmpty()) {
|
||||
es_brackets << es;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -859,10 +866,18 @@ void QCodeEdit::clearSearch() {
|
||||
|
||||
|
||||
void QCodeEdit::moveToSearch() {
|
||||
if (es_search_list.isEmpty()) return;
|
||||
if (cur_search_ind < 0) cur_search_ind += es_search_list.size();
|
||||
if (cur_search_ind >= es_search_list.size()) cur_search_ind = 0;
|
||||
if (cur_search_ind < 0 || cur_search_ind >= es_search_list.size()) return;
|
||||
if (es_search_list.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
if (cur_search_ind < 0) {
|
||||
cur_search_ind += es_search_list.size();
|
||||
}
|
||||
if (cur_search_ind >= es_search_list.size()) {
|
||||
cur_search_ind = 0;
|
||||
}
|
||||
if (cur_search_ind < 0 || cur_search_ind >= es_search_list.size()) {
|
||||
return;
|
||||
}
|
||||
ui->textCode->setTextCursor(es_search_list[cur_search_ind].cursor);
|
||||
}
|
||||
|
||||
@@ -870,9 +885,11 @@ void QCodeEdit::moveToSearch() {
|
||||
int QCodeEdit::searchIndFromCursor() {
|
||||
if (es_search_list.isEmpty()) return -1;
|
||||
int ci = ui->textCode->textCursor().anchor();
|
||||
for (int i = 0; i < es_search_list.size(); ++i)
|
||||
if (es_search_list[i].cursor.anchor() > ci)
|
||||
for (int i = 0; i < es_search_list.size(); ++i) {
|
||||
if (es_search_list[i].cursor.anchor() > ci) {
|
||||
return i - 1;
|
||||
}
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
@@ -891,11 +908,8 @@ QRect QCodeEdit::cursorRect() {
|
||||
|
||||
QRect QCodeEdit::blockSelectionRect() {
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
QPoint ps(block_start_cursor.positionInBlock(), block_start_cursor.blockNumber()),
|
||||
pe(tc.positionInBlock(), tc.blockNumber());
|
||||
//QRect bsr(QPoint(qMin(ps.x(), pe.x()), qMin(ps.y(), pe.y())),
|
||||
// QSize(qAbs(ps.x() - pe.x()), qAbs(ps.y() - pe.y()) + 1));
|
||||
//return bsr;
|
||||
QPoint ps(block_start_cursor.positionInBlock(), block_start_cursor.blockNumber());
|
||||
QPoint pe(tc.positionInBlock(), tc.blockNumber());
|
||||
return (ui->textCode->cursorRect(tc) | ui->textCode->cursorRect(block_start_cursor))
|
||||
.translated(ui->textCode->horizontalScrollBar()->value(), 0);
|
||||
}
|
||||
@@ -966,12 +980,16 @@ void QCodeEdit::cancelBlockSelection() {
|
||||
|
||||
void QCodeEdit::switchBlockSelection(QKeyEvent * ke) {
|
||||
bool alt = QApplication::keyboardModifiers().testFlag(Qt::AltModifier);
|
||||
if (ke) alt = ke->modifiers().testFlag(Qt::AltModifier) && ke->modifiers().testFlag(Qt::ShiftModifier);
|
||||
if (ke) {
|
||||
alt = ke->modifiers().testFlag(Qt::AltModifier) && ke->modifiers().testFlag(Qt::ShiftModifier);
|
||||
}
|
||||
if (alt) {
|
||||
startBlockSelection();
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
QTextCursor::MoveOperation op = QTextCursor::NoMove;
|
||||
if (!ke) return;
|
||||
if (!ke) {
|
||||
return;
|
||||
}
|
||||
switch (ke->key()) {
|
||||
case Qt::Key_Left : op = QTextCursor::Left ; break;
|
||||
case Qt::Key_Right: op = QTextCursor::Right; break;
|
||||
@@ -984,18 +1002,25 @@ void QCodeEdit::switchBlockSelection(QKeyEvent * ke) {
|
||||
ui->textCode->setTextCursor(tc);
|
||||
}
|
||||
repaintCursor();
|
||||
} else
|
||||
} else {
|
||||
cancelBlockSelection();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
bool QCodeEdit::removeBlockSelection(bool is_del) {
|
||||
if (!hasBlockSelection()) return false;
|
||||
if (!hasBlockSelection()) {
|
||||
return false;
|
||||
}
|
||||
QRect bsr = blockSelectionRect();
|
||||
bool del = false, back = false;
|
||||
bool del = false;
|
||||
bool back = false;
|
||||
if (bsr.width() <= 1) {
|
||||
if (is_del) del = true;
|
||||
else back = true;
|
||||
if (is_del) {
|
||||
del = true;
|
||||
} else {
|
||||
back = true;
|
||||
}
|
||||
}
|
||||
QVector<QTextCursor> clist = blockSelectionCursors(bsr);
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
@@ -1008,20 +1033,25 @@ bool QCodeEdit::removeBlockSelection(bool is_del) {
|
||||
width
|
||||
#endif
|
||||
(" ");
|
||||
int min_dist = nullw * 0.5;
|
||||
int min_dist = nullw / 2;
|
||||
int new_pos = -1;
|
||||
foreach (QTextCursor c, clist) {
|
||||
for (QTextCursor & c : clist) {
|
||||
if (del || back) {
|
||||
if (qAbs(bspx - ui->textCode->cursorRect(c).center().x()) > min_dist) continue;
|
||||
if (qAbs(bspx - ui->textCode->cursorRect(c).center().x()) > min_dist) {
|
||||
continue;
|
||||
}
|
||||
int line = c.blockNumber();
|
||||
c.movePosition(del ? QTextCursor::Right : QTextCursor::Left, QTextCursor::KeepAnchor);
|
||||
if (line != c.blockNumber()) continue;
|
||||
if (line != c.blockNumber()) {
|
||||
continue;
|
||||
}
|
||||
//qDebug() << qAbs(bspx - ui->textCode->cursorRect(c).center().x()) << min_dist;
|
||||
}
|
||||
c.removeSelectedText();
|
||||
if (c.blockNumber() == tc.blockNumber())
|
||||
if (c.blockNumber() == tc.blockNumber()) {
|
||||
new_pos = c.position();
|
||||
}
|
||||
}
|
||||
tc.setPosition(new_pos);
|
||||
ui->textCode->setTextCursor(tc);
|
||||
tc.endEditBlock();
|
||||
@@ -1030,7 +1060,9 @@ bool QCodeEdit::removeBlockSelection(bool is_del) {
|
||||
|
||||
|
||||
void QCodeEdit::insertBlockSelection(QString text) {
|
||||
if (!hasBlockSelection()) return;
|
||||
if (!hasBlockSelection()) {
|
||||
return;
|
||||
}
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
QRect bsr = blockSelectionRect();
|
||||
//qDebug() << "___" << bsr;
|
||||
@@ -1041,7 +1073,6 @@ void QCodeEdit::insertBlockSelection(QString text) {
|
||||
//qDebug() << "del" << bsr;
|
||||
}
|
||||
tc.beginEditBlock();
|
||||
//tc.joinPreviousEditBlock();
|
||||
int nullw = ui->textCode->fontMetrics().
|
||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 11, 0)
|
||||
horizontalAdvance
|
||||
@@ -1050,7 +1081,7 @@ void QCodeEdit::insertBlockSelection(QString text) {
|
||||
#endif
|
||||
(" ");
|
||||
QVector<QTextCursor> clist = blockSelectionCursors(bsr);
|
||||
foreach (QTextCursor c, clist) {
|
||||
for (QTextCursor & c : clist) {
|
||||
c.removeSelectedText();
|
||||
int spcnt = (bsr.left() - ui->textCode->cursorRect(c).center().x() - scrl) / nullw;
|
||||
if (spcnt > 0) {
|
||||
@@ -1058,20 +1089,20 @@ void QCodeEdit::insertBlockSelection(QString text) {
|
||||
}
|
||||
c.insertText(text);
|
||||
}
|
||||
//tc.setPosition(tc.block().position() + block_start_cursor.positionInBlock());
|
||||
//ui->textCode->setTextCursor(tc);
|
||||
tc.endEditBlock();
|
||||
}
|
||||
|
||||
|
||||
void QCodeEdit::createBlockSelection() {
|
||||
if (!hasBlockSelection()) return;
|
||||
if (!hasBlockSelection()) {
|
||||
return;
|
||||
}
|
||||
es_blockselection.clear();
|
||||
QTextEdit::ExtraSelection es;
|
||||
es.format.setForeground(palette().brush(QPalette::HighlightedText));
|
||||
es.format.setBackground(palette().brush(QPalette::Highlight));
|
||||
QVector<QTextCursor> clist = blockSelectionCursors(blockSelectionRect());
|
||||
foreach (QTextCursor c, clist) {
|
||||
for (QTextCursor & c : clist) {
|
||||
es.cursor = c;
|
||||
es_blockselection << es;
|
||||
}
|
||||
@@ -1096,15 +1127,18 @@ void QCodeEdit::searchAll() {
|
||||
QTextEdit::ExtraSelection es = es_search;
|
||||
while (true) {
|
||||
tc = ui->textCode->document()->find(st, tc, ff);
|
||||
if (tc.isNull()) break;
|
||||
if (tc.isNull()) {
|
||||
break;
|
||||
}
|
||||
es.cursor = tc;
|
||||
es_search_list << es;
|
||||
}
|
||||
}
|
||||
applyExtraSelection();
|
||||
QString ss;
|
||||
if (es_search_list.isEmpty())
|
||||
if (es_search_list.isEmpty()) {
|
||||
ss = "color: rgb(180, 0, 0);";
|
||||
}
|
||||
ui->comboSearch->lineEdit()->setStyleSheet(ss);
|
||||
}
|
||||
|
||||
@@ -1117,16 +1151,15 @@ void QCodeEdit::search_triggered() {
|
||||
st = tc.selectedText();
|
||||
}
|
||||
search(st);
|
||||
//QMetaObject::invokeMethod(ui->comboSearch->lineEdit(), "returnPressed");
|
||||
if (ui->comboSearch->findText(st) < 0)
|
||||
if (ui->comboSearch->findText(st) < 0) {
|
||||
ui->comboSearch->insertItem(0, st);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void QCodeEdit::syncScrolls() {
|
||||
ui->textLines->verticalScrollBar()->setValue(ui->textCode->verticalScrollBar()->value());
|
||||
ui->textLines->setHorizontalScrollBarPolicy(ui->textCode->horizontalScrollBar()->isVisible() ? Qt::ScrollBarAlwaysOn : Qt::ScrollBarAlwaysOff);
|
||||
//qDebug() << "!!!";
|
||||
}
|
||||
|
||||
|
||||
@@ -1163,23 +1196,35 @@ void QCodeEdit::deleteLine() {
|
||||
void QCodeEdit::copyLineUp() {
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
tc.beginEditBlock();
|
||||
int ss = tc.selectionStart(), ss_ = ss, se = tc.selectionEnd(), se_ = se;
|
||||
int ss = tc.selectionStart();
|
||||
int ss_ = ss;
|
||||
int se = tc.selectionEnd();
|
||||
QString st_ = tc.selection().toPlainText();
|
||||
if (st_.endsWith("\n")) {
|
||||
st_.chop(1);
|
||||
se--; se_--;
|
||||
se--;
|
||||
}
|
||||
tc.setPosition(ss); tc.movePosition(QTextCursor::StartOfLine); ss = tc.position();
|
||||
tc.setPosition(se); tc.movePosition(QTextCursor::EndOfLine); se = tc.position();
|
||||
tc.setPosition(ss); tc.setPosition(se, QTextCursor::KeepAnchor);
|
||||
int se_ = se;
|
||||
tc.setPosition(ss);
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
ss = tc.position();
|
||||
tc.setPosition(se);
|
||||
tc.movePosition(QTextCursor::EndOfLine);
|
||||
se = tc.position();
|
||||
tc.setPosition(ss);
|
||||
|
||||
tc.setPosition(se, QTextCursor::KeepAnchor);
|
||||
bool ins_nl = false;
|
||||
if (!tc.movePosition(QTextCursor::Right, QTextCursor::KeepAnchor))
|
||||
if (!tc.movePosition(QTextCursor::Right, QTextCursor::KeepAnchor)) {
|
||||
ins_nl = true;
|
||||
}
|
||||
QString l = tc.selectedText();
|
||||
tc.beginEditBlock();
|
||||
tc.setPosition(ss);
|
||||
if (ins_nl)
|
||||
if (ins_nl) {
|
||||
l.append("\n");
|
||||
}
|
||||
|
||||
tc.insertText(l);
|
||||
tc.setPosition(ss_);
|
||||
tc.setPosition(se_, QTextCursor::KeepAnchor);
|
||||
@@ -1192,26 +1237,39 @@ void QCodeEdit::copyLineUp() {
|
||||
void QCodeEdit::copyLineDown() {
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
tc.beginEditBlock();
|
||||
int ss = tc.selectionStart(), ss_ = ss, se = tc.selectionEnd(), se_ = se;
|
||||
int ss = tc.selectionStart();
|
||||
int ss_ = ss;
|
||||
int se = tc.selectionEnd();
|
||||
QString st_ = tc.selection().toPlainText();
|
||||
if (st_.endsWith("\n")) {
|
||||
st_.chop(1);
|
||||
se--; se_--;
|
||||
se--;
|
||||
}
|
||||
tc.setPosition(ss); tc.movePosition(QTextCursor::StartOfLine); ss = tc.position();
|
||||
tc.setPosition(se); tc.movePosition(QTextCursor::EndOfLine); se = tc.position();
|
||||
tc.setPosition(ss); tc.setPosition(se, QTextCursor::KeepAnchor);
|
||||
int se_ = se;
|
||||
tc.setPosition(ss);
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
ss = tc.position();
|
||||
tc.setPosition(se);
|
||||
tc.movePosition(QTextCursor::EndOfLine);
|
||||
se = tc.position();
|
||||
tc.setPosition(ss);
|
||||
|
||||
tc.setPosition(se, QTextCursor::KeepAnchor);
|
||||
bool ins_nl = false;
|
||||
if (!tc.movePosition(QTextCursor::Right, QTextCursor::KeepAnchor))
|
||||
if (!tc.movePosition(QTextCursor::Right, QTextCursor::KeepAnchor)) {
|
||||
ins_nl = true;
|
||||
}
|
||||
QString l = tc.selectedText();
|
||||
tc.beginEditBlock();
|
||||
tc.setPosition(ss);
|
||||
ss_ += l.size(); se_ += l.size();
|
||||
ss_ += l.size();
|
||||
se_ += l.size();
|
||||
if (ins_nl) {
|
||||
l.append("\n");
|
||||
ss_++; se_++;
|
||||
ss_++;
|
||||
se_++;
|
||||
}
|
||||
|
||||
tc.insertText(l);
|
||||
tc.setPosition(ss_);
|
||||
tc.setPosition(se_, QTextCursor::KeepAnchor);
|
||||
@@ -1223,22 +1281,33 @@ void QCodeEdit::copyLineDown() {
|
||||
|
||||
void QCodeEdit::moveLineUp() {
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
int ss = tc.selectionStart(), ss_ = ss, se = tc.selectionEnd(), se_ = se;
|
||||
int ss = tc.selectionStart();
|
||||
int ss_ = ss;
|
||||
int se = tc.selectionEnd();
|
||||
QString st_ = tc.selection().toPlainText();
|
||||
if (st_.endsWith("\n")) {
|
||||
st_.chop(1);
|
||||
se--; se_--;
|
||||
se--;
|
||||
}
|
||||
tc.setPosition(ss); tc.movePosition(QTextCursor::StartOfLine); ss = tc.position();
|
||||
tc.setPosition(se); tc.movePosition(QTextCursor::EndOfLine); se = tc.position();
|
||||
int se_ = se;
|
||||
tc.setPosition(ss);
|
||||
if (!tc.movePosition(QTextCursor::Up))
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
ss = tc.position();
|
||||
tc.setPosition(se);
|
||||
tc.movePosition(QTextCursor::EndOfLine);
|
||||
se = tc.position();
|
||||
tc.setPosition(ss);
|
||||
|
||||
if (!tc.movePosition(QTextCursor::Up)) {
|
||||
return;
|
||||
}
|
||||
tc.beginEditBlock();
|
||||
tc.movePosition(QTextCursor::Down, QTextCursor::KeepAnchor);
|
||||
QString l = tc.selectedText();
|
||||
ss -= l.size(); se -= l.size();
|
||||
ss_ -= l.size(); se_ -= l.size();
|
||||
ss -= l.size();
|
||||
se -= l.size();
|
||||
ss_ -= l.size();
|
||||
se_ -= l.size();
|
||||
tc.beginEditBlock();
|
||||
tc.removeSelectedText();
|
||||
tc.setPosition(se);
|
||||
@@ -1247,6 +1316,7 @@ void QCodeEdit::moveLineUp() {
|
||||
l.prepend("\n");
|
||||
de = true;
|
||||
}
|
||||
|
||||
tc.insertText(l);
|
||||
if (de) {
|
||||
tc.movePosition(QTextCursor::End);
|
||||
@@ -1263,17 +1333,26 @@ void QCodeEdit::moveLineUp() {
|
||||
|
||||
void QCodeEdit::moveLineDown() {
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
int ss = tc.selectionStart(), ss_ = ss, se = tc.selectionEnd(), se_ = se;
|
||||
int ss = tc.selectionStart();
|
||||
int ss_ = ss;
|
||||
int se = tc.selectionEnd();
|
||||
QString st_ = tc.selection().toPlainText();
|
||||
if (st_.endsWith("\n")) {
|
||||
st_.chop(1);
|
||||
se--; se_--;
|
||||
se--;
|
||||
}
|
||||
tc.setPosition(ss); tc.movePosition(QTextCursor::StartOfLine); ss = tc.position();
|
||||
tc.setPosition(se); tc.movePosition(QTextCursor::EndOfLine); se = tc.position();
|
||||
int se_ = se;
|
||||
tc.setPosition(ss);
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
ss = tc.position();
|
||||
tc.setPosition(se);
|
||||
if (!tc.movePosition(QTextCursor::Right))
|
||||
tc.movePosition(QTextCursor::EndOfLine);
|
||||
se = tc.position();
|
||||
tc.setPosition(se);
|
||||
|
||||
if (!tc.movePosition(QTextCursor::Right)) {
|
||||
return;
|
||||
}
|
||||
tc.beginEditBlock();
|
||||
bool de = false;
|
||||
if (!tc.movePosition(QTextCursor::Down, QTextCursor::KeepAnchor)) {
|
||||
@@ -1284,15 +1363,19 @@ void QCodeEdit::moveLineDown() {
|
||||
tc.beginEditBlock();
|
||||
tc.removeSelectedText();
|
||||
tc.setPosition(ss);
|
||||
if (de) l += "\n";
|
||||
if (de) {
|
||||
l += "\n";
|
||||
}
|
||||
tc.insertText(l);
|
||||
if (de) {
|
||||
tc.movePosition(QTextCursor::End);
|
||||
tc.movePosition(QTextCursor::Left, QTextCursor::KeepAnchor);
|
||||
tc.removeSelectedText();
|
||||
}
|
||||
ss += l.size(); se += l.size();
|
||||
ss_ += l.size(); se_ += l.size();
|
||||
ss += l.size();
|
||||
se += l.size();
|
||||
ss_ += l.size();
|
||||
se_ += l.size();
|
||||
tc.setPosition(ss_);
|
||||
tc.setPosition(se_, QTextCursor::KeepAnchor);
|
||||
tc.endEditBlock();
|
||||
@@ -1304,22 +1387,30 @@ void QCodeEdit::moveLineDown() {
|
||||
void QCodeEdit::indent() {
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
tc.beginEditBlock();
|
||||
int ss = tc.selectionStart(), ss_ = ss, se = tc.selectionEnd(), se_ = se;
|
||||
int ss = tc.selectionStart();
|
||||
int ss_ = ss;
|
||||
int se = tc.selectionEnd();
|
||||
QString st_ = tc.selection().toPlainText();
|
||||
if (st_.endsWith("\n")) {
|
||||
st_.chop(1);
|
||||
se--; se_--;
|
||||
se--;
|
||||
}
|
||||
tc.setPosition(ss); tc.movePosition(QTextCursor::StartOfLine); ss = tc.position();
|
||||
tc.setPosition(se); tc.movePosition(QTextCursor::EndOfLine); se = tc.position();
|
||||
int se_ = se;
|
||||
tc.setPosition(ss);
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
ss = tc.position();
|
||||
tc.setPosition(se);
|
||||
tc.movePosition(QTextCursor::EndOfLine);
|
||||
se = tc.position();
|
||||
tc.setPosition(ss);
|
||||
while (tc.position() < se_) {
|
||||
tc.insertText("\t");
|
||||
se_++;
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
if (!tc.movePosition(QTextCursor::Down))
|
||||
if (!tc.movePosition(QTextCursor::Down)) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
tc.setPosition(ss_ + 1);
|
||||
tc.setPosition(se_, QTextCursor::KeepAnchor);
|
||||
ui->textCode->setTextCursor(tc);
|
||||
@@ -1330,14 +1421,21 @@ void QCodeEdit::indent() {
|
||||
void QCodeEdit::deindent() {
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
tc.beginEditBlock();
|
||||
int ss = tc.selectionStart(), ss_ = ss, se = tc.selectionEnd(), se_ = se;
|
||||
int ss = tc.selectionStart();
|
||||
int ss_ = ss;
|
||||
int se = tc.selectionEnd();
|
||||
QString st_ = tc.selection().toPlainText();
|
||||
if (st_.endsWith("\n")) {
|
||||
st_.chop(1);
|
||||
se--; se_--;
|
||||
se--;
|
||||
}
|
||||
tc.setPosition(ss); tc.movePosition(QTextCursor::StartOfLine); ss = tc.position();
|
||||
tc.setPosition(se); tc.movePosition(QTextCursor::EndOfLine); se = tc.position();
|
||||
int se_ = se;
|
||||
tc.setPosition(ss);
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
ss = tc.position();
|
||||
tc.setPosition(se);
|
||||
tc.movePosition(QTextCursor::EndOfLine);
|
||||
se = tc.position();
|
||||
tc.setPosition(ss);
|
||||
bool first = true;
|
||||
while (tc.position() < se_) {
|
||||
@@ -1374,22 +1472,29 @@ void QCodeEdit::deindent() {
|
||||
|
||||
|
||||
void QCodeEdit::autoIndent() {
|
||||
QTextCursor tc = ui->textCode->textCursor(), stc = tc;
|
||||
QTextCursor tc = ui->textCode->textCursor();
|
||||
QTextCursor stc = tc;
|
||||
tc.movePosition(QTextCursor::StartOfLine);
|
||||
if (!tc.movePosition(QTextCursor::Up)) return;
|
||||
if (!tc.movePosition(QTextCursor::Up)) {
|
||||
return;
|
||||
}
|
||||
tc.movePosition(QTextCursor::Down, QTextCursor::KeepAnchor);
|
||||
QString line = tc.selectedText(), tabs;
|
||||
QString line = tc.selectedText();
|
||||
QString tabs;
|
||||
int i = 0;
|
||||
for (; i < line.size(); ++i)
|
||||
if (!line[i].isSpace()) {
|
||||
tabs = line.left(i);
|
||||
break;
|
||||
}
|
||||
if (i >= line.size())
|
||||
if (i >= line.size()) {
|
||||
tabs = line.left(line.size() - 1);
|
||||
}
|
||||
int nt = qMax<int>(0, line.count(QChar('{')) - line.count(QChar('}')));
|
||||
tabs.append(QString("\t").repeated(nt));
|
||||
if (tabs.isEmpty()) return;
|
||||
if (tabs.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
stc.beginEditBlock();
|
||||
stc.insertText(tabs);
|
||||
ui->textCode->setTextCursor(stc);
|
||||
@@ -1470,7 +1575,9 @@ void QCodeEdit::setText(const QString & t) {
|
||||
|
||||
|
||||
void QCodeEdit::updateLines() {
|
||||
if (timer_parse > 0) killTimer(timer_parse);
|
||||
if (timer_parse > 0) {
|
||||
killTimer(timer_parse);
|
||||
}
|
||||
timer_parse = startTimer(500);
|
||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 10, 0)
|
||||
# if QT_VERSION >= QT_VERSION_CHECK(5, 11, 0)
|
||||
@@ -1482,7 +1589,9 @@ void QCodeEdit::updateLines() {
|
||||
ui->textCode->setTabStopWidth(ui->textCode->fontMetrics().width(" "));
|
||||
#endif
|
||||
int lc = ui->textCode->document()->lineCount();
|
||||
if (prev_lc == lc) return;
|
||||
if (prev_lc == lc) {
|
||||
return;
|
||||
}
|
||||
prev_lc = lc;
|
||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 11, 0)
|
||||
ui->textLines->setFixedWidth(ui->textLines->fontMetrics().horizontalAdvance(QString(" %1").arg(lc)));
|
||||
@@ -1490,25 +1599,38 @@ void QCodeEdit::updateLines() {
|
||||
ui->textLines->setFixedWidth(ui->textLines->fontMetrics().width(QString(" %1").arg(lc)));
|
||||
#endif
|
||||
ui->textLines->clear();
|
||||
for (int i = 1; i <= lc; ++i)
|
||||
for (int i = 1; i <= lc; ++i) {
|
||||
ui->textLines->appendPlainText(QString("%1").arg(i));
|
||||
}
|
||||
ui->textLines->verticalScrollBar()->setValue(ui->textCode->verticalScrollBar()->value());
|
||||
}
|
||||
|
||||
|
||||
QString QCodeEdit::selectArg(QString s, int arg) {
|
||||
if (!s.contains('(') || arg < 0) return s;
|
||||
if (!s.contains('(') || arg < 0) {
|
||||
return s;
|
||||
}
|
||||
QString ss = s.left(s.indexOf('('));
|
||||
s.remove(0, ss.size());
|
||||
if (s.startsWith('(')) s.remove(0, 1);
|
||||
if (s.endsWith(')')) s.chop(1);
|
||||
if (s.startsWith('(')) {
|
||||
s.remove(0, 1);
|
||||
}
|
||||
if (s.endsWith(')')) {
|
||||
s.chop(1);
|
||||
}
|
||||
QStringList al = s.split(",");
|
||||
QString ret = ss + "(";
|
||||
for (int i = 0; i < al.size(); ++i) {
|
||||
if (i > 0) ret += ", ";
|
||||
if (i == arg) ret += "<span style=\"font-weight:600;\">";
|
||||
if (i > 0) {
|
||||
ret += ", ";
|
||||
}
|
||||
if (i == arg) {
|
||||
ret += "<span style=\"font-weight:600;\">";
|
||||
}
|
||||
ret += al[i].trimmed();
|
||||
if (i == arg) ret += "</span>";
|
||||
if (i == arg) {
|
||||
ret += "</span>";
|
||||
}
|
||||
}
|
||||
ret += ")";
|
||||
return ret;
|
||||
@@ -1518,16 +1640,20 @@ QString QCodeEdit::selectArg(QString s, int arg) {
|
||||
QCodeEdit::ACEntry QCodeEdit::findEntryOnCursor(QTextCursor tc, int arg, ACClass * acc, QPair<QStringList, QString> * scope) {
|
||||
bool ok = false;
|
||||
QPair<QStringList, QString> sc = getScope(tc, &ok);
|
||||
if (scope) *scope = sc;
|
||||
if (scope) {
|
||||
*scope = sc;
|
||||
}
|
||||
QString st = tc.selectedText();
|
||||
if (arg >= 0) st = sc.second;
|
||||
if (arg >= 0) {
|
||||
st = sc.second;
|
||||
}
|
||||
if (!ok || st.isEmpty()) {
|
||||
return ACEntry();
|
||||
}
|
||||
ok = false;
|
||||
ACList acl(autoCompletitionList(sc.first, sc.second));
|
||||
foreach (const ACSection & i, acl) {
|
||||
foreach (const ACEntry & s, i.second) {
|
||||
for (const ACSection & i : acl) {
|
||||
for (const ACEntry & s : i.second) {
|
||||
QString ts = s.name;
|
||||
//qDebug() << ts << st;
|
||||
if (ts != st) {
|
||||
@@ -1535,14 +1661,18 @@ QCodeEdit::ACEntry QCodeEdit::findEntryOnCursor(QTextCursor tc, int arg, ACClass
|
||||
ts.remove(0, st.size());
|
||||
ts = ts.trimmed();
|
||||
if (!ts.isEmpty()) {
|
||||
if (ts[0] != '(')
|
||||
if (ts[0] != '(') {
|
||||
continue;
|
||||
}
|
||||
} else
|
||||
}
|
||||
} else {
|
||||
continue;
|
||||
}
|
||||
}
|
||||
//qDebug() << s.second << st;
|
||||
if (acc) *acc = ac_classes.value(i.first);
|
||||
if (acc) {
|
||||
*acc = ac_classes.value(i.first);
|
||||
}
|
||||
return s;
|
||||
}
|
||||
}
|
||||
@@ -1561,8 +1691,9 @@ void QCodeEdit::raiseHelp(QTextCursor tc, int arg) {
|
||||
lbl_help[lhMain]->setText(QString("<html><body>[%1] %2 %3</html></body>").arg(acc.name, e.type, selectArg(e.name, arg)));
|
||||
lbl_help[lhMain]->setIcon(acc.icon);
|
||||
QString hint;
|
||||
if (!e.hint.isEmpty())
|
||||
if (!e.hint.isEmpty()) {
|
||||
hint = QString("<span style=\"font-style:italic;\">%1</span>").arg(e.hint);
|
||||
}
|
||||
lbl_help[lhHint]->setText(hint);
|
||||
lbl_help[lhHint]->setHidden(hint.isEmpty());
|
||||
//qDebug() << "help found" << tc.selectionStart() << tc.selectionEnd();
|
||||
@@ -1596,14 +1727,17 @@ void QCodeEdit::raiseHelp(QTextCursor tc, int arg) {
|
||||
|
||||
|
||||
void QCodeEdit::gotoHelpHRef(QCodeEdit::ACEntry e) {
|
||||
if (e.help_href.isEmpty()) return;
|
||||
if (e.help_href.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
QDesktopServices::openUrl(e.help_href);
|
||||
}
|
||||
|
||||
|
||||
void QCodeEdit::resizeOverlay() {
|
||||
if (overlay)
|
||||
if (overlay) {
|
||||
overlay->setGeometry(ui->textCode->viewport()->geometry());
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -1622,16 +1756,22 @@ QTextCursor QCodeEdit::functionStart(QTextCursor tc, int * arg) {
|
||||
for (i = tc.position() - 1; i >= 0; --i) {
|
||||
if (doc[i] == ')') bcnt++;
|
||||
if (doc[i] == '(') {
|
||||
if (bcnt == 0)
|
||||
if (bcnt == 0) {
|
||||
break;
|
||||
else
|
||||
} else {
|
||||
bcnt--;
|
||||
}
|
||||
//if (doc[i] == '(') bcnt--;
|
||||
if (doc[i] == ',' && bcnt == 0) a++;
|
||||
}
|
||||
if (i < 0) return QTextCursor();
|
||||
if (arg) *arg = a;
|
||||
if (doc[i] == ',' && bcnt == 0) {
|
||||
a++;
|
||||
}
|
||||
}
|
||||
if (i < 0) {
|
||||
return QTextCursor();
|
||||
}
|
||||
if (arg) {
|
||||
*arg = a;
|
||||
}
|
||||
QTextCursor ret(ui->textCode->document());
|
||||
ret.setPosition(i);
|
||||
//qDebug() << "found" << i << a;
|
||||
@@ -1642,23 +1782,28 @@ QTextCursor QCodeEdit::functionStart(QTextCursor tc, int * arg) {
|
||||
QCodeEdit::ACList QCodeEdit::wordsCompletitionList(const QString & written) const {
|
||||
QCodeEdit::ACList ret;
|
||||
if (!written.isEmpty()) {
|
||||
QTextCursor tc = QTextCursor(ui->textCode->document()->begin()), stc;
|
||||
QTextCursor tc = QTextCursor(ui->textCode->document()->begin());
|
||||
QTextCursor stc;
|
||||
QStringList acwl;
|
||||
tc = QTextCursor(ui->textCode->document()->begin());
|
||||
while (true) {
|
||||
tc = ui->textCode->document()->find(written, tc);
|
||||
if (tc.isNull()) break;
|
||||
if (tc.isNull()) {
|
||||
break;
|
||||
}
|
||||
stc = tc;
|
||||
stc.movePosition(QTextCursor::Left);
|
||||
stc.select(QTextCursor::WordUnderCursor);
|
||||
if (!stc.selectedText().isEmpty() && stc.selectedText().trimmed() != written)
|
||||
if (!stc.selectedText().isEmpty() && stc.selectedText().trimmed() != written) {
|
||||
acwl << stc.selectedText();
|
||||
}
|
||||
}
|
||||
acwl.removeDuplicates();
|
||||
ACSection acl;
|
||||
acl.first = -1;
|
||||
foreach (const QString & s, acwl)
|
||||
for (const QString & s : acwl) {
|
||||
acl.second << ACEntry("", s);
|
||||
}
|
||||
ret << acl;
|
||||
}
|
||||
return ret;
|
||||
@@ -1670,7 +1815,9 @@ QPair<QStringList, QString> QCodeEdit::getScope(QTextCursor tc, bool * ok) {
|
||||
QTextCursor stc = tc;
|
||||
if (tc.isNull()) {
|
||||
completer->hide();
|
||||
if (ok) *ok = false;
|
||||
if (ok) {
|
||||
*ok = false;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
int line = tc.block().firstLineNumber();
|
||||
@@ -1678,7 +1825,9 @@ QPair<QStringList, QString> QCodeEdit::getScope(QTextCursor tc, bool * ok) {
|
||||
if (auto_comp_pl != line) {
|
||||
completer->hide();
|
||||
auto_comp_pl = line;
|
||||
if (ok) *ok = false;
|
||||
if (ok) {
|
||||
*ok = false;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
@@ -1694,9 +1843,10 @@ QPair<QStringList, QString> QCodeEdit::getScope(QTextCursor tc, bool * ok) {
|
||||
written.clear();
|
||||
} else {
|
||||
cpos = skipCWord(doc, spos);
|
||||
if (cpos >= 0)
|
||||
if (cpos >= 0) {
|
||||
written = doc.mid(cpos, spos - cpos).trimmed();
|
||||
}
|
||||
}
|
||||
while (cpos >= 0) {
|
||||
cpos--;
|
||||
//qDebug() << "char =" << doc.mid(cpos, 1);
|
||||
@@ -1737,11 +1887,15 @@ void QCodeEdit::invokeAutoCompletition(bool force) {
|
||||
hideHelp();
|
||||
return;
|
||||
}
|
||||
if (word_complete) acl << wordsCompletitionList(scope.second);
|
||||
if (word_complete) {
|
||||
acl << wordsCompletitionList(scope.second);
|
||||
}
|
||||
QFont bf(font());
|
||||
bf.setBold(true);
|
||||
foreach (const ACSection & ac, acl) {
|
||||
if (ac.second.isEmpty()) continue;
|
||||
if (ac.second.isEmpty()) {
|
||||
continue;
|
||||
}
|
||||
ACClass acc = ac_classes.value(ac.first);
|
||||
completer->addItems(bf, acc, ac);
|
||||
}
|
||||
@@ -1750,14 +1904,13 @@ void QCodeEdit::invokeAutoCompletition(bool force) {
|
||||
|
||||
|
||||
void QCodeEdit::commitCompletition() {
|
||||
if (completer->currentItem() == 0) return;
|
||||
if (completer->currentItem() == nullptr) return;
|
||||
if (!completer->currentItem()->flags().testFlag(Qt::ItemIsSelectable)) return;
|
||||
QString ins = completer->currentValue(), ret = completer->currentReturn();
|
||||
QTextCursor tc = ui->textCode->textCursor(), stc = tc;
|
||||
tc.movePosition(QTextCursor::Right, QTextCursor::KeepAnchor);
|
||||
bool ins_br = true, shifted = false;
|
||||
if (!tc.selectedText().isEmpty()) {
|
||||
// if (tc.selectedText()[0].isSpace()) {
|
||||
if (!tc.selectedText()[0].isLetterOrNumber() && !tc.selectedText()[0].isSpace() && !(tc.selectedText()[0] == '_')) {
|
||||
stc.movePosition(QTextCursor::Left);
|
||||
shifted = true;
|
||||
@@ -1766,21 +1919,26 @@ void QCodeEdit::commitCompletition() {
|
||||
tc.movePosition(QTextCursor::EndOfWord);
|
||||
tc.movePosition(QTextCursor::Right, QTextCursor::KeepAnchor);
|
||||
}
|
||||
if (!tc.selectedText().isEmpty())
|
||||
if (tc.selectedText()[0].toLatin1() == '(')
|
||||
if (!tc.selectedText().isEmpty()) {
|
||||
if (tc.selectedText()[0].toLatin1() == '(') {
|
||||
ins_br = false;
|
||||
}
|
||||
if (ins.contains("("))
|
||||
}
|
||||
}
|
||||
if (ins.contains("(")) {
|
||||
ins = ins.left(ins.indexOf("(")) + "()";
|
||||
if (!ins_br && ins.endsWith("()"))
|
||||
}
|
||||
if (!ins_br && ins.endsWith("()")) {
|
||||
ins.chop(2);
|
||||
}
|
||||
tc = stc;
|
||||
tc.select(QTextCursor::WordUnderCursor);
|
||||
if (!tc.selectedText().leftJustified(1)[0].isLetterOrNumber() && !(tc.selectedText().leftJustified(1)[0] == '_')) {
|
||||
tc = stc;
|
||||
if (shifted)
|
||||
if (shifted) {
|
||||
tc.movePosition(QTextCursor::Right);
|
||||
}
|
||||
}
|
||||
ui->textCode->setTextCursor(tc);
|
||||
ui->textCode->textCursor().insertText(ins);
|
||||
tc = ui->textCode->textCursor();
|
||||
@@ -1817,7 +1975,9 @@ void QCodeEdit::textEdit_cursorPositionChanged() {
|
||||
es_line.cursor.movePosition(QTextCursor::Right, QTextCursor::KeepAnchor);
|
||||
highlightBrackets();
|
||||
applyExtraSelection();
|
||||
if (timer_blink) killTimer(timer_blink);
|
||||
if (timer_blink) {
|
||||
killTimer(timer_blink);
|
||||
}
|
||||
timer_blink = startTimer(QApplication::cursorFlashTime() / 2);
|
||||
cursor_state = true;
|
||||
createBlockSelection();
|
||||
@@ -1825,7 +1985,9 @@ void QCodeEdit::textEdit_cursorPositionChanged() {
|
||||
|
||||
|
||||
void QCodeEdit::textEdit_textChanged() {
|
||||
if (_replacing) return;
|
||||
if (_replacing) {
|
||||
return;
|
||||
}
|
||||
searchAll();
|
||||
updateLines();
|
||||
}
|
||||
@@ -1863,7 +2025,9 @@ void QCodeEdit::textEdit_selectionChanged() {
|
||||
|
||||
|
||||
void QCodeEdit::textEdit_redoAvailable(bool available) {
|
||||
if (available) cancelBlockSelection();
|
||||
if (available) {
|
||||
cancelBlockSelection();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -1871,8 +2035,11 @@ void QCodeEdit::setShowSpaces(bool yes) {
|
||||
spaces_ = yes;
|
||||
QTextOption to = ui->textCode->document()->defaultTextOption();
|
||||
QTextOption::Flags tof = to.flags();
|
||||
if (yes) tof |= QTextOption::ShowTabsAndSpaces;
|
||||
else tof &= ~QTextOption::ShowTabsAndSpaces;
|
||||
if (yes) {
|
||||
tof |= QTextOption::ShowTabsAndSpaces;
|
||||
} else {
|
||||
tof &= ~QTextOption::ShowTabsAndSpaces;
|
||||
}
|
||||
to.setFlags(tof);
|
||||
ui->textCode->document()->setDefaultTextOption(to);
|
||||
}
|
||||
@@ -1888,22 +2055,23 @@ void QCodeEdit::search(const QString & t) {
|
||||
ui->comboSearch->setEditText(QString());
|
||||
ui->comboSearch->setEditText(t);
|
||||
ui->comboSearch->setFocus();
|
||||
//searchAll();
|
||||
searchNext(false);
|
||||
}
|
||||
|
||||
|
||||
void QCodeEdit::searchNext(bool next) {
|
||||
if (es_search_list.isEmpty())
|
||||
if (es_search_list.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
cur_search_ind = searchIndFromCursor() + (next ? 1 : 0);
|
||||
moveToSearch();
|
||||
}
|
||||
|
||||
|
||||
void QCodeEdit::searchPrevious() {
|
||||
if (es_search_list.isEmpty())
|
||||
if (es_search_list.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
cur_search_ind = searchIndFromCursor() - 1;
|
||||
moveToSearch();
|
||||
}
|
||||
@@ -1922,9 +2090,15 @@ void QCodeEdit::on_comboSearch_currentTextChanged(const QString & t) {
|
||||
|
||||
|
||||
void QCodeEdit::on_buttonReplace_clicked() {
|
||||
if (es_search_list.isEmpty() || cur_search_ind < 0 || cur_search_ind >= es_search_list.size()) return;
|
||||
if (ui->textCode->textCursor() != es_search_list[cur_search_ind].cursor) return;
|
||||
if (ui->textCode->textCursor().selectedText().size() != es_search_list[cur_search_ind].cursor.selectedText().size()) return;
|
||||
if (es_search_list.isEmpty() || cur_search_ind < 0 || cur_search_ind >= es_search_list.size()) {
|
||||
return;
|
||||
}
|
||||
if (ui->textCode->textCursor() != es_search_list[cur_search_ind].cursor) {
|
||||
return;
|
||||
}
|
||||
if (ui->textCode->textCursor().selectedText().size() != es_search_list[cur_search_ind].cursor.selectedText().size()) {
|
||||
return;
|
||||
}
|
||||
ui->textCode->textCursor().insertText(ui->comboReplace->currentText());
|
||||
}
|
||||
|
||||
@@ -1939,8 +2113,9 @@ void QCodeEdit::on_buttonReplaceAll_clicked() {
|
||||
_replacing = true;
|
||||
QString rt = ui->comboReplace->currentText();
|
||||
textCursor().beginEditBlock();
|
||||
for (int i = es_search_list.size() - 1; i >= 0; --i)
|
||||
for (int i = es_search_list.size() - 1; i >= 0; --i) {
|
||||
es_search_list[i].cursor.insertText(rt);
|
||||
}
|
||||
_replacing = false;
|
||||
textCursor().endEditBlock();
|
||||
textEdit_textChanged();
|
||||
@@ -1950,6 +2125,8 @@ void QCodeEdit::on_buttonReplaceAll_clicked() {
|
||||
|
||||
|
||||
QString QCodeEdit::ACEntry::declaration() const {
|
||||
if (declaration_pos < 0 || declaration_file.isEmpty()) return QString();
|
||||
if (declaration_pos < 0 || declaration_file.isEmpty()) {
|
||||
return QString();
|
||||
}
|
||||
return (declaration_file + ": %1").arg(declaration_pos);
|
||||
}
|
||||
|
||||
@@ -20,19 +20,19 @@
|
||||
#ifndef QCODEEDIT_H
|
||||
#define QCODEEDIT_H
|
||||
|
||||
#include <QPlainTextEdit>
|
||||
#include <QTreeWidget>
|
||||
#include <QScrollBar>
|
||||
#include <QUrl>
|
||||
#include "iconedlabel.h"
|
||||
#include "qad_widgets_export.h"
|
||||
#include <QTextEdit>
|
||||
#include <QUrl>
|
||||
#include <QIcon>
|
||||
|
||||
|
||||
namespace Ui {
|
||||
class QCodeEdit;
|
||||
}
|
||||
|
||||
class QPlainTextEdit;
|
||||
class QCodeEditCompleter;
|
||||
class IconedLabel;
|
||||
class _QCE_Viewport;
|
||||
|
||||
|
||||
@@ -50,7 +50,7 @@ class QAD_WIDGETS_EXPORT QCodeEdit: public QWidget
|
||||
|
||||
public:
|
||||
QCodeEdit(QWidget * parent = nullptr);
|
||||
~QCodeEdit();
|
||||
~QCodeEdit() override;
|
||||
|
||||
enum ACClassType {
|
||||
Keyword,
|
||||
@@ -99,7 +99,6 @@ public:
|
||||
QPlainTextEdit * textEdit() const;
|
||||
|
||||
void registerAutoCompletitionClass(int id, ACClassType ac_class, const QString & name, const QIcon & icon = QIcon());
|
||||
|
||||
bool wordCompletitionEnabled() const {return word_complete;}
|
||||
|
||||
protected:
|
||||
@@ -118,72 +117,12 @@ protected:
|
||||
void raiseHelp(QTextCursor tc, int arg = -1);
|
||||
QTextCursor functionStart(QTextCursor tc, int * arg);
|
||||
ACList wordsCompletitionList(const QString & written) const;
|
||||
QPair<QStringList, QString> getScope(QTextCursor tc, bool * ok = 0);
|
||||
QPair<QStringList, QString> getScope(QTextCursor tc, bool * ok = nullptr);
|
||||
static int skipRange(const QString & s, int pos, QChar oc, QChar cc, QChar sc = QChar());
|
||||
static int skipCWord(const QString & s, int pos);
|
||||
static bool matchWritten(QString s, QString w);
|
||||
static QChar pairChar(QChar c);
|
||||
|
||||
Ui::QCodeEdit * ui;
|
||||
|
||||
private:
|
||||
struct QAD_WIDGETS_EXPORT ACClass {
|
||||
ACClass(int i = -2, ACClassType c = QCodeEdit::Keyword, const QString & n = QString(), const QIcon & ic = QIcon()): id(i), class_(c), name(n), icon(ic) {}
|
||||
int id;
|
||||
ACClassType class_;
|
||||
QString name;
|
||||
QIcon icon;
|
||||
};
|
||||
enum LabelHelpType {
|
||||
lhMain,
|
||||
lhHint,
|
||||
lhF1,
|
||||
lh_last
|
||||
};
|
||||
|
||||
QCodeEditCompleter * completer;
|
||||
IconedLabel * lbl_help[3];
|
||||
QFrame * widget_help;
|
||||
_QCE_Viewport * overlay;
|
||||
QTextEdit::ExtraSelection es_line, es_cursor, es_bracket, es_range, es_search, es_link;
|
||||
QList<QTextEdit::ExtraSelection> es_selected, es_custom, es_brackets, es_search_list, es_blockselection;
|
||||
QMap<int, ACClass> ac_classes;
|
||||
QStringList cursor_scope;
|
||||
QString comment_text;
|
||||
ACEntry link_entry, help_entry;
|
||||
QTextCursor block_start_cursor, drag_cursor;
|
||||
int prev_lc, auto_comp_pl, timer_parse, timer_blink, cur_search_ind, pos_press, pos_el_press;
|
||||
int cursor_width;
|
||||
bool spaces_, _ignore_focus_out, _first, _destructor, _replacing;
|
||||
bool word_complete, help_visible, cursor_state, block_sel_state;
|
||||
|
||||
bool eventFilter(QObject * o, QEvent * e) override;
|
||||
void showEvent(QShowEvent * ) override;
|
||||
void timerEvent(QTimerEvent * ) override;
|
||||
void leaveEvent(QEvent * ) override;
|
||||
void changeEvent(QEvent * e) override;
|
||||
bool codeKeyEvent(QKeyEvent * ke);
|
||||
void toggleComment();
|
||||
void highlightBrackets();
|
||||
void applyExtraSelection();
|
||||
void clearSearch();
|
||||
void moveToSearch();
|
||||
int searchIndFromCursor();
|
||||
QRect cursorRect();
|
||||
QRect blockSelectionRect();
|
||||
QVector<QTextCursor> blockSelectionCursors(QRect bsr);
|
||||
void repaintCursor();
|
||||
void drawCursor();
|
||||
bool hasBlockSelection() const;
|
||||
void startBlockSelection();
|
||||
void cancelBlockSelection();
|
||||
void switchBlockSelection(QKeyEvent * ke = nullptr);
|
||||
bool removeBlockSelection(bool is_del);
|
||||
void insertBlockSelection(QString text);
|
||||
void createBlockSelection();
|
||||
void cancelDragCursor();
|
||||
ACEntry findEntryOnCursor(QTextCursor tc, int arg = -1, ACClass * acc = 0, QPair<QStringList, QString> * scope = 0);
|
||||
|
||||
private slots:
|
||||
void _activateLink(QCodeEdit::ACEntry e) {linkClicked(e);}
|
||||
void gotoHelpHRef(QCodeEdit::ACEntry e);
|
||||
@@ -236,6 +175,64 @@ signals:
|
||||
void textChanged();
|
||||
void parseRequest();
|
||||
|
||||
private:
|
||||
struct QAD_WIDGETS_EXPORT ACClass {
|
||||
ACClass(int i = -2, ACClassType c = QCodeEdit::Keyword, const QString & n = QString(), const QIcon & ic = QIcon()): id(i), class_(c), name(n), icon(ic) {}
|
||||
int id;
|
||||
ACClassType class_;
|
||||
QString name;
|
||||
QIcon icon;
|
||||
};
|
||||
enum LabelHelpType {
|
||||
lhMain,
|
||||
lhHint,
|
||||
lhF1,
|
||||
lh_last
|
||||
};
|
||||
|
||||
bool eventFilter(QObject * o, QEvent * e) override;
|
||||
void showEvent(QShowEvent * ) override;
|
||||
void timerEvent(QTimerEvent * ) override;
|
||||
void leaveEvent(QEvent * ) override;
|
||||
void changeEvent(QEvent * e) override;
|
||||
bool codeKeyEvent(QKeyEvent * ke);
|
||||
void toggleComment();
|
||||
void highlightBrackets();
|
||||
void applyExtraSelection();
|
||||
void clearSearch();
|
||||
void moveToSearch();
|
||||
int searchIndFromCursor();
|
||||
QRect cursorRect();
|
||||
QRect blockSelectionRect();
|
||||
QVector<QTextCursor> blockSelectionCursors(QRect bsr);
|
||||
void repaintCursor();
|
||||
void drawCursor();
|
||||
bool hasBlockSelection() const;
|
||||
void startBlockSelection();
|
||||
void cancelBlockSelection();
|
||||
void switchBlockSelection(QKeyEvent * ke = nullptr);
|
||||
bool removeBlockSelection(bool is_del);
|
||||
void insertBlockSelection(QString text);
|
||||
void createBlockSelection();
|
||||
void cancelDragCursor();
|
||||
ACEntry findEntryOnCursor(QTextCursor tc, int arg = -1, ACClass * acc = nullptr, QPair<QStringList, QString> * scope = nullptr);
|
||||
|
||||
Ui::QCodeEdit * ui;
|
||||
QCodeEditCompleter * completer;
|
||||
IconedLabel * lbl_help[3];
|
||||
QFrame * widget_help;
|
||||
_QCE_Viewport * overlay;
|
||||
QTextEdit::ExtraSelection es_line, es_cursor, es_bracket, es_range, es_search, es_link;
|
||||
QList<QTextEdit::ExtraSelection> es_selected, es_custom, es_brackets, es_search_list, es_blockselection;
|
||||
QMap<int, ACClass> ac_classes;
|
||||
QStringList cursor_scope;
|
||||
QString comment_text;
|
||||
ACEntry link_entry, help_entry;
|
||||
QTextCursor block_start_cursor, drag_cursor;
|
||||
int prev_lc, auto_comp_pl, timer_parse, timer_blink, cur_search_ind, pos_press, pos_el_press;
|
||||
int cursor_width;
|
||||
bool spaces_, _ignore_focus_out, _first, _destructor, _replacing;
|
||||
bool word_complete, help_visible, cursor_state, block_sel_state;
|
||||
};
|
||||
|
||||
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
#include "qcodeedit_completer_p.h"
|
||||
#include "qad_types.h"
|
||||
#include <QKeyEvent>
|
||||
#include <QHeaderView>
|
||||
|
||||
|
||||
@@ -22,7 +23,6 @@ QCodeEditCompleter::QCodeEditCompleter(QWidget * parent): QTreeWidget(parent) {
|
||||
#endif
|
||||
(QHeaderView::ResizeToContents);
|
||||
header()->setStretchLastSection(false);
|
||||
//connect(verticalScrollBar(), SIGNAL(valueChanged(int)), this, SLOT(adjust()));
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -20,16 +20,16 @@
|
||||
#ifndef QCODEEDIT_COMPLETER_P_H
|
||||
#define QCODEEDIT_COMPLETER_P_H
|
||||
|
||||
#include <QTreeWidget>
|
||||
#include "qcodeedit.h"
|
||||
#include <QTreeWidget>
|
||||
|
||||
|
||||
class QCodeEditCompleter: public QTreeWidget
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
QCodeEditCompleter(QWidget * parent = 0);
|
||||
~QCodeEditCompleter();
|
||||
QCodeEditCompleter(QWidget * parent = nullptr);
|
||||
~QCodeEditCompleter() override;
|
||||
|
||||
void nextCompletition();
|
||||
void previousCompletition();
|
||||
@@ -39,9 +39,6 @@ public:
|
||||
QString currentReturn() const;
|
||||
QString currentValue() const;
|
||||
|
||||
private:
|
||||
void keyPressEvent(QKeyEvent * e) override;
|
||||
|
||||
private slots:
|
||||
void adjust();
|
||||
|
||||
@@ -49,6 +46,8 @@ signals:
|
||||
void commit();
|
||||
void gotoHRef(QCodeEdit::ACEntry e);
|
||||
|
||||
private:
|
||||
void keyPressEvent(QKeyEvent * e) override;
|
||||
};
|
||||
|
||||
|
||||
|
||||
@@ -1,4 +1,10 @@
|
||||
#include "qipedit.h"
|
||||
#include "qalgorithms.h"
|
||||
#include <QLabel>
|
||||
#include <QLineEdit>
|
||||
#include <QBoxLayout>
|
||||
#include <QIntValidator>
|
||||
|
||||
|
||||
QIPEdit::QIPEdit(QWidget * parent, const QString & ip): QWidget(parent) {
|
||||
layout = new QBoxLayout(QBoxLayout::LeftToRight, this);
|
||||
@@ -19,32 +25,20 @@ QIPEdit::QIPEdit(QWidget * parent, const QString & ip): QWidget(parent) {
|
||||
layout->addWidget(dots.back());
|
||||
}
|
||||
}
|
||||
//for (int i = 0; i < 3; i++) edits[i]->setTabOrder(edits[i+1], edits[i]);
|
||||
connect(edits[0], SIGNAL(returnPressed()), this, SLOT(returnPressed0()));
|
||||
connect(edits[1], SIGNAL(returnPressed()), this, SLOT(returnPressed1()));
|
||||
connect(edits[2], SIGNAL(returnPressed()), this, SLOT(returnPressed2()));
|
||||
connect(edits[3], SIGNAL(returnPressed()), this, SLOT(returnPressed3()));
|
||||
connect(edits[0], SIGNAL(textChanged(const QString & )), this, SLOT(textChanged0(const QString & )));
|
||||
connect(edits[1], SIGNAL(textChanged(const QString & )), this, SLOT(textChanged1(const QString & )));
|
||||
connect(edits[2], SIGNAL(textChanged(const QString & )), this, SLOT(textChanged2(const QString & )));
|
||||
connect(edits[3], SIGNAL(textChanged(const QString & )), this, SLOT(textChanged3(const QString & )));
|
||||
connect(edits[0], &QLineEdit::returnPressed, this, &QIPEdit::returnPressed0);
|
||||
connect(edits[1], &QLineEdit::returnPressed, this, &QIPEdit::returnPressed1);
|
||||
connect(edits[2], &QLineEdit::returnPressed, this, &QIPEdit::returnPressed2);
|
||||
connect(edits[3], &QLineEdit::returnPressed, this, &QIPEdit::returnPressed3);
|
||||
connect(edits[0], &QLineEdit::textChanged, this, &QIPEdit::textChanged0);
|
||||
connect(edits[1], &QLineEdit::textChanged, this, &QIPEdit::textChanged1);
|
||||
connect(edits[2], &QLineEdit::textChanged, this, &QIPEdit::textChanged2);
|
||||
connect(edits[3], &QLineEdit::textChanged, this, &QIPEdit::textChanged3);
|
||||
setLayout(layout);
|
||||
setIP(ip);
|
||||
cind = 0;
|
||||
}
|
||||
|
||||
|
||||
QIPEdit::~QIPEdit() {
|
||||
foreach (QLineEdit * i, edits)
|
||||
delete i;
|
||||
foreach (QLabel * i, dots)
|
||||
delete i;
|
||||
edits.clear();
|
||||
dots.clear();
|
||||
delete layout;
|
||||
}
|
||||
|
||||
|
||||
void QIPEdit::setIP(const QString & text) {
|
||||
QString s, str = text;
|
||||
s = str.left(str.indexOf('.'));
|
||||
@@ -80,3 +74,11 @@ void QIPEdit::returnPress(int index) {
|
||||
edits[index + 1]->setSelection(0, 3);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
inline void QIPEdit::textChange(int index, const QString &text) {
|
||||
if (text.length() == 3 && isVisible()) {
|
||||
returnPress(index);
|
||||
}
|
||||
emit valueChanged(IP());
|
||||
}
|
||||
|
||||
@@ -20,13 +20,13 @@
|
||||
#ifndef QIPEDIT_H
|
||||
#define QIPEDIT_H
|
||||
|
||||
#include <QVector>
|
||||
#include <QBoxLayout>
|
||||
#include <QIntValidator>
|
||||
#include <QFocusEvent>
|
||||
#include <QLineEdit>
|
||||
#include <QLabel>
|
||||
#include "qad_widgets_export.h"
|
||||
#include <QWidget>
|
||||
|
||||
|
||||
class QBoxLayout;
|
||||
class QLineEdit;
|
||||
class QLabel;
|
||||
|
||||
|
||||
class QAD_WIDGETS_EXPORT QIPEdit: public QWidget
|
||||
@@ -35,20 +35,10 @@ class QAD_WIDGETS_EXPORT QIPEdit: public QWidget
|
||||
Q_PROPERTY(QString IP READ IP WRITE setIP)
|
||||
|
||||
public:
|
||||
QIPEdit(QWidget * parent = 0, const QString & ip = "");
|
||||
~QIPEdit();
|
||||
QIPEdit(QWidget * parent = nullptr, const QString & ip = "");
|
||||
|
||||
QString IP();
|
||||
|
||||
private:
|
||||
void returnPress(int index);
|
||||
inline void textChange(int index, const QString & text) {if (text.length() == 3 && isVisible()) returnPress(index); emit valueChanged(IP());}
|
||||
|
||||
int cind;
|
||||
QBoxLayout * layout;
|
||||
QVector<QLineEdit * > edits;
|
||||
QVector<QLabel * > dots;
|
||||
|
||||
public slots:
|
||||
void setIP(const QString & text);
|
||||
|
||||
@@ -64,6 +54,15 @@ private slots:
|
||||
|
||||
signals:
|
||||
void valueChanged(QString);
|
||||
|
||||
private:
|
||||
void returnPress(int index);
|
||||
void textChange(int index, const QString &text);
|
||||
|
||||
int cind;
|
||||
QBoxLayout * layout;
|
||||
QList<QLineEdit * > edits;
|
||||
QList<QLabel * > dots;
|
||||
};
|
||||
|
||||
#endif // QIPEDIT_H
|
||||
|
||||
@@ -24,7 +24,7 @@ void QPIConfigNewDialog::changeEvent(QEvent * e) {
|
||||
|
||||
|
||||
void QPIConfigNewDialog::typeChanged() {
|
||||
foreach (QRadioButton * i, radios) {
|
||||
for (const QRadioButton * i : radios) {
|
||||
if (i->isChecked()) {
|
||||
ui->widgetValue->setType(i->property("type").toString());
|
||||
return;
|
||||
@@ -34,9 +34,11 @@ void QPIConfigNewDialog::typeChanged() {
|
||||
|
||||
|
||||
QString QPIConfigNewDialog::type() {
|
||||
foreach (QRadioButton * i, radios)
|
||||
if (i->isChecked())
|
||||
for (const QRadioButton * i : radios) {
|
||||
if (i->isChecked()) {
|
||||
return i->property("type").toString();
|
||||
}
|
||||
}
|
||||
return " ";
|
||||
}
|
||||
|
||||
|
||||
@@ -21,7 +21,6 @@
|
||||
#define QPICONFIGNEWDIALOG_H
|
||||
|
||||
#include <QDialog>
|
||||
#include <QRadioButton>
|
||||
#include "qad_widgets_export.h"
|
||||
|
||||
|
||||
@@ -29,13 +28,15 @@ namespace Ui {
|
||||
class QPIConfigNewDialog;
|
||||
}
|
||||
|
||||
class QRadioButton;
|
||||
|
||||
|
||||
class QAD_WIDGETS_EXPORT QPIConfigNewDialog: public QDialog
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
QPIConfigNewDialog(QWidget * parent = 0);
|
||||
QPIConfigNewDialog(QWidget * parent = nullptr);
|
||||
|
||||
QString type();
|
||||
QString name();
|
||||
@@ -44,15 +45,14 @@ public:
|
||||
void reset(bool node = false);
|
||||
|
||||
protected:
|
||||
void changeEvent(QEvent * e);
|
||||
|
||||
Ui::QPIConfigNewDialog * ui;
|
||||
void changeEvent(QEvent * e) override;
|
||||
|
||||
private slots:
|
||||
void on_lineName_textChanged(const QString & text);
|
||||
void typeChanged();
|
||||
|
||||
private:
|
||||
Ui::QPIConfigNewDialog * ui;
|
||||
QList<QRadioButton * > radios;
|
||||
|
||||
};
|
||||
|
||||
@@ -1,4 +1,9 @@
|
||||
#include "qpiconfigwidget.h"
|
||||
#include "qalgorithms.h"
|
||||
#include "qpiconfigvaluewidget.h"
|
||||
#include <QMouseEvent>
|
||||
#include <QApplication>
|
||||
#include <QVariant>
|
||||
|
||||
|
||||
QPIConfigWidget::QPIConfigWidget(QWidget * parent, QPIConfig * c, bool on): QTreeWidget(parent), actionAddItem(this), actionAddNode(this),
|
||||
@@ -9,7 +14,9 @@ QPIConfigWidget::QPIConfigWidget(QWidget * parent, QPIConfig * c, bool on): QTre
|
||||
setColumnCount(4);
|
||||
setColumnWidth(0, 150);
|
||||
setColumnWidth(1, 200);
|
||||
} else setColumnCount(0);
|
||||
} else {
|
||||
setColumnCount(0);
|
||||
}
|
||||
setSelectionMode(ExtendedSelection);
|
||||
setVerticalScrollMode(ScrollPerPixel);
|
||||
actionAddItem.setIcon(QIcon(":/icons/item-add.png"));
|
||||
@@ -20,9 +27,6 @@ QPIConfigWidget::QPIConfigWidget(QWidget * parent, QPIConfig * c, bool on): QTre
|
||||
popupMenu.addAction(&actionAddItem);
|
||||
popupMenu.addAction(&actionAddNode);
|
||||
popupMenu.addSeparator();
|
||||
/*popupMenu.addAction(&actionToItem);
|
||||
popupMenu.addAction(&actionToNode);
|
||||
popupMenu.addSeparator();*/
|
||||
popupMenu.addAction(&actionRemove);
|
||||
popupMenu.addSeparator();
|
||||
popupMenu.addAction(&actionExpandAll);
|
||||
@@ -40,8 +44,6 @@ QPIConfigWidget::QPIConfigWidget(QWidget * parent, QPIConfig * c, bool on): QTre
|
||||
pi = c_pi = 0;
|
||||
translate();
|
||||
setQPIConfig(c);
|
||||
//resize(600, 400);
|
||||
//show();
|
||||
}
|
||||
|
||||
|
||||
@@ -62,11 +64,11 @@ bool QPIConfigWidget::eventFilter(QObject * o, QEvent * e) {
|
||||
qApp->processEvents();
|
||||
itemClicked(pi, 1);
|
||||
popupMenu.popup(
|
||||
#if QT_VERSION_MAJOR <= 5
|
||||
#if QT_VERSION_MAJOR <= 5
|
||||
((QMouseEvent * )e)->globalPos()
|
||||
#else
|
||||
#else
|
||||
((QMouseEvent * )e)->globalPosition().toPoint()
|
||||
#endif
|
||||
#endif
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -76,15 +78,21 @@ bool QPIConfigWidget::eventFilter(QObject * o, QEvent * e) {
|
||||
|
||||
|
||||
void QPIConfigWidget::itemClicked(QTreeWidgetItem * item, int column) {
|
||||
if (item != 0) {
|
||||
if ((column == 0 && !read_only_name) || (column == 3 && !read_only_comment)) item->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsEditable);
|
||||
else item->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled);
|
||||
if (item) {
|
||||
if ((column == 0 && !read_only_name) || (column == 3 && !read_only_comment)) {
|
||||
item->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsEditable);
|
||||
} else {
|
||||
item->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled);
|
||||
}
|
||||
}
|
||||
bool node = true, ro = read_only_name || read_only_type || read_only_value;
|
||||
if (item != 0)
|
||||
if (itemTWidget(item) != 0)
|
||||
if (itemTWidget(item)->isEnabled())
|
||||
if (item) {
|
||||
if (itemTWidget(item)) {
|
||||
if (itemTWidget(item)->isEnabled()) {
|
||||
node = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
actionAddItem.setVisible(node && !ro);
|
||||
actionAddNode.setVisible(node && !ro);
|
||||
actionRemove.setVisible(!ro && !selectedItems().isEmpty());
|
||||
@@ -94,24 +102,32 @@ void QPIConfigWidget::itemClicked(QTreeWidgetItem * item, int column) {
|
||||
void QPIConfigWidget::itemChanged(QTreeWidgetItem * item, int column) {
|
||||
if (item != c_pi) {
|
||||
c_pi = item;
|
||||
if (item != 0) {
|
||||
if (item) {
|
||||
c_name = item->text(0);
|
||||
c_comment = item->text(3);
|
||||
}
|
||||
return;
|
||||
}
|
||||
if (item == 0) return;
|
||||
if (c_name == item->text(0) && c_comment == item->text(3)) return;
|
||||
if (item == nullptr) {
|
||||
return;
|
||||
}
|
||||
if (c_name == item->text(0) && c_comment == item->text(3)) {
|
||||
return;
|
||||
}
|
||||
//qDebug() << "change" << item->text(0);
|
||||
QPIConfig::Entry * e = itemEntry(item);
|
||||
if (e == 0) return;
|
||||
if (e == nullptr) {
|
||||
return;
|
||||
}
|
||||
if (column == 0) {
|
||||
buildFullNames(item);
|
||||
e->setName(item->text(column));
|
||||
conf->buildFullNames(e->parent());
|
||||
//qDebug() << itemCWidget(item)->full_name;
|
||||
}
|
||||
if (column == 3) e->setComment(item->text(column));
|
||||
if (column == 3) {
|
||||
e->setComment(item->text(column));
|
||||
}
|
||||
c_name = item->text(0);
|
||||
c_comment = item->text(3);
|
||||
emit changed();
|
||||
@@ -119,7 +135,7 @@ void QPIConfigWidget::itemChanged(QTreeWidgetItem * item, int column) {
|
||||
|
||||
|
||||
void QPIConfigWidget::typeChange(int t, UComboBox * c) {
|
||||
ConfigValueWidget * cw = (ConfigValueWidget * )c->property("qpic_widget").toLongLong();
|
||||
auto cw = reinterpret_cast<ConfigValueWidget *>(c->property("qpic_widget").toLongLong());
|
||||
cw->setType(types.key(s_types[t]));
|
||||
conf->getValue(cw->full_name).setType(types.key(s_types[t]));
|
||||
emit changed();
|
||||
@@ -133,12 +149,19 @@ void QPIConfigWidget::valueChange(ConfigValueWidget * w, QString v) {
|
||||
|
||||
|
||||
void QPIConfigWidget::on_actionAddItem_triggered() {
|
||||
if (conf == 0 || !active) return;
|
||||
if (conf == nullptr || !active) {
|
||||
return;
|
||||
}
|
||||
QString fp;
|
||||
if (pi == 0) pi = invisibleRootItem();
|
||||
else fp = itemCWidget(pi)->full_name + conf->delim;
|
||||
if (pi == nullptr) {
|
||||
pi = invisibleRootItem();
|
||||
} else {
|
||||
fp = itemCWidget(pi)->full_name + conf->delim;
|
||||
}
|
||||
new_dialog.reset();
|
||||
if (new_dialog.exec() == QDialog::Rejected) return;
|
||||
if (new_dialog.exec() == QDialog::Rejected) {
|
||||
return;
|
||||
}
|
||||
QPIConfig::Entry * e;
|
||||
if (pi->childCount() == 0) {
|
||||
//qDebug() << "pi empty, remove " << itemCWidget(pi)->full_name;
|
||||
@@ -151,40 +174,50 @@ void QPIConfigWidget::on_actionAddItem_triggered() {
|
||||
pi->setText(0, new_dialog.name());
|
||||
pi->setText(3, new_dialog.comment());
|
||||
int ind = s_types.indexOf(types[new_dialog.type()]);
|
||||
if (ind < 0) w_types.back()->setCurrentIndex(0);
|
||||
else w_types.back()->setCurrentIndex(ind);
|
||||
if (ind < 0) {
|
||||
w_types.back()->setCurrentIndex(0);
|
||||
} else {
|
||||
w_types.back()->setCurrentIndex(ind);
|
||||
}
|
||||
emit changed();
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::on_actionAddNode_triggered() {
|
||||
if (conf == 0 || !active) return;
|
||||
if (conf == nullptr || !active) {
|
||||
return;
|
||||
}
|
||||
QString fp;
|
||||
if (pi == 0) pi = invisibleRootItem();
|
||||
else fp = itemCWidget(pi)->full_name + conf->delim;
|
||||
if (pi == nullptr) {
|
||||
pi = invisibleRootItem();
|
||||
} else {
|
||||
fp = itemCWidget(pi)->full_name + conf->delim;
|
||||
}
|
||||
new_dialog.reset(true);
|
||||
if (new_dialog.exec() == QDialog::Rejected) return;
|
||||
if (new_dialog.exec() == QDialog::Rejected) {
|
||||
return;
|
||||
}
|
||||
QPIConfig::Entry e;
|
||||
//e = &(conf->addEntry(fp + new_dialog.name(), "", "", false));
|
||||
e._full_name = fp + new_dialog.name();
|
||||
expandItem(pi);
|
||||
pi = addEntry(pi, &e, true);
|
||||
pi->setText(0, new_dialog.name());
|
||||
pi->setText(3, new_dialog.comment());
|
||||
setItemWidget(pi, 2, 0);
|
||||
setItemWidget(pi, 2, nullptr);
|
||||
emit changed();
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::on_actionRemove_triggered() {
|
||||
//hide();
|
||||
if (conf == 0 || !active) return;
|
||||
if (conf == nullptr || !active) {
|
||||
return;
|
||||
}
|
||||
QList<QTreeWidgetItem * > si = selectedItems();
|
||||
conf->buildFullNames(&(conf->root));
|
||||
QPIConfig::Entry * e;
|
||||
foreach (QTreeWidgetItem * i, si) {
|
||||
for (QTreeWidgetItem * i : si) {
|
||||
e = itemEntry(i);
|
||||
if (e == 0) continue;
|
||||
if (e == nullptr) continue;
|
||||
//qDebug() << "remove " + e->_full_name;
|
||||
conf->removeEntry(e->_full_name, false);
|
||||
deleteEntry(i);
|
||||
@@ -199,10 +232,8 @@ void QPIConfigWidget::clear() {
|
||||
bool hidden = isHidden();
|
||||
hide();
|
||||
QTreeWidget::clear();
|
||||
foreach (ConfigValueWidget * i, w_values)
|
||||
delete i;
|
||||
foreach (QComboBox * i, w_types)
|
||||
delete i;
|
||||
qDeleteAll(w_values);
|
||||
qDeleteAll(w_types);
|
||||
w_values.clear();
|
||||
w_types.clear();
|
||||
if (!hidden) show();
|
||||
@@ -211,7 +242,7 @@ void QPIConfigWidget::clear() {
|
||||
|
||||
void QPIConfigWidget::buildTree() {
|
||||
if (!active) return;
|
||||
if (conf == 0) return;
|
||||
if (conf == nullptr) return;
|
||||
bool hidden = isHidden();
|
||||
hide();
|
||||
clear();
|
||||
@@ -223,14 +254,15 @@ void QPIConfigWidget::buildTree() {
|
||||
|
||||
void QPIConfigWidget::setReadOnlyValue(bool yes) {
|
||||
read_only_value = yes;
|
||||
foreach (ConfigValueWidget * i, w_values)
|
||||
for (ConfigValueWidget * i : w_values) {
|
||||
i->setEnabled(!yes);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::setReadOnlyType(bool yes) {
|
||||
read_only_type = yes;
|
||||
foreach (QComboBox * i, w_types) {
|
||||
for (QComboBox * i : w_types) {
|
||||
i->setEnabled(!yes);
|
||||
i->setFrame(!yes);
|
||||
}
|
||||
@@ -238,32 +270,36 @@ void QPIConfigWidget::setReadOnlyType(bool yes) {
|
||||
|
||||
|
||||
void QPIConfigWidget::buildEntry(QTreeWidgetItem * i, QPIConfig::Entry * e) {
|
||||
foreach (QPIConfig::Entry * j, e->children())
|
||||
for (QPIConfig::Entry * j : e->children()) {
|
||||
buildEntry(addEntry(i, j, !j->isLeaf()), j);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::buildFullNames(QTreeWidgetItem * i) {
|
||||
ConfigValueWidget * cw, * pw;
|
||||
cw = itemCWidget(i);
|
||||
if (i->parent() != 0) {
|
||||
if (i->parent()) {
|
||||
pw = itemCWidget(i->parent());
|
||||
cw->full_name = pw->full_name + conf->delim + i->text(0);
|
||||
} else cw->full_name = i->text(0);
|
||||
for (int j = 0; j < i->childCount(); ++j)
|
||||
} else {
|
||||
cw->full_name = i->text(0);
|
||||
}
|
||||
for (int j = 0; j < i->childCount(); ++j) {
|
||||
buildFullNames(i->child(j));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
QPIConfig::Entry * QPIConfigWidget::itemEntry(QTreeWidgetItem * i) {
|
||||
ConfigValueWidget * cfw = itemCWidget(i);
|
||||
if (cfw == 0) return 0;
|
||||
if (!cfw) return nullptr;
|
||||
return &(conf->getValue(cfw->full_name));
|
||||
}
|
||||
|
||||
|
||||
QTreeWidgetItem * QPIConfigWidget::addEntry(QTreeWidgetItem * i, QPIConfig::Entry * e, bool node) {
|
||||
if (conf == 0) return 0;
|
||||
if (conf == nullptr) return nullptr;
|
||||
ti = new QTreeWidgetItem();
|
||||
ti->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled);
|
||||
ti->setSizeHint(0, QSize(26, 26));
|
||||
@@ -276,7 +312,7 @@ QTreeWidgetItem * QPIConfigWidget::addEntry(QTreeWidgetItem * i, QPIConfig::Entr
|
||||
w_types.push_back(new UComboBox());
|
||||
w_types.back()->addItems(s_types);
|
||||
w_types.back()->setCurrentIndex(s_types.indexOf(types[e->type().leftJustified(1).left(1)]));
|
||||
w_types.back()->setProperty("qpic_widget", QVariant((qlonglong)w_values.back()));
|
||||
w_types.back()->setProperty("qpic_widget", QVariant(reinterpret_cast<qlonglong>(w_values.back())));
|
||||
w_types.back()->setEnabled(!read_only_type);
|
||||
w_types.back()->setFrame(!read_only_type);
|
||||
connect(w_types.back(), SIGNAL(currentIndexChanged(int, UComboBox * )), this, SLOT(typeChange(int,UComboBox * )));
|
||||
@@ -286,9 +322,9 @@ QTreeWidgetItem * QPIConfigWidget::addEntry(QTreeWidgetItem * i, QPIConfig::Entr
|
||||
setItemWidget(ti, 1, w_values.back());
|
||||
if (!node) {
|
||||
setItemWidget(ti, 2, w_types.back());
|
||||
if (itemTWidget(i) != 0) { //itemTWidget(i)->setEnabled(false);
|
||||
if (itemTWidget(i)) {
|
||||
w_types.remove(w_types.indexOf(itemTWidget(i)));
|
||||
setItemWidget(i, 2, 0);
|
||||
setItemWidget(i, 2, nullptr);
|
||||
}
|
||||
}
|
||||
return ti;
|
||||
@@ -299,15 +335,16 @@ void QPIConfigWidget::deleteEntry(QTreeWidgetItem * i) {
|
||||
ConfigValueWidget * vw;
|
||||
UComboBox * cb;
|
||||
int cc = i->childCount();
|
||||
for (int j = 0; j < cc; ++j)
|
||||
for (int j = 0; j < cc; ++j) {
|
||||
deleteEntry(i->child(0));
|
||||
}
|
||||
vw = qobject_cast<ConfigValueWidget * >(itemWidget(i, 1));
|
||||
cb = qobject_cast<UComboBox * >(itemWidget(i, 2));
|
||||
if (vw != 0) {
|
||||
if (vw) {
|
||||
w_values.remove(w_values.indexOf(vw));
|
||||
delete vw;
|
||||
}
|
||||
if (cb != 0) {
|
||||
if (cb) {
|
||||
w_types.remove(w_types.indexOf(cb));
|
||||
delete cb;
|
||||
}
|
||||
@@ -316,10 +353,15 @@ void QPIConfigWidget::deleteEntry(QTreeWidgetItem * i) {
|
||||
|
||||
|
||||
bool QPIConfigWidget::filter(const QString & f, QTreeWidgetItem * i) {
|
||||
if (i->childCount() == 0) return filterItem(f, i);
|
||||
if (i->childCount() == 0) {
|
||||
return filterItem(f, i);
|
||||
}
|
||||
bool found = false;
|
||||
for (int j = 0; j < i->childCount(); ++j)
|
||||
if (filter(f, i->child(j))) found = true;
|
||||
for (int j = 0; j < i->childCount(); ++j) {
|
||||
if (filter(f, i->child(j))) {
|
||||
found = true;
|
||||
}
|
||||
}
|
||||
i->setHidden(!found);
|
||||
return found;
|
||||
}
|
||||
@@ -333,8 +375,9 @@ bool QPIConfigWidget::filterItem(const QString & f, QTreeWidgetItem * i) {
|
||||
bool ret = (!isColumnHidden(0) && i->text(0).indexOf(f, 0, Qt::CaseInsensitive) >= 0) ||
|
||||
(!isColumnHidden(1) && itemCWidget(i)->value.indexOf(f, 0, Qt::CaseInsensitive) >= 0) ||
|
||||
(!isColumnHidden(3) && i->text(3).indexOf(f, 0, Qt::CaseInsensitive) >= 0);
|
||||
if (itemTWidget(i) != 0)
|
||||
if (itemTWidget(i)) {
|
||||
ret = ret || (!isColumnHidden(2) && itemTWidget(i)->currentText().indexOf(f, 0, Qt::CaseInsensitive) >= 0);
|
||||
}
|
||||
i->setHidden(!ret);
|
||||
return ret;
|
||||
}
|
||||
@@ -364,21 +407,121 @@ void QPIConfigWidget::translate() {
|
||||
actionRemove.setText(tr("Remove"));
|
||||
actionExpandAll.setText(tr("Expand all"));
|
||||
actionCollapseAll.setText(tr("Collapse all"));
|
||||
if (!active) return;
|
||||
for (int i = 0; i < 4; ++i)
|
||||
if (!active) {
|
||||
return;
|
||||
}
|
||||
for (int i = 0; i < 4; ++i) {
|
||||
setColumnHidden(i, c_hidden[i]);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
QString QPIConfigWidget::writeToString() {
|
||||
if (conf == 0) return QString();
|
||||
if (conf == nullptr) {
|
||||
return QString();
|
||||
}
|
||||
conf->buildFullNames(&(conf->root));
|
||||
return conf->writeAllToString();
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::readFromString(QString str) {
|
||||
if (conf == 0) return;
|
||||
if (conf == nullptr) {
|
||||
return;
|
||||
}
|
||||
conf->readAllFromString(str);
|
||||
buildTree();
|
||||
}
|
||||
|
||||
|
||||
UComboBox::UComboBox(QWidget *parent) : QComboBox(parent) {
|
||||
connect(this, SIGNAL(currentIndexChanged(int)), this, SLOT(indexChange(int)));
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::filter(const QString &f) {
|
||||
if (!active) {
|
||||
return;
|
||||
}
|
||||
filter(f, invisibleRootItem());
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::write() {
|
||||
if (conf == nullptr) {
|
||||
return;
|
||||
}
|
||||
conf->buildFullNames(&(conf->root));
|
||||
conf->writeAll();
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::parse() {
|
||||
if (conf == nullptr) {
|
||||
clear();
|
||||
} else {
|
||||
conf->readAll();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::setColumnNameVisible(bool yes) {
|
||||
setColumnHidden(0, !yes);
|
||||
c_hidden[0] = !yes;
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::setColumnValueVisible(bool yes) {
|
||||
setColumnHidden(1, !yes);
|
||||
c_hidden[1] = !yes;
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::setColumnCommentVisible(bool yes) {
|
||||
setColumnHidden(3, !yes);
|
||||
c_hidden[3] = !yes;
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::setColumnTypeVisible(bool yes) {
|
||||
setColumnHidden(2, !yes);
|
||||
c_hidden[2] = !yes;
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::setReadOnlyComment(bool yes) {
|
||||
read_only_comment = yes;
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::setReadOnlyName(bool yes) {
|
||||
read_only_name = yes;
|
||||
}
|
||||
|
||||
|
||||
ConfigValueWidget *QPIConfigWidget::itemCWidget(QTreeWidgetItem *i) {
|
||||
return qobject_cast<ConfigValueWidget *>(itemWidget(i, 1));
|
||||
}
|
||||
|
||||
|
||||
UComboBox *QPIConfigWidget::itemTWidget(QTreeWidgetItem *i) {
|
||||
return qobject_cast<UComboBox *>(itemWidget(i, 2));
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::addTrEntry(const QString &s, const QString &f) {
|
||||
types.insert(s, f);
|
||||
s_types << f;
|
||||
}
|
||||
|
||||
|
||||
void QPIConfigWidget::setQPIConfig(QPIConfig *c) {
|
||||
conf = c;
|
||||
buildTree();
|
||||
}
|
||||
|
||||
|
||||
void UComboBox::indexChange(int i) {
|
||||
emit currentIndexChanged(i, this);
|
||||
}
|
||||
|
||||
|
||||
@@ -20,26 +20,28 @@
|
||||
#ifndef QPICONFIGWIDGET_H
|
||||
#define QPICONFIGWIDGET_H
|
||||
|
||||
#include <QTreeWidget>
|
||||
#include <QComboBox>
|
||||
#include <QEvent>
|
||||
#include <QBoxLayout>
|
||||
#include <QAction>
|
||||
#include <QMenu>
|
||||
#include "qad_widgets_export.h"
|
||||
#include "qpiconfig.h"
|
||||
#include "qpiconfignewdialog.h"
|
||||
#include "qpiconfigvaluewidget.h"
|
||||
#include "qad_widgets_export.h"
|
||||
#include <QComboBox>
|
||||
#include <QTreeWidget>
|
||||
#include <QAction>
|
||||
#include <QMenu>
|
||||
|
||||
|
||||
class ConfigValueWidget;
|
||||
|
||||
|
||||
class QAD_WIDGETS_EXPORT UComboBox: public QComboBox
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
UComboBox(QWidget * parent = 0): QComboBox(parent) {connect(this, SIGNAL(currentIndexChanged(int)), this, SLOT(indexChange(int)));}
|
||||
UComboBox(QWidget *parent = nullptr);
|
||||
|
||||
private slots:
|
||||
void indexChange(int i) {emit currentIndexChanged(i, this);}
|
||||
void indexChange(int i);
|
||||
signals:
|
||||
|
||||
void currentIndexChanged(int, UComboBox * );
|
||||
};
|
||||
|
||||
@@ -56,10 +58,10 @@ class QAD_WIDGETS_EXPORT QPIConfigWidget: public QTreeWidget
|
||||
Q_PROPERTY(bool columnTypeVisible READ columnTypeVisible WRITE setColumnTypeVisible)
|
||||
Q_PROPERTY(bool columnCommentVisible READ columnCommentVisible WRITE setColumnCommentVisible)
|
||||
public:
|
||||
QPIConfigWidget(QWidget * parent = 0, QPIConfig * c = 0, bool on = true);
|
||||
~QPIConfigWidget() {clear();}
|
||||
QPIConfigWidget(QWidget * parent = nullptr, QPIConfig * c = nullptr, bool on = true);
|
||||
~QPIConfigWidget() override {clear();}
|
||||
|
||||
void setQPIConfig(QPIConfig * c) {conf = c; buildTree();}
|
||||
void setQPIConfig(QPIConfig *c);
|
||||
bool readOnlyName() {return read_only_name;}
|
||||
bool readOnlyValue() {return read_only_value;}
|
||||
bool readOnlyType() {return read_only_type;}
|
||||
@@ -71,48 +73,20 @@ public:
|
||||
QString writeToString();
|
||||
void readFromString(QString str);
|
||||
|
||||
private:
|
||||
void changeEvent(QEvent * e);
|
||||
bool eventFilter(QObject * o, QEvent * e);
|
||||
void buildEntry(QTreeWidgetItem * i, QPIConfig::Entry * e);
|
||||
void buildFullNames(QTreeWidgetItem * i);
|
||||
QPIConfig::Entry * itemEntry(QTreeWidgetItem * i);
|
||||
ConfigValueWidget * itemCWidget(QTreeWidgetItem * i) {return qobject_cast<ConfigValueWidget * >(itemWidget(i, 1));}
|
||||
UComboBox * itemTWidget(QTreeWidgetItem * i) {return qobject_cast<UComboBox * >(itemWidget(i, 2));}
|
||||
QTreeWidgetItem * addEntry(QTreeWidgetItem * i, QPIConfig::Entry * e, bool node = false);
|
||||
void deleteEntry(QTreeWidgetItem * i);
|
||||
bool filter(const QString & f, QTreeWidgetItem * i);
|
||||
bool filterItem(const QString & f, QTreeWidgetItem * i);
|
||||
void translate();
|
||||
void addTrEntry(const QString & s, const QString & f) {types.insert(s, f); s_types << f;}
|
||||
|
||||
QPIConfig * conf;
|
||||
QPIConfigNewDialog new_dialog;
|
||||
QAction actionAddItem, actionAddNode, actionToItem, actionToNode, actionRemove, actionExpandAll, actionCollapseAll;
|
||||
QMenu popupMenu;
|
||||
QString c_name, c_comment;
|
||||
QTreeWidgetItem * pi, * ti, * c_pi;
|
||||
QHash<QString, QString> types;
|
||||
QStringList s_types;
|
||||
QVector<ConfigValueWidget * > w_values;
|
||||
QVector<UComboBox * > w_types;
|
||||
QVector<bool> c_hidden;
|
||||
bool active, read_only_name, read_only_value, read_only_type, read_only_comment;
|
||||
|
||||
public slots:
|
||||
void parse() {if (conf == 0) clear(); else conf->readAll();}
|
||||
void write() {if (conf == 0) return; conf->buildFullNames(&(conf->root)); conf->writeAll();}
|
||||
void parse();
|
||||
void write();
|
||||
void clear();
|
||||
void buildTree();
|
||||
void filter(const QString & f) {if (!active) return; filter(f, invisibleRootItem());}
|
||||
void setReadOnlyName(bool yes) {read_only_name = yes;}
|
||||
void filter(const QString &f);
|
||||
void setReadOnlyName(bool yes);
|
||||
void setReadOnlyValue(bool yes);
|
||||
void setReadOnlyType(bool yes);
|
||||
void setReadOnlyComment(bool yes) {read_only_comment = yes;}
|
||||
void setColumnNameVisible(bool yes) {setColumnHidden(0, !yes); c_hidden[0] = !yes;}
|
||||
void setColumnValueVisible(bool yes) {setColumnHidden(1, !yes); c_hidden[1] = !yes;}
|
||||
void setColumnTypeVisible(bool yes) {setColumnHidden(2, !yes); c_hidden[2] = !yes;}
|
||||
void setColumnCommentVisible(bool yes) {setColumnHidden(3, !yes); c_hidden[3] = !yes;}
|
||||
void setReadOnlyComment(bool yes);
|
||||
void setColumnNameVisible(bool yes);
|
||||
void setColumnValueVisible(bool yes);
|
||||
void setColumnTypeVisible(bool yes);
|
||||
void setColumnCommentVisible(bool yes);
|
||||
|
||||
private slots:
|
||||
void itemClicked(QTreeWidgetItem * item, int column);
|
||||
@@ -126,6 +100,33 @@ private slots:
|
||||
signals:
|
||||
void changed();
|
||||
|
||||
private:
|
||||
void changeEvent(QEvent * e) override;
|
||||
bool eventFilter(QObject * o, QEvent * e) override;
|
||||
void buildEntry(QTreeWidgetItem * i, QPIConfig::Entry * e);
|
||||
void buildFullNames(QTreeWidgetItem * i);
|
||||
QPIConfig::Entry * itemEntry(QTreeWidgetItem * i);
|
||||
ConfigValueWidget *itemCWidget(QTreeWidgetItem *i);
|
||||
UComboBox *itemTWidget(QTreeWidgetItem *i);
|
||||
QTreeWidgetItem * addEntry(QTreeWidgetItem * i, QPIConfig::Entry * e, bool node = false);
|
||||
void deleteEntry(QTreeWidgetItem * i);
|
||||
bool filter(const QString & f, QTreeWidgetItem * i);
|
||||
bool filterItem(const QString & f, QTreeWidgetItem * i);
|
||||
void translate();
|
||||
void addTrEntry(const QString &s, const QString &f);
|
||||
|
||||
QPIConfig * conf;
|
||||
QPIConfigNewDialog new_dialog;
|
||||
QAction actionAddItem, actionAddNode, actionToItem, actionToNode, actionRemove, actionExpandAll, actionCollapseAll;
|
||||
QMenu popupMenu;
|
||||
QString c_name, c_comment;
|
||||
QTreeWidgetItem * pi, * ti, * c_pi;
|
||||
QHash<QString, QString> types;
|
||||
QStringList s_types;
|
||||
QVector<ConfigValueWidget * > w_values;
|
||||
QVector<UComboBox * > w_types;
|
||||
QVector<bool> c_hidden;
|
||||
bool active, read_only_name, read_only_value, read_only_type, read_only_comment;
|
||||
};
|
||||
|
||||
#endif // QPICONFIGWIDGET_H
|
||||
|
||||
@@ -33,6 +33,7 @@ class QAD_WIDGETS_EXPORT QVariantEditorFactoryBase {
|
||||
friend class QVariantEdit;
|
||||
public:
|
||||
QVariantEditorFactoryBase() {}
|
||||
virtual ~QVariantEditorFactoryBase() {}
|
||||
virtual QWidget * createEditor() = 0;
|
||||
private:
|
||||
|
||||
|
||||
Reference in New Issue
Block a user