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