From da3dda97e308f008b2cecab0183490cdc14b0b3e Mon Sep 17 00:00:00 2001 From: Roy Qu Date: Fri, 3 Mar 2023 17:20:33 +0800 Subject: [PATCH] - enhancement: Add "Close window" and "Move to other view" in the "Window" menu - enhancement: Auto open CPU info dialog, if the program in debug is stopped at a position that have no source file. - enhancement: "add watchpoint" when debug. It's hitted when the watch variable is modified, or it's out of scope. - enhancement: Switch current call stack frame in the CPU info dialog - fix: Shouldn't try evaluate value of the selection in the cpu info dialog. - enhancement: Show oct/bin/bin value in the memory view's tooltip. - Don't set optimization level to -Og in the Debug compiler set. (Some variable can't be view in the memory view, because they are put in registers.) --- NEWS.md | 6 +- RedPandaIDE/debugger.cpp | 90 +- RedPandaIDE/debugger.h | 5 +- RedPandaIDE/editor.cpp | 9 +- RedPandaIDE/gdbmiresultparser.cpp | 15 +- RedPandaIDE/gdbmiresultparser.h | 4 +- RedPandaIDE/mainwindow.cpp | 80 +- RedPandaIDE/mainwindow.h | 5 + RedPandaIDE/mainwindow.ui | 16 +- RedPandaIDE/settings.cpp | 2 +- RedPandaIDE/translations/RedPandaIDE_pt_BR.ts | 51 + RedPandaIDE/translations/RedPandaIDE_zh_CN.ts | 1891 +++++++++-------- RedPandaIDE/translations/RedPandaIDE_zh_TW.ts | 51 + RedPandaIDE/widgets/cpudialog.cpp | 25 +- RedPandaIDE/widgets/cpudialog.h | 6 +- RedPandaIDE/widgets/cpudialog.ui | 12 +- 16 files changed, 1303 insertions(+), 965 deletions(-) diff --git a/NEWS.md b/NEWS.md index 172d6403..83380a2c 100644 --- a/NEWS.md +++ b/NEWS.md @@ -7,7 +7,6 @@ Red Panda C++ Version 2.16 - enhancement: Add cfi directives for asm syntaxer in linux. - change: Editor option "Scroll past end of line" default to false. - emhancement: Improve display of disassembled codes in the cpu info dialog. - - change: Set optimization level to -Og for Debug compiler settings by default. - fix: Can't correctly parse function pointer var definition. - enhancement: Improve support for function pointer typedefs. - enhancement: Improve support for function pointer vars. @@ -15,6 +14,11 @@ Red Panda C++ Version 2.16 - change: Don't rebuild the whole project when run/debug, if only contents of project unit file is modified. - fix: rebuild may not work, if project's parallel build option is enabled. - enhancement: Add "Close window" and "Move to other view" in the "Window" menu + - enhancement: Auto open CPU info dialog, if the program in debug is stopped at a position that have no source file. + - enhancement: "add watchpoint" when debug. It's hitted when the watch variable is modified, or it's out of scope. + - enhancement: Switch current call stack frame in the CPU info dialog + - fix: Shouldn't try evaluate value of the selection in the cpu info dialog. + - enhancement: Show oct/bin/bin value in the memory view's tooltip. Red Panda C++ Version 2.15 diff --git a/RedPandaIDE/debugger.cpp b/RedPandaIDE/debugger.cpp index f45870d7..e31849fe 100644 --- a/RedPandaIDE/debugger.cpp +++ b/RedPandaIDE/debugger.cpp @@ -194,6 +194,8 @@ bool Debugger::start(int compilerSetIndex, const QString& inferior, const QStrin &MainWindow::removeActiveBreakpoints); connect(mReader, &DebugReader::inferiorStopped,pMainWindow, &MainWindow::setActiveBreakpoint); + connect(mReader, &DebugReader::watchpointHitted,pMainWindow, + &MainWindow::onWatchpointHitted); connect(mReader, &DebugReader::errorNoSymbolTable,pMainWindow, &MainWindow::stopDebugForNoSymbolTable); connect(mReader, &DebugReader::inferiorStopped,this, @@ -485,6 +487,14 @@ void Debugger::loadForProject(const QString &filename, const QString &projectFol } } +void Debugger::addWatchpoint(const QString &expression) +{ + QString s=expression.trimmed(); + if (!s.isEmpty()) { + sendCommand("-break-watch",s,DebugCommandSource::Other); + } +} + void Debugger::addWatchVar(const QString &expression) { // Don't allow duplicates... @@ -923,7 +933,7 @@ void Debugger::updateEval(const QString &value) void Debugger::updateDisassembly(const QString& file, const QString& func, const QStringList &value) { if (pMainWindow->cpuDialog()) { - pMainWindow->cpuDialog()->setDisassembly(file,func,value); + pMainWindow->cpuDialog()->setDisassembly(file,func,value,mBacktraceModel->backtraces()); } } @@ -1088,12 +1098,14 @@ void DebugReader::processResult(const QByteArray &result) return; switch(resultType) { case GDBMIResultType::BreakpointTable: - case GDBMIResultType::Frame: case GDBMIResultType::Locals: break; case GDBMIResultType::Breakpoint: handleBreakpoint(multiValues["bkpt"].object()); return; + case GDBMIResultType::Frame: + handleFrame(multiValues["frame"]); + return; case GDBMIResultType::FrameStack: handleStack(multiValues["stack"].array()); return; @@ -1163,27 +1175,33 @@ void DebugReader::processExecAsyncRecord(const QByteArray &line) return; } mUpdateCPUInfo = true; - GDBMIResultParser::ParseValue frame(multiValues["frame"]); - if (frame.isValid()) { - GDBMIResultParser::ParseObject frameObj = frame.object(); - mCurrentAddress = frameObj["addr"].hexValue(); - mCurrentLine = frameObj["line"].intValue(); - if (mDebugger->forceUTF8()) - mCurrentFile = frameObj["fullname"].utf8PathValue(); - else - mCurrentFile = frameObj["fullname"].pathValue(); - mCurrentFunc = frameObj["func"].value(); - } + handleFrame(multiValues["frame"]); if (reason == "signal-received") { mSignalReceived = true; mSignalName = multiValues["signal-name"].value(); mSignalMeaning = multiValues["signal-meaning"].value(); + } else if (reason == "watchpoint-trigger") { + QString var,oldVal,newVal; + GDBMIResultParser::ParseValue wpt=multiValues["wpt"]; + if (wpt.isValid()) { + GDBMIResultParser::ParseObject wptObj = wpt.object(); + var=wptObj["exp"].value(); + } + GDBMIResultParser::ParseValue varValue=multiValues["value"]; + if (varValue.isValid()) { + GDBMIResultParser::ParseObject valueObj = varValue.object(); + oldVal=valueObj["old"].value(); + newVal=valueObj["new"].value(); + } + if (!var.isEmpty()) { + emit watchpointHitted(var,oldVal,newVal); + } } runInferiorStoppedHook(); if (mCurrentCmd && mCurrentCmd->source == DebugCommandSource::Console) - emit inferiorStopped(mCurrentFile, mCurrentLine,false); + emit inferiorStopped(mCurrentFile, mCurrentLine, false); else - emit inferiorStopped(mCurrentFile, mCurrentLine,true); + emit inferiorStopped(mCurrentFile, mCurrentLine, true); } } @@ -1466,6 +1484,23 @@ void DebugReader::handleBreakpoint(const GDBMIResultParser::ParseObject& breakpo emit breakpointInfoGetted(filename, line , number); } +void DebugReader::handleFrame(const GDBMIResultParser::ParseValue &frame) +{ + if (frame.isValid()) { + GDBMIResultParser::ParseObject frameObj = frame.object(); + bool ok; + mCurrentAddress = frameObj["addr"].hexValue(ok); + if (!ok) + mCurrentAddress=0; + mCurrentLine = frameObj["line"].intValue(); + if (mDebugger->forceUTF8()) + mCurrentFile = frameObj["fullname"].utf8PathValue(); + else + mCurrentFile = frameObj["fullname"].pathValue(); + mCurrentFunc = frameObj["func"].value(); + } +} + void DebugReader::handleStack(const QList & stack) { mDebugger->backtraceModel()->clear(); @@ -3113,6 +3148,31 @@ QVariant MemoryModel::data(const QModelIndex &index, int role) const return s; } else return QString("%1").arg(line->datas[col],2,16,QChar('0')); + } else if (role == Qt::ToolTipRole) { + if (coldatas.count()) { + QString s =tr("dec: %1").arg(line->datas[col]) + +"
" + +tr("hex: %1").arg(line->datas[col],2,16,QChar('0')) + +"
" + +tr("bin: %1").arg(line->datas[col],8,2,QChar('0')) + +"
"; + QString chVal; + if (line->datas[col]==0) { + chVal="\\0"; + } else if (line->datas[col]=='\n') { + chVal="\\n"; + } else if (line->datas[col]=='\t') { + chVal="\\t"; + } else if (line->datas[col]=='\r') { + chVal="\\r"; + } else if (line->datas[col]>'\n' && line->datas[col]<127) { + chVal=QChar(line->datas[col]); + } + if (!chVal.isEmpty()) { + s+=tr("ascii: \'%1\'").arg(chVal); + } + return s; + } } return QVariant(); } diff --git a/RedPandaIDE/debugger.h b/RedPandaIDE/debugger.h index 3debb9cd..a2922a67 100644 --- a/RedPandaIDE/debugger.h +++ b/RedPandaIDE/debugger.h @@ -340,6 +340,7 @@ public: void loadForNonproject(const QString &filename); void loadForProject(const QString& filename, const QString& projectFolder); + void addWatchpoint(const QString& expression); //watch vars void addWatchVar(const QString& expression); void modifyWatchVarExpression(const QString& oldExpr, const QString& newExpr); @@ -522,6 +523,7 @@ signals: void errorNoSymbolTable(); void breakpointInfoGetted(const QString& filename, int line, int number); void inferiorContinued(); + void watchpointHitted(const QString& var, const QString& oldVal, const QString& newVal); void inferiorStopped(const QString& filename, int line, bool setFocus); void localsUpdated(const QStringList& localsValue); void evalUpdated(const QString& value); @@ -554,6 +556,7 @@ private: bool outputTerminated(const QByteArray& text); void handleBreakpoint(const GDBMIResultParser::ParseObject& breakpoint); + void handleFrame(const GDBMIResultParser::ParseValue &frame); void handleStack(const QList & stack); void handleLocalVariables(const QList & variables); void handleEvaluation(const QString& value); @@ -606,7 +609,7 @@ private: bool mReceivedSFWarning; int mCurrentLine; - int mCurrentAddress; + qulonglong mCurrentAddress; QString mCurrentFunc; QString mCurrentFile; QStringList mConsoleOutput; diff --git a/RedPandaIDE/editor.cpp b/RedPandaIDE/editor.cpp index de4e5a86..e8d9f593 100644 --- a/RedPandaIDE/editor.cpp +++ b/RedPandaIDE/editor.cpp @@ -1903,8 +1903,7 @@ void Editor::onTooltipTimer() break; case TipType::Identifier: if (pMainWindow->debugger()->executing() && !pMainWindow->debugger()->inferiorRunning()) { - if (mParentPageControl) - s = getWordAtPosition(this,p, pBeginPos,pEndPos, WordPurpose::wpEvaluation); // debugging + s = getWordAtPosition(this,p, pBeginPos,pEndPos, WordPurpose::wpEvaluation); // debugging } else if (!mCompletionPopup->isVisible() && !mHeaderCompletionPopup->isVisible()) { expression = getExpressionAtPosition(p); @@ -1977,7 +1976,9 @@ void Editor::onTooltipTimer() && !mHeaderCompletionPopup->isVisible()) { if (pMainWindow->debugger()->executing() && (pSettings->editor().enableDebugTooltips())) { - showDebugHint(s,p.line); + if (mParentPageControl) { + showDebugHint(s,p.line); + } } else if (pSettings->editor().enableIdentifierToolTips()) { hint = getParserHint(expression, s, p.line); } @@ -3851,7 +3852,7 @@ Editor::TipType Editor::getTipType(QPoint point, QSynedit::BufferCoord& pos) return TipType::Selection; } else if (mParser && mParser->isIncludeLine(document()->getLine(pos.line-1))) { return TipType::Preprocessor; - }else if (attr->tokenType() == QSynedit::TokenType::Identifier) { + } else if (attr->tokenType() == QSynedit::TokenType::Identifier) { return TipType::Identifier; } else if (attr->tokenType() == QSynedit::TokenType::Keyword) { return TipType::Keyword; diff --git a/RedPandaIDE/gdbmiresultparser.cpp b/RedPandaIDE/gdbmiresultparser.cpp index 0bea0e6f..3e16926e 100644 --- a/RedPandaIDE/gdbmiresultparser.cpp +++ b/RedPandaIDE/gdbmiresultparser.cpp @@ -37,6 +37,7 @@ GDBMIResultParser::GDBMIResultParser() mResultTypes.insert("-var-create",GDBMIResultType::CreateVar); mResultTypes.insert("-var-list-children",GDBMIResultType::ListVarChildren); mResultTypes.insert("-var-update",GDBMIResultType::UpdateVarValue); + mResultTypes.insert("-stack-info-frame",GDBMIResultType::Frame); } bool GDBMIResultParser::parse(const QByteArray &record, const QString& command, GDBMIResultType &type, ParseObject& multiValues) @@ -349,26 +350,22 @@ const GDBMIResultParser::ParseObject &GDBMIResultParser::ParseValue::object() co return mObject; } -int GDBMIResultParser::ParseValue::intValue(int defaultValue) const +int64_t GDBMIResultParser::ParseValue::intValue(int defaultValue) const { //Q_ASSERT(mType == ParseValueType::Value); bool ok; - int value = QString(mValue).toInt(&ok); + qlonglong value = QString(mValue).toLongLong(&ok); if (ok) return value; else return defaultValue; } -int GDBMIResultParser::ParseValue::hexValue(int defaultValue) const +qulonglong GDBMIResultParser::ParseValue::hexValue(bool &ok) const { //Q_ASSERT(mType == ParseValueType::Value); - bool ok; - int value = QString(mValue).toInt(&ok,16); - if (ok) - return value; - else - return defaultValue; + qulonglong value = QString(mValue).toULongLong(&ok,16); + return value; } QString GDBMIResultParser::ParseValue::pathValue() const diff --git a/RedPandaIDE/gdbmiresultparser.h b/RedPandaIDE/gdbmiresultparser.h index 0759b60c..7bfec00c 100644 --- a/RedPandaIDE/gdbmiresultparser.h +++ b/RedPandaIDE/gdbmiresultparser.h @@ -74,8 +74,8 @@ public: const QByteArray &value() const; const QList &array() const; const ParseObject &object() const; - int intValue(int defaultValue=-1) const; - int hexValue(int defaultValue=-1) const; + qlonglong intValue(int defaultValue=-1) const; + qulonglong hexValue(bool &ok) const; QString pathValue() const; QString utf8PathValue() const; diff --git a/RedPandaIDE/mainwindow.cpp b/RedPandaIDE/mainwindow.cpp index 15aa2488..b1141737 100644 --- a/RedPandaIDE/mainwindow.cpp +++ b/RedPandaIDE/mainwindow.cpp @@ -1019,16 +1019,17 @@ void MainWindow::removeActiveBreakpoints() void MainWindow::setActiveBreakpoint(QString fileName, int Line, bool setFocus) { removeActiveBreakpoints(); - if (!fileExists(fileName)) - return; // Then active the current line in the current file Editor *e = openFile(fileName); if (e!=nullptr) { e->setActiveBreakpointFocus(Line,setFocus); + if (setFocus) { + activateWindow(); + } + } else { + pMainWindow->showCPUInfoDialog(); } - if (setFocus) { - activateWindow(); - } + return; } void MainWindow::updateDPI(int oldDPI, int /*newDPI*/) @@ -4892,6 +4893,7 @@ void MainWindow::onEditorContextMenu(const QPoint& pos) menu.addSeparator(); if (canDebug) { menu.addAction(ui->actionAdd_Watch); + menu.addAction(ui->actionAdd_Watchpoint); menu.addAction(ui->actionToggle_Breakpoint); menu.addAction(ui->actionClear_all_breakpoints); menu.addSeparator(); @@ -4981,6 +4983,7 @@ void MainWindow::disableDebugActions() ui->actionStep_Out->setEnabled(false); ui->actionRun_To_Cursor->setEnabled(false); ui->actionContinue->setEnabled(false); + ui->actionAdd_Watchpoint->setEnabled(false); ui->cbEvaluate->setEnabled(false); ui->cbMemoryAddress->setEnabled(false); if (mCPUDialog) { @@ -4997,6 +5000,7 @@ void MainWindow::enableDebugActions() ui->actionStep_Out->setEnabled(!mDebugger->inferiorRunning()); ui->actionRun_To_Cursor->setEnabled(!mDebugger->inferiorRunning()); ui->actionContinue->setEnabled(!mDebugger->inferiorRunning()); + ui->actionAdd_Watchpoint->setEnabled(!mDebugger->inferiorRunning()); ui->cbEvaluate->setEnabled(!mDebugger->inferiorRunning()); ui->cbMemoryAddress->setEnabled(!mDebugger->inferiorRunning()); if (mCPUDialog) { @@ -5034,6 +5038,17 @@ void MainWindow::onTodoParseFinished() { } +void MainWindow::onWatchpointHitted(const QString &var, const QString &oldVal, const QString &newVal) +{ + QMessageBox::information(this, + tr("Watchpoint hitted"), + tr("Value of \"%1\" has changed:").arg(var) + +"
" + +tr("Old value: %1").arg(oldVal) + +"
" + +tr("New value: %1").arg(newVal)); +} + void MainWindow::prepareProjectForCompile() { if (!mProject) @@ -6698,19 +6713,7 @@ void MainWindow::on_searchView_doubleClicked(const QModelIndex &index) void MainWindow::on_tblStackTrace_doubleClicked(const QModelIndex &index) { - PTrace trace = mDebugger->backtraceModel()->backtrace(index.row()); - if (trace) { - Editor *e = openFile(trace->filename); - if (e) { - e->setCaretPositionAndActivate(trace->line,1); - } - mDebugger->sendCommand("-stack-select-frame", QString("%1").arg(trace->level)); - mDebugger->sendCommand("-stack-list-variables", "--all-values"); - mDebugger->sendCommand("-var-update", "--all-values *"); - if (this->mCPUDialog) { - this->mCPUDialog->updateInfo(); - } - } + switchCurrentStackTrace(index.row()); } @@ -7637,8 +7640,12 @@ void MainWindow::updateVCSActions() canBranch =!mFileSystemModelIconProvider.VCSRepository()->hasChangedFiles() && !mFileSystemModelIconProvider.VCSRepository()->hasStagedFiles(); } + ui->actionGit_Remotes->setEnabled(hasRepository && shouldEnable); ui->actionGit_Create_Repository->setEnabled(!hasRepository && shouldEnable); + ui->actionGit_Push->setEnabled(hasRepository && shouldEnable); + ui->actionGit_Pull->setEnabled(hasRepository && shouldEnable); + ui->actionGit_Fetch->setEnabled(hasRepository && shouldEnable); ui->actionGit_Log->setEnabled(hasRepository && shouldEnable); ui->actionGit_Commit->setEnabled(hasRepository && shouldEnable); ui->actionGit_Branch->setEnabled(hasRepository && shouldEnable && canBranch); @@ -8468,6 +8475,27 @@ QList MainWindow::listShortCutableActions() return actions; } +void MainWindow::switchCurrentStackTrace(int idx) +{ + PTrace trace = mDebugger->backtraceModel()->backtrace(idx); + if (trace) { + Editor *e = openFile(trace->filename); + if (e) { + e->setCaretPositionAndActivate(trace->line,1); + } + mDebugger->sendCommand("-stack-select-frame", QString("%1").arg(trace->level)); + mDebugger->sendCommand("-stack-list-variables", "--all-values"); + mDebugger->sendCommand("-var-update", "--all-values *"); + if (this->mCPUDialog) { + this->mCPUDialog->updateInfo(); + } + if (idx!=ui->tblStackTrace->currentIndex().row()) { + ui->tblStackTrace->setCurrentIndex(ui->tblStackTrace->model()->index(idx,0)); + } + } + +} + void MainWindow::on_actionTool_Window_Bars_triggered() { @@ -9595,3 +9623,19 @@ void MainWindow::on_actionIA_32_Assembly_Language_Reference_Manual_triggered() QDesktopServices::openUrl(QUrl("https://docs.oracle.com/cd/E19455-01/806-3773/index.html")); } + +void MainWindow::on_actionAdd_Watchpoint_triggered() +{ + QString s = ""; + bool isOk; + s=QInputDialog::getText(this, + tr("Watchpoint variable name"), + tr("Stop execution when the following variable is modified (it must be visible from the currect scope):"), + QLineEdit::Normal, + s,&isOk); + if (!isOk) + return; + s = s.trimmed(); + mDebugger->addWatchpoint(s); +} + diff --git a/RedPandaIDE/mainwindow.h b/RedPandaIDE/mainwindow.h index 1c0aa813..53f27538 100644 --- a/RedPandaIDE/mainwindow.h +++ b/RedPandaIDE/mainwindow.h @@ -229,6 +229,8 @@ public: QList listShortCutableActions(); + void switchCurrentStackTrace(int idx); + public slots: void logToolsOutput(const QString& msg); void onCompileIssue(PCompileIssue issue); @@ -267,6 +269,7 @@ public slots: void onTodoParseStarted(); void onTodoFound(const QString& filename, int lineNo, int ch, const QString& line); void onTodoParseFinished(); + void onWatchpointHitted(const QString& var, const QString& oldVal, const QString& newVal); void setActiveBreakpoint(QString FileName, int Line, bool setFocus); void updateDPI(int oldDPI, int newDPI); void onFileSaved(const QString& path, bool inProject); @@ -795,6 +798,8 @@ private slots: void on_actionIA_32_Assembly_Language_Reference_Manual_triggered(); + void on_actionAdd_Watchpoint_triggered(); + private: Ui::MainWindow *ui; bool mFullInitialized; diff --git a/RedPandaIDE/mainwindow.ui b/RedPandaIDE/mainwindow.ui index 334caea9..028fb4d7 100644 --- a/RedPandaIDE/mainwindow.ui +++ b/RedPandaIDE/mainwindow.ui @@ -170,6 +170,7 @@ + @@ -935,7 +936,7 @@ QTabWidget::South - 3 + 2 @@ -1131,7 +1132,7 @@ QTabWidget::North - 3 + 1 @@ -3290,6 +3291,9 @@ Generate Assembly + + Ctrl+F9 + @@ -3334,6 +3338,14 @@ IA-32 Assembly Language Reference Manual + + + Add Watchpoint... + + + Add a watchpoint that's triggered when it's modified. + + diff --git a/RedPandaIDE/settings.cpp b/RedPandaIDE/settings.cpp index bdbb8937..0e61842f 100644 --- a/RedPandaIDE/settings.cpp +++ b/RedPandaIDE/settings.cpp @@ -2728,7 +2728,7 @@ static void setReleaseOptions(Settings::PCompilerSet pSet) { } static void setDebugOptions(Settings::PCompilerSet pSet, bool enableAsan = false) { - pSet->setCompileOption(CC_CMD_OPT_OPTIMIZE,"g"); + //pSet->setCompileOption(CC_CMD_OPT_OPTIMIZE,"g"); pSet->setCompileOption(CC_CMD_OPT_DEBUG_INFO, COMPILER_OPTION_ON); pSet->setCompileOption(CC_CMD_OPT_WARNING_ALL, COMPILER_OPTION_ON); //pSet->setCompileOption(CC_CMD_OPT_WARNING_EXTRA, COMPILER_OPTION_ON); diff --git a/RedPandaIDE/translations/RedPandaIDE_pt_BR.ts b/RedPandaIDE/translations/RedPandaIDE_pt_BR.ts index 92c4657a..683ca38e 100644 --- a/RedPandaIDE/translations/RedPandaIDE_pt_BR.ts +++ b/RedPandaIDE/translations/RedPandaIDE_pt_BR.ts @@ -5079,6 +5079,57 @@ IA-32 Assembly Language Reference Manual + + Add Watchpoint... + + + + Add a watchpoint that's triggered when it's modified. + + + + Old value: %1 + + + + Watchpoint variable name + + + + Stop execution when the following variable is modified (it must be visible from the currect scope): + + + + Watchpoint hitted + + + + Value of "%1" has changed: + + + + New value: %1 + + + + + MemoryModel + + dec: %1 + + + + hex: %1 + + + + bin: %1 + + + + ascii: '%1' + + NewClassDialog diff --git a/RedPandaIDE/translations/RedPandaIDE_zh_CN.ts b/RedPandaIDE/translations/RedPandaIDE_zh_CN.ts index 59d9d2bc..69fffbcd 100644 --- a/RedPandaIDE/translations/RedPandaIDE_zh_CN.ts +++ b/RedPandaIDE/translations/RedPandaIDE_zh_CN.ts @@ -193,17 +193,17 @@ p, li { white-space: pre-wrap; } BacktraceModel - + Function 函数 - + Filename 文件名 - + Line @@ -249,17 +249,17 @@ p, li { white-space: pre-wrap; } BreakpointModel - + Filename 文件名 - + Line - + Condition 条件 @@ -293,29 +293,29 @@ p, li { white-space: pre-wrap; } 反汇编 - - + + Step over one machine instruction 单步执行一条机器指令 - - + + Step into one machine instruction 单步进入一条机器指令 - + AT&&T AT&&T - + Intel Intel - + Blend Mode 混合模式 @@ -538,57 +538,57 @@ p, li { white-space: pre-wrap; } 重编译前的清理准备工作失败! - + Compile Result: 编译结果: - + - Errors: %1 - 错误数: %1 - + - Warnings: %1 - 警告数: %1 - + - Output Filename: %1 - 输出文件名: %1 - + - Output Size: %1 - 输出文件大小: %1 - + - Compilation Time: %1 secs - 编译时间: %1 秒 - + [Error] [错误] - + [Warning] [警告] - + [Info] [信息] - + [Note] [说明] - + The compiler process for '%1' failed to start. 无法启动编译器进程'%1'。 @@ -597,27 +597,27 @@ p, li { white-space: pre-wrap; } 无法启动编译进程。 - + The compiler process crashed after starting successfully. 编译进程启动后崩溃。 - + The last waitFor...() function timed out. waitFor()函数等待超时。 - + An error occurred when attempting to write to the compiler process. 在向编译进程输入内容时出错。 - + An error occurred when attempting to read from the compiler process. 在从编译进程读取内容时出错。 - + An unknown error occurred. 发生了未知错误。 @@ -1344,27 +1344,27 @@ Are you really want to continue? 无法在"%1"找到gdb server - + Execute to evaluate 执行以求值 - + Save file '%1' failed. 保存文件'%1'失败。 - + Can't open file '%1' for write. 无法写入文件'%1'. - + Error in json file '%1':%2 : %3 JSON文件'%1':%2中存在错误:%3 - + Can't open file '%1' for read. 无法读取文件'%1'. @@ -1373,22 +1373,22 @@ Are you really want to continue? 不在当前语境中 - + Compile 编译 - + Source file is more recent than executable. 源文件比程序文件新。 - + Recompile? 重新编译? - + Signal "%1" Received: 收到信号"%1": @@ -1483,14 +1483,14 @@ Are you really want to continue? 要剪切的内容超过了字符数限制! - + Print Document 打印文档 - - - + + + Ctrl+click for more info Ctrl+单击以获取更多信息 @@ -1499,27 +1499,27 @@ Are you really want to continue? 未找到符号'%1'! - + astyle not found 找不到astyle程序 - + Can't find astyle in "%1". 找不到astyle程序"%1". - + Break point condition 断点条件 - + Enter the condition of the breakpoint: 输入当前断点的生效条件: - + Readonly 只读 @@ -4136,9 +4136,9 @@ Are you really want to continue? Intel - + Don't generate cli directives. - 不生成cli指令。 + 不生成cli指令。 @@ -4238,18 +4238,18 @@ Are you really want to continue? MainWindow - + Red Panda C++ 小熊猫C++ - - - - - - - + + + + + + + Issues 编译器 @@ -4268,38 +4268,38 @@ Are you really want to continue? 工具 - - + + Run 运行 - + Edit 编辑 - - - + + + Project 项目 - - + + Watch 监视 - - + + Structure 结构 - - + + Files 文件 @@ -4308,69 +4308,69 @@ Are you really want to continue? 资源 - - - - - + + + + + Debug 调试 - + Evaluate: 求值 - - + + Debug Console 调试主控台 - + Call Stack 调用栈 - + Breakpoints 断点 - + Locals 局部变量 - - - + + + Search 查找 - + History: 历史: - + Search Again 重新查找 - + Replace with: 替换为: - + Replace 替换 - + Close 关闭 @@ -4380,13 +4380,13 @@ Are you really want to continue? 运行 - - + + Code 代码 - + Window 窗口 @@ -4404,71 +4404,71 @@ Are you really want to continue? 新建 - + Ctrl+N Ctrl+N - + Open... 打开... - + Ctrl+O Ctrl+O - + Save 保存 - + Ctrl+S Ctrl+S - + Save As... 另存为... - + Save As 另存为 - + Save All 全部保存 - + Ctrl+Shift+S Ctrl+Shift+S - + Options 选项 - - - + + + Compile 编译 - - + + Tools Output 工具输出 - - + + Choose Input File 选择输入文件 @@ -4477,148 +4477,148 @@ Are you really want to continue? ... - + Tool Panels 工具面板 - + Git Git - + Selection 选择 - + F9 F9 - + F10 F10 - + Undo 恢复 - + Ctrl+Z Ctrl+Z - + Redo 重做 - + Ctrl+Y Ctrl+Y - + Cut 剪切 - + Ctrl+X Ctrl+X - - - - + + + + Copy 复制 - + Ctrl+C Ctrl+C - - + + Paste 粘贴 - + Ctrl+V Ctrl+V - - - + + + Select All 选择全部 - + Ctrl+A Ctrl+A - + Indent 缩进 - + UnIndent 取消缩进 - + Toggle Comment 切换注释 - + Ctrl+/ Ctrl+/ - + Collapse All 全部收起 - + Uncollapse All 全部展开 - + Encode in ANSI 使用ANSI编码 - + Encode in UTF-8 使用UTF-8编码 - + Auto Detect 自动检测 - + Convert to ANSI 转换为ANSI编码 - + Convert to UTF-8 转换为UTF-8编码 @@ -4631,193 +4631,193 @@ Are you really want to continue? F11 - - + + Rebuild All 全部重编译 - + F12 F12 - + Stop Execution 停止执行 - + F6 F6 - + F5 F5 - + Step Over 单步跳过 - + F7 F7 - + Step Into 单步进入 - - - + + + Problem Set 试题集 - - - + + + New Problem Set 新建试题集 - - + + Add Problem 添加试题 - - + + Remove Problem 删除试题 - - - + + + Save Problem Set 保存试题集 - - - + + + Load Problem Set 载入试题集 - + Memory 内存 - + Address Expression: Address: 地址表达式: - + Cancel 取消 - - + + TODO TODO - - + + Bookmark 书签 - - - + + + Problem 试题 - - + + Add Probem Case 添加试题案例 - - - + + + Remove Problem Case Remove Problem Set 删除试题集 - - - + + + Open Anwser Source File 打开答案源代码文件 - - - + + + Run All Cases Run Current Case 运行所有案例 - - + + Problem Cases Validation Options 测试案例验证选项 - + %v/%m %v/%m - + Output 输出 - + Input 输入 - + Expected 期望输出 - + Help 帮助 - + Refactor 重构 - + View 视图 @@ -4826,509 +4826,520 @@ Are you really want to continue? 工具窗口 - + Main 主工具栏 - + Compiler Set 编译器配置集 - + Explorer 管理器 - - - + + + Import FPS Problem Set 导入FPS试题集 - - - + + + Export FPS Problem Set 导出FPS试题集 - + Messages 消息 - + Open file in editors 在编辑器中打开文件 - + Choose Expected Output File 选择期望输出文件 - + Ignore Spaces 忽略空格 - + New C/C++ File 新建C/C++文件 - + New Source File 新建源代码文件 - + Tab Tab - + Shift+Tab Shift+Tab - + F8 F8 - + Step Out 单步跳出 - + Ctrl+F8 Ctrl+F8 - + Run To Cursor 执行到光标处 - + Ctrl+F5 Ctrl+F5 - + Continue 继续执行 - + F4 F4 - + Add Watch... 添加监视 - + View CPU Window... 打开CPU信息窗口... - + Exit 退出 - + Find... 查找... - + Ctrl+F Ctrl+F - + Find in Files... 在文件中查找... - + Ctrl+Shift+F Ctrl+Shift+F - + Replace... 替换 - + Ctrl+R Ctrl+R - + Find Next 查找下一个 - + F3 F3 - + Find Previous 查找前一个 - + Shift+F3 Shift+F3 - + Remove Watch 删除监视值 - + Remove All Watches Remove All 删除全部监视值 - + Modify Watch... 修改监视值 - + Reformat Code 对代码重新排版 - + Ctrl+Shift+A Ctrl+Shift+A - + Go back 前一次编辑位置 - + Ctrl+Alt+Left Ctrl+Alt+Left - + Forward 后一次编辑位置 - + Ctrl+Alt+Right Ctrl+Alt+Right - + Ctrl+W Ctrl+W - + Close All 全部关闭 - + Ctrl+Shift+W Ctrl+Shift+W - + Maximize Editor 最大化编辑器 - + Ctrl+F11 Ctrl+F11 - + Next 下一窗口 - + Ctrl+Tab Ctrl+Tab - + Previous 前一窗口 - + Ctrl+Shift+Tab Ctrl+Shift+Tab - + Toggle breakpoint 切换断点 - + Ctrl+F4 Ctrl+F4 - - + + Clear all breakpoints 删除所有断点 - + Breakpoint property... 设置断点条件... - + Goto Declaration 跳转到声明处 - + Ctrl+Shift+G Ctrl+Shift+G - + Goto Definition 跳转到定义处 - + Ctrl+G Ctrl+G - + Find references 查找符号的引用 - + Open containing folder 打开所在的文件夹 - + Ctrl+B Ctrl+B - + Open a terminal here 打开命令行窗口 - + File Properties... 文件属性... - + Close Project 关闭项目 - + Project options 项目属性 - + New Project... 新建项目... - - + + New Project File 新建项目文件 - + F1 F1 - + New GAS File 新建GNU汇编文件 - + GNU Assembler Manual GNU汇编器手册 - + x86 Assembly Language Reference Manual X86汇编语言参考手册 - + IA-32 Assembly Language Reference Manual IA32汇编语言参考手册 - + + Add Watchpoint... + 添加变量断点... + + + + Add a watchpoint that's triggered when it's modified. + 添加一个变量断点。当该变量的值被改动时程序暂停。 + + + Move Selection Up 向上移动选中的行 - + Ctrl+Shift+Up Ctrl+Shift+Up - + Move Selection Down 向下移动选中的行 - + Ctrl+Shift+Down Ctrl+Shift+Down - + Convert to UTF-8 BOM 转换为UTF-8 BOM编码 - + Encode in UTF-8 BOM 使用UTF-8 BOM编码 - + Compiler Options... 编译器选项... - + Toggle Explorer Panel 切换管理器面板 - + + Ctrl+F9 Ctrl+F9 - + Toggle Messages Panel 切换消息面板 - + Ctrl+F10 Ctrl+F10 - + Raylib Manual Raylib教程 - + Select Word 选中当前单词 - + Go to Line... 跳转到行... - + New Template... 新建模板... - + New Template from Project 从项目创建模板 - + Goto block start 跳转到代码段开始 - + Ctrl+Alt+Up Ctrl+Alt+Up - + Goto block end 跳转到代码段结束 - + Ctrl+Alt+Down Ctrl+Alt+Down - + Switch header/source 切换头文件/源文件 - + Switch Header/Source 切换头文件/源文件 - + Generate Assembly 生成汇编 - + Trim trailing spaces 删除行尾空格 - + Toggle Readonly 切换只读模式 - + Submit Issues 反馈与建议 - + Document 使用说明 @@ -5337,199 +5348,199 @@ Are you really want to continue? 保存为模板... - + New File 新建文件 - + Add to project... 添加到项目... - + Remove from project 从项目删除 - + View Makefile 查看Makefile - + Clean 清理构建文件 - + Open Folder in Explorer 在浏览器中打开 - + Open In Terminal 在终端中打开 - + About 关于 - - + + Rename Symbol 重命名符号 - + Shift+F6 Shift+F6 - + Print... 打印... - + Ctrl+P Ctrl+P - - + + Export As RTF 导出为RTF - - + + Export As HTML 导出为HTML - + Move To Other View 移动到其他视图 - + Ctrl+M Ctrl+M - - + + C++ Reference C++参考手册 - + C Reference C参考手册 - + Show Tool Panels 显示全部工具面板 - + Create Git Repository Create Repository 创建Git仓库 - + Commit 提交(Commit) - + Revert 撤销(Revert) - + Reset 回滚(Reset) - + Add Files 添加文件 - + Restore 还原(Restore) - + Website 官方网站 - + Branch/Switch 分支切换(Switch) - + Merge 合并(Merge) - - + + Show Log Log 显示日志(Log) - + Remotes... 远程仓库... - + Fetch 取回(Fetch) - + Pull 拉取(Pull) - + Push 推送(Push) - + Hide Non Support Files 隐藏不支持的文件 - + Toggle Block Comment 切换块注释 - + Alt+Shift+A Alt+Shift+A - + Match Bracket 匹配当前括号 - + Ctrl+] Ctrl+] @@ -5538,50 +5549,50 @@ Are you really want to continue? 工具窗口栏 - + Status Bar 状态栏 - + Ctrl+Backspace Ctrl+Backspace - + Interrupt 中断 - - + + Delete To Word Begin 删除到单词开头 - + Ctrl+Shift+B Ctrl+Shift+B - + Delete to Word End 删除到单词结尾 - + Ctrl+Shift+E Ctrl+Shift+E - + New Class... Add Class... 新建类... - - + + New Header... New Header 新建头文件... @@ -5591,47 +5602,47 @@ Are you really want to continue? 插入行 - + Delete Line 删除当前行 - + Ctrl+D Ctrl+D - + Duplicate Line 复制当前行 - + Ctrl+E Ctrl+E - + Delete Word 删除当前单词 - + Ctrl+Shift+D Ctrl+Shift+D - + Delete to EOL 删除到行尾 - + Ctrl+Del Ctrl+Del - + Delete to BOL 删除到行首 @@ -5640,27 +5651,27 @@ Are you really want to continue? C/C++参考 - + EGE Manual EGE图形库手册 - + Add Bookmark 添加书签 - + Remove Bookmark 删除书签 - + Modify Bookmark Description 修改书签说明 - + Locate in Files View 在文件视图中定位 @@ -5669,12 +5680,12 @@ Are you really want to continue? 打开文件夹 - + Running Parameters... 运行参数... - + File Encoding 文件编码 @@ -5684,32 +5695,32 @@ Are you really want to continue? 文件历史 - - - - - - + + + + + + Debugging 正在调试 - - - - - - + + + + + + Running 正在运行 - - - - - - + + + + + + Compiling 正在编译 @@ -5723,17 +5734,17 @@ Are you really want to continue? 行: %1 列: %2 已选择 :%3 总行数: %4 总长度: %5 - + Read Only 只读 - + Insert 插入 - + Overwrite 覆写 @@ -5750,7 +5761,7 @@ Are you really want to continue? 确认 - + Source file is not compiled. 源文件尚未编译。 @@ -5767,44 +5778,44 @@ Are you really want to continue? 重新编译? - - - - + + + + Wrong Compiler Settings 错误的编译器设置 - - - - + + + + Compiler is set not to generate executable. 编译器被设置为不生成可执行文件。 - - + + We need the executabe to run problem case. 我们需要可执行文件来运行试题案例。 - + No compiler set 无编译器设置 - + No compiler set is configured. 没有配置编译器设置。 - + Can't start debugging. 无法启动调试器 - + Enable debugging 启用调试参数 @@ -5821,33 +5832,33 @@ Are you really want to continue? 项目尚未构建。是否构建? - + Host applcation missing 宿主程序不存在 - + DLL project needs a host application to run. 动态链接库(DLL)需要一个宿主程序来运行。 - + But it's missing. 但它不存在。 - + Host application not exists 宿主程序不存在 - + Host application file '%1' doesn't exist. 宿主程序'%1'不存在。 - - + + Please correct this before start debugging 请在调试前改正设置。 @@ -5856,8 +5867,8 @@ Are you really want to continue? 重新编译? - - + + Save last open info error 保存上次打开信息失败 @@ -5866,70 +5877,70 @@ Are you really want to continue? 无法删除旧上次打开信息文件'%1' - + Can't save last open info file '%1' 无法保存上次打开信息文件'%1' - - + + Load last open info error 载入上次打开信息失败 - - + + Can't load last open info file '%1' 无法载入上次打开信息文件'%1' - + Open Source File 打开源代码文件 - - + + Batch Set Cases 批量设置案例 - + Show detail debug logs 显示详细调试器日志 - + Copy all 全部复制 - + Go to Line 跳转到行 - + Line - + Template Exists 模板已存在 - + Template %1 already exists. Do you want to overwrite? 模板%1已存在。是否覆盖? - - - - - - + + + + + + Clear 清除 @@ -5945,7 +5956,7 @@ Are you really want to continue? - + Problem Set %1 试题集%1 @@ -5974,56 +5985,56 @@ Are you really want to continue? 项目已经被修改过,是否需要重新构建? - + Auto Save Error 自动保存出错 - + Auto save "%1" to "%2" failed:%3 自动保存"%1"到"%2"失败:%3 - + Properties... 试题属性... - + Set Problem Set Name 设置试题集名称 - + Problem Set Name: 试题集名称: - + Remove 删除 - + Remove All Bookmarks 删除全部书签 - + Modify Description 修改描述 - - - + + + Bookmark Description 书签描述 - - - + + + Description: 描述: @@ -6032,65 +6043,65 @@ Are you really want to continue? 在调试主控台中显示调试器输出 - + Remove this search 清除这次搜索 - + Clear all searches 删除所有搜索 - + Breakpoint condition... 断点条件... - + Break point condition 断点条件 - + Enter the condition of the breakpoint: 输入当前断点的生效条件: - + Remove All Breakpoints Remove all breakpoints 删除所有断点 - + Remove Breakpoint 删除当前断点 - + Rename File 重命名文件 - - + + Add Folder 添加文件夹 - - + + New folder 新文件夹 - + Folder name: 文件夹: - + Rename Folder 重命名 @@ -6103,226 +6114,251 @@ Are you really want to continue? 要现在去修改设置吗? - + Rename Problem Set 修改试题集名称 - + Can't open last open information file '%1' for write! 无法写入配置文件'%1'。 - + Rename Problem 修改试题名称 - + Line: %1 Col: %2 Lines: %3 行: %1 列: %2 总行数: %3 - + Correct compiler setting 改正编译器设置 - - + + You are using a Debug compiler set with wrong compile/link settings: 您使用的Debug编译器配置集中存在错误的“编译/链接”选项设置: - - + + - "Generate debug info (-g3)" should be turned on - 应勾选"生成调试信息(-g3)"选项 - + - "Strip executable (-s)" should be turned off - 应取消"剥除附加信息(-s)"选项 - - + + Do you want to correct it now? 是否现在去改正? - - + + Can't Debug 无法调试 - - + + Your compiler set's "Strip executable (-s)" options is turnned on 您的编译器配置集中的“剥除附加信息(-s)”选项被勾选了。 - - + + Please correct it, recompile and retry debug. 请取消该设置,重新编译然后重新启动调试。 - + Goto Url 跳转到试题网址 - + Add Problem Case 添加试题案例 - + Run Current Case 运行当前案例 - + Remove Folder 删除文件夹 - + Switch to normal view 切换为普通视图 - + Switch to custom view 切换为自定义视图 - + Sort By Type 按类型排序 - + Sort alphabetically 按名称排序 - + Show inherited members 显示继承的成员 - + Goto declaration 跳转到声明处 - + Goto definition 跳转到定义处 - + In current file 仅当前文件 - + In current project 整个项目 - - + + New Folder 新建文件夹 - + Rename 重命名 - - - - + + + + Delete 删除 - + Open in Editor 在编辑器中打开 - + Open in External Program 使用外部程序打开 - + Open in Terminal 在终端中打开 - + Open in Windows Explorer 在Windows浏览器中打开 - + Character sets 字符集 - + Convert to %1 转换为%1编码 - + Newline 换行符 - + %1 files autosaved 已自动保存%1个文件 - + Set answer to... 设置答案源代码... - + select other file... 选择其他文件... - + Select Answer Source File 选择答案源代码文件 + + + Watchpoint hitted + 变量断点被触发 + + + + Value of "%1" has changed: + "%1"的值发生了变化: + + + + New value: %1 + 新值: %1 + + + + Watchpoint variable name + 被监控的变量 + + + + Stop execution when the following variable is modified (it must be visible from the currect scope): + 当下面的变量被修改时暂停执行(该变量必须可以从当前程序处访问): + Abort 中止 - + FPS Problem Set Files (*.fps;*.xml) FPS试题集文件(*.fps;*.xml) - + FPS Problem Set Files (*.fps) FPS试题集文件(*.fps) - + Export Error 导出时出错 @@ -6332,7 +6368,7 @@ Are you really want to continue? C/C++源代码文件 (*.c *.cpp *.cc *.cxx) - + New Folder %1 新建文件夹%1 @@ -6345,70 +6381,87 @@ Are you really want to continue? 无标题%1 - + Do you really want to delete %1? 你真的要删除%1吗? - + Do you really want to delete %1 files? 你真的要删除%1个文件吗? - + Watchpoint triggered + 变量断点被触发 + + + Watchpoint of "%1" is triggered: + 变量"%1"有改动: + + + + Old value: %1 + 旧值: %1 + + + New value: %2 + 新值: %1 + + + Save project 保存项目 - + The project '%1' has modifications. 项目'%1'有改动。 - - + + Do you want to save it? 需要保存吗? - - + + File Changed 文件已发生变化 - - + + New Project File? 新建项目文件? - - + + Do you want to add the new file to the project? 您是否要将新建的文件加入项目? - - - - + + + + Save Error 保存失败 - + Change Project Compiler Set 改变项目编译器配置集 - + Change the project's compiler set will lose all custom compiler set options. 改变项目的编译器配置集会导致所有的自定义编译器选项被重置。 - - + + Do you really want to do that? 你真的想要那么做吗? @@ -6417,12 +6470,12 @@ Are you really want to continue? 批量设置案例 - + Choose input files 选择输入数据文件 - + Input data files (*.in) 输入数据文件 (*.in) @@ -6431,78 +6484,78 @@ Are you really want to continue? 无标题%1 - + Modify Watch 修改监视表达式 - + Watch Expression 监视表达式 - + Do you really want to clear all breakpoints in this file? 您真的要清除该文件的所有断点吗? - + New project 新建项目 - + Close %1 and start new project? 关闭'%1'以打开新项目? - + Folder not exist 文件夹不存在 - + Folder '%1' doesn't exist. Create it now? 文件夹'%1'不存在。是否创建? - + Can't create folder 无法创建文件夹 - + Failed to create folder '%1'. 创建文件夹'%1'失败。 - + Save new project as - + Folder %1 is not empty. 文件夹%1不是空的。 - + Do you really want to delete it? 你真的要删除它吗? - + Change working folder 改变工作文件夹 - + File '%1' is not in the current working folder. File '%1' is not in the current working folder 文件'%1'不在当前工作文件夹中。 - + Do you want to change working folder to '%1'? 是否将工作文件夹改设为'%1'? @@ -6511,28 +6564,28 @@ Are you really want to continue? 正在删除试题... - + Can't Commit 无法提交 - + Git needs user info to commit. Git需要用信息进行提交。 - + Choose Input Data File 选择输入数据文件 - - + + All files (*.*) 所有文件 (*.*) - + Choose Expected Output Data File Choose Expected Input Data File 选择期望输出文件 @@ -6542,61 +6595,61 @@ Are you really want to continue? 第%1行 - - - + + + Choose Working Folder 选择工作文件夹 - - + + Header Exists 头文件已存在 - - + + Header file "%1" already exists! 头文件"%1"已存在! - + Source Exists 源文件已存在! - + Source file "%1" already exists! 源文件"%1"已存在! - + Can't commit! 无法提交! - + The following files are in conflicting: 下列文件处于冲突状态,请解决后重新添加和提交: - + Commit Message 提交信息 - + Commit Message: 提交信息: - + Commit Failed 提交失败 - + Commit message shouldn't be empty! 提交信息不能为空! @@ -6605,22 +6658,22 @@ Are you really want to continue? 小熊猫Dev-C++项目文件 (*.dev) - + New project fail 新建项目失败 - + Can't assign project template 无法使用模板创建项目 - + Remove file 删除文件 - + Remove the file from disk? 同时从硬盘上删除文件? @@ -6629,27 +6682,27 @@ Are you really want to continue? 无标题 - + New Project File Name 新的项目文件名 - + File Name: 文件名: - + File Already Exists! 文件已存在! - + File '%1' already exists! 文件'%1'已经存在! - + Add to project 添加到项目 @@ -6666,27 +6719,27 @@ Are you really want to continue? 请在工具栏中选择Debug编译器配置集,或者在“编译器配置集”设置的“编译/链接选项”页中<b>启用</b>“生成调试信息(-g3)”、<b>禁用</b>“剥除附件信息(-3)”。 - + C/C++ Source Files (*.c *.cpp *.cc *.cxx) C/C++源代码文件 (*.c *.cpp *.cc *.cxx) - + This operation will remove all cases for the current problem. 本操作会删除此试题的所有案例。 - + Debug Failed 调试失败 - + The executable doesn't have symbol table, and can't be debugged. 可执行文件中没有符号表信息,无法调试。 - + Please turn off your compiler set's "Strip executable (-s)" option, recompile and retry debug. 请在选项对话框的编译器配置集页中取消“剥除附加信息(-s)”选项,重新编译后再调试。 @@ -6707,88 +6760,88 @@ Are you really want to continue? 您也可以删除所有断点,打开“CPU信息窗口”,然后调试汇编代码。 - + Failed to generate the executable. 未能生成可执行文件。 - + Please check detail info in "Tools Output" panel. 请查看“工具输出”面板中的详细信息。 - + Red Panda C++ project file (*.dev) 小熊猫C++项目文件(*.dev) - + Rename Error 重命名出错 - + Symbol '%1' is defined in system header. 符号'%1'在系统头文件中定义,无法修改。 - + New Name 新名称 - - - - + + + + Replace Error 替换出错 - + Can't open file '%1' for replace! 无法打开文件'%1'进行替换! - + Contents has changed since last search! 内容和上次查找时不一致。 - + Rich Text Format Files (*.rtf) RTF格式文件 (*.rtf) - + HTML Files (*.html) HTML文件 (*.html) - + The current problem set is not empty. 当前的试题集不是空的。 - + Problem %1 试题%1 - - + + Problem Set Files (*.pbs) 试题集文件 (*.pbs) - - + + Load Error 载入失败 - - + + Problem Case %1 试题案例%1 @@ -6799,14 +6852,14 @@ Are you really want to continue? - - - - - - - - + + + + + + + + Error 错误 @@ -6816,25 +6869,25 @@ Are you really want to continue? 项目历史 - + Load Theme Error 载入主题失败 - - + + Clear History 清除历史 - - + + The generated executable doesn't have symbol table, and can't be debugged. 编译生成的可执行文件中没有符号表,无法被调试。 - - + + Version Control 版本控制 @@ -6843,84 +6896,107 @@ Are you really want to continue? 请在工具栏中选用Debug编译器配置集,或者在选项对话框的编辑器配置集页中勾选“生成调试信息(-g3)"选项。 - + File '%1' was changed. 磁盘文件'%1'已被修改。 - + Reload its content from disk? 是否重新读取它的内容? - + File '%1' was removed. 磁盘文件'%1'已被删除。 - + Keep it open? 是否保持它在小熊猫C++中打开的编辑窗口? - + Open 打开 - - + + Compile Failed 编译失败 - + Run Failed 运行失败 - - - - + + + + Confirm Convertion 确认转换 - - - - + + + + The editing file will be saved using %1 encoding. <br />This operation can't be reverted. <br />Are you sure to continue? 当前编辑器中的文件将会使用%1编码保存。<br />这项操作无法被撤回。<br />你确定要继续吗? - + New Watch Expression 新监视表达式 - + Enter Watch Expression (it is recommended to use 'this->' for class members): 输入监视表达式 - + Parsing file %1 of %2: "%3" (%1/%2)正在解析文件"%3" - - + + Done parsing %1 files in %2 seconds 完成%1个文件的解析,用时%2秒 - + (%1 files per second) (每秒%1个文件) + + MemoryModel + + + dec: %1 + 十进制: %1 + + + + hex: %1 + 16进制: %1 + + + + bin: %1 + 二进制: %1 + + + + ascii: '%1' + ASCII字符: '%1' + + NewClassDialog @@ -7319,105 +7395,105 @@ Are you really want to continue? 无法保存文件'%1'. - + Error Load File 载入文件错误 - - + + Error 错误 - + Can't create folder %1 无法创建文件夹%1 - + Warning 警告 - - + + Can't save file %1 无法保存文件%1 - + File Exists 文件已存在 - + File '%1' is already in the project 文件'%1'已在项目中 - + Project Updated 项目已升级 - + Your project was succesfully updated to a newer file format! 已成功将项目升级到新的格式 - + If something has gone wrong, we kept a backup-file: '%1'... 旧项目文件备份在'%1'。 - + Headers 头文件 - + Sources 源文件 - + Others 其他文件 - + Settings need update 设置需要更新 - + The compiler settings format of Red Panda C++ has changed. The compiler settings format of Dev-C++ has changed. 小熊猫C++的编译器设置格式已发生改变。 - + Please update your settings at Project >> Project Options >> Compiler and save your project. 请在项目 >> 项目属性 >> 编译器设置中修改您的设置并保存您的项目 - + Compiler not found 未找到编译器 - + The compiler set you have selected for this project, no longer exists. 您为该项目设置的编译器不存在。 - + It will be substituted by the global compiler set. 它将会被全局编译器设置代替。 - + Developed using the Red Panda C++ IDE Developed using the Red Panda Dev-C++ IDE 使用小熊猫C++编辑器开发 @@ -7566,17 +7642,18 @@ Are you really want to continue? 请检查编译器配置中的“程序”页。 - + Processing makefile: 正在处理makefile... - + - makefile processer: %1 - makefile处理器: %1 - + + - Command: %1 %2 - 命令: %1 %2 @@ -7918,32 +7995,32 @@ Are you really want to continue? ProjectModel - + File exists 文件已存在 - + File '%1' already exists. Delete it now? 文件'%1'已存在。是否删除? - + Remove failed 删除失败 - + Failed to remove file '%1' 无法删除文件'%1' - + Rename failed 改名失败 - + Failed to rename file '%1' to '%2' 无法将文件'%1'改名为'%2' @@ -8200,14 +8277,14 @@ Are you really want to continue? QObject - - + + Save 保存 - - + + Save changes to %1? 将修改保存到"%1"? @@ -8385,7 +8462,7 @@ Are you really want to continue? 生成调试信息(-g3) - + Would you like Red Panda C++ to search for compilers in PATH? 您同意小熊猫C++在PATH路径中寻找gcc编译器吗? @@ -8498,7 +8575,7 @@ Are you really want to continue? 只生成汇编代码(-S) - + Confirm 确认 @@ -8519,13 +8596,13 @@ Are you really want to continue? 如果仍然保留这些设置,可能会导致编译错误。<br /><br />请选择“是”,除非您清楚的知道选择“否”的后果, - - + + Compiler set not configuared. 未配置编译器设置。 - + Would you like Red Panda C++ to search for compilers in the following locations: <BR />'%1'<BR />'%2'? 您需要小熊猫C++在下列位置搜索编译器吗:<br />%1<br />%2 @@ -8905,7 +8982,7 @@ Are you really want to continue? - + Can't open file '%1' for write. 无法写入文件'%1'. @@ -8944,84 +9021,9 @@ Are you really want to continue? RegisterModel - - - - - - - - - - - - - - - - - - - - - - - - - - 64-bit - 64位 - - - Accumulator - 累加器 - - - - - - - - - - - - - - - - - - - General purpose - 通用 - - - Instruction Pointer - 指令 - - - - - - - - - - - - - - - - - - 32-bit - 32位 - - + @@ -9036,13 +9038,47 @@ Are you really want to continue? - - - - lower 16 bits of %1 - %1的低16位 + + + + + + + + + 64-bit + 64位 + Accumulator + 累加器 + + + + + + + + + + + + + + + + + + + General purpose + 通用 + + + Instruction Pointer + 指令 + + + @@ -9059,24 +9095,65 @@ Are you really want to continue? - lower 8 bits of %1 - %1的低8位 + 32-bit + 32位 - 8 high bits of lower 16 bits of %1 - %1的低16位数据中的高8位 - - + + + + + + + + lower 16 bits of %1 + %1的低16位 + + + + + + + + + + + + + + + + + + + lower 8 bits of %1 + %1的低8位 + + + + + + + 8 high bits of lower 16 bits of %1 + %1的低16位数据中的高8位 + + + + + + + + 16-bit 16位 @@ -9088,15 +9165,113 @@ Are you really want to continue? Media 媒体 + + + + + + + + + + + + + + + + + 128-bit + 128位 + + + + Floating-point control + 浮点运算控制 + + + + + Accumulator for operands and results data + 操作数和结果的累加器 + + + + + Pointer to data in the DS segment + 指向DS段中数据的指针 + + + + + Counter for string and loop operations + 字符串和循环操作计数器 + + + + + I/O pointer + I/O指针 + + + + + Source index for string operations; Pointer to data in the segment pointed to by the DS register + 字符串操作来源下标;指向DS段中数据的指针 + + + + + Destination index for string operations; Pointer to data (or destination) in the segment pointed to by the ES register + 字符串操作目的下标;指向ES段中数据(或目标)的指针 + + + + + Stack pointer (in the SS segment) + 栈指针(在SS段中) + + + + + Pointer to data on the stack (in the SS segment) + 指向(SS段中)栈内数据的指针 + + + + + Instruction pointer + 指令指针 + + + + + Flags + 标志 + + Code segment selector + 代码段选择器 + + + Data segment selector + 数据段选择器 + + + Extra data segment selector + 额外的数据段选择器 + + - - + Stack segment selector + 栈段选择器 + + @@ -9104,155 +9279,57 @@ Are you really want to continue? - 128-bit - 128位 - - - - Floating-point control - 浮点运算控制 - - - - - Accumulator for operands and results data - 操作数和结果的累加器 - - - - - Pointer to data in the DS segment - 指向DS段中数据的指针 - - - - - Counter for string and loop operations - 字符串和循环操作计数器 - - - - - I/O pointer - I/O指针 - - - - - Source index for string operations; Pointer to data in the segment pointed to by the DS register - 字符串操作来源下标;指向DS段中数据的指针 - - - - - Destination index for string operations; Pointer to data (or destination) in the segment pointed to by the ES register - 字符串操作目的下标;指向ES段中数据(或目标)的指针 - - - - - Stack pointer (in the SS segment) - 栈指针(在SS段中) - - - - - Pointer to data on the stack (in the SS segment) - 指向(SS段中)栈内数据的指针 - - - - - Instruction pointer - 指令指针 - - - - - Flags - 标志 - - - - Code segment selector - 代码段选择器 - - - - Data segment selector - 数据段选择器 - - - - - - Extra data segment selector - 额外的数据段选择器 - - - - Stack segment selector - 栈段选择器 - - - - - - - - - - + Floating-point data 浮点运算数据 - + Floating-point status 浮点运算状态 - + Floating-point tag word 浮点运算标签word - + Floating-point operation 浮点运算操作 - + Floating-point last instruction segment 浮点运算上次指令段 - + Floating-point last instruction offset 浮点运算上次指令位移 - + Floating-point last operand segment 浮点运算上次操作数段 - + Floating-point last operand offset 浮点运算上次操作数位移 - + SSE status and control SSE状态和控制 - + Register 寄存器 - + Value @@ -9913,18 +9990,18 @@ Are you really want to continue? 性能 - - - + + + Compiler Set 编译器配置集 - - - + + + Compiler @@ -9936,7 +10013,7 @@ Are you really want to continue? 自动链接 - + @@ -10012,15 +10089,15 @@ Are you really want to continue? 杂项 - - + + Program Runner 程序运行 - + Problem Set 试题集 @@ -10554,14 +10631,14 @@ Are you really want to continue? JSON文件'%1':%2中存在错误:%3 - - + + Execute to evaluate 执行以求值 - - + + Not Valid 在当前作用域中无效 @@ -10570,17 +10647,17 @@ Are you really want to continue? 无法读取文件'%1'. - + Expression 表达式 - + Type 类型 - + Value diff --git a/RedPandaIDE/translations/RedPandaIDE_zh_TW.ts b/RedPandaIDE/translations/RedPandaIDE_zh_TW.ts index 0a3a45ec..ced2466f 100644 --- a/RedPandaIDE/translations/RedPandaIDE_zh_TW.ts +++ b/RedPandaIDE/translations/RedPandaIDE_zh_TW.ts @@ -4832,6 +4832,57 @@ IA-32 Assembly Language Reference Manual + + Add Watchpoint... + + + + Add a watchpoint that's triggered when it's modified. + + + + Old value: %1 + + + + Watchpoint variable name + + + + Stop execution when the following variable is modified (it must be visible from the currect scope): + + + + Watchpoint hitted + + + + Value of "%1" has changed: + + + + New value: %1 + + + + + MemoryModel + + dec: %1 + + + + hex: %1 + + + + bin: %1 + + + + ascii: '%1' + + NewClassDialog diff --git a/RedPandaIDE/widgets/cpudialog.cpp b/RedPandaIDE/widgets/cpudialog.cpp index 62079ca2..8c9636b8 100644 --- a/RedPandaIDE/widgets/cpudialog.cpp +++ b/RedPandaIDE/widgets/cpudialog.cpp @@ -27,7 +27,8 @@ CPUDialog::CPUDialog(QWidget *parent) : QDialog(parent), ui(new Ui::CPUDialog), - mInited(false) + mInited(false), + mSetting(false) { setWindowFlags(windowFlags() | Qt::WindowMinimizeButtonHint | Qt::WindowMaximizeButtonHint); setWindowFlag(Qt::WindowContextHelpButtonHint,false); @@ -84,6 +85,7 @@ CPUDialog::~CPUDialog() void CPUDialog::updateInfo() { if (pMainWindow->debugger()->executing()) { + pMainWindow->debugger()->sendCommand("-stack-info-frame", ""); // Load the registers.. sendSyntaxCommand(); pMainWindow->debugger()->sendCommand("-data-list-register-values", "N"); @@ -114,9 +116,17 @@ void CPUDialog::updateDPI(float dpi) onUpdateIcons(); } -void CPUDialog::setDisassembly(const QString& file, const QString& funcName,const QStringList& lines) +void CPUDialog::setDisassembly(const QString& file, const QString& funcName,const QStringList& lines,const QList& traces) { - ui->txtFunctionName->setText(QString("%1:%2").arg(file, funcName)); + mSetting=true; + ui->cbCallStack->clear(); + int currentIndex=-1; + for (int i=0;icbCallStack->addItem(QString("%1:%2").arg(traces[i]->filename, traces[i]->funcname)); + if (file==traces[i]->filename && funcName == traces[i]->funcname) + currentIndex=i; + } + ui->cbCallStack->setCurrentIndex(currentIndex); int activeLine = -1; for (int i=0;itxtCode->document()->setContents(lines); if (activeLine!=-1) ui->txtCode->setCaretXYCentered(QSynedit::BufferCoord{1,activeLine+1}); + mSetting=false; } void CPUDialog::resetEditorFont(float dpi) @@ -216,3 +227,11 @@ void CPUDialog::showEvent(QShowEvent *event) } } + +void CPUDialog::on_cbCallStack_currentIndexChanged(int index) +{ + if (mSetting) + return ; + pMainWindow->switchCurrentStackTrace(index); +} + diff --git a/RedPandaIDE/widgets/cpudialog.h b/RedPandaIDE/widgets/cpudialog.h index f0885401..7bfb35d3 100644 --- a/RedPandaIDE/widgets/cpudialog.h +++ b/RedPandaIDE/widgets/cpudialog.h @@ -18,6 +18,7 @@ #define CPUDIALOG_H #include +#include "../debugger.h" namespace Ui { class CPUDialog; @@ -34,7 +35,7 @@ public: void updateButtonStates(bool enable); public slots: void updateDPI(float dpi); - void setDisassembly(const QString& file, const QString& funcName,const QStringList& lines); + void setDisassembly(const QString& file, const QString& funcName,const QStringList& linesconst,const QList& traces); void resetEditorFont(float dpi); signals: void closed(); @@ -43,6 +44,7 @@ private: private: Ui::CPUDialog *ui; bool mInited; + bool mSetting; // QWidget interface protected: void closeEvent(QCloseEvent *event) override; @@ -55,6 +57,8 @@ private slots: void onUpdateIcons(); // QWidget interface + void on_cbCallStack_currentIndexChanged(int index); + protected: void showEvent(QShowEvent *event) override; }; diff --git a/RedPandaIDE/widgets/cpudialog.ui b/RedPandaIDE/widgets/cpudialog.ui index f760cee6..27bfa6f0 100644 --- a/RedPandaIDE/widgets/cpudialog.ui +++ b/RedPandaIDE/widgets/cpudialog.ui @@ -74,7 +74,17 @@ - + + + + 0 + 0 + + + + QComboBox::NoInsert + +