diff --git a/NEWS.md b/NEWS.md
index 08619459..70970dcb 100644
--- a/NEWS.md
+++ b/NEWS.md
@@ -9,6 +9,11 @@ Red Panda C++ Version 2.19
- enhancement: Open Containing folder will auto select the file in windows file explore.
- fix: Class constructor & destructor is not correctly handled.
- fix: Remove multiple files in the project panel is not correctly handled.
+ - fix: Reformat code when select contents in column mode will mess up the document.
+ - enhancement: Add "save as" icon to the toolbar.
+ - enhancement: Use key sequences as shortcut to actions in the options dialog's environment->shortcut page.
+ - change: Use ctrl+shift+S as the shortcut for "save as".
+ - change: Use ctrl+K,ctrl+S as the shortcut for "save all".
Red Panda C++ Version 2.18
diff --git a/RedPandaIDE/mainwindow.ui b/RedPandaIDE/mainwindow.ui
index 034ad9b0..fc51584b 100644
--- a/RedPandaIDE/mainwindow.ui
+++ b/RedPandaIDE/mainwindow.ui
@@ -379,6 +379,7 @@
+
@@ -2114,6 +2115,9 @@
Save As
+
+ Ctrl+Shift+S
+
@@ -2125,7 +2129,7 @@
Save All
- Ctrl+Shift+S
+ Ctrl+K, Ctrl+S
diff --git a/RedPandaIDE/toolsmanager.cpp b/RedPandaIDE/toolsmanager.cpp
index 14b2dd50..603a526b 100644
--- a/RedPandaIDE/toolsmanager.cpp
+++ b/RedPandaIDE/toolsmanager.cpp
@@ -46,6 +46,15 @@ void ToolsManager::load()
item->parameters = "";
item->pauseAfterExit = false;
mTools.append(item);
+//#ifdef Q_OS_WIN
+// item = std::make_shared();
+// item->title = tr("Open compiled in explorer");
+// item->program = "explorer.exe";
+// item->workingDirectory = "";
+// item->parameters = " /n, /select, ";
+// item->pauseAfterExit = false;
+// mTools.append(item);
+//#endif
return;
}
//read config file
diff --git a/RedPandaIDE/translations/RedPandaIDE_pt_BR.ts b/RedPandaIDE/translations/RedPandaIDE_pt_BR.ts
index f3d2122e..a7e35ac5 100644
--- a/RedPandaIDE/translations/RedPandaIDE_pt_BR.ts
+++ b/RedPandaIDE/translations/RedPandaIDE_pt_BR.ts
@@ -5199,6 +5199,10 @@
+
+
+
+
MemoryModel
@@ -7818,6 +7822,10 @@
Falha ao gravar o arquivo de configurações '%1'.
+
+
+
+
WatchModel
diff --git a/RedPandaIDE/translations/RedPandaIDE_zh_CN.ts b/RedPandaIDE/translations/RedPandaIDE_zh_CN.ts
index d7ba211d..043a9083 100644
--- a/RedPandaIDE/translations/RedPandaIDE_zh_CN.ts
+++ b/RedPandaIDE/translations/RedPandaIDE_zh_CN.ts
@@ -1532,14 +1532,14 @@ Are you really want to continue?
十进制: %1
-
+
打印文档
-
-
-
+
+
+
Ctrl+单击以获取更多信息
@@ -1548,27 +1548,27 @@ Are you really want to continue?
未找到符号'%1'!
-
+
找不到astyle程序
-
+
找不到astyle程序"%1".
-
+
断点条件
-
+
输入当前断点的生效条件:
-
+
只读
@@ -4307,18 +4307,18 @@ Are you really want to continue?
MainWindow
-
+
小熊猫C++
-
-
-
-
-
-
-
+
+
+
+
+
+
+
编译器
@@ -4337,8 +4337,8 @@ Are you really want to continue?
工具
-
-
+
+
运行
@@ -4349,26 +4349,26 @@ Are you really want to continue?
-
-
+
+
项目
-
-
+
+
监视
-
-
+
+
结构
-
-
+
+
文件
@@ -4377,69 +4377,69 @@ Are you really want to continue?
资源
-
-
-
-
-
+
+
+
+
+
调试
-
+
求值
-
-
+
+
调试主控台
-
+
调用栈
-
+
断点
-
+
局部变量
-
-
+
+
查找
-
+
历史:
-
+
重新查找
-
+
替换为:
-
+
替换
-
+
关闭
@@ -4450,7 +4450,7 @@ Are you really want to continue?
-
+
代码
@@ -4468,76 +4468,76 @@ Are you really want to continue?
工具栏2
-
+
新建
-
+
Ctrl+N
-
+
打开...
-
+
Ctrl+O
-
+
保存
-
+
Ctrl+S
-
+
另存为...
-
+
另存为
-
+
全部保存
-
+
Ctrl+Shift+S
-
+
选项
-
-
-
+
+
+
编译
-
-
+
+
工具输出
-
-
+
+
选择输入文件
@@ -4561,7 +4561,7 @@ Are you really want to continue?
选择
-
+
F9
@@ -4570,123 +4570,123 @@ Are you really want to continue?
F10
-
+
恢复
-
+
Ctrl+Z
-
+
重做
-
+
Ctrl+Y
-
+
剪切
-
+
Ctrl+X
-
-
-
-
+
+
+
+
复制
-
+
Ctrl+C
-
-
+
+
粘贴
-
+
Ctrl+V
-
-
-
+
+
+
选择全部
-
+
Ctrl+A
-
+
缩进
-
+
取消缩进
-
+
切换注释
-
+
Ctrl+/
-
+
全部收起
-
+
全部展开
-
+
使用ANSI编码
-
+
使用UTF-8编码
-
+
自动检测
-
+
转换为ANSI编码
-
+
转换为UTF-8编码
@@ -4695,183 +4695,183 @@ Are you really want to continue?
编译运行
-
+
F11
-
-
+
+
全部重编译
-
+
F12
-
+
停止执行
-
+
F6
-
+
F5
-
+
单步跨过
-
+
F7
-
+
单步进入
-
-
-
+
+
+
试题集
-
-
-
-
+
+
+
+
新建试题集
-
-
-
+
+
+
添加试题
-
-
-
+
+
+
删除试题
-
-
-
-
+
+
+
+
保存试题集
-
-
-
-
+
+
+
+
载入试题集
-
+
内存
-
+
Address:
地址表达式:
-
+
取消
-
-
+
+
TODO
-
-
+
+
书签
-
-
-
+
+
+
试题
-
-
+
+
添加试题案例
-
-
-
+
+
+
Remove Problem Set
删除试题集
-
-
-
+
+
+
打开答案源代码文件
-
-
-
+
+
+
Run Current Case
运行所有案例
-
-
+
+
测试案例验证选项
-
+
%v/%m
-
+
输出
-
+
输入
-
+
期望输出
@@ -4900,524 +4900,529 @@ Are you really want to continue?
主工具栏
-
+
编译器配置集
-
+
管理器
-
-
-
+
+
+
导入FPS试题集
-
-
-
+
+
+
导出FPS试题集
-
+
消息
-
+
在编辑器中打开文件
-
+
选择期望输出文件
-
+
忽略空格
-
+
新建C/C++文件
-
+
新建源代码文件
-
+
+
+
+
+
+
Tab
-
+
Shift+Tab
-
+
F8
-
+
单步跳出
-
+
Ctrl+F8
-
+
执行到光标处
-
+
Ctrl+F5
-
+
继续执行
-
+
F4
-
+
添加监视
-
+
打开CPU信息窗口...
-
+
退出
-
+
查找...
-
+
Ctrl+F
-
+
在文件中查找...
-
+
Ctrl+Shift+F
-
+
替换
-
+
Ctrl+R
-
+
查找下一个
-
+
F3
-
+
查找前一个
-
+
Shift+F3
-
+
删除监视值
-
+
Remove All
删除全部监视值
-
+
修改监视值
-
+
对代码重新排版
-
+
Ctrl+Shift+A
-
+
前一次编辑位置
-
+
Ctrl+Alt+Left
-
+
后一次编辑位置
-
+
Ctrl+Alt+Right
-
+
Ctrl+W
-
+
全部关闭
-
+
Ctrl+Shift+W
-
+
最大化编辑器
-
+
Ctrl+F11
-
+
下一窗口
-
+
Ctrl+Tab
-
+
前一窗口
-
+
Ctrl+Shift+Tab
-
+
切换断点
-
+
Ctrl+F4
-
-
+
+
删除所有断点
-
+
设置断点条件...
-
+
跳转到声明处
-
+
Ctrl+Shift+G
-
+
跳转到定义处
-
+
Ctrl+G
-
+
查找符号的引用
-
+
打开所在的文件夹
-
+
Ctrl+B
-
+
打开命令行窗口
-
+
文件属性...
-
+
关闭项目
-
+
项目属性
-
+
新建项目...
-
-
+
+
新建项目文件
-
+
Ctrl+F12
-
+
F1
-
+
新建GNU汇编文件
-
+
GNU汇编器手册
-
+
X86汇编语言参考手册
-
+
IA32汇编语言参考手册
-
+
添加变量断点...
-
+
添加一个变量断点。当该变量的值被改动时程序暂停。
-
+
新建文本文件
-
+
向上移动选中的行
-
+
Ctrl+Shift+Up
-
+
向下移动选中的行
-
+
Ctrl+Shift+Down
-
+
转换为UTF-8 BOM编码
-
+
使用UTF-8 BOM编码
-
+
编译器选项...
-
+
切换管理器面板
-
+
Ctrl+F9
-
+
切换消息面板
-
+
Ctrl+F10
-
+
Raylib教程
-
+
选中当前单词
-
+
跳转到行...
-
+
新建模板...
-
+
从项目创建模板
-
+
跳转到代码段开始
-
+
Ctrl+Alt+Up
-
+
跳转到代码段结束
-
+
Ctrl+Alt+Down
-
+
切换头文件/源文件
-
+
切换头文件/源文件
-
+
生成汇编
-
+
删除行尾空格
-
+
切换只读模式
-
+
反馈与建议
-
+
使用说明
@@ -5426,199 +5431,199 @@ Are you really want to continue?
保存为模板...
-
+
新建文件
-
+
添加到项目...
-
+
从项目删除
-
+
查看Makefile
-
+
清理构建文件
-
+
在浏览器中打开
-
+
在终端中打开
-
+
关于
-
-
+
+
重命名符号
-
+
Shift+F6
-
+
打印...
-
+
Ctrl+P
-
-
+
+
导出为RTF
-
-
+
+
导出为HTML
-
+
移动到其他视图
-
+
Ctrl+M
-
-
+
+
C++参考手册
-
+
C参考手册
-
+
显示全部工具面板
-
+
Create Repository
创建Git仓库
-
+
提交(Commit)
-
+
撤销(Revert)
-
+
回滚(Reset)
-
+
添加文件
-
+
还原(Restore)
-
+
官方网站
-
+
分支切换(Switch)
-
+
合并(Merge)
-
-
+
+
Log
显示日志(Log)
-
+
远程仓库...
-
+
取回(Fetch)
-
+
拉取(Pull)
-
+
推送(Push)
-
+
隐藏不支持的文件
-
+
切换块注释
-
+
Alt+Shift+A
-
+
匹配当前括号
-
+
Ctrl+]
@@ -5627,50 +5632,50 @@ Are you really want to continue?
工具窗口栏
-
+
状态栏
-
+
Ctrl+Backspace
-
+
中断
-
-
+
+
删除到单词开头
-
+
Ctrl+Shift+B
-
+
删除到单词结尾
-
+
Ctrl+Shift+E
-
+
Add Class...
新建类...
-
-
+
+
New Header
新建头文件...
@@ -5680,47 +5685,47 @@ Are you really want to continue?
插入行
-
+
删除当前行
-
+
Ctrl+D
-
+
复制当前行
-
+
Ctrl+E
-
+
删除当前单词
-
+
Ctrl+Shift+D
-
+
删除到行尾
-
+
Ctrl+Del
-
+
删除到行首
@@ -5729,27 +5734,27 @@ Are you really want to continue?
C/C++参考
-
+
EGE图形库手册
-
+
添加书签
-
+
删除书签
-
+
修改书签说明
-
+
在文件视图中定位
@@ -5758,47 +5763,47 @@ Are you really want to continue?
打开文件夹
-
+
运行参数...
-
+
文件编码
-
+
文件历史
+
-
+
-
+
-
正在调试
+
-
+
-
+
-
正在运行
+
-
+
-
+
-
正在编译
@@ -5812,17 +5817,17 @@ Are you really want to continue?
行: %1 列: %2 已选择 :%3 总行数: %4 总长度: %5
-
+
只读
-
+
插入
-
+
覆写
@@ -5839,7 +5844,7 @@ Are you really want to continue?
确认
-
+
源文件尚未编译。
@@ -5856,44 +5861,44 @@ Are you really want to continue?
重新编译?
-
-
-
-
+
+
+
+
错误的编译器设置
-
-
-
-
+
+
+
+
编译器被设置为不生成可执行文件。
-
-
+
+
我们需要可执行文件来运行试题案例。
-
+
无编译器设置
-
+
没有配置编译器设置。
-
+
无法启动调试器
-
+
启用调试参数
@@ -5910,33 +5915,33 @@ Are you really want to continue?
项目尚未构建。是否构建?
-
+
宿主程序不存在
-
+
动态链接库(DLL)需要一个宿主程序来运行。
-
+
但它不存在。
-
+
宿主程序不存在
-
+
宿主程序'%1'不存在。
-
-
+
+
请在调试前改正设置。
@@ -5945,8 +5950,8 @@ Are you really want to continue?
重新编译?
-
-
+
+
保存上次打开信息失败
@@ -5955,86 +5960,86 @@ Are you really want to continue?
无法删除旧上次打开信息文件'%1'
-
+
无法保存上次打开信息文件'%1'
-
-
+
+
载入上次打开信息失败
-
-
+
+
无法载入上次打开信息文件'%1'
-
+
打开源代码文件
-
-
+
+
批量设置案例
-
+
显示详细调试器日志
-
+
全部复制
-
+
跳转到行
-
+
行
-
+
模板已存在
-
+
模板%1已存在。是否覆盖?
-
-
-
-
-
-
+
+
+
+
+
+
清除
-
+
导出
-
+
插入代码段
-
-
+
+
试题集%1
@@ -6063,56 +6068,56 @@ Are you really want to continue?
项目已经被修改过,是否需要重新构建?
-
+
自动保存出错
-
+
自动保存"%1"到"%2"失败:%3
-
+
试题属性...
-
+
设置试题集名称
-
+
试题集名称:
-
+
删除
-
+
删除全部书签
-
+
修改描述
-
-
-
+
+
+
书签描述
-
-
-
+
+
+
描述:
@@ -6121,65 +6126,65 @@ Are you really want to continue?
在调试主控台中显示调试器输出
-
+
清除这次搜索
-
+
删除所有搜索
-
+
断点条件...
-
+
断点条件
-
+
输入当前断点的生效条件:
-
+
Remove all breakpoints
删除所有断点
-
+
删除当前断点
-
+
重命名文件
-
-
+
+
添加文件夹
-
-
+
+
新文件夹
-
+
文件夹:
-
+
重命名
@@ -6192,262 +6197,262 @@ Are you really want to continue?
要现在去修改设置吗?
-
+
修改试题集名称
-
+
无法写入配置文件'%1'。
-
+
修改试题名称
-
+
行: %1 列: %2 总行数: %3
-
+
改正编译器设置
-
-
+
+
您使用的Debug编译器配置集中存在错误的“编译/链接”选项设置:
-
-
+
+
- 应勾选"生成调试信息(-g3)"选项
-
+
- 应取消"剥除附加信息(-s)"选项
-
-
+
+
是否现在去改正?
-
+
项目文件缺失
-
+
下列项目文件缺失,无法构建项目:
-
-
+
+
无法调试
-
-
+
+
您的编译器配置集中的“剥除附加信息(-s)”选项被勾选了。
-
-
+
+
请取消该设置,重新编译然后重新启动调试。
-
+
跳转到试题网址
-
+
添加试题案例
-
+
运行当前案例
-
+
删除文件夹
-
+
切换为普通视图
-
+
切换为自定义视图
-
+
按类型排序
-
+
按名称排序
-
+
显示继承的成员
-
+
跳转到声明处
-
+
跳转到定义处
-
+
仅当前文件
-
+
整个项目
-
-
+
+
新建文件夹
-
+
重命名
-
-
-
-
+
+
+
+
删除
-
+
在编辑器中打开
-
+
使用外部程序打开
-
+
在终端中打开
-
+
在Windows浏览器中打开
-
+
字符集
-
+
转换为%1编码
-
+
换行符
-
+
已自动保存%1个文件
-
+
设置答案源代码...
-
+
选择其他文件...
-
+
选择答案源代码文件
-
+
变量断点被触发
-
+
"%1"的值发生了变化:
-
+
新值: %1
-
+
项目文件夹被删除
-
+
项目"%1"的文件夹已被外部程序删除.
-
+
项目将被关闭.
-
+
保存设置失败
-
+
被监控的变量
-
+
当下面的变量被修改时暂停执行(该变量必须可以从当前程序处访问):
@@ -6456,17 +6461,17 @@ Are you really want to continue?
中止
-
+
FPS试题集文件(*.fps;*.xml)
-
+
FPS试题集文件(*.fps)
-
+
导出时出错
@@ -6476,7 +6481,7 @@ Are you really want to continue?
C/C++源代码文件 (*.c *.cpp *.cc *.cxx)
-
+
新建文件夹%1
@@ -6489,12 +6494,12 @@ Are you really want to continue?
无标题%1
-
+
你真的要删除%1吗?
-
+
你真的要删除%1个文件吗?
@@ -6507,7 +6512,7 @@ Are you really want to continue?
变量"%1"有改动:
-
+
旧值: %1
@@ -6516,63 +6521,63 @@ Are you really want to continue?
新值: %1
-
+
保存项目
-
+
项目'%1'有改动。
-
-
+
+
需要保存吗?
-
-
+
+
文件已发生变化
-
-
-
+
+
+
新建项目文件?
-
-
-
+
+
+
您是否要将新建的文件加入项目?
-
+
+
-
-
-
+
+
保存失败
-
+
改变项目编译器配置集
-
+
改变项目的编译器配置集会导致所有的自定义编译器选项被重置。
-
-
+
+
你真的想要那么做吗?
@@ -6581,12 +6586,12 @@ Are you really want to continue?
批量设置案例
-
+
选择输入数据文件
-
+
输入数据文件 (*.in)
@@ -6595,78 +6600,78 @@ Are you really want to continue?
无标题%1
-
+
修改监视表达式
-
+
监视表达式
-
+
您真的要清除该文件的所有断点吗?
-
+
新建项目
-
+
关闭'%1'以打开新项目?
-
+
文件夹不存在
-
+
文件夹'%1'不存在。是否创建?
-
+
无法创建文件夹
-
+
创建文件夹'%1'失败。
-
+
-
+
文件夹%1不是空的。
-
+
你真的要删除它吗?
-
+
改变工作文件夹
-
+
File '%1' is not in the current working folder
文件'%1'不在当前工作文件夹中。
-
+
是否将工作文件夹改设为'%1'?
@@ -6675,28 +6680,28 @@ Are you really want to continue?
正在删除试题...
-
+
无法提交
-
+
Git需要用信息进行提交。
-
+
选择输入数据文件
-
-
+
+
所有文件 (*.*)
-
+
Choose Expected Input Data File
选择期望输出文件
@@ -6706,61 +6711,61 @@ Are you really want to continue?
第%1行
-
-
-
+
+
+
选择工作文件夹
-
-
+
+
头文件已存在
-
-
+
+
头文件"%1"已存在!
-
+
源文件已存在!
-
+
源文件"%1"已存在!
-
+
无法提交!
-
+
下列文件处于冲突状态,请解决后重新添加和提交:
-
+
提交信息
-
+
提交信息:
-
+
提交失败
-
+
提交信息不能为空!
@@ -6769,22 +6774,22 @@ Are you really want to continue?
小熊猫Dev-C++项目文件 (*.dev)
-
+
新建项目失败
-
+
无法使用模板创建项目
-
+
删除文件
-
+
同时从硬盘上删除文件?
@@ -6793,27 +6798,27 @@ Are you really want to continue?
无标题
-
+
新的项目文件名
-
+
文件名:
-
+
文件已存在!
-
+
文件'%1'已经存在!
-
+
添加到项目
@@ -6830,27 +6835,27 @@ Are you really want to continue?
请在工具栏中选择Debug编译器配置集,或者在“编译器配置集”设置的“编译/链接选项”页中<b>启用</b>“生成调试信息(-g3)”、<b>禁用</b>“剥除附件信息(-3)”。
-
+
C/C++源代码文件 (*.c *.cpp *.cc *.cxx)
-
+
本操作会删除此试题的所有案例。
-
+
调试失败
-
+
可执行文件中没有符号表信息,无法调试。
-
+
请在选项对话框的编译器配置集页中取消“剥除附加信息(-s)”选项,重新编译后再调试。
@@ -6871,134 +6876,134 @@ Are you really want to continue?
您也可以删除所有断点,打开“CPU信息窗口”,然后调试汇编代码。
-
+
未能生成可执行文件。
-
+
请查看“工具输出”面板中的详细信息。
-
+
小熊猫C++项目文件(*.dev)
-
+
重命名出错
-
+
符号'%1'在系统头文件中定义,无法修改。
-
+
新名称
-
-
-
-
+
+
+
+
替换出错
-
+
无法打开文件'%1'进行替换!
-
+
内容和上次查找时不一致。
-
+
RTF格式文件 (*.rtf)
-
+
HTML文件 (*.html)
-
+
当前的试题集不是空的。
-
+
试题%1
-
-
+
+
试题集文件 (*.pbs)
-
-
+
+
载入失败
-
-
+
+
试题案例%1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
错误
-
+
项目历史
-
+
载入主题失败
-
-
+
+
清除历史
-
-
+
+
编译生成的可执行文件中没有符号表,无法被调试。
-
-
+
+
版本控制
@@ -7007,80 +7012,80 @@ Are you really want to continue?
请在工具栏中选用Debug编译器配置集,或者在选项对话框的编辑器配置集页中勾选“生成调试信息(-g3)"选项。
-
+
磁盘文件'%1'已被修改。
-
+
是否重新读取它的内容?
-
+
磁盘文件'%1'已被删除。
-
+
是否保持它在小熊猫C++中打开的编辑窗口?
-
+
打开
-
-
+
+
编译失败
-
+
运行失败
-
-
-
-
+
+
+
+
确认转换
-
-
-
-
+
+
+
+
当前编辑器中的文件将会使用%1编码保存。<br />这项操作无法被撤回。<br />你确定要继续吗?
-
+
新监视表达式
-
+
输入监视表达式
-
+
(%1/%2)正在解析文件"%3"
-
-
+
+
完成%1个文件的解析,用时%2秒
-
+
(每秒%1个文件)
@@ -8421,13 +8426,13 @@ Are you really want to continue?
QObject
-
+
保存
-
+
将修改保存到"%1"?
@@ -8810,22 +8815,22 @@ Are you really want to continue?
下标"%1"越界
-
+
字节
-
+
KB
-
+
MB
-
+
GB
@@ -10165,18 +10170,18 @@ Are you really want to continue?
性能
-
-
-
+
+
+
编译器配置集
-
-
-
+
+
+
@@ -10188,7 +10193,7 @@ Are you really want to continue?
自动链接
-
+
@@ -10264,15 +10269,15 @@ Are you really want to continue?
杂项
-
-
+
+
程序运行
-
+
试题集
@@ -10758,34 +10763,39 @@ Are you really want to continue?
删除编译文件
-
-
+
+
+
+
+
+
+
读取工具配置失败
-
+
无法读取工具配置文件'%1'
-
+
读取工具配置文件'%1'失败:%2
-
-
+
+
保存工具配置失败
-
+
无法写入工具配置文件'%1'。
-
+
Write to tool config file '%1' failed.
写入工具配置文件'%1'失败。
diff --git a/RedPandaIDE/translations/RedPandaIDE_zh_TW.ts b/RedPandaIDE/translations/RedPandaIDE_zh_TW.ts
index 502b78f7..71b3995f 100644
--- a/RedPandaIDE/translations/RedPandaIDE_zh_TW.ts
+++ b/RedPandaIDE/translations/RedPandaIDE_zh_TW.ts
@@ -4932,6 +4932,10 @@
+
+
+
+
MemoryModel
@@ -7154,6 +7158,10 @@
+
+
+
+
WatchModel
diff --git a/RedPandaIDE/widgets/shortcutinputedit.cpp b/RedPandaIDE/widgets/shortcutinputedit.cpp
index 6dd4d95f..5b4c5316 100644
--- a/RedPandaIDE/widgets/shortcutinputedit.cpp
+++ b/RedPandaIDE/widgets/shortcutinputedit.cpp
@@ -31,6 +31,7 @@ ShortcutInputEdit::ShortcutInputEdit(QWidget* parent):QLineEdit(parent)
void ShortcutInputEdit::keyPressEvent(QKeyEvent *event)
{
+ QString lastKeys=text();
if (event->key()==Qt::Key_Delete && event->modifiers()==Qt::NoModifier) {
setText("");
} else if (event->key()==Qt::Key_Backspace && event->modifiers()==Qt::NoModifier) {
@@ -66,11 +67,13 @@ void ShortcutInputEdit::keyPressEvent(QKeyEvent *event)
&& event->text().at(0).unicode()<127) {
s = s.mid(0,s.lastIndexOf('+')+1) + event->text().at(0);
}
+ if (!lastKeys.isEmpty())
+ s=lastKeys+","+s;
setText(s);
- if (key!=Qt::Key_Tab
- && key!=Qt::Key_Enter
- && key!=Qt::Key_Return)
- emit inputFinished(this);
+// if (key!=Qt::Key_Tab
+// && key!=Qt::Key_Enter
+// && key!=Qt::Key_Return)
+// emit inputFinished(this);
}
event->accept();
}
@@ -78,7 +81,10 @@ void ShortcutInputEdit::keyPressEvent(QKeyEvent *event)
bool ShortcutInputEdit::event(QEvent *event)
{
if (event->type()==QEvent::ShortcutOverride) {
- keyPressEvent((QKeyEvent*)event);
+ QKeyEvent* keyEvent = static_cast(event);
+ if (keyEvent->key()==Qt::Key_Tab)
+ keyPressEvent((QKeyEvent*)event);
+
event->accept();
return true;
} else if (event->type()==QEvent::KeyPress) {
diff --git a/RedPandaIDE/widgets/shortcutinputedit.h b/RedPandaIDE/widgets/shortcutinputedit.h
index 52eeca4e..bf8d6655 100644
--- a/RedPandaIDE/widgets/shortcutinputedit.h
+++ b/RedPandaIDE/widgets/shortcutinputedit.h
@@ -33,6 +33,7 @@ protected:
// QObject interface
public:
bool event(QEvent *event) override;
+
};
#endif // SHORTCUTINPUTEDIT_H
diff --git a/libs/qsynedit/qsynedit/qsynedit.cpp b/libs/qsynedit/qsynedit/qsynedit.cpp
index d2c4fe4b..1778adc0 100644
--- a/libs/qsynedit/qsynedit/qsynedit.cpp
+++ b/libs/qsynedit/qsynedit/qsynedit.cpp
@@ -1194,6 +1194,7 @@ void QSynEdit::setCaretAndSelection(const BufferCoord &ptCaret, const BufferCoor
{
incPaintLock();
internalSetCaretXY(ptCaret);
+ setActiveSelectionMode(SelectionMode::Normal);
setBlockBegin(ptSelBegin);
setBlockEnd(ptSelEnd);
decPaintLock();
@@ -2730,11 +2731,11 @@ void QSynEdit::doBlockUnindent()
endEditing();
}
-void QSynEdit::doAddChar(QChar AChar)
+void QSynEdit::doAddChar(const QChar& ch)
{
if (mReadOnly)
return;
- if (!AChar.isPrint() && AChar!='\t')
+ if (!ch.isPrint() && ch!='\t')
return;
//DoOnPaintTransient(ttBefore);
//mCaretX will change after setSelLength;
@@ -2759,12 +2760,31 @@ void QSynEdit::doAddChar(QChar AChar)
}
}
- if (isIdentChar(AChar)) {
- doSetSelText(AChar);
- } else if (AChar.isSpace()) {
+ QChar lastCh{0};
+ if (!selAvail()) {
+ PUndoItem undoItem = mUndoList->peekItem();
+ if (undoItem && undoItem->changeReason()==ChangeReason::Insert
+ && undoItem->changeEndPos().line == mCaretY
+ && undoItem->changeEndPos().ch == mCaretX
+ && undoItem->changeStartPos().line == mCaretY
+ && undoItem->changeStartPos().ch == mCaretX-1) {
+ QString s = mDocument->getLine(mCaretY-1);
+ int i=mCaretX-2;
+ if (i>=0 && iaddGroupBreak();
+ }
+ doSetSelText(ch);
+ } else if (ch.isSpace()) {
// break group undo chain
- mUndoList->addGroupBreak();
- doSetSelText(AChar);
+ if (!lastCh.isSpace()) {
+ mUndoList->addGroupBreak();
+ }
+ doSetSelText(ch);
// break group undo chain
// if (mActiveSelectionMode!=SynSelectionMode::smColumn)
// mUndoList->AddChange(SynChangeReason::crNothing,
@@ -2772,8 +2792,11 @@ void QSynEdit::doAddChar(QChar AChar)
// BufferCoord{0, 0},
// "", SynSelectionMode::smNormal);
} else {
+ if (lastCh.isSpace() || isIdentChar(lastCh)) {
+ mUndoList->addGroupBreak();
+ }
beginEditing();
- doSetSelText(AChar);
+ doSetSelText(ch);
int oldCaretX=mCaretX-1;
int oldCaretY=mCaretY;
// auto
@@ -2784,7 +2807,7 @@ void QSynEdit::doAddChar(QChar AChar)
&& (oldCaretY<=mDocument->count()) ) {
//unindent if ':' at end of the line
- if (AChar == ':') {
+ if (ch == ':') {
QString line = mDocument->getLine(oldCaretY-1);
if (line.length() <= oldCaretX) {
int indentSpaces = calcIndentSpaces(oldCaretY,line+":", true);
@@ -2810,7 +2833,7 @@ void QSynEdit::doAddChar(QChar AChar)
);
}
}
- } else if (AChar == '*') {
+ } else if (ch == '*') {
QString line = mDocument->getLine(oldCaretY-1);
if (line.length() <= oldCaretX) {
int indentSpaces = calcIndentSpaces(oldCaretY,line+"*", true);
@@ -2836,12 +2859,12 @@ void QSynEdit::doAddChar(QChar AChar)
);
}
}
- } else if (AChar == '{' || AChar == '}' || AChar == '#') {
+ } else if (ch == '{' || ch == '}' || ch == '#') {
//Reindent line when add '{' '}' and '#' at the beginning
QString left = mDocument->getLine(oldCaretY-1).mid(0,oldCaretX-1);
// and the first nonblank char is this new {
if (left.trimmed().isEmpty()) {
- int indentSpaces = calcIndentSpaces(oldCaretY,AChar, true);
+ int indentSpaces = calcIndentSpaces(oldCaretY,ch, true);
if (indentSpaces != leftSpaces(left)) {
QString right = mDocument->getLine(oldCaretY-1).mid(oldCaretX-1);
QString newLeft = GetLeftSpacing(indentSpaces,true);
@@ -6674,7 +6697,6 @@ void QSynEdit::clearSelection()
void QSynEdit::setBlockEnd(BufferCoord value)
{
- //setActiveSelectionMode(mSelectionMode);
value.line = minMax(value.line, 1, mDocument->count());
if (mActiveSelectionMode == SelectionMode::Normal) {
if (value.line >= 1 && value.line <= mDocument->count())
@@ -6782,7 +6804,6 @@ void QSynEdit::setBlockBegin(BufferCoord value)
{
int nInval1, nInval2;
bool SelChanged;
- //setActiveSelectionMode(mSelectionMode);
value.line = minMax(value.line, 1, mDocument->count());
if (mActiveSelectionMode == SelectionMode::Normal) {
if (value.line >= 1 && value.line <= mDocument->count())
diff --git a/libs/qsynedit/qsynedit/qsynedit.h b/libs/qsynedit/qsynedit/qsynedit.h
index a1627080..1fdb422c 100644
--- a/libs/qsynedit/qsynedit/qsynedit.h
+++ b/libs/qsynedit/qsynedit/qsynedit.h
@@ -600,7 +600,7 @@ private:
void doShiftTabKey();
void doBlockIndent();
void doBlockUnindent();
- void doAddChar(QChar AChar);
+ void doAddChar(const QChar& ch);
void doCutToClipboard();
void doCopyToClipboard();
void internalDoCopyToClipboard(const QString& s);