notepad--/patchs/base-4c8661d74aa78ea504a9a2...

891 lines
30 KiB
Diff
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

From 34d458cf82810609bee2c85f1eb772bbef40a152 Mon Sep 17 00:00:00 2001
From: zinface <zinface@163.com>
Date: Mon, 6 Feb 2023 16:40:36 +0800
Subject: [PATCH] =?UTF-8?q?linux-qt6:=20=E6=B7=BB=E5=8A=A0=E7=94=A8?=
=?UTF-8?q?=E4=BA=8E=20Qt6=20=E7=BC=96=E8=AF=91=E7=9A=84=E7=9B=B8=E5=85=B3?=
=?UTF-8?q?=E5=8F=98=E6=9B=B4?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/CmpareMode.cpp | 4 +-
src/Encode.cpp | 2 +-
src/RealCompare.pro | 44 ++++++++++----------
src/batchfindreplace.cpp | 6 +--
src/cceditor/ccnotepad.cpp | 64 ++++++++++++++--------------
src/columnedit.cpp | 4 +-
src/ctipwin.cpp | 2 +-
src/draglineedit.cpp | 1 +
src/encodeconvert.cpp | 2 +-
src/findresultwin.cpp | 26 +++++++-----
src/findwin.cpp | 4 +-
src/langstyledefine.cpp | 8 ++--
src/nddsetting.cpp | 2 +-
src/qscint/src/qscilexer.cpp | 4 +-
src/qscint/src/qscintilla.pro | 18 ++------
src/qtlangset.cpp | 78 +++++++++++++++++------------------
src/scintillaeditview.cpp | 8 ++--
src/userlexdef.cpp | 6 +--
18 files changed, 139 insertions(+), 144 deletions(-)
diff --git a/src/CmpareMode.cpp b/src/CmpareMode.cpp
index b8fb335..1245275 100755
--- a/src/CmpareMode.cpp
+++ b/src/CmpareMode.cpp
@@ -181,7 +181,7 @@ quint32 CmpareMode::readLineFromFileWithUnicodeLe(uchar* m_fileFpr, const int fi
else if (mode == 2)
{
QString temp = lineInfo.unicodeStr;
- md4.addData(temp.replace(QRegExp("\\s"), QString("")).toUtf8());
+ md4.addData(temp.replace(QRegularExpression("\\s"), QString("")).toUtf8());
}
};
@@ -429,7 +429,7 @@ CODE_ID CmpareMode::readLineFromFile(uchar* m_fileFpr, const int fileLength, con
else if (mode == 2)
{
QString temp = lineInfo.unicodeStr;
- md4.addData(temp.replace(QRegExp("\\s"), QString("")).toUtf8());
+ md4.addData(temp.replace(QRegularExpression("\\s"), QString("")).toUtf8());
}
};
diff --git a/src/Encode.cpp b/src/Encode.cpp
index 2164880..9fd8af1 100755
--- a/src/Encode.cpp
+++ b/src/Encode.cpp
@@ -1,6 +1,6 @@
#include "Encode.h"
#include <QTextCodec>
-#include <QtDebug>
+#include <QDebug>
/* 检查字符串编码的类。看了大量文献,结论如下:
*如果是UTF BOM格式或者UNICODE格式其文件头部前几个字节2-3有一定的标识。由此标识直接按对应编码处理。
diff --git a/src/RealCompare.pro b/src/RealCompare.pro
index 1035414..0da717e 100755
--- a/src/RealCompare.pro
+++ b/src/RealCompare.pro
@@ -3,9 +3,9 @@ LANGUAGE = C++
TARGET = Notepad--
-CONFIG += qt warn_on Debug
+CONFIG += qt warn_on
-QT += core gui widgets concurrent network xmlpatterns
+QT += core gui widgets concurrent network core5compat
HEADERS += *.h \
@@ -33,47 +33,47 @@ INCLUDEPATH += cceditor
TRANSLATIONS += realcompare_zh.ts
- if(contains(QMAKE_HOST.arch, x86_64)){
- CONFIG(Debug, Debug|Release){
+ if(contains(QMAKE_HOST.arch, x86_64|loongarch64)){
+ CONFIG(debug, debug|release){
DESTDIR = x64/Debug
- LIBS += -Lx64/Debug
- LIBS += -lqmyedit_qt5d
+ LIBS += -Lx64/Debug
+ LIBS += -lqmyedit_qt6d
}else{
DESTDIR = x64/Release
LIBS += -Lx64/Release
- LIBS += -lqmyedit_qt5
+ LIBS += -lqmyedit_qt6
#QMAKE_CXXFLAGS += /openmp
}
- }
+}
+
unix{
-if(CONFIG(debug, Debug|Release)){
- LIBS += -L/home/yzw/build/CCNotePad/x64/Debug -lqmyedit_qt5
+ if(CONFIG(debug, debug|release)){
+ LIBS += -L/home/yzw/build/CCNotePad/x64/Debug -lqmyedit_qt6
-QMAKE_CXXFLAGS += -fopenmp
-LIBS += -lgomp -lpthread
+ QMAKE_CXXFLAGS += -fopenmp
+ LIBS += -lgomp -lpthread
}else{
- LIBS += -L/home/yzw/build/CCNotePad/x64/Release -lqmyedit_qt5
+ LIBS += -L/home/yzw/build/CCNotePad/x64/Release -lqmyedit_qt6
DESTDIR = x64/Release
QMAKE_CXXFLAGS += -fopenmp -O2
LIBS += -lgomp -lpthread
}
- }
-
+}
RC_FILE += RealCompare.rc
+
unix
{
-
-INCLUDEPATH += $$PWD/.
-DEPENDPATH += $$PWD/.
+ INCLUDEPATH += $$PWD/.
+ DEPENDPATH += $$PWD/.
-unix:!macx: LIBS += -L$$PWD/x64/Release/ -lqmyedit_qt5
+ unix:!macx: LIBS += -L$$PWD/x64/Release/ -lqmyedit_qt6
-INCLUDEPATH += $$PWD/x64/Release
-DEPENDPATH += $$PWD/x64/Release
+ INCLUDEPATH += $$PWD/x64/Release
+ DEPENDPATH += $$PWD/x64/Release
-unix:!macx: PRE_TARGETDEPS += $$PWD/x64/Release/libqmyedit_qt5.a
+ unix:!macx: PRE_TARGETDEPS += $$PWD/x64/Release/libqmyedit_qt6.a
}
diff --git a/src/batchfindreplace.cpp b/src/batchfindreplace.cpp
index cb071c3..2602e3c 100755
--- a/src/batchfindreplace.cpp
+++ b/src/batchfindreplace.cpp
@@ -89,7 +89,7 @@ void BatchFindReplace::appendToFindReplaceTable(QStringList& findKeyword)
bool BatchFindReplace::tranInputKeyword(QString& findKeyWord, QStringList& outputKeyWordList)
{
//<2F>ѿհ<D1BF><D5B0>ַ<EFBFBD><D6B7><EFBFBD><EFBFBD>ո<EFBFBD><D5B8><EFBFBD><EFBFBD><EFBFBD>\t \r\n <20><><EFBFBD>ַ<EFBFBD><D6B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD>滻Ϊ<E6BBBB>ո<EFBFBD>
- QRegExp re("\\s");
+ QRegularExpression re("\\s");
findKeyWord.replace(re, QString(" "));
//<2F>ٽ<EFBFBD><D9BD>пո<D0BF><D5B8>ָ<EFBFBD><D6B8><EFBFBD><EFBFBD><EFBFBD>
@@ -257,7 +257,7 @@ void BatchFindReplace::on_export()
if (!fileName.isEmpty())
{
QSettings setting(fileName, QSettings::IniFormat);
- setting.setIniCodec("UTF-8");
+// setting.setIniCodec("UTF-8");
int rowNums = ui.findReplaceTable->rowCount();
@@ -303,7 +303,7 @@ void BatchFindReplace::on_import()
QFileInfo fi(fileNameList[0]);
QSettings setting(fi.filePath(), QSettings::IniFormat);
- setting.setIniCodec("UTF-8");
+// setting.setIniCodec("UTF-8");
ui.findKeywordEdit->setPlainText(setting.value("find").toStringList().join(" "));
ui.replaceKeywordEdit->setPlainText(setting.value("replace").toStringList().join(" "));
diff --git a/src/cceditor/ccnotepad.cpp b/src/cceditor/ccnotepad.cpp
index 1f04879..5efe091 100755
--- a/src/cceditor/ccnotepad.cpp
+++ b/src/cceditor/ccnotepad.cpp
@@ -507,7 +507,7 @@ void initFileTypeLangMap()
//把新语言tagName,和关联ext单独存放起来ext_tag.ini。只读取一个文件就能获取所有避免遍历慢
QString extsFile = QString("notepad/userlang/ext_tag");//ext_tag是存在所有tag ext的文件
QSettings qs(QSettings::IniFormat, QSettings::UserScope, extsFile);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
QStringList keys = qs.allKeys();
//LangType lexId = L_USER_TXT;
@@ -3981,7 +3981,7 @@ void CCNotePad::initFileListDockWin()
}
});
m_dockFileListWin->setAttribute(Qt::WA_DeleteOnClose);
- m_dockFileListWin->layout()->setMargin(0);
+ m_dockFileListWin->layout()->setContentsMargins(0, 0, 0, 0);
m_dockFileListWin->layout()->setSpacing(0);
//暂时不提供关闭因为关闭后需要同步菜单的check状态
@@ -4312,7 +4312,7 @@ void CCNotePad::slot_actionSaveFile_toggle(bool /*checked*/)
if (pEdit != nullptr)
{
//如果是新建的文件,则弹出保存对话框,进行保存
- if (pEdit->property(Edit_File_New) >= 0)
+ if (pEdit->property(Edit_File_New).toString().length() >= 0)
{
QString filter("Text files (*.txt);;XML files (*.xml);;h files (*.h);;cpp file(*.cpp);;All types(*.*)");
QString fileName = QFileDialog::getSaveFileName(this, tr("Save File"), QString(), filter);
@@ -4472,7 +4472,7 @@ void CCNotePad::slot_actionSaveAsFile_toggle(bool /*checked*/)
if (pEdit != nullptr)
{
//如果是新建的文件,则弹出保存对话框,进行保存
- if (pEdit->property(Edit_File_New) >= 0)
+ if (pEdit->property(Edit_File_New).toString().length() >= 0)
{
QString filter("Text files (*.txt);;XML files (*.xml);;h files (*.h);;cpp file(*.cpp);;All types(*.*)");
QString fileName = QFileDialog::getSaveFileName(this, tr("Save File As ..."),QString(), filter);
@@ -4763,7 +4763,7 @@ void CCNotePad::saveTempFile(ScintillaEditView* pEdit,int index, QSettings& qs)
return;
}
- QVariant v = pEdit->property(Edit_Text_Change);
+ QVariant v = pEdit->property(Edit_Text_Change);
bool isDirty = v.toBool();
//不脏则不需要保存直接跳过。不脏的文件只记录1个名称下次打开时恢复
@@ -4773,7 +4773,7 @@ void CCNotePad::saveTempFile(ScintillaEditView* pEdit,int index, QSettings& qs)
//把文件记录到qs中去
//index一定不能重复。n表示新建
//如果是新建的文件
- if (pEdit->property(Edit_File_New) >= 0)
+ if (pEdit->property(Edit_File_New).toInt() >= 0)
{
qs.setValue(QString("%1").arg(index), QString("%1|1").arg(fileName));
}
@@ -4792,7 +4792,7 @@ void CCNotePad::saveTempFile(ScintillaEditView* pEdit,int index, QSettings& qs)
}
//如果是新建的文件
- if (pEdit->property(Edit_File_New) >= 0)
+ if (pEdit->property(Edit_File_New).toInt() >= 0)
{
QString qsSavePath = qs.fileName();
@@ -4963,7 +4963,7 @@ void CCNotePad::closeAllFileStatic()
{
QString tempFileList = QString("notepad/temp/list");
QSettings qs(QSettings::IniFormat, QSettings::UserScope, tempFileList);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
qs.clear();
//从尾部开始依次调用保存所有文件。没修改的不需要保存
@@ -5047,7 +5047,7 @@ void CCNotePad::closeEvent(QCloseEvent * event)
#else
if ((s_restoreLastFile == 1) && m_isMainWindows)
{
- closeAllFileStatic();
+ closeAllFileStatic();
m_isQuitCancel = false;
}
else
@@ -5094,9 +5094,9 @@ void CCNotePad::closeEvent(QCloseEvent * event)
{
c->showNormal();
}
- qlonglong winId = (qlonglong)c->effectiveWinId();
- m_shareMem->lock();
- memcpy(m_shareMem->data(), &winId, sizeof(qlonglong));
+ qlonglong winId = (qlonglong)c->effectiveWinId();
+ m_shareMem->lock();
+ memcpy(m_shareMem->data(), &winId, sizeof(qlonglong));
m_shareMem->unlock();
c->m_isMainWindows = true;
}
@@ -5480,7 +5480,7 @@ void CCNotePad::initFindWindow()
//从历史查找记录文件中加载
QString searchHistory = QString("notepad/searchHistory");//历史查找记录
QSettings qs(QSettings::IniFormat, QSettings::UserScope, searchHistory);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
if (qs.contains("keys"))
{
@@ -5545,7 +5545,7 @@ void CCNotePad::slot_saveSearchHistory()
//从历史查找记录文件中加载
QString searchHistory = QString("notepad/searchHistory");//历史查找记录
QSettings qs(QSettings::IniFormat, QSettings::UserScope, searchHistory);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
if (s_findHistroy.count() > 15)
{
@@ -5772,7 +5772,7 @@ void CCNotePad::initFindResultDockWin()
m_dockSelectTreeWin = new QDockWidget(tr("Find result"), this);
connect(m_dockSelectTreeWin, &QDockWidget::dockLocationChanged, this, &CCNotePad::slot_findResultPosChangeed);
- m_dockSelectTreeWin->layout()->setMargin(0);
+ m_dockSelectTreeWin->layout()->setContentsMargins(0, 0, 0, 0);
m_dockSelectTreeWin->layout()->setSpacing(0);
//暂时不提供关闭因为关闭后需要同步菜单的check状态
@@ -6573,7 +6573,7 @@ bool CCNotePad::eventFilter(QObject * watched, QEvent * event)
}
return false;
}
-
+
#ifdef Q_OS_WIN
static const ULONG_PTR CUSTOM_TYPE = 10000;
@@ -6581,16 +6581,16 @@ static const ULONG_PTR OPEN_NOTEPAD_TYPE = 10001;
bool CCNotePad::nativeEvent(const QByteArray & eventType, void * message, long * result)
{
- MSG *param = static_cast<MSG *>(message);
-
- switch (param->message)
- {
- case WM_COPYDATA:
- {
- COPYDATASTRUCT *cds = reinterpret_cast<COPYDATASTRUCT*>(param->lParam);
- if (cds->dwData == CUSTOM_TYPE)
- {
- QString openFilePath = QString::fromUtf8(reinterpret_cast<char*>(cds->lpData), cds->cbData);
+ MSG *param = static_cast<MSG *>(message);
+
+ switch (param->message)
+ {
+ case WM_COPYDATA:
+ {
+ COPYDATASTRUCT *cds = reinterpret_cast<COPYDATASTRUCT*>(param->lParam);
+ if (cds->dwData == CUSTOM_TYPE)
+ {
+ QString openFilePath = QString::fromUtf8(reinterpret_cast<char*>(cds->lpData), cds->cbData);
int retIndex = findFileIsOpenAtPad(openFilePath);
if (-1 == retIndex)
@@ -6622,9 +6622,9 @@ bool CCNotePad::nativeEvent(const QByteArray & eventType, void * message, long *
this->activateWindow();
- *result = 1;
- return true;
- }
+ *result = 1;
+ return true;
+ }
else if (cds->dwData == OPEN_NOTEPAD_TYPE)
{
activateWindow();
@@ -6632,8 +6632,8 @@ bool CCNotePad::nativeEvent(const QByteArray & eventType, void * message, long *
*result = 1;
return true;
- }
- }
+ }
+ }
}
return QWidget::nativeEvent(eventType, message, result);
@@ -7124,7 +7124,7 @@ int CCNotePad::restoreLastFiles()
QString tempFileList = QString("notepad/temp/list");
QSettings qs(QSettings::IniFormat, QSettings::UserScope, tempFileList);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
QStringList fileList = qs.allKeys();
//从小到大排序一下
diff --git a/src/columnedit.cpp b/src/columnedit.cpp
index 50fd9ae..aaf93f1 100755
--- a/src/columnedit.cpp
+++ b/src/columnedit.cpp
@@ -216,13 +216,13 @@ void ColumnEdit::slot_ok()
{
QByteArray s_space(cursorCol - lineEndCol, ' ');
lineData.append(s_space);
- lineData.append(text);
+ lineData.append(text.toLatin1());
}
else
{
int posAbs2Start = pEdit->execute(SCI_FINDCOLUMN, i, cursorCol);
int posRelative2Start = posAbs2Start - lineBegin;
- lineData.insert(posRelative2Start, text);
+ lineData.insert(posRelative2Start, text.toLatin1());
}
pEdit->SendScintilla(SCI_SETTARGETRANGE, lineBegin, lineEnd);
diff --git a/src/ctipwin.cpp b/src/ctipwin.cpp
index 9412777..5bf16a9 100755
--- a/src/ctipwin.cpp
+++ b/src/ctipwin.cpp
@@ -9,7 +9,7 @@ CTipWin::CTipWin(QWidget *parent)
this->setWindowFlags(Qt::ToolTip);
QPalette palette(this->palette());
- palette.setColor(QPalette::Background, QColor(0xfff29d));
+ palette.setColor(QPalette::Window, QColor(0xfff29d));
this->setPalette(palette);
}
diff --git a/src/draglineedit.cpp b/src/draglineedit.cpp
index c21f3de..d8a8513 100755
--- a/src/draglineedit.cpp
+++ b/src/draglineedit.cpp
@@ -1,4 +1,5 @@
#include "draglineedit.h"
+#include <QFile>
DragLineEdit::DragLineEdit(QWidget *parent)
: QLineEdit(parent)
diff --git a/src/encodeconvert.cpp b/src/encodeconvert.cpp
index c17022e..7bbcfc5 100755
--- a/src/encodeconvert.cpp
+++ b/src/encodeconvert.cpp
@@ -11,7 +11,7 @@
#include <QtConcurrent>
#include <QInputDialog>
#include <QDragEnterEvent>
-
+#include <QTextCodec>
const int ITEM_CODE = Qt::UserRole + 1;
diff --git a/src/findresultwin.cpp b/src/findresultwin.cpp
index 7d86701..ad01b46 100755
--- a/src/findresultwin.cpp
+++ b/src/findresultwin.cpp
@@ -5,7 +5,7 @@
#include <QTreeWidgetItem>
#include <QStyleFactory>
#include <QToolButton>
-#include <qtreeview.h>
+#include <QTreeView>>
#include <QStandardItem>
#include <QStandardItemModel>
#include <QClipboard>
@@ -151,8 +151,8 @@ void FindResultWin::slot_selectAll()
QModelIndex pMi = curSelItem.parent();
if (pMi.isValid())
{
- curSelItem = pMi;
-}
+ curSelItem = pMi;
+ }
else
{
break;
@@ -176,12 +176,13 @@ void FindResultWin::slot_selectAll()
//遍历下面的子节点
int i = 0;
QModelIndex childMi;
- childMi = sectionItem.child(i, 0);
+ const QAbstractItemModel *const sectionItemModel = sectionItem.model();
+ childMi = sectionItemModel->index(i, 0);
while (childMi.isValid())
{
++i;
ui.resultTreeView->selectionModel()->select(childMi, QItemSelectionModel::Select);
- childMi = sectionItem.child(i, 0);
+ childMi = sectionItemModel->index(i, 0);
}
return i+1;
};
@@ -189,17 +190,20 @@ void FindResultWin::slot_selectAll()
QModelIndex rootItem = firstRootItem;
int j = 0;
int selectCount = 0;
+ const QAbstractItemModel *const rootItemModel = rootItem.model();
+ const QAbstractItemModel *const firstRootItemModel = firstRootItem.model();
+
while (rootItem.isValid())
{
//遍历根节点下面每一个section
{
int i = 0;
- QModelIndex section = rootItem.child(i, 0);
+ QModelIndex section = rootItemModel->index(i, 0);
while (section.isValid() && !section.data(ResultItemEditor).isNull())
{
++i;
selectCount += selectSection(section);
- section = firstRootItem.child(i, 0);
+ section = firstRootItemModel->index(i, 0);
}
}
@@ -223,12 +227,12 @@ void FindResultWin::slot_selectSection()
//遍历下面的子节点
int i = 0;
QModelIndex childMi;
- childMi = sectionItem.child(i, 0);
+ childMi = sectionItem.model()->index(i, 0);
while (childMi.isValid())
{
++i;
ui.resultTreeView->selectionModel()->select(childMi, QItemSelectionModel::Select);
- childMi = sectionItem.child(i, 0);
+ childMi = sectionItem.model()->index(i, 0);
}
return i+1;
};
@@ -420,7 +424,7 @@ QString FindResultWin::highlightFindText(FindRecord& record)
}
src = QString("<font style='background-color:#ffffbf'>%1</font>").arg(QString(utf8bytes.mid(targetStart, targetLens)).toHtmlEscaped());
tail = QString(utf8bytes.mid(tailStart));
- if (tail > MAX_TAIL_LENGTH)
+ if (tail.size() > MAX_TAIL_LENGTH)
{
tail = (tail.mid(0, MAX_TAIL_LENGTH) + "...").toHtmlEscaped();
}
@@ -454,7 +458,7 @@ QString FindResultWin::highlightFindText(FindRecord& record)
src = QString("<font style='font-weight:bold;color:#ffaa00'>%1</font>").arg(QString(utf8bytes.mid(targetStart, targetLens)).toHtmlEscaped());
QString tailContens = QString(utf8bytes.mid(tailStart));
- if (tailContens > MAX_TAIL_LENGTH)
+ if (tailContens.size() > MAX_TAIL_LENGTH)
{
tailContens = (tailContens.mid(0, MAX_TAIL_LENGTH) + "...").toHtmlEscaped();
}
diff --git a/src/findwin.cpp b/src/findwin.cpp
index 7a55059..8fe891e 100755
--- a/src/findwin.cpp
+++ b/src/findwin.cpp
@@ -559,8 +559,8 @@ bool readBase(const QChar * str, int * value, int base, int size)
current = str[i];
if (current >= 'A')
{
- current = current.digitValue() & 0xdf;
- current = current.digitValue() - ('A' - '0' - 10);
+ current = static_cast<QChar>(current.digitValue() & 0xdf);
+ current = static_cast<QChar>(current.digitValue() - ('A' - '0' - 10));
}
else if (current > '9')
return false;
diff --git a/src/langstyledefine.cpp b/src/langstyledefine.cpp
index 2df3a4f..f667f09 100755
--- a/src/langstyledefine.cpp
+++ b/src/langstyledefine.cpp
@@ -30,7 +30,7 @@ bool LangStyleDefine::readLangSetFile(QString langName, bool isLoadToUI)
{
QString userLangFile = QString("notepad/userlang/%1").arg(langName);//自定义语言中不能有.字符,否则可能有错,后续要检查
QSettings qs(QSettings::IniFormat, QSettings::UserScope, userLangFile);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
qDebug() << qs.fileName();
if (!qs.contains("mz"))
@@ -160,7 +160,7 @@ void LangStyleDefine::slot_save()
//把新语言tagName,和关联ext单独存放起来。后面只读取一个文件就能获取所有避免遍历慢
QString extsFile = QString("notepad/userlang/ext_tag");//ext_tag是存在所有tag ext的文件
QSettings qs(QSettings::IniFormat, QSettings::UserScope, extsFile);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
QStringList extList = ui.extNameLe->text().trimmed().split(" ");
extList.append(QString::number(motherLangs)); //最后一个是mother lexer
@@ -201,7 +201,7 @@ void LangStyleDefine::slot_delete()
{
QString userLangFile = QString("notepad/userlang/%1").arg(name);//自定义语言中不能有.字符,否则可能有错,后续要检查
QSettings qs(QSettings::IniFormat, QSettings::UserScope, userLangFile);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
//删除userlang下面的tag.ini
QFile::remove(qs.fileName());
@@ -211,7 +211,7 @@ void LangStyleDefine::slot_delete()
//把新语言在ext_tag中的关联文件记录也删除
QString extsFile = QString("notepad/userlang/ext_tag");//ext_tag是存在所有tag ext的文件
QSettings qs(QSettings::IniFormat, QSettings::UserScope, extsFile);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
QStringList extList = qs.value(name).toStringList();
//更新当前ExtLexerManager::getInstance()。如果不更新,就要重启软件才能生效
diff --git a/src/nddsetting.cpp b/src/nddsetting.cpp
index ed20f73..7e2070a 100755
--- a/src/nddsetting.cpp
+++ b/src/nddsetting.cpp
@@ -50,7 +50,7 @@ void NddSetting::init()
QString qsSetPath = qs.fileName();
s_nddSet = new QSettings(QSettings::IniFormat, QSettings::UserScope, settingDir);
- s_nddSet->setIniCodec("UTF-8");
+// s_nddSet->setIniCodec("UTF-8");
bool initOk = true;
auto initNddSet = []() {
diff --git a/src/qscint/src/qscilexer.cpp b/src/qscint/src/qscilexer.cpp
index b49fdc5..f21fff8 100755
--- a/src/qscint/src/qscilexer.cpp
+++ b/src/qscint/src/qscilexer.cpp
@@ -896,7 +896,7 @@ const char* QsciLexer::getUserDefineKeywords()
QString userLangFile = QString("notepad/userlang/%1").arg(m_tagName);//自定义语言中不能有.字符,否则可能有错,后续要检查
QSettings qs(QSettings::IniFormat, QSettings::UserScope, userLangFile);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
if (!qs.contains("mz"))
{
@@ -948,4 +948,4 @@ void QsciLexer::setCommentEnd(QByteArray commentEnd)
void QsciLexer::setCurThemes(int themesId)
{
m_themesId = themesId;
-}
\ No newline at end of file
+}
diff --git a/src/qscint/src/qscintilla.pro b/src/qscint/src/qscintilla.pro
index 2704d72..9ef4520 100755
--- a/src/qscint/src/qscintilla.pro
+++ b/src/qscint/src/qscintilla.pro
@@ -21,24 +21,14 @@
!win32:VERSION = 15.1.0
TEMPLATE = lib
-CONFIG += qt warn_off thread exceptions hide_symbols debug staticlib
+CONFIG += qt warn_off thread exceptions hide_symbols staticlib
CONFIG(debug, debug|release) {
- mac: {
- TARGET = qmyedit_qt$${QT_MAJOR_VERSION}_debug
- } else {
- win32: {
- TARGET = qmyedit_qt$${QT_MAJOR_VERSION}d
- } else {
- TARGET = qmyedit_qt$${QT_MAJOR_VERSION}
- }
- }
-
- DESTDIR = ../../x64/Debug
+ TARGET = qmyedit_qt$${QT_MAJOR_VERSION}
+ DESTDIR = ../../x64/Debug
} else {
TARGET = qmyedit_qt$${QT_MAJOR_VERSION}
-
- DESTDIR = ../../x64/Release
+ DESTDIR = ../../x64/Release
}
macx:!CONFIG(staticlib) {
diff --git a/src/qtlangset.cpp b/src/qtlangset.cpp
index e88d132..99b6258 100755
--- a/src/qtlangset.cpp
+++ b/src/qtlangset.cpp
@@ -36,8 +36,8 @@ enum LangType {
// Don't use L_JS, use L_JAVASCRIPT instead
// The end of enumated language type, so it should be always at the end
L_EXTERNAL = 100, L_USER_DEFINE = 200
-};
-#endif
+};
+#endif
//static const QColor blackColor(Qt::black);
//static const QColor lightColor(0xdedede);
@@ -421,14 +421,14 @@ void QtLangSet::updateAllLangeStyleWithGlobal(GLOBAL_STYLE_SET flag)
QsciLexer *pLexer = ScintillaEditView::createLexer(index);
if (nullptr != pLexer)
{
-
+
switch (flag)
{
case GLOBAL_FONT:
{
- for (int i = 0; i <= 255; ++i)
- {
- if (!pLexer->description(i).isEmpty())
+ for (int i = 0; i <= 255; ++i)
+ {
+ if (!pLexer->description(i).isEmpty())
{
oldfont = pLexer->font(i);
oldfont.setFamily(m_curStyleData.font.family());
@@ -439,9 +439,9 @@ void QtLangSet::updateAllLangeStyleWithGlobal(GLOBAL_STYLE_SET flag)
break;
case GLOBAL_FONT_SIZE:
{
- for (int i = 0; i <= 255; ++i)
- {
- if (!pLexer->description(i).isEmpty())
+ for (int i = 0; i <= 255; ++i)
+ {
+ if (!pLexer->description(i).isEmpty())
{
oldfont = pLexer->font(i);
oldfont.setPointSize(m_curStyleData.font.pointSize());
@@ -452,9 +452,9 @@ void QtLangSet::updateAllLangeStyleWithGlobal(GLOBAL_STYLE_SET flag)
break;
case GLOBAL_FONT_BOLD:
{
- for (int i = 0; i <= 255; ++i)
- {
- if (!pLexer->description(i).isEmpty())
+ for (int i = 0; i <= 255; ++i)
+ {
+ if (!pLexer->description(i).isEmpty())
{
oldfont = pLexer->font(i);
oldfont.setBold(m_curStyleData.font.bold());
@@ -465,9 +465,9 @@ void QtLangSet::updateAllLangeStyleWithGlobal(GLOBAL_STYLE_SET flag)
break;
case GLOBAL_FONT_UNDERLINE:
{
- for (int i = 0; i <= 255; ++i)
- {
- if (!pLexer->description(i).isEmpty())
+ for (int i = 0; i <= 255; ++i)
+ {
+ if (!pLexer->description(i).isEmpty())
{
oldfont = pLexer->font(i);
oldfont.setUnderline(m_curStyleData.font.underline());
@@ -478,9 +478,9 @@ void QtLangSet::updateAllLangeStyleWithGlobal(GLOBAL_STYLE_SET flag)
break;
case GLOBAL_FONT_ITALIC:
{
- for (int i = 0; i <= 255; ++i)
- {
- if (!pLexer->description(i).isEmpty())
+ for (int i = 0; i <= 255; ++i)
+ {
+ if (!pLexer->description(i).isEmpty())
{
oldfont = pLexer->font(i);
oldfont.setItalic(m_curStyleData.font.italic());
@@ -503,10 +503,10 @@ void QtLangSet::updateAllLangeStyleWithGlobal(GLOBAL_STYLE_SET flag)
break;
default:
break;
- }
+ }
saveLangeSet(pLexer);
- }
+ }
delete pLexer;
}
}
@@ -537,7 +537,7 @@ void QtLangSet::restoreOriginLangAllStyle()
{
QFile::remove(qs.fileName());
}
-
+
delete pLexer;
pLexer = nullptr;
}
@@ -578,12 +578,12 @@ void QtLangSet::restoreOriginLangOneStyle(GLOBAL_STYLE_SET flag)
QsciLexer *pLexer = ScintillaEditView::createLexer(index);
QsciLexer *pOriginLexer = ScintillaEditView::createLexer(index,"",true);
if (nullptr != pLexer)
- {
- for (int i = 0; i <= 255; ++i)
- {
- if (!pLexer->description(i).isEmpty())
- {
-
+ {
+ for (int i = 0; i <= 255; ++i)
+ {
+ if (!pLexer->description(i).isEmpty())
+ {
+
switch (flag)
{
case GLOBAL_FONT:
@@ -649,11 +649,11 @@ void QtLangSet::restoreOriginLangOneStyle(GLOBAL_STYLE_SET flag)
break;
default:
break;
- }
- }
+ }
+ }
}
saveLangeSet(pLexer);
- }
+ }
delete pLexer;
delete pOriginLexer;
}
@@ -795,7 +795,7 @@ bool QtLangSet::readLangSetFile(QString langName,QString &keyword, QString &moth
{
QString userLangFile = QString("notepad/userlang/%1").arg(langName);//<2F>Զ<EFBFBD><D4B6><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>в<EFBFBD><D0B2><EFBFBD><EFBFBD><EFBFBD>.<2E>ַ<EFBFBD><D6B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>д<EFBFBD><D0B4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><D2AA><EFBFBD><EFBFBD>
QSettings qs(QSettings::IniFormat, QSettings::UserScope, userLangFile);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
//qDebug() << qs.fileName();
if (!qs.contains("mz"))
@@ -917,15 +917,15 @@ void QtLangSet::slot_itemSelect(QListWidgetItem *item)
ui.keywordTe->setPlainText(keyword);
ui.motherLangCb->setCurrentIndex(0);
- for (int i = 0; i <= 255; ++i)
- {
- QString desc = pLexer->description(i);
- if (!desc.isEmpty())
- {
+ for (int i = 0; i <= 255; ++i)
+ {
+ QString desc = pLexer->description(i);
+ if (!desc.isEmpty())
+ {
QListWidgetItem *itemtemp = new QListWidgetItem(desc);
- itemtemp->setData(Qt::UserRole, i);
- ui.styleListWidget->addItem(itemtemp);
- }
+ itemtemp->setData(Qt::UserRole, i);
+ ui.styleListWidget->addItem(itemtemp);
+ }
}
}
diff --git a/src/scintillaeditview.cpp b/src/scintillaeditview.cpp
index 60181dd..fac3648 100755
--- a/src/scintillaeditview.cpp
+++ b/src/scintillaeditview.cpp
@@ -2155,7 +2155,7 @@ void ScintillaEditView::changeCase(const TextCaseType & caseToConvert, QString&
else if (caseToConvert == TITLECASE_FORCE)
strToConvert[i] = strToConvert[i].toLower();
//An exception
- if ((i < 2) ? false : (strToConvert[i - 1] == L'\'' && (strToConvert[i - 2].isLetter())))
+ if ((i < 2) ? false : (strToConvert[i - 1] == QChar(L'\'') && (strToConvert[i - 2].isLetter())))
strToConvert[i] = strToConvert[i].toLower();
}
}
@@ -2183,11 +2183,11 @@ void ScintillaEditView::changeCase(const TextCaseType & caseToConvert, QString&
wasEolR = false;
wasEolN = false;
//An exception
- if (strToConvert[i] == L'i' &&
+ if (strToConvert[i] == static_cast<QChar>(L'i') &&
((i < 1) ? false : (strToConvert[i - 1].isSpace() || strToConvert[i - 1] == '(' || strToConvert[i - 1] == '"')) && \
((i + 1 == nbChars) ? false : (strToConvert[i + 1].isSpace() || strToConvert[i + 1] == '\'')))
{
- strToConvert[i] = L'I';
+ strToConvert[i] = static_cast<QChar>(L'I');
}
}
else if (strToConvert[i] == '.' || strToConvert[i] == '!' || strToConvert[i] == '?')
@@ -2856,7 +2856,7 @@ bool isUrlQueryDelimiter(QChar const c)
void scanToUrlEnd(QString & text, int textLen, int start, int* distance)
{
int p = start;
- QChar q = 0;
+ QChar q;
enum { sHostAndPath, sQuery, sQueryAfterDelimiter, sQueryQuotes, sQueryAfterQuotes, sFragment } s = sHostAndPath;
while (p < textLen)
{
diff --git a/src/userlexdef.cpp b/src/userlexdef.cpp
index 6b8c7d2..86e238b 100755
--- a/src/userlexdef.cpp
+++ b/src/userlexdef.cpp
@@ -24,7 +24,7 @@ bool UserLexDef::readUserSettings(QString langTagName)
QString userLangFile = QString("notepad/userlang/%1").arg(langTagName);
QSettings qs(QSettings::IniFormat, QSettings::UserScope, userLangFile);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
if (!qs.contains(QString("mz")))
{
@@ -93,13 +93,13 @@ bool UserLexDef::writeUserSettings(QString langTagName)
QString userLangFile = QString("notepad/userlang/%1").arg(langTagName);
QSettings qs(QSettings::IniFormat, QSettings::UserScope, userLangFile);
- qs.setIniCodec("UTF-8");
+// qs.setIniCodec("UTF-8");
qs.clear();
qs.setValue("mz", langTagName);
qs.setValue("mother", m_motherLang);
qs.setValue("ext", m_extTypes);
- qs.setValue("keyword", m_keyword.data());
+ qs.setValue("keyword", m_keyword.toStdString().c_str());
return true;
}
--
2.20.1