/* * Copyright (C) 2020-2022 Roy Qu (royqh1979@gmail.com) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "settings.h" #include #include #include #include "utils.h" #include "utils/escape.h" #include "utils/font.h" #include "utils/parsearg.h" #include #include "systemconsts.h" #include #include #include #include #include #include #include #include #include #ifdef Q_OS_LINUX #include #endif #ifdef ENABLE_LUA_ADDON # include "addon/executor.h" # include "addon/runtime.h" #endif const char ValueToChar[28] = {'0', '1', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'}; Settings* pSettings; Settings::Settings(const QString &filename): mFilename(filename), mSettings(filename,QSettings::IniFormat), mDirs(this), mEditor(this), mEnvironment(this), mCompilerSets(this), mExecutor(this), mDebugger(this), mCodeCompletion(this), mCodeFormatter(this), mUI(this), #ifdef ENABLE_VCS mVCS(this), #endif mLanguages(this) { //load(); } Settings::~Settings() { //mEditor.save(); } void Settings::beginGroup(const QString &group) { mSettings.beginGroup(group); } void Settings::endGroup() { mSettings.endGroup(); } void Settings::remove(const QString &key) { mSettings.remove(key); } void Settings::saveValue(const QString& group, const QString &key, const QVariant &value) { mSettings.beginGroup(group); auto act = finally([this] { this->mSettings.endGroup(); }); mSettings.setValue(key,value); } void Settings::saveValue(const QString &key, const QVariant &value) { mSettings.setValue(key,value); } QVariant Settings::value(const QString &group, const QString &key, const QVariant &defaultValue) { mSettings.beginGroup(group); auto act = finally([this] { this->mSettings.endGroup(); }); return mSettings.value(key,defaultValue); } QVariant Settings::value(const QString &key, const QVariant &defaultValue) { return mSettings.value(key,defaultValue); } void Settings::load() { mCompilerSets.loadSets(); mEnvironment.load(); mEditor.load(); mExecutor.load(); mDebugger.load(); mCodeCompletion.load(); mCodeFormatter.load(); mUI.load(); mDirs.load(); #ifdef ENABLE_VCS mVCS.load(); #endif mLanguages.load(); } QSettings::Status Settings::sync() { mSettings.sync(); return mSettings.status(); } Settings::Dirs &Settings::dirs() { return mDirs; } Settings::Editor &Settings::editor() { return mEditor; } Settings::CompilerSets &Settings::compilerSets() { return mCompilerSets; } Settings::Environment &Settings::environment() { return mEnvironment; } Settings::Executor &Settings::executor() { return mExecutor; } QString Settings::filename() const { return mFilename; } Settings::Languages &Settings::languages() { return mLanguages; } Settings::CodeCompletion& Settings::codeCompletion() { return mCodeCompletion; } Settings::CodeFormatter &Settings::codeFormatter() { return mCodeFormatter; } Settings::UI &Settings::ui() { return mUI; } #ifdef ENABLE_VCS Settings::VCS &Settings::vcs() { return mVCS; } #endif Settings::Debugger& Settings::debugger() { return mDebugger; } Settings::Dirs::Dirs(Settings *settings): _Base(settings, SETTING_DIRS) { } QString Settings::Dirs::appDir() const { return QApplication::instance()->applicationDirPath(); } QString Settings::Dirs::appResourceDir() const { #ifdef Q_OS_WIN return appDir(); #elif defined(Q_OS_MACOS) // return QApplication::instance()->applicationDirPath(); return ""; #else // XDG desktop // in AppImage or tarball PREFIX is not true, resolve from relative path const static QString absoluteResourceDir(QDir(appDir()).absoluteFilePath("../share/" APP_NAME)); return absoluteResourceDir; #endif } QString Settings::Dirs::appLibexecDir() const { #ifdef Q_OS_WIN return appDir(); #elif defined(Q_OS_MACOS) return QApplication::instance()->applicationDirPath(); #else // XDG desktop // in AppImage or tarball LIBEXECDIR is not true, resolve from relative path const static QString relativeLibExecDir(QDir(PREFIX "/bin").relativeFilePath(LIBEXECDIR "/" APP_NAME)); const static QString absoluteLibExecDir(QDir(appDir()).absoluteFilePath(relativeLibExecDir)); return absoluteLibExecDir; #endif } QString Settings::Dirs::projectDir() const { return mProjectDir; } QString Settings::Dirs::data(Settings::Dirs::DataType dataType) const { using DataType = Settings::Dirs::DataType; QString dataDir = includeTrailingPathDelimiter(appDir())+"data"; switch (dataType) { case DataType::None: return dataDir; case DataType::ColorScheme: return ":/colorschemes"; case DataType::IconSet: return ":/resources/iconsets"; case DataType::Theme: return ":/themes"; case DataType::Template: return includeTrailingPathDelimiter(appResourceDir()) + "templates"; } return ""; } QString Settings::Dirs::config(Settings::Dirs::DataType dataType) const { using DataType = Settings::Dirs::DataType; QFileInfo configFile(pSettings->filename()); QString configDir = configFile.path(); switch (dataType) { case DataType::None: return configDir; case DataType::ColorScheme: return includeTrailingPathDelimiter(configDir)+"scheme"; case DataType::IconSet: return includeTrailingPathDelimiter(configDir)+"iconsets"; case DataType::Theme: return includeTrailingPathDelimiter(configDir)+"themes"; case DataType::Template: return includeTrailingPathDelimiter(configDir) + "templates"; } return ""; } QString Settings::Dirs::executable() const { QString s = QApplication::instance()->applicationFilePath(); s.replace("/",QDir::separator()); return s; } void Settings::Dirs::doSave() { saveValue("projectDir",mProjectDir); } void Settings::Dirs::doLoad() { QString defaultProjectDir; if (isGreenEdition()) { defaultProjectDir = includeTrailingPathDelimiter(appDir()) + "projects"; } else { defaultProjectDir = includeTrailingPathDelimiter(QStandardPaths::standardLocations(QStandardPaths::DocumentsLocation)[0]) + "projects"; } mProjectDir = stringValue("projectDir",defaultProjectDir); } void Settings::Dirs::setProjectDir(const QString &newProjectDir) { mProjectDir = newProjectDir; } Settings::_Base::_Base(Settings *settings, const QString &groupName): mSettings(settings), mGroup(groupName) { } void Settings::_Base::beginGroup() { mSettings->beginGroup(mGroup); } void Settings::_Base::endGroup() { mSettings->endGroup(); } void Settings::_Base::remove(const QString &key) { mSettings->remove(key); } void Settings::_Base::saveValue(const QString &key, const QVariant &value) { mSettings->saveValue(key,value); } void Settings::_Base::saveValue(const QString &key, const QSet &set) { QStringList val; foreach(const QString& s,set) { val.append(s); } mSettings->saveValue(key,val); } QVariant Settings::_Base::value(const QString &key, const QVariant &defaultValue) { return mSettings->value(key,defaultValue); } bool Settings::_Base::boolValue(const QString &key, bool defaultValue) { return value(key,defaultValue).toBool(); } QSize Settings::_Base::sizeValue(const QString &key, const QSize& size) { return value(key,size).toSize(); } int Settings::_Base::intValue(const QString &key, int defaultValue) { return value(key,defaultValue).toInt(); } double Settings::_Base::doubleValue(const QString &key, double defaultValue) { return value(key,defaultValue).toDouble(); } unsigned int Settings::_Base::uintValue(const QString &key, unsigned int defaultValue) { return value(key,defaultValue).toUInt(); } QStringList Settings::_Base::stringListValue(const QString &key, const QStringList &defaultValue) { return value(key,defaultValue).toStringList(); } QSet Settings::_Base::stringSetValue(const QString &key) { QStringList lst=value(key,QStringList()).toStringList(); QSet result; foreach(const QString& s, lst) result.insert(s); return result; } QColor Settings::_Base::colorValue(const QString &key, const QColor& defaultValue) { return value(key,defaultValue).value(); } QString Settings::_Base::stringValue(const QString &key, const QString& defaultValue) { return value(key,defaultValue).toString(); } void Settings::_Base::save() { beginGroup(); doSave(); endGroup(); } void Settings::_Base::load() { beginGroup(); doLoad(); endGroup(); } Settings::Editor::Editor(Settings *settings): _Base(settings, SETTING_EDITOR) { } QByteArray Settings::Editor::defaultEncoding() { return mDefaultEncoding; } void Settings::Editor::setDefaultEncoding(const QByteArray &value) { mDefaultEncoding = value; } bool Settings::Editor::autoIndent() { return mAutoIndent; } void Settings::Editor::setAutoIndent(bool value) { mAutoIndent = value; } QColor Settings::Editor::caretColor() const { return mCaretColor; } void Settings::Editor::setCaretColor(const QColor &caretColor) { mCaretColor = caretColor; } bool Settings::Editor::keepCaretX() const { return mKeepCaretX; } void Settings::Editor::setKeepCaretX(bool keepCaretX) { mKeepCaretX = keepCaretX; } bool Settings::Editor::halfPageScroll() const { return mHalfPageScroll; } void Settings::Editor::setHalfPageScroll(bool halfPageScroll) { mHalfPageScroll = halfPageScroll; } bool Settings::Editor::gutterFontOnlyMonospaced() const { return mGutterFontOnlyMonospaced; } void Settings::Editor::setGutterFontOnlyMonospaced(bool gutterFontOnlyMonospaced) { mGutterFontOnlyMonospaced = gutterFontOnlyMonospaced; } int Settings::Editor::gutterRightOffset() const { return mGutterRightOffset; } void Settings::Editor::setGutterRightOffset(int gutterRightOffset) { mGutterRightOffset = gutterRightOffset; } int Settings::Editor::copyWithFormatAs() const { return mCopyWithFormatAs; } void Settings::Editor::setCopyWithFormatAs(int copyWithFormatAs) { mCopyWithFormatAs = copyWithFormatAs; } QString Settings::Editor::colorScheme() const { return mColorScheme; } void Settings::Editor::setColorScheme(const QString &colorScheme) { mColorScheme = colorScheme; } bool Settings::Editor::removeSymbolPairs() const { return mRemoveSymbolPairs; } void Settings::Editor::setRemoveSymbolPairs(bool value) { mRemoveSymbolPairs = value; } bool Settings::Editor::syntaxCheckWhenLineChanged() const { return mSyntaxCheckWhenLineChanged; } void Settings::Editor::setSyntaxCheckWhenLineChanged(bool syntaxCheckWhenLineChanged) { mSyntaxCheckWhenLineChanged = syntaxCheckWhenLineChanged; } bool Settings::Editor::readOnlySytemHeader() const { return mReadOnlySytemHeader; } void Settings::Editor::setReadOnlySytemHeader(bool newReadOnlySytemHeader) { mReadOnlySytemHeader = newReadOnlySytemHeader; } bool Settings::Editor::defaultFileCpp() const { return mDefaultFileCpp; } void Settings::Editor::setDefaultFileCpp(bool newDefaultFileCpp) { mDefaultFileCpp = newDefaultFileCpp; } bool Settings::Editor::enableAutoSave() const { return mEnableAutoSave; } void Settings::Editor::setEnableAutoSave(bool newEnableAutoSave) { mEnableAutoSave = newEnableAutoSave; } int Settings::Editor::autoSaveInterval() const { return mAutoSaveInterval; } void Settings::Editor::setAutoSaveInterval(int newInterval) { mAutoSaveInterval = newInterval; } AutoSaveStrategy Settings::Editor::autoSaveStrategy() const { return mAutoSaveStrategy; } void Settings::Editor::setAutoSaveStrategy(AutoSaveStrategy newAutoSaveStrategy) { mAutoSaveStrategy = newAutoSaveStrategy; } bool Settings::Editor::enableAutolink() const { return mEnableAutolink; } void Settings::Editor::setEnableAutolink(bool newEnableAutolink) { mEnableAutolink = newEnableAutolink; } const QColor &Settings::Editor::rightEdgeLineColor() const { return mRightEdgeLineColor; } void Settings::Editor::setRightEdgeLineColor(const QColor &newRightMarginLineColor) { mRightEdgeLineColor = newRightMarginLineColor; } bool Settings::Editor::caretUseTextColor() const { return mCaretUseTextColor; } void Settings::Editor::setCaretUseTextColor(bool newUseIdentifierColor) { mCaretUseTextColor = newUseIdentifierColor; } bool Settings::Editor::rainbowParenthesis() const { return mRainbowParenthesis; } void Settings::Editor::setRainbowParenthesis(bool newRainbowParenthesis) { mRainbowParenthesis = newRainbowParenthesis; } bool Settings::Editor::showFunctionTips() const { return mShowFunctionTips; } void Settings::Editor::setShowFunctionTips(bool newShowFunctionTips) { mShowFunctionTips = newShowFunctionTips; } bool Settings::Editor::fillIndents() const { return mfillIndents; } void Settings::Editor::setFillIndents(bool newFillIndents) { mfillIndents = newFillIndents; } int Settings::Editor::mouseWheelScrollSpeed() const { return mMouseWheelScrollSpeed; } void Settings::Editor::setMouseWheelScrollSpeed(int newMouseWheelScrollSpeed) { mMouseWheelScrollSpeed = newMouseWheelScrollSpeed; } bool Settings::Editor::highlightMathingBraces() const { return mHighlightMathingBraces; } void Settings::Editor::setHighlightMathingBraces(bool newHighlightMathingBraces) { mHighlightMathingBraces = newHighlightMathingBraces; } bool Settings::Editor::enableLigaturesSupport() const { return mEnableLigaturesSupport; } void Settings::Editor::setEnableLigaturesSupport(bool newEnableLigaturesSupport) { mEnableLigaturesSupport = newEnableLigaturesSupport; } QStringList Settings::Editor::fontFamilies() const { return mFontFamilies; } void Settings::Editor::setFontFamilies(const QStringList &newFontFamilies) { mFontFamilies = newFontFamilies; } QStringList Settings::Editor::fontFamiliesWithControlFont() const { return mFontFamilies + QStringList{"Red Panda Control"}; } int Settings::Editor::mouseSelectionScrollSpeed() const { return mMouseSelectionScrollSpeed; } void Settings::Editor::setMouseSelectionScrollSpeed(int newMouseSelectionScrollSpeed) { mMouseSelectionScrollSpeed = newMouseSelectionScrollSpeed; } bool Settings::Editor::autoDetectFileEncoding() const { return mAutoDetectFileEncoding; } void Settings::Editor::setAutoDetectFileEncoding(bool newAutoDetectFileEncoding) { mAutoDetectFileEncoding = newAutoDetectFileEncoding; } int Settings::Editor::undoLimit() const { return mUndoLimit; } void Settings::Editor::setUndoLimit(int newUndoLimit) { mUndoLimit = newUndoLimit; } int Settings::Editor::undoMemoryUsage() const { return mUndoMemoryUsage; } void Settings::Editor::setUndoMemoryUsage(int newUndoMemoryUsage) { mUndoMemoryUsage = newUndoMemoryUsage; } bool Settings::Editor::autoFormatWhenSaved() const { return mAutoFormatWhenSaved; } void Settings::Editor::setAutoFormatWhenSaved(bool newAutoFormatWhenSaved) { mAutoFormatWhenSaved = newAutoFormatWhenSaved; } bool Settings::Editor::parseTodos() const { return mParseTodos; } void Settings::Editor::setParseTodos(bool newParseTodos) { mParseTodos = newParseTodos; } const QStringList &Settings::Editor::customCTypeKeywords() const { return mCustomCTypeKeywords; } void Settings::Editor::setCustomCTypeKeywords(const QStringList &newCustomTypeKeywords) { mCustomCTypeKeywords = newCustomTypeKeywords; } bool Settings::Editor::enableCustomCTypeKeywords() const { return mEnableCustomCTypeKeywords; } void Settings::Editor::setEnableCustomCTypeKeywords(bool newEnableCustomCTypeKeywords) { mEnableCustomCTypeKeywords = newEnableCustomCTypeKeywords; } bool Settings::Editor::removeTrailingSpacesWhenSaved() const { return mRemoveTrailingSpacesWhenSaved; } void Settings::Editor::setRemoveTrailingSpacesWhenSaved(bool newRemoveTrailingSpacesWhenSaved) { mRemoveTrailingSpacesWhenSaved = newRemoveTrailingSpacesWhenSaved; } double Settings::Editor::lineSpacing() const { return mLineSpacing; } void Settings::Editor::setLineSpacing(double newLineSpacing) { mLineSpacing = newLineSpacing; } bool Settings::Editor::showLeadingSpaces() const { return mShowLeadingSpaces; } void Settings::Editor::setShowLeadingSpaces(bool newShowStartSpaces) { mShowLeadingSpaces = newShowStartSpaces; } bool Settings::Editor::enableEditTempBackup() const { return mEnableEditTempBackup; } void Settings::Editor::setEnableEditTempBackup(bool newEnableEditTempBackup) { mEnableEditTempBackup = newEnableEditTempBackup; } int Settings::Editor::tipsDelay() const { return mTipsDelay; } void Settings::Editor::setTipsDelay(int newTipsDelay) { mTipsDelay = newTipsDelay; } bool Settings::Editor::forceFixedFontWidth() const { return mForceFixedFontWidth; } void Settings::Editor::setForceFixedFontWidth(bool newForceFixedWidth) { mForceFixedFontWidth = newForceFixedWidth; } bool Settings::Editor::showTrailingSpaces() const { return mShowTrailingSpaces; } void Settings::Editor::setShowTrailingSpaces(bool newShowEndSpaces) { mShowTrailingSpaces = newShowEndSpaces; } bool Settings::Editor::showInnerSpaces() const { return mShowInnerSpaces; } void Settings::Editor::setShowInnerSpaces(bool newShowMiddleSpaces) { mShowInnerSpaces = newShowMiddleSpaces; } bool Settings::Editor::showLineBreaks() const { return mShowLineBreaks; } void Settings::Editor::setShowLineBreaks(bool newShowLineBreaks) { mShowLineBreaks = newShowLineBreaks; } bool Settings::Editor::highlightCurrentWord() const { return mHighlightCurrentWord; } void Settings::Editor::setHighlightCurrentWord(bool newHighlightCurrentWord) { mHighlightCurrentWord = newHighlightCurrentWord; } bool Settings::Editor::enableTooltips() const { return mEnableTooltips; } void Settings::Editor::setEnableTooltips(bool newEnableTooltips) { mEnableTooltips = newEnableTooltips; } bool Settings::Editor::enableDebugTooltips() const { return mEnableDebugTooltips; } void Settings::Editor::setEnableDebugTooltips(bool newEnableDebugTooltips) { mEnableDebugTooltips = newEnableDebugTooltips; } bool Settings::Editor::enableIdentifierToolTips() const { return mEnableIdentifierToolTips; } void Settings::Editor::setEnableIdentifierToolTips(bool newEnableIdentifierToolTips) { mEnableIdentifierToolTips = newEnableIdentifierToolTips; } bool Settings::Editor::enableHeaderToolTips() const { return mEnableHeaderToolTips; } void Settings::Editor::setEnableHeaderToolTips(bool newEnableHeaderToolTips) { mEnableHeaderToolTips = newEnableHeaderToolTips; } bool Settings::Editor::enableIssueToolTips() const { return mEnableIssueToolTips; } void Settings::Editor::setEnableIssueToolTips(bool newEnableIssueToolTips) { mEnableIssueToolTips = newEnableIssueToolTips; } int Settings::Editor::rightEdgeWidth() const { return mRightEdgeWidth; } void Settings::Editor::setRightEdgeWidth(int newRightMarginWidth) { mRightEdgeWidth = newRightMarginWidth; } bool Settings::Editor::showRightEdgeLine() const { return mShowRightEdgeLine; } void Settings::Editor::setShowRightEdgeLine(bool newShowRightMarginLine) { mShowRightEdgeLine = newShowRightMarginLine; } AutoSaveTarget Settings::Editor::autoSaveTarget() const { return mAutoSaveTarget; } void Settings::Editor::setAutoSaveTarget(AutoSaveTarget newAutoSaveTarget) { mAutoSaveTarget = newAutoSaveTarget; } bool Settings::Editor::autoLoadLastFiles() const { return mAutoLoadLastFiles; } void Settings::Editor::setAutoLoadLastFiles(bool newAutoLoadLastFiles) { mAutoLoadLastFiles = newAutoLoadLastFiles; } bool Settings::Editor::syntaxCheckWhenSave() const { return mSyntaxCheckWhenSave; } void Settings::Editor::setSyntaxCheckWhenSave(bool syntaxCheckWhenSave) { mSyntaxCheckWhenSave = syntaxCheckWhenSave; } bool Settings::Editor::syntaxCheck() const { return mSyntaxCheck; } void Settings::Editor::setSyntaxCheck(bool syntaxCheck) { mSyntaxCheck = syntaxCheck; } bool Settings::Editor::overwriteSymbols() const { return mOverwriteSymbols; } void Settings::Editor::setOverwriteSymbols(bool overwriteSymbols) { mOverwriteSymbols = overwriteSymbols; } bool Settings::Editor::completeGlobalInclude() const { return mCompleteGlobalInclude; } void Settings::Editor::setCompleteGlobalInclude(bool completeGlobalInclude) { mCompleteGlobalInclude = completeGlobalInclude; } bool Settings::Editor::completeDoubleQuote() const { return mCompleteDoubleQuote; } void Settings::Editor::setCompleteDoubleQuote(bool completeDoubleQuote) { mCompleteDoubleQuote = completeDoubleQuote; } bool Settings::Editor::completeSingleQuote() const { return mCompleteSingleQuote; } void Settings::Editor::setCompleteSingleQuote(bool completeSingleQuote) { mCompleteSingleQuote = completeSingleQuote; } bool Settings::Editor::completeComment() const { return mCompleteComment; } void Settings::Editor::setCompleteComment(bool completeComment) { mCompleteComment = completeComment; } bool Settings::Editor::completeBrace() const { return mCompleteBrace; } void Settings::Editor::setCompleteBrace(bool completeBrace) { mCompleteBrace = completeBrace; } bool Settings::Editor::completeBracket() const { return mCompleteBracket; } void Settings::Editor::setCompleteBracket(bool completeBracket) { mCompleteBracket = completeBracket; } bool Settings::Editor::completeParenthese() const { return mCompleteParenthese; } void Settings::Editor::setCompleteParenthese(bool completeParenthese) { mCompleteParenthese = completeParenthese; } bool Settings::Editor::completeSymbols() const { return mCompleteSymbols; } void Settings::Editor::setCompleteSymbols(bool completeSymbols) { mCompleteSymbols = completeSymbols; } QString Settings::Editor::copyHTMLColorScheme() const { return mCopyHTMLColorScheme; } void Settings::Editor::setCopyHTMLColorScheme(const QString ©HTMLColorScheme) { mCopyHTMLColorScheme = copyHTMLColorScheme; } bool Settings::Editor::copyHTMLUseEditorColor() const { return mCopyHTMLUseEditorColor; } void Settings::Editor::setCopyHTMLUseEditorColor(bool copyHTMLUseEditorColor) { mCopyHTMLUseEditorColor = copyHTMLUseEditorColor; } bool Settings::Editor::copyHTMLUseBackground() const { return mCopyHTMLUseBackground; } void Settings::Editor::setCopyHTMLUseBackground(bool copyHTMLUseBackground) { mCopyHTMLUseBackground = copyHTMLUseBackground; } QString Settings::Editor::copyRTFColorScheme() const { return mCopyRTFColorScheme; } void Settings::Editor::setCopyRTFColorScheme(const QString ©RTFColorScheme) { mCopyRTFColorScheme = copyRTFColorScheme; } bool Settings::Editor::copyRTFUseEditorColor() const { return mCopyRTFUseEditorColor; } void Settings::Editor::setCopyRTFUseEditorColor(bool copyRTFUseEditorColor) { mCopyRTFUseEditorColor = copyRTFUseEditorColor; } bool Settings::Editor::copyRTFUseBackground() const { return mCopyRTFUseBackground; } void Settings::Editor::setCopyRTFUseBackground(bool copyRTFUseBackground) { mCopyRTFUseBackground = copyRTFUseBackground; } int Settings::Editor::copyLineLimits() const { return mCopyLineLimits; } void Settings::Editor::setCopyLineLimits(int copyLineLimits) { mCopyLineLimits = copyLineLimits; } int Settings::Editor::copyCharLimits() const { return mCopyCharLimits; } void Settings::Editor::setCopyCharLimits(int copyCharLimits) { mCopyCharLimits = copyCharLimits; } bool Settings::Editor::copySizeLimit() const { return mCopySizeLimit; } void Settings::Editor::setCopySizeLimit(bool copyLimit) { mCopySizeLimit = copyLimit; } int Settings::Editor::gutterLeftOffset() const { return mGutterLeftOffset; } void Settings::Editor::setGutterLeftOffset(int gutterLeftOffset) { mGutterLeftOffset = gutterLeftOffset; } int Settings::Editor::gutterFontSize() const { return mGutterFontSize; } void Settings::Editor::setGutterFontSize(int gutterFontSize) { mGutterFontSize = gutterFontSize; } QString Settings::Editor::gutterFontName() const { return mGutterFontName; } void Settings::Editor::setGutterFontName(const QString &gutterFontName) { mGutterFontName = gutterFontName; } bool Settings::Editor::gutterUseCustomFont() const { return mGutterUseCustomFont; } void Settings::Editor::setGutterUseCustomFont(bool gutterUseCustomFont) { mGutterUseCustomFont = gutterUseCustomFont; } bool Settings::Editor::gutterLineNumbersStartZero() const { return mGutterLineNumbersStartZero; } void Settings::Editor::setGutterLineNumbersStartZero(bool gutterLineNumbersStartZero) { mGutterLineNumbersStartZero = gutterLineNumbersStartZero; } bool Settings::Editor::gutterAddLeadingZero() const { return mGutterAddLeadingZero; } void Settings::Editor::setGutterAddLeadingZero(bool gutterAddLeadingZero) { mGutterAddLeadingZero = gutterAddLeadingZero; } bool Settings::Editor::gutterShowLineNumbers() const { return mGutterShowLineNumbers; } void Settings::Editor::setGutterShowLineNumbers(bool gutterShowLineNumbers) { mGutterShowLineNumbers = gutterShowLineNumbers; } int Settings::Editor::gutterDigitsCount() const { return mGutterDigitsCount; } void Settings::Editor::setGutterDigitsCount(int gutterDigitsCount) { mGutterDigitsCount = gutterDigitsCount; } bool Settings::Editor::gutterAutoSize() const { return mGutterAutoSize; } void Settings::Editor::setGutterAutoSize(bool gutterAutoSize) { mGutterAutoSize = gutterAutoSize; } bool Settings::Editor::gutterVisible() const { return mGutterVisible; } void Settings::Editor::setGutterVisible(bool gutterVisible) { mGutterVisible = gutterVisible; } int Settings::Editor::fontSize() const { return mFontSize; } void Settings::Editor::setFontSize(int fontSize) { mFontSize = fontSize; } QString Settings::Editor::fontName() const { return mFontFamilies.length() > 0 ? mFontFamilies[0] : ""; } bool Settings::Editor::scrollPastEol() const { return mScrollPastEol; } void Settings::Editor::setScrollPastEol(bool scrollPastEol) { mScrollPastEol = scrollPastEol; } bool Settings::Editor::scrollPastEof() const { return mScrollPastEof; } void Settings::Editor::setScrollPastEof(bool scrollPastEof) { mScrollPastEof = scrollPastEof; } bool Settings::Editor::autoHideScrollbar() const { return mAutoHideScrollbar; } void Settings::Editor::setAutoHideScrollbar(bool autoHideScrollbar) { mAutoHideScrollbar = autoHideScrollbar; } void Settings::Editor::doSave() { // indents saveValue("auto_indent", mAutoIndent); saveValue("tab_to_spaces", mTabToSpaces); saveValue("tab_width", mTabWidth); saveValue("show_indent_lines", mShowIndentLines); saveValue("indent_line_color",mIndentLineColor); saveValue("fill_indents",mfillIndents); // caret saveValue("enhance_home_key",mEnhanceHomeKey); saveValue("enhance_end_key",mEnhanceEndKey); saveValue("keep_caret_x",mKeepCaretX); saveValue("caret_for_insert",static_cast(mCaretForInsert)); saveValue("caret_for_overwrite",static_cast(mCaretForOverwrite)); saveValue("caret_use_text_color",mCaretUseTextColor); saveValue("caret_color",mCaretColor); //highlight saveValue("highlight_matching_braces",mHighlightMathingBraces); saveValue("highlight_current_word",mHighlightCurrentWord); //scroll saveValue("auto_hide_scroll_bar", mAutoHideScrollbar); saveValue("scroll_past_eof", mScrollPastEof); saveValue("scroll_past_eol", mScrollPastEol); saveValue("half_page_scroll", mHalfPageScroll); saveValue("mouse_wheel_scroll_speed", mMouseWheelScrollSpeed); saveValue("mouse_drag_scroll_speed",mMouseSelectionScrollSpeed); //right edge saveValue("show_right_edge_line",mShowRightEdgeLine); saveValue("right_edge_width",mRightEdgeWidth); saveValue("right_edge_line_color",mRightEdgeLineColor); //Font //font saveValue("font_families", mFontFamilies); saveValue("font_size", mFontSize); saveValue("line_spacing",mLineSpacing); saveValue("enable_ligatures_support", mEnableLigaturesSupport); saveValue("force_fixed_font_width", mForceFixedFontWidth); saveValue("show_leading_spaces", mShowLeadingSpaces); saveValue("show_trailing_spaces", mShowTrailingSpaces); saveValue("show_inner_spaces", mShowInnerSpaces); saveValue("show_line_breaks", mShowLineBreaks); //gutter saveValue("gutter_visible", mGutterVisible); saveValue("gutter_auto_size", mGutterAutoSize); saveValue("gutter_left_offset",mGutterLeftOffset); saveValue("gutter_right_offset2",mGutterRightOffset); saveValue("gutter_digits_count", mGutterDigitsCount); saveValue("gutter_show_line_numbers",mGutterShowLineNumbers); saveValue("gutter_add_leading_zero",mGutterAddLeadingZero); saveValue("gutter_line_numbers_start_zero",mGutterLineNumbersStartZero); saveValue("gutter_use_custom_font",mGutterUseCustomFont); saveValue("gutter_font_name",mGutterFontName); saveValue("gutter_font_size",mGutterFontSize); saveValue("gutter_font_only_monospaced",mGutterFontOnlyMonospaced); //copy saveValue("copy_limit",mCopySizeLimit); saveValue("copy_char_limits",mCopyCharLimits); saveValue("copy_line_limits",mCopyLineLimits); saveValue("copy_with_format_as",mCopyWithFormatAs); saveValue("copy_rtf_use_background",mCopyRTFUseBackground); saveValue("copy_rtf_use_editor_color_scheme",mCopyRTFUseEditorColor); saveValue("copy_rtf_color_scheme",mCopyRTFColorScheme); saveValue("copy_html_use_background",mCopyHTMLUseBackground); saveValue("copy_html_use_editor_color_scheme",mCopyHTMLUseEditorColor); saveValue("copy_html_color_scheme", mCopyHTMLColorScheme); //color scheme saveValue("color_scheme", mColorScheme); saveValue("rainbow_parenthesis",mRainbowParenthesis); //Symbol Completion saveValue("complete_symbols", mCompleteSymbols); saveValue("complete_parenthese", mCompleteParenthese); saveValue("complete_bracket", mCompleteBracket); saveValue("complete_brace", mCompleteBrace); saveValue("complete_comment", mCompleteComment); saveValue("complete_single_quote", mCompleteSingleQuote); saveValue("complete_double_quote", mCompleteDoubleQuote); saveValue("complete_global_include", mCompleteGlobalInclude); saveValue("overwrite_symbols", mOverwriteSymbols); saveValue("remove_symbol_pairs",mRemoveSymbolPairs); //Auto Syntax Check saveValue("check_syntax",mSyntaxCheck); saveValue("check_syntax_when_save",mSyntaxCheckWhenSave); saveValue("check_syntax_when_line_changed",mSyntaxCheckWhenLineChanged); //auto save saveValue("enable_edit_temp_backup",mEnableEditTempBackup); saveValue("enable_auto_save",mEnableAutoSave); saveValue("auto_save_interal",mAutoSaveInterval); saveValue("auto_save_target",mAutoSaveTarget); saveValue("auto_save_strategy",mAutoSaveStrategy); //auto link saveValue("enable_autolink",mEnableAutolink); //misc saveValue("default_encoding",mDefaultEncoding); saveValue("readonly_system_header",mReadOnlySytemHeader); saveValue("auto_load_last_files",mAutoLoadLastFiles); saveValue("default_file_cpp",mDefaultFileCpp); saveValue("auto_detect_file_encoding",mAutoDetectFileEncoding); saveValue("undo_limit",mUndoLimit); saveValue("undo_memory_usage", mUndoMemoryUsage); saveValue("auto_format_when_saved", mAutoFormatWhenSaved); saveValue("remove_trailing_spaces_when_saved",mRemoveTrailingSpacesWhenSaved); saveValue("parse_todos",mParseTodos); saveValue("custom_c_type_keywords", mCustomCTypeKeywords); saveValue("enable_custom_c_type_keywords",mEnableCustomCTypeKeywords); //tooltips saveValue("enable_tooltips",mEnableTooltips); saveValue("enable_debug_tooltips",mEnableDebugTooltips); saveValue("enable_identifier_tooltips",mEnableIdentifierToolTips); saveValue("enable_header_tooltips",mEnableHeaderToolTips); saveValue("enable_issue_tooltips",mEnableIssueToolTips); saveValue("show_function_tips",mShowFunctionTips); saveValue("tips_delay",mTipsDelay); } void Settings::Editor::doLoad() { // indents mAutoIndent = boolValue("auto_indent", true); mTabToSpaces = boolValue("tab_to_spaces",false); mTabWidth = intValue("tab_width",4); mShowIndentLines = boolValue("show_indent_lines",true); mIndentLineColor = colorValue("indent_line_color",Qt::lightGray); mfillIndents = boolValue("fill_indents", false); // caret mEnhanceHomeKey = boolValue("enhance_home_key", true); mEnhanceEndKey = boolValue("enhance_end_key",true); mKeepCaretX = boolValue("keep_caret_x",true); mCaretForInsert = static_cast( intValue("caret_for_insert",static_cast(QSynedit::EditCaretType::ctVerticalLine))); mCaretForOverwrite = static_cast( intValue("caret_for_overwrite",static_cast(QSynedit::EditCaretType::ctBlock))); mCaretUseTextColor = boolValue("caret_use_text_color",true); mCaretColor = colorValue("caret_color",Qt::yellow); //highlight mHighlightMathingBraces = boolValue("highlight_matching_braces",true); mHighlightCurrentWord = boolValue("highlight_current_word",true); //scroll mAutoHideScrollbar = boolValue("auto_hide_scroll_bar", false); mScrollPastEof = boolValue("scroll_past_eof", true); mScrollPastEol = boolValue("scroll_past_eol", false); mHalfPageScroll = boolValue("half_page_scroll",false); mMouseWheelScrollSpeed = intValue("mouse_wheel_scroll_speed", 3); mMouseSelectionScrollSpeed = intValue("mouse_drag_scroll_speed",10); //right edge mShowRightEdgeLine = boolValue("show_right_edge_line",false); mRightEdgeWidth = intValue("right_edge_width",80); mRightEdgeLineColor = colorValue("right_edge_line_color",Qt::yellow); //Editor font QStringList fontFamilies = stringListValue("font_families", QStringList()); if (fontFamilies.empty()) { // backward compatibility: try old font settings QString fontName = stringValue("font_name", ""); if (!fontName.isEmpty()) fontFamilies.append(fontName); QString nonAsciiFontName = stringValue("non_ascii_font_name", ""); if (!nonAsciiFontName.isEmpty()) fontFamilies.append(nonAsciiFontName); mFontFamilies = fontFamilies.empty() ? defaultEditorFonts() : fontFamilies; } else { mFontFamilies = fontFamilies; } mFontSize = intValue("font_size",12); mLineSpacing = doubleValue("line_spacing",1.1); mForceFixedFontWidth = boolValue("force_fixed_font_width", isCjk()); // if (mForceFixedFontWidth) // mEnableLigaturesSupport = false; // else // mEnableLigaturesSupport = boolValue("enable_ligatures_support", !isZhJa); mEnableLigaturesSupport = boolValue("enable_ligatures_support", false); mShowLeadingSpaces = boolValue("show_leading_spaces", false); mShowTrailingSpaces = boolValue("show_trailing_spaces", false); mShowInnerSpaces = boolValue("show_inner_spaces", false); mShowLineBreaks = boolValue("show_line_breaks", false); //gutter mGutterVisible = boolValue("gutter_visible",true); mGutterAutoSize = boolValue("gutter_auto_size",true); mGutterLeftOffset = intValue("gutter_left_offset",6); mGutterRightOffset = intValue("gutter_right_offset",-1); if (mGutterRightOffset>0) mGutterRightOffset = std::max(0, mGutterRightOffset-20); else mGutterRightOffset = intValue("gutter_right_offset2",4); mGutterDigitsCount = intValue("gutter_digits_count",1); mGutterShowLineNumbers = boolValue("gutter_show_line_numbers",true); mGutterAddLeadingZero = boolValue("gutter_add_leading_zero",false); mGutterLineNumbersStartZero = boolValue("gutter_line_numbers_start_zero",false); mGutterUseCustomFont = boolValue("gutter_use_custom_font",false); mGutterFontName = stringValue("gutter_font_name", defaultMonoFont()); mGutterFontSize = intValue("gutter_font_size",12); mGutterFontOnlyMonospaced = boolValue("gutter_font_only_monospaced",true); //copy mCopySizeLimit = boolValue("copy_limit",false); mCopyCharLimits = intValue("copy_char_limits",100); mCopyLineLimits = intValue("copy_line_limits",100000); #ifdef Q_OS_WIN mCopyWithFormatAs = intValue("copy_with_format_as",1); //html #else mCopyWithFormatAs = intValue("copy_with_format_as",0); //none #endif mCopyRTFUseBackground = boolValue("copy_rtf_use_background",false); mCopyRTFUseEditorColor = boolValue("copy_rtf_use_editor_color_scheme",false); mCopyRTFColorScheme = stringValue("copy_rtf_color_scheme","Intellij Classic"); mCopyHTMLUseBackground = boolValue("copy_html_use_background",false); mCopyHTMLUseEditorColor = boolValue("copy_html_use_editor_color_scheme",false); mCopyHTMLColorScheme = stringValue("copy_html_color_scheme","Intellij Classic"); //color mColorScheme = stringValue("color_scheme", "VS Code"); mRainbowParenthesis = boolValue("rainbow_parenthesis", true); //Symbol Completion mCompleteSymbols = boolValue("complete_symbols",true); mCompleteParenthese = boolValue("complete_parenthese",true); mCompleteBracket = boolValue("complete_bracket",true); mCompleteBrace = boolValue("complete_brace",true); mCompleteComment = boolValue("complete_comment",true); mCompleteSingleQuote = boolValue("complete_single_quote",true); mCompleteDoubleQuote = boolValue("complete_double_quote",true); mCompleteGlobalInclude = boolValue("complete_global_include",true); mOverwriteSymbols = boolValue("overwrite_symbols",true); mRemoveSymbolPairs = boolValue("remove_symbol_pairs",true); //Auto Syntax Check mSyntaxCheck = boolValue("check_syntax",true); mSyntaxCheckWhenSave = boolValue("check_syntax_when_save",true); mSyntaxCheckWhenLineChanged = boolValue("check_syntax_when_line_changed",true); //auto save mEnableEditTempBackup = boolValue("enable_edit_temp_backup", false); mEnableAutoSave = boolValue("enable_auto_save",false); mAutoSaveInterval = intValue("auto_save_interal",10); mAutoSaveTarget = static_cast( intValue("auto_save_target",AutoSaveTarget::astCurrentFile)); mAutoSaveStrategy = static_cast( intValue("auto_save_strategy",AutoSaveStrategy::assOverwrite)); //auto link mEnableAutolink = boolValue("enable_autolink",true); //misc mReadOnlySytemHeader = boolValue("readonly_system_header",true); mAutoLoadLastFiles = boolValue("auto_load_last_files",true); mDefaultFileCpp = boolValue("default_file_cpp",true); bool useUTF8ByDefault = boolValue("use_utf8_by_default",false); if (useUTF8ByDefault) mDefaultEncoding = ENCODING_UTF8; else mDefaultEncoding = value("default_encoding", ENCODING_UTF8).toByteArray(); mAutoDetectFileEncoding = boolValue("auto_detect_file_encoding",true); mUndoLimit = intValue("undo_limit",0); mUndoMemoryUsage = intValue("undo_memory_usage", 0); mAutoFormatWhenSaved = boolValue("auto_format_when_saved", false); mRemoveTrailingSpacesWhenSaved = boolValue("remove_trailing_spaces_when_saved",false); mParseTodos = boolValue("parse_todos",true); mCustomCTypeKeywords = stringListValue("custom_c_type_keywords"); mEnableCustomCTypeKeywords = boolValue("enable_custom_c_type_keywords",false); //tooltips mEnableTooltips = boolValue("enable_tooltips",true); mEnableDebugTooltips = boolValue("enable_debug_tooltips",true); mEnableIdentifierToolTips = boolValue("enable_identifier_tooltips",true); mEnableHeaderToolTips = boolValue("enable_header_tooltips", true); mEnableIssueToolTips = boolValue("enable_issue_tooltips", true); mShowFunctionTips = boolValue("show_function_tips",true); mTipsDelay = intValue("tips_delay",500); } QSynedit::EditCaretType Settings::Editor::caretForOverwrite() const { return mCaretForOverwrite; } void Settings::Editor::setCaretForOverwrite(const QSynedit::EditCaretType &caretForOverwrite) { mCaretForOverwrite = caretForOverwrite; } QSynedit::EditCaretType Settings::Editor::caretForInsert() const { return mCaretForInsert; } void Settings::Editor::setCaretForInsert(const QSynedit::EditCaretType &caretForInsert) { mCaretForInsert = caretForInsert; } bool Settings::Editor::enhanceEndKey() const { return mEnhanceEndKey; } void Settings::Editor::setEnhanceEndKey(bool enhanceEndKey) { mEnhanceEndKey = enhanceEndKey; } bool Settings::Editor::enhanceHomeKey() const { return mEnhanceHomeKey; } void Settings::Editor::setEnhanceHomeKey(bool enhanceHomeKey) { mEnhanceHomeKey = enhanceHomeKey; } QColor Settings::Editor::indentLineColor() const { return mIndentLineColor; } void Settings::Editor::setIndentLineColor(const QColor &indentLineColor) { mIndentLineColor = indentLineColor; } bool Settings::Editor::showIndentLines() const { return mShowIndentLines; } void Settings::Editor::setShowIndentLines(bool showIndentLines) { mShowIndentLines = showIndentLines; } int Settings::Editor::tabWidth() const { return mTabWidth; } void Settings::Editor::setTabWidth(int tabWidth) { mTabWidth = tabWidth; } bool Settings::Editor::tabToSpaces() const { return mTabToSpaces; } void Settings::Editor::setTabToSpaces(bool tabToSpaces) { mTabToSpaces = tabToSpaces; } Settings::CompilerSet::CompilerSet(): mFullLoaded{false}, mCompilerType{CompilerType::Unknown}, mAutoAddCharsetParams{false}, mExecCharset{ENCODING_SYSTEM_DEFAULT}, mStaticLink{false}, mPersistInAutoFind{false}, mForceEnglishOutput{false}, mPreprocessingSuffix{DEFAULT_PREPROCESSING_SUFFIX}, mCompilationProperSuffix{DEFAULT_COMPILATION_SUFFIX}, mAssemblingSuffix{DEFAULT_ASSEMBLING_SUFFIX}, mExecutableSuffix{DEFAULT_EXECUTABLE_SUFFIX}, mCompilationStage{Settings::CompilerSet::CompilationStage::GenerateExecutable} { } Settings::CompilerSet::CompilerSet(const QString& compilerFolder, const QString& c_prog): mAutoAddCharsetParams{true}, mExecCharset{ENCODING_SYSTEM_DEFAULT}, mStaticLink{true}, mPersistInAutoFind{false}, mForceEnglishOutput{false}, mPreprocessingSuffix{DEFAULT_PREPROCESSING_SUFFIX}, mCompilationProperSuffix{DEFAULT_COMPILATION_SUFFIX}, mAssemblingSuffix{DEFAULT_ASSEMBLING_SUFFIX}, mExecutableSuffix{DEFAULT_EXECUTABLE_SUFFIX}, mCompilationStage{Settings::CompilerSet::CompilationStage::GenerateExecutable} { QDir dir(compilerFolder); if (dir.exists(c_prog)) { setProperties(compilerFolder,c_prog); if (mName.isEmpty()) { mFullLoaded = false; return; } //manually set the directories setDirectories(compilerFolder); setExecutables(); setUserInput(); #ifdef ENABLE_SDCC if (mCompilerType == CompilerType::SDCC) { mExecutableSuffix = SDCC_HEX_SUFFIX; } #endif mFullLoaded = true; } else { mFullLoaded = false; } } Settings::CompilerSet::CompilerSet(const Settings::CompilerSet &set): mFullLoaded{set.mFullLoaded}, mCCompiler{set.mCCompiler}, mCppCompiler{set.mCppCompiler}, mMake{set.mMake}, mDebugger{set.mDebugger}, mResourceCompiler{set.mResourceCompiler}, mDebugServer{set.mDebugServer}, mBinDirs{set.mBinDirs}, mCIncludeDirs{set.mCIncludeDirs}, mCppIncludeDirs{set.mCppIncludeDirs}, mLibDirs{set.mLibDirs}, mDefaultLibDirs{set.mDefaultLibDirs}, mDefaultCIncludeDirs{set.mDefaultCIncludeDirs}, mDefaultCppIncludeDirs{set.mDefaultCppIncludeDirs}, mDumpMachine{set.mDumpMachine}, mVersion{set.mVersion}, mType{set.mType}, mName{set.mName}, mTarget{set.mTarget}, mCompilerType{set.mCompilerType}, mUseCustomCompileParams{set.mUseCustomCompileParams}, mUseCustomLinkParams{set.mUseCustomLinkParams}, mCustomCompileParams{set.mCustomCompileParams}, mCustomLinkParams{set.mCustomLinkParams}, mAutoAddCharsetParams{set.mAutoAddCharsetParams}, mExecCharset{set.mExecCharset}, mStaticLink{set.mStaticLink}, mPersistInAutoFind{set.mPersistInAutoFind}, mForceEnglishOutput{set.mForceEnglishOutput}, mPreprocessingSuffix{set.mPreprocessingSuffix}, mCompilationProperSuffix{set.mCompilationProperSuffix}, mAssemblingSuffix{set.mAssemblingSuffix}, mExecutableSuffix{set.mExecutableSuffix}, mCompilationStage{set.mCompilationStage}, mCompileOptions{set.mCompileOptions} { } Settings::CompilerSet::CompilerSet(const QJsonObject &set) : mFullLoaded{true}, mCCompiler{set["cCompiler"].toString()}, mCppCompiler{set["cxxCompiler"].toString()}, mMake{set["make"].toString()}, mDebugger{set["debugger"].toString()}, mResourceCompiler{set["resourceCompiler"].toString()}, mDebugServer{set["debugServer"].toString()}, mBinDirs{}, // handle later mCIncludeDirs{}, // handle later mCppIncludeDirs{}, // handle later mLibDirs{}, // handle later mDefaultLibDirs{}, // handle later mDefaultCIncludeDirs{}, // handle later mDefaultCppIncludeDirs{}, // handle later mDumpMachine{set["dumpMachine"].toString()}, mVersion{set["version"].toString()}, mType{set["type"].toString()}, mName{set["name"].toString()}, mTarget{set["target"].toString()}, mCompilerType{}, // handle later mUseCustomCompileParams{!set["customCompileParams"].toArray().isEmpty()}, mUseCustomLinkParams{!set["customLinkParams"].toArray().isEmpty()}, mCustomCompileParams{}, // handle later mCustomLinkParams{}, // handle later mAutoAddCharsetParams{!set["execCharset"].toString().isEmpty()}, mExecCharset{}, // handle later mStaticLink{set["staticLink"].toBool()}, mPersistInAutoFind{false}, mForceEnglishOutput{false}, mPreprocessingSuffix{set["preprocessingSuffix"].toString()}, mCompilationProperSuffix{set["compilationProperSuffix"].toString()}, mAssemblingSuffix{set["assemblingSuffix"].toString()}, mExecutableSuffix{set["executableSuffix"].toString()}, mCompilationStage{CompilationStage(set["compilationStage"].toInt())}, mCompileOptions{} // handle later { for (const QJsonValue &dir : set["binDirs"].toArray()) mBinDirs.append(dir.toString()); for (const QJsonValue &dir : set["cIncludeDirs"].toArray()) mCIncludeDirs.append(dir.toString()); for (const QJsonValue &dir : set["cxxIncludeDirs"].toArray()) mCppIncludeDirs.append(dir.toString()); for (const QJsonValue &dir : set["libDirs"].toArray()) mLibDirs.append(dir.toString()); for (const QJsonValue &dir : set["defaultLibDirs"].toArray()) mDefaultLibDirs.append(dir.toString()); for (const QJsonValue &dir : set["defaultCIncludeDirs"].toArray()) mDefaultCIncludeDirs.append(dir.toString()); for (const QJsonValue &dir : set["defaultCxxIncludeDirs"].toArray()) mDefaultCppIncludeDirs.append(dir.toString()); QString compilerType = set["compilerType"].toString(); if (compilerType == "GCC") { mCompilerType = CompilerType::GCC; } else if (compilerType == "GCC_UTF8") { mCompilerType = CompilerType::GCC_UTF8; } else if (compilerType == "Clang") { mCompilerType = CompilerType::Clang; } #if ENABLE_SDCC else if (compilerType == "SDCC") { mCompilerType = CompilerType::SDCC; } #endif else { mCompilerType = CompilerType::Unknown; mFullLoaded = false; } QStringList compileParams; for (const QJsonValue ¶m : set["customCompileParams"].toArray()) compileParams << param.toString(); mCustomCompileParams = escapeArgumentsForInputField(compileParams); QStringList linkParams; for (const QJsonValue ¶m : set["customLinkParams"].toArray()) linkParams << param.toString(); mCustomLinkParams = escapeArgumentsForInputField(linkParams); if (!mAutoAddCharsetParams) mExecCharset = "UTF-8"; else mExecCharset = set["execCharset"].toString(); const static QMap optionMap = { {CC_CMD_OPT_OPTIMIZE, "ccCmdOptOptimize"}, {CC_CMD_OPT_STD, "ccCmdOptStd"}, {C_CMD_OPT_STD, "cCmdOptStd"}, {CC_CMD_OPT_INSTRUCTION, "ccCmdOptInstruction"}, {CC_CMD_OPT_POINTER_SIZE, "ccCmdOptPointerSize"}, {CC_CMD_OPT_DEBUG_INFO, "ccCmdOptDebugInfo"}, {CC_CMD_OPT_PROFILE_INFO, "ccCmdOptProfileInfo"}, {CC_CMD_OPT_SYNTAX_ONLY, "ccCmdOptSyntaxOnly"}, {CC_CMD_OPT_INHIBIT_ALL_WARNING, "ccCmdOptInhibitAllWarning"}, {CC_CMD_OPT_WARNING_ALL, "ccCmdOptWarningAll"}, {CC_CMD_OPT_WARNING_EXTRA, "ccCmdOptWarningExtra"}, {CC_CMD_OPT_CHECK_ISO_CONFORMANCE, "ccCmdOptCheckIsoConformance"}, {CC_CMD_OPT_WARNING_AS_ERROR, "ccCmdOptWarningAsError"}, {CC_CMD_OPT_ABORT_ON_ERROR, "ccCmdOptAbortOnError"}, {CC_CMD_OPT_STACK_PROTECTOR, "ccCmdOptStackProtector"}, {CC_CMD_OPT_ADDRESS_SANITIZER, "ccCmdOptAddressSanitizer"}, {CC_CMD_OPT_USE_PIPE, "ccCmdOptUsePipe"}, {LINK_CMD_OPT_NO_LINK_STDLIB, "linkCmdOptNoLinkStdlib"}, {LINK_CMD_OPT_NO_CONSOLE, "linkCmdOptNoConsole"}, {LINK_CMD_OPT_STRIP_EXE, "linkCmdOptStripExe"}, }; for (const QString &key : optionMap.keys()) { const QString &jsonKey = optionMap[key]; QString value = set[jsonKey].toString(); if (!value.isEmpty()) setCompileOption(key, value); } } void Settings::CompilerSet::resetCompileOptionts() { mCompileOptions.clear(); } bool Settings::CompilerSet::setCompileOption(const QString &key, int valIndex) { PCompilerOption op = CompilerInfoManager::getCompilerOption(mCompilerType, key); if (!op) return false; if (op->choices.isEmpty()) { if (valIndex==1) mCompileOptions.insert(key,COMPILER_OPTION_ON); else mCompileOptions.remove(key); return true; } else if (valIndex>0 && valIndex <= op->choices.length()) { mCompileOptions.insert(key,op->choices[valIndex-1].second); return true; } else { mCompileOptions.remove(key); return true; } return false; } bool Settings::CompilerSet::setCompileOption(const QString &key, const QString &value) { PCompilerOption op = CompilerInfoManager::getCompilerOption(mCompilerType,key); if (!op) return false; mCompileOptions.insert(key,value); return true; } void Settings::CompilerSet::unsetCompileOption(const QString &key) { mCompileOptions.remove(key); } void Settings::CompilerSet::setCompileOptions(const QMap options) { mCompileOptions=options; } QString Settings::CompilerSet::getCompileOptionValue(const QString &key) const { return mCompileOptions.value(key,QString()); } //static void checkDirs(const QStringList& dirlist, QString& gooddirs, QString& baddirs) { // gooddirs = ""; // baddirs = ""; // for (int i=0; i0) {// we need some bin dir, so treat count=0 as an error too // checkDirs(mBinDirs,goodbin,badbin); // if (!badbin.isEmpty()) { // msg += QObject::tr("The following %1 directories don't exist:").arg( // QObject::tr("binary") // ); // msg += "
"; // msg += badbin.replace(';',"
"); // msg += "
"; // msg += "
"; // return false; // } // } else { // msg += QObject::tr("No %1 directories have been specified.").arg( // QObject::tr("binary") // ); // msg += "
"; // msg += "
"; // return false; // } // checkDirs(mCIncludeDirs,goodbin,badbin); // if (!badbin.isEmpty()) { // msg += QObject::tr("The following %1 directories don't exist:").arg( // QObject::tr("C include") // ); // msg += "
"; // msg += badbin.replace(';',"
"); // msg += "
"; // msg += "
"; // return false; // } // checkDirs(mCppIncludeDirs,goodbin,badbin); // if (!badbin.isEmpty()) { // msg += QObject::tr("The following %1 directories don't exist:").arg( // QObject::tr("C++ include") // ); // msg += "
"; // msg += badbin.replace(';',"
"); // msg += "
"; // msg += "
"; // return false; // } // checkDirs(mLibDirs,goodbin,badbin); // if (!badbin.isEmpty()) { // msg += QObject::tr("The following %1 directories don't exist:").arg( // QObject::tr("C++ include") // ); // msg += "
"; // msg += badbin.replace(';',"
"); // msg += "
"; // msg += "
"; // return false; // } // if (!msg.isEmpty()) // return false; // else // return true; //} //bool Settings::CompilerSet::validateExes(QString &msg) //{ // msg =""; // if (!fileExists(mCCompiler)) { // msg += QObject::tr("Cannot find the %1 \"%2\"") // .arg(QObject::tr("C Compiler")) // .arg(mCCompiler); // } // if (!fileExists(mCppCompiler)) { // msg += QObject::tr("Cannot find the %1 \"%2\"") // .arg(QObject::tr("C++ Compiler")) // .arg(mCppCompiler); // } // if (!mMake.isEmpty() && !fileExists(mMake)) { // msg += QObject::tr("Cannot find the %1 \"%2\"") // .arg(QObject::tr("Maker")) // .arg(mMake); // } // if (!fileExists(mDebugger)) { // msg += QObject::tr("Cannot find the %1 \"%2\"") // .arg(QObject::tr("Debugger")) // .arg(mDebugger); // } // if (!msg.isEmpty()) // return false; // else // return true; //} const QString &Settings::CompilerSet::CCompiler() const { return mCCompiler; } void Settings::CompilerSet::setCCompiler(const QString &name) { if (mCCompiler!=name) { mCCompiler = name; if (mCompilerType == CompilerType::Unknown) { QString temp=extractFileName(mCCompiler); if (temp == CLANG_PROGRAM) { setCompilerType(CompilerType::Clang); } else if (temp == GCC_PROGRAM) { setCompilerType(CompilerType::GCC); } } } } const QString &Settings::CompilerSet::cppCompiler() const { return mCppCompiler; } void Settings::CompilerSet::setCppCompiler(const QString &name) { mCppCompiler = name; } const QString &Settings::CompilerSet::make() const { return mMake; } void Settings::CompilerSet::setMake(const QString &name) { mMake = name; } const QString &Settings::CompilerSet::debugger() const { return mDebugger; } void Settings::CompilerSet::setDebugger(const QString &name) { mDebugger = name; } const QString &Settings::CompilerSet::resourceCompiler() const { return mResourceCompiler; } void Settings::CompilerSet::setResourceCompiler(const QString &name) { mResourceCompiler = name; } QStringList &Settings::CompilerSet::binDirs() { return mBinDirs; } QStringList &Settings::CompilerSet::CIncludeDirs() { return mCIncludeDirs; } QStringList &Settings::CompilerSet::CppIncludeDirs() { return mCppIncludeDirs; } QStringList &Settings::CompilerSet::libDirs() { return mLibDirs; } QStringList &Settings::CompilerSet::defaultCIncludeDirs() { if (!mFullLoaded && !binDirs().isEmpty()) { mFullLoaded=true; setDirectories(binDirs()[0]); } return mDefaultCIncludeDirs; } QStringList &Settings::CompilerSet::defaultCppIncludeDirs() { if (!mFullLoaded && !binDirs().isEmpty()) { mFullLoaded=true; setDirectories(binDirs()[0]); } return mDefaultCppIncludeDirs; } QStringList &Settings::CompilerSet::defaultLibDirs() { if (!mFullLoaded && !binDirs().isEmpty()) { mFullLoaded=true; setDirectories(binDirs()[0]); } return mLibDirs; } const QString &Settings::CompilerSet::dumpMachine() const { return mDumpMachine; } void Settings::CompilerSet::setDumpMachine(const QString &value) { mDumpMachine = value; } const QString &Settings::CompilerSet::version() const { return mVersion; } void Settings::CompilerSet::setVersion(const QString &value) { mVersion = value; } const QString &Settings::CompilerSet::type() const { return mType; } void Settings::CompilerSet::setType(const QString& value) { mType = value; } const QString &Settings::CompilerSet::name() const { return mName; } void Settings::CompilerSet::setName(const QString &value) { mName = value; } const QString &Settings::CompilerSet::target() const { return mTarget; } void Settings::CompilerSet::setTarget(const QString &value) { mTarget = value; } void Settings::CompilerSet::setUseCustomCompileParams(bool value) { mUseCustomCompileParams = value; } bool Settings::CompilerSet::useCustomLinkParams() const { return mUseCustomLinkParams; } void Settings::CompilerSet::setUseCustomLinkParams(bool value) { mUseCustomLinkParams = value; } const QString &Settings::CompilerSet::customCompileParams() const { return mCustomCompileParams; } void Settings::CompilerSet::setCustomCompileParams(const QString &value) { mCustomCompileParams = value; } const QString &Settings::CompilerSet::customLinkParams() const { return mCustomLinkParams; } void Settings::CompilerSet::setCustomLinkParams(const QString &value) { mCustomLinkParams = value; } bool Settings::CompilerSet::autoAddCharsetParams() const { return mAutoAddCharsetParams; } void Settings::CompilerSet::setAutoAddCharsetParams(bool value) { mAutoAddCharsetParams = value; } int Settings::CompilerSet::charToValue(char valueChar) { if (valueChar == '1') { return 1; } else if ( (valueChar>='a') && (valueChar<='z')) { return (valueChar-'a')+2; } else { return 0; } } char Settings::CompilerSet::valueToChar(int val) { return ValueToChar[val]; } static void addExistingDirectory(QStringList& dirs, const QString& directory) { if (!directoryExists(directory)) return; QFileInfo dirInfo(directory); QString dirPath = dirInfo.absoluteFilePath(); if (dirs.contains(dirPath)) return; dirs.append(dirPath); } void Settings::CompilerSet::setProperties(const QString& binDir, const QString& c_prog) { #ifdef ENABLE_SDCC if (c_prog == SDCC_PROGRAM) { setSDCCProperties(binDir,c_prog); } else { #endif setGCCProperties(binDir,c_prog); #ifdef ENABLE_SDCC } #endif } void Settings::CompilerSet::setGCCProperties(const QString& binDir, const QString& c_prog) { // We have tested before the call // if (!fileExists(c_prog)) // return; // Obtain version number and compiler distro etc QStringList arguments; arguments.append("-v"); QByteArray output = getCompilerOutput(binDir, c_prog,arguments); //Target QByteArray targetStr = "Target: "; int delimPos1 = output.indexOf(targetStr); if (delimPos1<0) return; // unknown binary delimPos1+=strlen(targetStr); int delimPos2 = delimPos1; while (delimPos2=0) { mCompilerType = CompilerType::Clang; delimPos1+=strlen(targetStr); delimPos2 = delimPos1; while (delimPos20) { bool ok; majorVersion=mVersion.left(mVersion.indexOf('.')).toInt(&ok); if (!ok) majorVersion=-1; } else { bool ok; majorVersion=mVersion.toInt(&ok); if (!ok) majorVersion=-1; } // //fix for mingw64 gcc // double versionValue; // bool ok; // versionValue = mVersion.toDouble(&ok); // if (ok && versionValue>=12) { // mCompilerType=COMPILER_GCC_UTF8; // } // Find compiler builder delimPos1 = delimPos2; while ((delimPos1 < output.length()) && !(output[delimPos1] == '(')) delimPos1++; while ((delimPos2 < output.length()) && !(output[delimPos2] == ')')) delimPos2++; mType = output.mid(delimPos1 + 1, delimPos2 - delimPos1 - 1); if (majorVersion>=12 && mType.contains("MSYS2")) mCompilerType = CompilerType::GCC_UTF8; // Assemble user friendly name if we don't have one yet if (mName == "") { if (mType.contains("tdm64",Qt::CaseInsensitive)) { mName = "TDM-GCC " + mVersion; } else if (mType.contains("tdm",Qt::CaseInsensitive)) { mName = "TDM-GCC " + mVersion; } else if (mType.contains("MSYS2",Qt::CaseInsensitive)) { mName = "MinGW-w64 GCC " + mVersion; } else if (mType.contains("MinGW-W64",Qt::CaseInsensitive)) { mName = "MinGW-w64 GCC " + mVersion; } else if (mType.contains("GCC",Qt::CaseInsensitive)) { #ifdef Q_OS_WIN mName = "MinGW GCC " + mVersion; #else mName = "GCC " + mVersion; #endif } else { #ifdef Q_OS_WIN mName = "MinGW-w64 GCC " + mVersion; #else mName = "GCC " + mVersion; #endif } } } // Set compiler folder QDir tmpDir(binDir); tmpDir.cdUp(); QString folder = tmpDir.path(); // Obtain compiler target arguments.clear(); arguments.append("-dumpmachine"); mDumpMachine = getCompilerOutput(binDir, c_prog, arguments); // Add the default directories addExistingDirectory(mBinDirs, includeTrailingPathDelimiter(folder) + "bin"); if (!mDumpMachine.isEmpty()) { //mingw-w64 bin folder addExistingDirectory(mBinDirs, includeTrailingPathDelimiter(folder) + "lib/" "gcc/" + mDumpMachine + "/" + mVersion); } } #ifdef ENABLE_SDCC void Settings::CompilerSet::setSDCCProperties(const QString& binDir, const QString& c_prog) { // We have tested before the call // if (!fileExists(c_prog)) // return; // Obtain version number and compiler distro etc QStringList arguments; arguments.append("-v"); QByteArray output = getCompilerOutput(binDir, c_prog,arguments); if (!output.startsWith("SDCC")) return; //Target int delimPos = 0; while (delimPos=((char)32))) delimPos++; QString triplet = output.mid(0,delimPos); QRegularExpression re("\\s+(\\d+\\.\\d+\\.\\d+)\\s+"); QRegularExpressionMatch match = re.match(triplet); if (match.hasMatch()) mVersion = match.captured(1); if (mVersion.isEmpty()) mName = "SDCC"; else mName = "SDCC "+mVersion; mCompilerType=CompilerType::SDCC; addExistingDirectory(mBinDirs, binDir); } #endif QStringList Settings::CompilerSet::defines(bool isCpp) { // get default defines QStringList arguments; arguments.append("-dM"); arguments.append("-E"); arguments.append("-x"); QString key; #ifdef ENABLE_SDCC if (mCompilerType==CompilerType::SDCC) { arguments.append("c"); arguments.append("-V"); key=SDCC_CMD_OPT_PROCESSOR; //language standard PCompilerOption pOption = CompilerInfoManager::getCompilerOption(compilerType(), key); if (pOption) { if (!mCompileOptions[key].isEmpty()) arguments.append(pOption->setting + mCompileOptions[key]); } key=SDCC_CMD_OPT_STD; //language standard pOption = CompilerInfoManager::getCompilerOption(compilerType(), key); if (pOption) { if (!mCompileOptions[key].isEmpty()) arguments.append(pOption->setting + mCompileOptions[key]); } } else { #endif if (isCpp) { arguments.append("c++"); key=CC_CMD_OPT_STD; } else { arguments.append("c"); key=C_CMD_OPT_STD; } //language standard PCompilerOption pOption = CompilerInfoManager::getCompilerOption(compilerType(), key); if (pOption) { if (!mCompileOptions[key].isEmpty()) arguments.append(pOption->setting + mCompileOptions[key]); } pOption = CompilerInfoManager::getCompilerOption(compilerType(), CC_CMD_OPT_DEBUG_INFO); if (pOption && mCompileOptions.contains(CC_CMD_OPT_DEBUG_INFO)) { arguments.append(pOption->setting); } #ifdef ENABLE_SDCC } #endif if (mUseCustomCompileParams) { QStringList extraParams = parseArgumentsWithoutVariables(mCustomCompileParams); arguments.append(extraParams); } if (arguments.contains("-g3")) arguments.append("-D_DEBUG"); arguments.append(NULL_FILE); QFileInfo ccompiler(mCCompiler); QByteArray output = getCompilerOutput(ccompiler.absolutePath(),ccompiler.fileName(),arguments); // 'cpp.exe -dM -E -x c++ -std=c++17 NUL' // qDebug()<<"------------------"; QStringList result; #ifdef ENABLE_SDCC if (mCompilerType==CompilerType::SDCC) { QList lines = output.split('\n'); QByteArray currentLine; for (QByteArray& line:lines) { QByteArray trimmedLine = line.trimmed(); if (trimmedLine.startsWith("+")) { currentLine = line; break; } } lines = currentLine.split(' '); for (QByteArray& line:lines) { QByteArray trimmedLine = line.trimmed(); if (trimmedLine.startsWith("-D")) { trimmedLine = trimmedLine.mid(2); if (trimmedLine.contains("=")) { QList items=trimmedLine.split('='); result.append(QString("#define %1 %2").arg(QString(items[0]),QString(items[1]))); } else { result.append("#define "+trimmedLine); } } } } else { #else { #endif QList lines = output.split('\n'); for (QByteArray& line:lines) { QByteArray trimmedLine = line.trimmed(); if (!trimmedLine.isEmpty()) { result.append(trimmedLine); } } } return result; } void Settings::CompilerSet::setExecutables() { if (mCompilerType == CompilerType::Clang) { mCCompiler = findProgramInBinDirs(CLANG_PROGRAM); mCppCompiler = findProgramInBinDirs(CLANG_CPP_PROGRAM); mDebugger = findProgramInBinDirs(GDB_PROGRAM); if (mDebugger.isEmpty()) { mDebugger = findProgramInBinDirs(LLDB_MI_PROGRAM); mDebugServer = findProgramInBinDirs(LLDB_SERVER_PROGRAM); } else { mDebugServer = findProgramInBinDirs(GDB_SERVER_PROGRAM); } if (mCCompiler.isEmpty()) mCCompiler = findProgramInBinDirs(GCC_PROGRAM); if (mCppCompiler.isEmpty()) mCppCompiler = findProgramInBinDirs(GPP_PROGRAM); #ifdef ENABLE_SDCC } else if (mCompilerType == CompilerType::SDCC) { mCCompiler = findProgramInBinDirs(SDCC_PROGRAM); if (mCCompiler.isEmpty()) mCCompiler = findProgramInBinDirs(SDCC_PROGRAM); #endif } else { mCCompiler = findProgramInBinDirs(GCC_PROGRAM); mCppCompiler = findProgramInBinDirs(GPP_PROGRAM); mDebugger = findProgramInBinDirs(GDB_PROGRAM); mDebugServer = findProgramInBinDirs(GDB_SERVER_PROGRAM); } mMake = findProgramInBinDirs(MAKE_PROGRAM); #ifdef Q_OS_WIN mResourceCompiler = findProgramInBinDirs(WINDRES_PROGRAM); #endif } void Settings::CompilerSet::setDirectories(const QString& binDir) { #ifdef ENABLE_SDCC if (mCompilerType == CompilerType::SDCC) { setSDCCDirectories(binDir); } else { #endif setGCCDirectories(binDir); #ifdef ENABLE_SDCC } #endif } void Settings::CompilerSet::setGCCDirectories(const QString& binDir) { QString folder = QFileInfo(binDir).absolutePath(); QString c_prog; if (mCompilerType==CompilerType::Clang) c_prog = CLANG_PROGRAM; else c_prog = GCC_PROGRAM; // Find default directories // C include dirs QStringList arguments; arguments.clear(); arguments.append("-xc"); arguments.append("-v"); arguments.append("-E"); arguments.append(NULL_FILE); QByteArray output = getCompilerOutput(binDir,c_prog,arguments); int delimPos1 = output.indexOf("#include <...> search starts here:"); int delimPos2 = output.indexOf("End of search list."); if (delimPos1 >0 && delimPos2>0 ) { delimPos1 += QByteArray("#include <...> search starts here:").length(); QList lines = output.mid(delimPos1, delimPos2-delimPos1).split('\n'); for (QByteArray& line:lines) { QByteArray trimmedLine = line.trimmed(); if (!trimmedLine.isEmpty()) { addExistingDirectory(mDefaultCIncludeDirs,trimmedLine); } } } // Find default directories // C++ include dirs arguments.clear(); arguments.append("-xc++"); arguments.append("-E"); arguments.append("-v"); arguments.append(NULL_FILE); output = getCompilerOutput(binDir,c_prog,arguments); //gcc -xc++ -E -v NUL delimPos1 = output.indexOf("#include <...> search starts here:"); delimPos2 = output.indexOf("End of search list."); if (delimPos1 >0 && delimPos2>0 ) { delimPos1 += QByteArray("#include <...> search starts here:").length(); QList lines = output.mid(delimPos1, delimPos2-delimPos1).split('\n'); for (QByteArray& line:lines) { QByteArray trimmedLine = line.trimmed(); if (!trimmedLine.isEmpty()) { addExistingDirectory(mDefaultCppIncludeDirs,trimmedLine); } } } // Find default directories arguments.clear(); arguments.append("-print-search-dirs"); arguments.append(NULL_FILE); output = getCompilerOutput(binDir,c_prog,arguments); // bin dirs QByteArray targetStr = QByteArray("programs: ="); delimPos1 = output.indexOf(targetStr); if (delimPos1>=0) { delimPos1+=targetStr.length(); delimPos2 = delimPos1; while (delimPos2 < output.length() && output[delimPos2]!='\n') delimPos2+=1; QList lines = output.mid(delimPos1,delimPos2-delimPos1).split(';'); for (QByteArray& line:lines) { QByteArray trimmedLine = line.trimmed(); if (!trimmedLine.isEmpty()) addExistingDirectory(mBinDirs,trimmedLine); } } // lib dirs targetStr = QByteArray("libraries: ="); delimPos1 = output.indexOf(targetStr); if (delimPos1>=0) { delimPos1+=targetStr.length(); delimPos2 = delimPos1; while (delimPos2 < output.length() && output[delimPos2]!='\n') delimPos2+=1; QList lines = output.mid(delimPos1,delimPos2-delimPos1).split(';'); for (QByteArray& line:lines) { QByteArray trimmedLine = line.trimmed(); if (!trimmedLine.isEmpty()) addExistingDirectory(mDefaultLibDirs,trimmedLine); } } // Try to obtain our target/autoconf folder if (!mDumpMachine.isEmpty()) { //mingw-w64 bin folder addExistingDirectory(mBinDirs, includeTrailingPathDelimiter(folder) + "lib/" "gcc/" + mDumpMachine + "/" + mVersion); // Regular include folder addExistingDirectory(mDefaultCIncludeDirs, includeTrailingPathDelimiter(folder) + mDumpMachine + "/include"); addExistingDirectory(mDefaultCppIncludeDirs, includeTrailingPathDelimiter(folder)+ mDumpMachine + "/include"); // Other include folder? addExistingDirectory(mDefaultCIncludeDirs, includeTrailingPathDelimiter(folder) + "lib/gcc/" + mDumpMachine + "/" + mVersion + "/include"); addExistingDirectory(mDefaultCppIncludeDirs, includeTrailingPathDelimiter(folder) + "lib/gcc/" + mDumpMachine + "/" + mVersion + "/include"); addExistingDirectory(mDefaultCIncludeDirs, includeTrailingPathDelimiter(folder) + "lib/gcc/" + mDumpMachine + "/" + mVersion + "/include-fixed"); addExistingDirectory(mDefaultCppIncludeDirs, includeTrailingPathDelimiter(folder) + "lib/gcc/" + mDumpMachine + "/" + mVersion + "/include-fixed"); // C++ only folder (mingw.org) addExistingDirectory(mDefaultCppIncludeDirs, includeTrailingPathDelimiter(folder) + "lib/gcc/" + mDumpMachine + "/" + mVersion + "/include/c++"); addExistingDirectory(mDefaultCppIncludeDirs, includeTrailingPathDelimiter(folder) + "lib/gcc/" + mDumpMachine + "/" + mVersion + "/include/c++/" + mDumpMachine); addExistingDirectory(mDefaultCppIncludeDirs, includeTrailingPathDelimiter(folder) + "lib/gcc/" + mDumpMachine + "/" + mVersion + "/include/c++/backward"); // C++ only folder (Mingw-w64) addExistingDirectory(mDefaultCppIncludeDirs, includeTrailingPathDelimiter(folder) + "include/c++/" + mVersion ); addExistingDirectory(mDefaultCppIncludeDirs, includeTrailingPathDelimiter(folder) + "include/c++/" + mVersion + "/backward"); addExistingDirectory(mDefaultCppIncludeDirs, includeTrailingPathDelimiter(folder) + "include/c++/" + mVersion + "/" + mDumpMachine); } } #ifdef ENABLE_SDCC void Settings::CompilerSet::setSDCCDirectories(const QString& binDir) { QString folder = QFileInfo(binDir).absolutePath(); QString c_prog = SDCC_PROGRAM; // Find default directories // C include dirs QStringList arguments; arguments.clear(); arguments.append("--print-search-dirs"); QString key = SDCC_CMD_OPT_PROCESSOR; PCompilerOption pOption = CompilerInfoManager::getCompilerOption(compilerType(), key); if (pOption) { if (!mCompileOptions[key].isEmpty()) arguments.append(pOption->setting + mCompileOptions[key]); } QByteArray output = getCompilerOutput(binDir,c_prog,arguments); //bindirs QByteArray targetStr = QByteArray("programs:"); int delimPos1 = output.indexOf(targetStr); int delimPos2 = output.indexOf("datadir:"); if (delimPos1 >0 && delimPos2>delimPos1 ) { delimPos1 += targetStr.length(); QList lines = output.mid(delimPos1, delimPos2-delimPos1).split('\n'); for (QByteArray& line:lines) { QByteArray trimmedLine = line.trimmed(); if (!trimmedLine.isEmpty()) { addExistingDirectory(mBinDirs,trimmedLine); } } } targetStr = QByteArray("includedir:"); delimPos1 = output.indexOf(targetStr); delimPos2 = output.indexOf("libdir:"); if (delimPos1 >0 && delimPos2>delimPos1 ) { delimPos1 += targetStr.length(); QList lines = output.mid(delimPos1, delimPos2-delimPos1).split('\n'); for (QByteArray& line:lines) { QByteArray trimmedLine = line.trimmed(); if (!trimmedLine.isEmpty()) { addExistingDirectory(mDefaultCIncludeDirs,trimmedLine); } } } targetStr = QByteArray("libdir:"); delimPos1 = output.indexOf(targetStr); delimPos2 = output.indexOf("libpath:"); if (delimPos1 >0 && delimPos2>delimPos1 ) { delimPos1 += targetStr.length(); QList lines = output.mid(delimPos1, delimPos2-delimPos1).split('\n'); for (QByteArray& line:lines) { QByteArray trimmedLine = line.trimmed(); if (!trimmedLine.isEmpty()) { addExistingDirectory(mDefaultLibDirs,trimmedLine); } } } } #endif int Settings::CompilerSet::mainVersion() const { int i = mVersion.indexOf('.'); if (i<0) return -1; bool ok; int num = mVersion.left(i).toInt(&ok); if (!ok) return -1; return num; } bool Settings::CompilerSet::canCompileC() const { return fileExists(mCCompiler); } bool Settings::CompilerSet::canCompileCPP() const { #ifdef ENABLE_SDCC if (mCompilerType==CompilerType::SDCC) return false; #endif return fileExists(mCppCompiler); } bool Settings::CompilerSet::canMake() const { return fileExists(mMake); } bool Settings::CompilerSet::canDebug() const { #ifdef ENABLE_SDCC if (mCompilerType==CompilerType::SDCC) return false; #endif return fileExists(mDebugger); } void Settings::CompilerSet::setUserInput() { mUseCustomCompileParams = false; mUseCustomLinkParams = false; #ifdef ENABLE_SDCC if (mCompilerType==CompilerType::SDCC) { mAutoAddCharsetParams = false; mStaticLink = false; } else { #else { #endif mAutoAddCharsetParams = true; mStaticLink = true; } } QString Settings::CompilerSet::findProgramInBinDirs(const QString name) const { for (const QString& dir : mBinDirs) { QFileInfo f(includeTrailingPathDelimiter(dir) + name); if (f.exists() && f.isExecutable()) { return f.absoluteFilePath(); } } return QString(); } void Settings::CompilerSet::setIniOptions(const QByteArray &value) { if (value.isEmpty()) return; mCompileOptions.clear(); for (int i=0;icompilerSets().getKeyFromCompilerCompatibleIndex(i); setCompileOption(key,charToValue(value[i])); } } QByteArray Settings::CompilerSet::getCompilerOutput(const QString &binDir, const QString &binFile, const QStringList &arguments) { QProcessEnvironment env; env.insert("LANG","en"); QString path = binDir; env.insert("PATH",path); QByteArray result = runAndGetOutput( includeTrailingPathDelimiter(binDir)+binFile, binDir, arguments, QByteArray(), false, env); return result.trimmed(); } bool Settings::CompilerSet::forceEnglishOutput() const { return mForceEnglishOutput; } void Settings::CompilerSet::setForceEnglishOutput(bool newForceEnglishOutput) { mForceEnglishOutput = newForceEnglishOutput; } bool Settings::CompilerSet::persistInAutoFind() const { return mPersistInAutoFind; } void Settings::CompilerSet::setPersistInAutoFind(bool newPersistInAutoFind) { mPersistInAutoFind = newPersistInAutoFind; } Settings::CompilerSet::CompilationStage Settings::CompilerSet::compilationStage() const { return mCompilationStage; } void Settings::CompilerSet::setCompilationStage(CompilationStage newCompilationStage) { mCompilationStage = newCompilationStage; } QString Settings::CompilerSet::getOutputFilename(const QString &sourceFilename) { return getOutputFilename(sourceFilename, compilationStage()); } QString Settings::CompilerSet::getOutputFilename(const QString &sourceFilename, CompilationStage stage) { switch(stage) { case Settings::CompilerSet::CompilationStage::PreprocessingOnly: return changeFileExt(sourceFilename, preprocessingSuffix()); case Settings::CompilerSet::CompilationStage::CompilationProperOnly: return changeFileExt(sourceFilename, compilationProperSuffix()); case Settings::CompilerSet::CompilationStage::AssemblingOnly: return changeFileExt(sourceFilename, assemblingSuffix()); case Settings::CompilerSet::CompilationStage::GenerateExecutable: return changeFileExt(sourceFilename, executableSuffix()); } return changeFileExt(sourceFilename,DEFAULT_EXECUTABLE_SUFFIX); } bool Settings::CompilerSet::isOutputExecutable() { return isOutputExecutable(mCompilationStage); } bool Settings::CompilerSet::isOutputExecutable(CompilationStage stage) { return stage == CompilationStage::GenerateExecutable; } bool Settings::CompilerSet::isDebugInfoUsingUTF8() const { switch(mCompilerType) { case CompilerType::Clang: case CompilerType::GCC_UTF8: return true; case CompilerType::GCC: #ifdef Q_OS_WIN if (mainVersion()>=13) { bool isOk; int productVersion = QSysInfo::productVersion().toInt(&isOk); // qDebug()<=10; } #else break; #endif default: break; } return false; } bool Settings::CompilerSet::forceUTF8() const { return CompilerInfoManager::forceUTF8InDebugger(mCompilerType); } bool Settings::CompilerSet::isCompilerInfoUsingUTF8() const { return isDebugInfoUsingUTF8(); } const QString &Settings::CompilerSet::assemblingSuffix() const { return mAssemblingSuffix; } void Settings::CompilerSet::setAssemblingSuffix(const QString &newAssemblingSuffix) { mAssemblingSuffix = newAssemblingSuffix; } const QString &Settings::CompilerSet::compilationProperSuffix() const { return mCompilationProperSuffix; } void Settings::CompilerSet::setCompilationProperSuffix(const QString &newCompilationProperSuffix) { mCompilationProperSuffix = newCompilationProperSuffix; } const QString &Settings::CompilerSet::preprocessingSuffix() const { return mPreprocessingSuffix; } void Settings::CompilerSet::setPreprocessingSuffix(const QString &newPreprocessingSuffix) { mPreprocessingSuffix = newPreprocessingSuffix; } const QString &Settings::CompilerSet::executableSuffix() const { return mExecutableSuffix; } void Settings::CompilerSet::setExecutableSuffix(const QString &newExecutableSuffix) { mExecutableSuffix = newExecutableSuffix; } const QMap &Settings::CompilerSet::compileOptions() const { return mCompileOptions; } const QString &Settings::CompilerSet::execCharset() const { return mExecCharset; } void Settings::CompilerSet::setExecCharset(const QString &newExecCharset) { mExecCharset = newExecCharset; } const QString &Settings::CompilerSet::debugServer() const { return mDebugServer; } void Settings::CompilerSet::setDebugServer(const QString &newDebugServer) { mDebugServer = newDebugServer; } void Settings::CompilerSet::setCompilerType(CompilerType newCompilerType) { mCompilerType = newCompilerType; } CompilerType Settings::CompilerSet::compilerType() const { return mCompilerType; } bool Settings::CompilerSet::staticLink() const { return mStaticLink; } void Settings::CompilerSet::setStaticLink(bool newStaticLink) { mStaticLink = newStaticLink; } bool Settings::CompilerSet::useCustomCompileParams() const { return mUseCustomCompileParams; } Settings::CompilerSets::CompilerSets(Settings *settings): mDefaultIndex(-1), mSettings(settings) { prepareCompatibleIndex(); } Settings::PCompilerSet Settings::CompilerSets::addSet() { PCompilerSet p=std::make_shared(); mList.push_back(p); return p; } Settings::PCompilerSet Settings::CompilerSets::addSet(const QString &folder, const QString& c_prog) { PCompilerSet p=std::make_shared(folder,c_prog); if (c_prog==GCC_PROGRAM && p->compilerType()==CompilerType::Clang) return PCompilerSet(); mList.push_back(p); return p; } Settings::PCompilerSet Settings::CompilerSets::addSet(const PCompilerSet &pSet) { PCompilerSet p=std::make_shared(*pSet); mList.push_back(p); return p; } Settings::PCompilerSet Settings::CompilerSets::addSet(const QJsonObject &set) { PCompilerSet p = std::make_shared(set); mList.push_back(p); return p; } static void set64_32Options(Settings::PCompilerSet pSet) { pSet->setCompileOption(CC_CMD_OPT_POINTER_SIZE,"32"); } static void setReleaseOptions(Settings::PCompilerSet pSet) { pSet->setCompileOption(CC_CMD_OPT_OPTIMIZE,"2"); pSet->setCompileOption(LINK_CMD_OPT_STRIP_EXE, COMPILER_OPTION_ON); pSet->setCompileOption(CC_CMD_OPT_USE_PIPE, COMPILER_OPTION_ON); pSet->setStaticLink(true); } static void setDebugOptions(Settings::PCompilerSet pSet, bool enableAsan = false) { //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); pSet->setCompileOption(CC_CMD_OPT_USE_PIPE, COMPILER_OPTION_ON); if (enableAsan) { #ifdef __aarch64__ pSet->setCompileOption(CC_CMD_OPT_ADDRESS_SANITIZER, "hwaddress"); #else pSet->setCompileOption(CC_CMD_OPT_ADDRESS_SANITIZER, "address"); #endif } //Some windows gcc don't correctly support this //pSet->setCompileOption(CC_CMD_OPT_STACK_PROTECTOR, "-strong"); pSet->setStaticLink(false); } bool Settings::CompilerSets::addSets(const QString &folder, const QString& c_prog) { foreach (const PCompilerSet& set, mList) { if (set->binDirs().contains(folder) && extractFileName(set->CCompiler())==c_prog) return false; } // Default, release profile PCompilerSet baseSet = addSet(folder,c_prog); if (!baseSet || baseSet->name().isEmpty()) return false; #if ENABLE_SDCC if (c_prog == SDCC_PROGRAM) { baseSet->setCompileOption(SDCC_OPT_NOSTARTUP,COMPILER_OPTION_ON); } else { #else { #endif QString baseName = baseSet->name(); QString platformName; if (isTarget64Bit(baseSet->target())) { if (baseName.startsWith("TDM-GCC ")) { PCompilerSet set= addSet(baseSet); platformName = "32-bit"; set->setName(baseName + " " + platformName + " Release"); set64_32Options(set); setReleaseOptions(set); set = addSet(baseSet); set->setName(baseName + " " + platformName + " Debug"); set64_32Options(set); setDebugOptions(set); } platformName = "64-bit"; } else { platformName = "32-bit"; } PCompilerSet debugSet = addSet(baseSet); debugSet->setName(baseName + " " + platformName + " Debug"); setDebugOptions(debugSet); // Enable ASan compiler set if it is supported and gdb works with ASan. #ifdef Q_OS_LINUX PCompilerSet debugAsanSet = addSet(baseSet); debugAsanSet->setName(baseName + " " + platformName + " Debug with ASan"); setDebugOptions(debugAsanSet, true); #endif baseSet->setName(baseName + " " + platformName + " Release"); setReleaseOptions(baseSet); } #ifdef Q_OS_LINUX # if defined(__x86_64__) || defined(__aarch64__) || __SIZEOF_POINTER__ == 4 mDefaultIndex = (int)mList.size() - 1; // x86-64, AArch64 Linux or 32-bit Unix, default to "debug with ASan" # else mDefaultIndex = (int)mList.size() - 2; // other Unix, where ASan can be very slow, default to "debug" # endif #else mDefaultIndex = (int)mList.size() - 1; #endif return true; } bool Settings::CompilerSets::addSets(const QString &folder) { bool found = false; if (!directoryExists(folder)) return found; if (fileExists(folder, GCC_PROGRAM)) { addSets(folder,GCC_PROGRAM); found=true; } if (fileExists(folder, CLANG_PROGRAM)) { addSets(folder,CLANG_PROGRAM); found=true; } #ifdef ENABLE_SDCC //qDebug()<mSettings.beginGroup(QString(SETTING_COMPILTER_SET).arg(i)); mSettings->mSettings.remove(""); mSettings->mSettings.endGroup(); if (mList[i]->persistInAutoFind()) persisted.push_back(std::move(mList[i])); } mList.clear(); mDefaultIndex = -1; return persisted; } void Settings::CompilerSets::findSets() { CompilerSetList persisted = clearSets(); // canonical paths that has been searched. // use canonical paths here to resolve symbolic links. QSet searched; #ifdef ENABLE_LUA_ADDON QJsonObject compilerHint; if ( QFile scriptFile(pSettings->dirs().appLibexecDir() + "/compiler_hint.lua"); scriptFile.exists() && scriptFile.open(QFile::ReadOnly) ) { QByteArray script = scriptFile.readAll(); try { compilerHint = AddOn::CompilerHintExecutor{}(script); } catch (const AddOn::LuaError &e) { QMessageBox::critical(nullptr, QObject::tr("Error executing platform compiler hint add-on"), e.reason()); } if (!compilerHint.empty()) { QJsonArray compilerList = compilerHint["compilerList"].toArray(); for (const QJsonValue &value : compilerList) { addSet(value.toObject()); } QJsonArray noSearch = compilerHint["noSearch"].toArray(); QString canonicalPath; for (const QJsonValue &value : noSearch) { canonicalPath = QDir(value.toString()).canonicalPath(); if (!canonicalPath.isEmpty()) searched.insert(canonicalPath); } } } #endif QProcessEnvironment env = QProcessEnvironment::systemEnvironment(); QString path = env.value("PATH"); QStringList pathList = path.split(PATH_SEPARATOR); #ifdef Q_OS_WIN pathList = QStringList{ mSettings->dirs().appDir() + "/Clang64/bin", mSettings->dirs().appDir() + "/MinGW64/bin", mSettings->dirs().appDir() + "/MinGW32/bin", } + pathList; #endif QString folder, canonicalFolder; for (int i=pathList.count()-1;i>=0;i--) { folder = QDir(pathList[i]).absolutePath(); canonicalFolder = QDir(pathList[i]).canonicalPath(); if (canonicalFolder.isEmpty()) continue; if (searched.contains(canonicalFolder)) continue; searched.insert(canonicalFolder); // but use absolute path to search so compiler set can survive system upgrades. // during search: // /opt/gcc-13 -> /opt/gcc-13.1.0 // after upgrade: // /opt/gcc-13 -> /opt/gcc-13.2.0 addSets(folder); } #ifdef ENABLE_LUA_ADDON if ( // note that array index starts from 1 in Lua int preferCompilerInLua = compilerHint["preferCompiler"].toInt(); preferCompilerInLua >= 1 && preferCompilerInLua <= (int)mList.size() ) { mDefaultIndex = preferCompilerInLua - 1; } #endif for (PCompilerSet &set: persisted) addSet(set); } void Settings::CompilerSets::saveSets() { for (size_t i=0;i=(int)mList.size()) { setDefaultIndex( mList.size()-1 ); } mSettings->mSettings.beginGroup(SETTING_COMPILTER_SETS); mSettings->mSettings.setValue(SETTING_COMPILTER_SETS_DEFAULT_INDEX,mDefaultIndex); mSettings->mSettings.setValue(SETTING_COMPILTER_SETS_DEFAULT_INDEX_TIMESTAMP,mDefaultIndexTimeStamp); mSettings->mSettings.setValue(SETTING_COMPILTER_SETS_COUNT,(int)mList.size()); mSettings->mSettings.endGroup(); } void Settings::CompilerSets::loadSets() { mList.clear(); mSettings->mSettings.beginGroup(SETTING_COMPILTER_SETS); mDefaultIndex = mSettings->mSettings.value(SETTING_COMPILTER_SETS_DEFAULT_INDEX,-1).toInt(); mDefaultIndexTimeStamp = mSettings->mSettings.value(SETTING_COMPILTER_SETS_DEFAULT_INDEX_TIMESTAMP,0).toLongLong(); //fix error time if (mDefaultIndexTimeStamp > QDateTime::currentMSecsSinceEpoch()) mDefaultIndexTimeStamp = QDateTime::currentMSecsSinceEpoch(); int listSize = mSettings->mSettings.value(SETTING_COMPILTER_SETS_COUNT,0).toInt(); mSettings->mSettings.endGroup(); bool loadError = false; for (int i=0;idirsValid(msg)) { // if (QMessageBox::warning(nullptr,QObject::tr("Confirm"), // QObject::tr("The following problems were found during validation of compiler set \"%1\":") // .arg(pCurrentSet->name()) // +"

" // +msg // +"

" // +QObject::tr("Leaving those directories will lead to problems during compilation.") // +"

" // +QObject::tr("Would you like Red Panda C++ to remove them for you and add the default paths to the valid paths?") // , // QMessageBox::Yes | QMessageBox::No) != QMessageBox::Yes) { // return; // } // findSets(); // if ( (int)mList.size() <= mDefaultIndex) // mDefaultIndex = mList.size()-1; // pCurrentSet = defaultSet(); // if (!pCurrentSet) { // mList.clear(); // mDefaultIndex = -1; // saveSets(); // return; // } // saveSets(); // pCurrentSet->setProperties(pCurrentSet->CCompiler()); // } else { // return; // } return; } else { #ifdef Q_OS_WIN QString msg = QObject::tr("Compiler set not configuared.") +"

" +QObject::tr("Would you like Red Panda C++ to search for compilers in the following locations:
'%1'
'%2'? ") .arg(includeTrailingPathDelimiter(pSettings->dirs().appDir()) + "MinGW32") .arg(includeTrailingPathDelimiter(pSettings->dirs().appDir()) + "MinGW64"); #else QString msg = QObject::tr("Compiler set not configuared.") +"

" +QObject::tr("Would you like Red Panda C++ to search for compilers in PATH?"); #endif if (QMessageBox::warning(nullptr,QObject::tr("Confirm"), msg, QMessageBox::Yes | QMessageBox::No) != QMessageBox::Yes) { return; } findSets(); pCurrentSet = defaultSet(); if (!pCurrentSet) { mList.clear(); setDefaultIndex(-1); saveSets(); return; } saveSets(); } } void Settings::CompilerSets::saveDefaultIndex() { mSettings->mSettings.beginGroup(SETTING_COMPILTER_SETS); mSettings->mSettings.setValue(SETTING_COMPILTER_SETS_DEFAULT_INDEX,mDefaultIndex); mSettings->mSettings.setValue(SETTING_COMPILTER_SETS_DEFAULT_INDEX_TIMESTAMP,mDefaultIndexTimeStamp); mSettings->mSettings.endGroup(); } void Settings::CompilerSets::deleteSet(int index) { // Erase all sections at and above from disk for (size_t i=index;imSettings.beginGroup(QString(SETTING_COMPILTER_SET).arg(i)); mSettings->mSettings.remove(""); mSettings->mSettings.endGroup(); } mList.erase(std::begin(mList)+index); saveSets(); } size_t Settings::CompilerSets::size() const { return mList.size(); } int Settings::CompilerSets::defaultIndex() const { return mDefaultIndex; } qint64 Settings::CompilerSets::defaultIndexTimestamp() const { return mDefaultIndexTimeStamp; } void Settings::CompilerSets::setDefaultIndex(int value) { mDefaultIndex = value; mDefaultIndexTimeStamp = QDateTime::currentMSecsSinceEpoch(); } Settings::PCompilerSet Settings::CompilerSets::defaultSet() { return getSet(mDefaultIndex); } Settings::PCompilerSet Settings::CompilerSets::getSet(int index) { if (index>=0 && index<(int)mList.size()) { return mList[index]; } return PCompilerSet(); } void Settings::CompilerSets::savePath(const QString& name, const QString& path) { QString s; QString prefix1 = excludeTrailingPathDelimiter(mSettings->mDirs.appDir()) + "/"; QString prefix2 = excludeTrailingPathDelimiter(mSettings->mDirs.appDir()) + QDir::separator(); if (path.startsWith(prefix1, PATH_SENSITIVITY)) { s = "%AppPath%/"+ path.mid(prefix1.length()); } else if (path.startsWith(prefix2, PATH_SENSITIVITY)) { s = "%AppPath%/"+ path.mid(prefix2.length()); } else { s= path; } mSettings->mSettings.setValue(name,s); } void Settings::CompilerSets::savePathList(const QString& name, const QStringList& pathList) { QStringList sl; for (const QString& path: pathList) { QString s; QString prefix1 = excludeTrailingPathDelimiter(mSettings->mDirs.appDir()) + "/"; QString prefix2 = excludeTrailingPathDelimiter(mSettings->mDirs.appDir()) + QDir::separator(); if (path.startsWith(prefix1, PATH_SENSITIVITY)) { s = "%AppPath%/"+ path.mid(prefix1.length()); } else if (path.startsWith(prefix2, PATH_SENSITIVITY)) { s = "%AppPath%/" + path.mid(prefix2.length()); } else { s= path; } sl.append(s); } mSettings->mSettings.setValue(name,sl); } void Settings::CompilerSets::saveSet(int index) { PCompilerSet pSet = mList[index]; mSettings->mSettings.beginGroup(QString(SETTING_COMPILTER_SET).arg(index)); savePath("ccompiler", pSet->CCompiler()); savePath("cppcompiler", pSet->cppCompiler()); savePath("debugger", pSet->debugger()); savePath("debug_server", pSet->debugServer()); savePath("make", pSet->make()); savePath("windres", pSet->resourceCompiler()); mSettings->mSettings.remove("Options"); foreach(const PCompilerOption& option, CompilerInfoManager::getInstance()->getCompilerOptions(pSet->compilerType())) { mSettings->mSettings.remove(option->key); } // Save option string for (const QString& optionKey : pSet->compileOptions().keys()) { mSettings->mSettings.setValue(optionKey, pSet->compileOptions().value(optionKey)); } // Save extra 'general' options mSettings->mSettings.setValue("useCustomCompileParams", pSet->useCustomCompileParams()); mSettings->mSettings.setValue("customCompileParams", pSet->customCompileParams()); mSettings->mSettings.setValue("useCustomLinkParams", pSet->useCustomLinkParams()); mSettings->mSettings.setValue("customLinkParams", pSet->customLinkParams()); mSettings->mSettings.setValue("AddCharset", pSet->autoAddCharsetParams()); mSettings->mSettings.setValue("StaticLink", pSet->staticLink()); mSettings->mSettings.setValue("ExecCharset", pSet->execCharset()); mSettings->mSettings.setValue("PersistInAutoFind", pSet->persistInAutoFind()); mSettings->mSettings.setValue("forceEnglishOutput", pSet->forceEnglishOutput()); mSettings->mSettings.setValue("preprocessingSuffix", pSet->preprocessingSuffix()); mSettings->mSettings.setValue("compilationProperSuffix", pSet->compilationProperSuffix()); mSettings->mSettings.setValue("assemblingSuffix", pSet->assemblingSuffix()); mSettings->mSettings.setValue("executableSuffix", pSet->executableSuffix()); mSettings->mSettings.setValue("compilationStage", (int)pSet->compilationStage()); // Misc. properties mSettings->mSettings.setValue("DumpMachine", pSet->dumpMachine()); mSettings->mSettings.setValue("Version", pSet->version()); mSettings->mSettings.setValue("Type", pSet->type()); mSettings->mSettings.setValue("Name", pSet->name()); mSettings->mSettings.setValue("Target", pSet->target()); mSettings->mSettings.setValue("CompilerType", (int)pSet->compilerType()); // Paths savePathList("Bins",pSet->binDirs()); savePathList("C",pSet->CIncludeDirs()); savePathList("Cpp",pSet->CppIncludeDirs()); savePathList("Libs",pSet->libDirs()); mSettings->mSettings.endGroup(); } QString Settings::CompilerSets::loadPath(const QString &name) { QString s = mSettings->mSettings.value(name).toString(); QString prefix = "%AppPath%/"; if (s.startsWith(prefix)) { s = includeTrailingPathDelimiter(mSettings->mDirs.appDir()) + s.mid(prefix.length()); } return QFileInfo(s).absoluteFilePath(); } void Settings::CompilerSets::loadPathList(const QString &name, QStringList& list) { list.clear(); QStringList sl = mSettings->mSettings.value(name).toStringList(); QString prefix = "%AppPath%/"; for (QString& s:sl) { if (s.startsWith(prefix)) { s = includeTrailingPathDelimiter(mSettings->mDirs.appDir()) + s.mid(prefix.length()); } list.append(QFileInfo(s).absoluteFilePath()); } } Settings::PCompilerSet Settings::CompilerSets::loadSet(int index) { PCompilerSet pSet = std::make_shared(); mSettings->mSettings.beginGroup(QString(SETTING_COMPILTER_SET).arg(index)); pSet->setCCompiler(loadPath("ccompiler")); pSet->setCppCompiler(loadPath("cppcompiler")); pSet->setDebugger(loadPath("debugger")); pSet->setDebugServer(loadPath("debug_server")); pSet->setMake(loadPath("make")); pSet->setResourceCompiler(loadPath("windres")); pSet->setDumpMachine(mSettings->mSettings.value("DumpMachine").toString()); pSet->setVersion(mSettings->mSettings.value("Version").toString()); pSet->setType(mSettings->mSettings.value("Type").toString()); pSet->setName(mSettings->mSettings.value("Name").toString()); pSet->setTarget(mSettings->mSettings.value("Target").toString()); //compatibility QString temp = mSettings->mSettings.value("CompilerType").toString(); if (temp==COMPILER_CLANG) { pSet->setCompilerType(CompilerType::Clang); } else if (temp==COMPILER_GCC) { pSet->setCompilerType(CompilerType::GCC); } else if (temp==COMPILER_GCC_UTF8) { pSet->setCompilerType(CompilerType::GCC_UTF8); #ifdef ENABLE_SDCC } else if (temp==COMPILER_SDCC) { pSet->setCompilerType(CompilerType::SDCC); #endif } else { pSet->setCompilerType((CompilerType)mSettings->mSettings.value("CompilerType").toInt()); } // Load extra 'general' options pSet->setUseCustomCompileParams(mSettings->mSettings.value("useCustomCompileParams", false).toBool()); pSet->setCustomCompileParams(mSettings->mSettings.value("customCompileParams").toString()); pSet->setUseCustomLinkParams(mSettings->mSettings.value("useCustomLinkParams", false).toBool()); pSet->setCustomLinkParams(mSettings->mSettings.value("customLinkParams").toString()); pSet->setAutoAddCharsetParams(mSettings->mSettings.value("AddCharset", true).toBool()); pSet->setStaticLink(mSettings->mSettings.value("StaticLink", false).toBool()); pSet->setPersistInAutoFind(mSettings->mSettings.value("PersistInAutoFind", false).toBool()); bool forceEnglishOutput=QLocale::system().name().startsWith("zh")?false:true; pSet->setForceEnglishOutput(mSettings->mSettings.value("forceEnglishOutput", forceEnglishOutput).toBool()); pSet->setExecCharset(mSettings->mSettings.value("ExecCharset", ENCODING_SYSTEM_DEFAULT).toString()); if (pSet->execCharset().isEmpty()) { pSet->setExecCharset(ENCODING_SYSTEM_DEFAULT); } pSet->setPreprocessingSuffix(mSettings->mSettings.value("preprocessingSuffix", DEFAULT_PREPROCESSING_SUFFIX).toString()); pSet->setCompilationProperSuffix(mSettings->mSettings.value("compilationProperSuffix",DEFAULT_COMPILATION_SUFFIX).toString()); pSet->setAssemblingSuffix(mSettings->mSettings.value("assemblingSuffix", DEFAULT_ASSEMBLING_SUFFIX).toString()); pSet->setExecutableSuffix(mSettings->mSettings.value("executableSuffix", DEFAULT_EXECUTABLE_SUFFIX).toString()); pSet->setCompilationStage((Settings::CompilerSet::CompilationStage)mSettings->mSettings.value( "compilationStage", (int)Settings::CompilerSet::CompilationStage::GenerateExecutable).toInt()); // Load options QByteArray iniOptions = mSettings->mSettings.value("Options","").toByteArray(); if (!iniOptions.isEmpty()) pSet->setIniOptions(iniOptions); else { foreach (const QString &optionKey, mSettings->mSettings.allKeys()) { if (CompilerInfoManager::hasCompilerOption(pSet->compilerType(),optionKey)) { pSet->setCompileOption(optionKey, mSettings->mSettings.value(optionKey).toString()); } } } // Paths loadPathList("Bins",pSet->binDirs()); loadPathList("C",pSet->CIncludeDirs()); loadPathList("Cpp",pSet->CppIncludeDirs()); loadPathList("Libs",pSet->libDirs()); mSettings->mSettings.endGroup(); // if (pSet->binDirs().isEmpty()) // return PCompilerSet(); return pSet; } void Settings::CompilerSets::prepareCompatibleIndex() { //old settings compatibility, don't reorder, add or remove items mCompilerCompatibleIndex.append(CC_CMD_OPT_ANSI); mCompilerCompatibleIndex.append(CC_CMD_OPT_NO_ASM); mCompilerCompatibleIndex.append(CC_CMD_OPT_TRADITIONAL_CPP); mCompilerCompatibleIndex.append(CC_CMD_OPT_ARCH); mCompilerCompatibleIndex.append(CC_CMD_OPT_TUNE); mCompilerCompatibleIndex.append(CC_CMD_OPT_INSTRUCTION); mCompilerCompatibleIndex.append(CC_CMD_OPT_OPTIMIZE); mCompilerCompatibleIndex.append(CC_CMD_OPT_POINTER_SIZE); mCompilerCompatibleIndex.append(CC_CMD_OPT_STD); mCompilerCompatibleIndex.append(CC_CMD_OPT_INHIBIT_ALL_WARNING); mCompilerCompatibleIndex.append(CC_CMD_OPT_WARNING_ALL); mCompilerCompatibleIndex.append(CC_CMD_OPT_WARNING_EXTRA); mCompilerCompatibleIndex.append(CC_CMD_OPT_CHECK_ISO_CONFORMANCE); mCompilerCompatibleIndex.append(CC_CMD_OPT_SYNTAX_ONLY); mCompilerCompatibleIndex.append(CC_CMD_OPT_WARNING_AS_ERROR); mCompilerCompatibleIndex.append(CC_CMD_OPT_ABORT_ON_ERROR); mCompilerCompatibleIndex.append(CC_CMD_OPT_PROFILE_INFO); mCompilerCompatibleIndex.append(LINK_CMD_OPT_LINK_OBJC); mCompilerCompatibleIndex.append(LINK_CMD_OPT_NO_LINK_STDLIB); mCompilerCompatibleIndex.append(LINK_CMD_OPT_NO_CONSOLE); mCompilerCompatibleIndex.append(LINK_CMD_OPT_STRIP_EXE); mCompilerCompatibleIndex.append(CC_CMD_OPT_DEBUG_INFO); mCompilerCompatibleIndex.append(CC_CMD_OPT_VERBOSE_ASM); mCompilerCompatibleIndex.append(CC_CMD_OPT_ONLY_GEN_ASM_CODE); mCompilerCompatibleIndex.append(CC_CMD_OPT_USE_PIPE); } QString Settings::CompilerSets::getKeyFromCompilerCompatibleIndex(int idx) const { if (idx<0 || idx >= mCompilerCompatibleIndex.length()) return QString(); return mCompilerCompatibleIndex[idx]; } bool Settings::CompilerSets::isTarget64Bit(const QString &target) { /* Fetched from LLVM 15.0.6's arch parser, * `Triple::ArchType parseArch(StringRef ArchName)` * in `llvm/lib/Support/Triple.cpp`. * The following non-CPU targets are not included: * nvptx64, le64, amdil64, hsail64, spir64, spirv64, renderscript64. */ QSet targets { // x86_64 "amd64", "x86_64", "x86_64h", // ppc64 "powerpc64", "ppu", "ppc64", // ppc64le "powerpc64le", "ppc64le", // aarch64 "aarch64", "arm64", "arm64e", // aarch64_be "aarch64_be", // aarch64_32 "aarch64_32", "arm64_32", // mips64 "mips64", "mips64eb", "mipsn32", "mipsisa64r6", "mips64r6", "mipsn32r6", // mips64el "mips64el", "mipsn32el", "mipsisa64r6el", "mips64r6el", "mipsn32r6el", // riscv64 "riscv64", // systemz "s390x", "systemz", // sparcv9 "sparcv9", "sparc64", // wasm64 "wasm64", // loongarch64 "loongarch64", }; return targets.contains(target); } Settings::Environment::Environment(Settings *settings):_Base(settings, SETTING_ENVIRONMENT) { } void Settings::Environment::doLoad() { //Appearance mTheme = stringValue("theme","dark"); mInterfaceFont = stringValue("interface_font", defaultUiFont()); mInterfaceFontSize = intValue("interface_font_size",11); mIconZoomFactor = doubleValue("icon_zoom_factor",1.0); mLanguage = stringValue("language", QLocale::system().name()); mIconSet = stringValue("icon_set","contrast"); mUseCustomIconSet = boolValue("use_custom_icon_set", false); mUseCustomTheme = boolValue("use_custom_theme", false); mCurrentFolder = stringValue("current_folder",QDir::currentPath()); if (!fileExists(mCurrentFolder)) { mCurrentFolder = QDir::currentPath(); } mDefaultOpenFolder = stringValue("default_open_folder",QDir::currentPath()); if (!fileExists(mDefaultOpenFolder)) { mDefaultOpenFolder = QDir::currentPath(); } #ifdef Q_OS_WINDOWS # ifdef WINDOWS_PREFER_OPENCONSOLE // prefer UTF-8 compatible OpenConsole.exe mUseCustomTerminal = boolValue("use_custom_terminal", true); # else mUseCustomTerminal = boolValue("use_custom_terminal", false); # endif #else // UNIX mUseCustomTerminal = true; #endif // check saved terminal path mTerminalPath = stringValue("terminal_path", ""); #ifdef Q_OS_WINDOWS // APP_DIR trick for windows portable app // on other platforms multiple instances share the same configuration and thus the trick may break terminal path mTerminalPath.replace("%*APP_DIR*%",pSettings->dirs().appDir()); #endif mTerminalArgumentsPattern = stringValue("terminal_arguments_pattern", ""); checkAndSetTerminal(); mAStylePath = includeTrailingPathDelimiter(pSettings->dirs().appLibexecDir())+"astyle"; mHideNonSupportFilesInFileView=boolValue("hide_non_support_files_file_view",true); mOpenFilesInSingleInstance = boolValue("open_files_in_single_instance",false); } int Settings::Environment::interfaceFontSize() const { return mInterfaceFontSize; } void Settings::Environment::setInterfaceFontSize(int interfaceFontSize) { mInterfaceFontSize = interfaceFontSize; } QString Settings::Environment::language() const { return mLanguage; } void Settings::Environment::setLanguage(const QString &language) { mLanguage = language; } const QString &Settings::Environment::currentFolder() const { return mCurrentFolder; } void Settings::Environment::setCurrentFolder(const QString &newCurrentFolder) { mCurrentFolder = newCurrentFolder; } const QString &Settings::Environment::defaultOpenFolder() const { return mDefaultOpenFolder; } void Settings::Environment::setDefaultOpenFolder(const QString &newDefaultOpenFolder) { mDefaultOpenFolder = newDefaultOpenFolder; } const QString &Settings::Environment::iconSet() const { return mIconSet; } void Settings::Environment::setIconSet(const QString &newIconSet) { mIconSet = newIconSet; } QString Settings::Environment::terminalPath() const { return mTerminalPath; } void Settings::Environment::setTerminalPath(const QString &terminalPath) { mTerminalPath = terminalPath; } QString Settings::Environment::AStylePath() const { return mAStylePath; } void Settings::Environment::setAStylePath(const QString &aStylePath) { mAStylePath = aStylePath; } QString Settings::Environment::terminalArgumentsPattern() const { return mTerminalArgumentsPattern; } void Settings::Environment::setTerminalArgumentsPattern(const QString &argsPattern) { mTerminalArgumentsPattern = argsPattern; } bool Settings::Environment::useCustomIconSet() const { return mUseCustomIconSet; } void Settings::Environment::setUseCustomIconSet(bool newUseCustomIconSet) { mUseCustomIconSet = newUseCustomIconSet; } bool Settings::Environment::useCustomTheme() const { return mUseCustomTheme; } void Settings::Environment::setUseCustomTheme(bool newUseCustomTheme) { mUseCustomTheme = newUseCustomTheme; } bool Settings::Environment::hideNonSupportFilesInFileView() const { return mHideNonSupportFilesInFileView; } void Settings::Environment::setHideNonSupportFilesInFileView(bool newHideNonSupportFilesInFileView) { mHideNonSupportFilesInFileView = newHideNonSupportFilesInFileView; } bool Settings::Environment::openFilesInSingleInstance() const { return mOpenFilesInSingleInstance; } void Settings::Environment::setOpenFilesInSingleInstance(bool newOpenFilesInSingleInstance) { mOpenFilesInSingleInstance = newOpenFilesInSingleInstance; } double Settings::Environment::iconZoomFactor() const { return mIconZoomFactor; } void Settings::Environment::setIconZoomFactor(double newIconZoomFactor) { mIconZoomFactor = newIconZoomFactor; } QString Settings::Environment::queryPredefinedTerminalArgumentsPattern(const QString &executable) const { QString execName = extractFileName(executable); for (const TerminalItem& item: loadTerminalList()) { QString termName = extractFileName(item.terminal); if (termName.compare(execName,PATH_SENSITIVITY)==0) return item.param; } return QString(); } bool Settings::Environment::useCustomTerminal() const { return mUseCustomTerminal; } void Settings::Environment::setUseCustomTerminal(bool newUseCustomTerminal) { mUseCustomTerminal = newUseCustomTerminal; } void Settings::Environment::checkAndSetTerminal() { if (isTerminalValid()) return; QStringList pathList = getExecutableSearchPaths(); QList terminalList = loadTerminalList(); for (const TerminalItem& termItem:terminalList) { QString term=termItem.terminal; term.replace("%*APP_DIR*%",pSettings->dirs().appDir()); QFileInfo info{term}; QString absoluteTerminalPath; if (info.isAbsolute()) { absoluteTerminalPath = info.absoluteFilePath(); if(fileExists(absoluteTerminalPath)) { mTerminalPath = absoluteTerminalPath; mTerminalArgumentsPattern = termItem.param; return; } } else { for (const QString &dirPath: pathList) { QDir dir{dirPath}; absoluteTerminalPath = dir.absoluteFilePath(termItem.terminal); if(fileExists(absoluteTerminalPath)) { mTerminalPath = absoluteTerminalPath; mTerminalArgumentsPattern = termItem.param; return; } } } } //Can't Find a term QMessageBox::critical( nullptr, QCoreApplication::translate("Settings","Error"), QCoreApplication::translate("Settings","Can't find terminal program!")); } QMap Settings::Environment::terminalArgsPatternMagicVariables() { return mTerminalArgsPatternMagicVariables; } QList Settings::Environment::loadTerminalList() const { #ifdef Q_OS_WINDOWS QString terminalListFilename(":/config/terminal-windows.json"); #else // UNIX QString terminalListFilename(":/config/terminal-unix.json"); #endif QFile terminalListFile(terminalListFilename); if (!terminalListFile.open(QFile::ReadOnly)) throw FileError(QObject::tr("Can't open file '%1' for read.") .arg(terminalListFilename)); QByteArray terminalListContent = terminalListFile.readAll(); QJsonDocument terminalListDocument(QJsonDocument::fromJson(terminalListContent)); QList result; // determing terminal (if not set yet) and build predefined arguments pattern map from our list for (const auto &terminalGroup: terminalListDocument.array()) { const QJsonArray &terminals = terminalGroup.toObject()["terminals"].toArray(); for (const auto &terminal_: terminals) { const QJsonObject& terminal = terminal_.toObject(); QString path = terminal["path"].toString(); QString termExecutable = QFileInfo(path).fileName(); QString pattern = terminal["argsPattern"].toString(); Settings::Environment::TerminalItem terminalItem; path.replace("%*APP_DIR*%", pSettings->dirs().appDir()); terminalItem.terminal = path; terminalItem.param = pattern; result.append(terminalItem); } } return result; } bool Settings::Environment::isTerminalValid() { // don't use custom terminal if (!mUseCustomTerminal) return true; // terminal patter is empty if (mTerminalArgumentsPattern.isEmpty()) return false; QStringList patternItems = parseArguments(mTerminalArgumentsPattern, mTerminalArgsPatternMagicVariables, false); if (!(patternItems.contains("$argv") || patternItems.contains("$command") || patternItems.contains("$tmpfile"))) { // program not referenced return false; } QFileInfo termPathInfo{mTerminalPath}; if (termPathInfo.isAbsolute()) { return termPathInfo.exists(); } else { QStringList pathList = getExecutableSearchPaths(); for (const QString &dirName: pathList) { QDir dir{dirName}; QString absoluteTerminalPath = dir.absoluteFilePath(mTerminalPath); QFileInfo absTermPathInfo(absoluteTerminalPath); if (absTermPathInfo.exists()) return true; } } return false; } void Settings::Environment::doSave() { //Appearance saveValue("theme", mTheme); saveValue("interface_font", mInterfaceFont); saveValue("interface_font_size", mInterfaceFontSize); saveValue("icon_zoom_factor",mIconZoomFactor); saveValue("language", mLanguage); saveValue("icon_set",mIconSet); saveValue("use_custom_icon_set", mUseCustomIconSet); saveValue("use_custom_theme", mUseCustomTheme); saveValue("current_folder",mCurrentFolder); saveValue("default_open_folder",mDefaultOpenFolder); QString terminalPath = mTerminalPath; #ifdef Q_OS_WINDOWS // APP_DIR trick for windows portable app // on other platforms multiple instances share the same configuration and thus the trick may break terminal path if (terminalPath.startsWith(pSettings->dirs().appDir())) { terminalPath="%*APP_DIR*%"+terminalPath.mid(pSettings->dirs().appDir().length()); } #endif saveValue("terminal_path",terminalPath); saveValue("terminal_arguments_pattern",mTerminalArgumentsPattern); #ifdef Q_OS_WINDOWS saveValue("use_custom_terminal",mUseCustomTerminal); #endif saveValue("asyle_path",mAStylePath); saveValue("hide_non_support_files_file_view",mHideNonSupportFilesInFileView); saveValue("open_files_in_single_instance",mOpenFilesInSingleInstance); } QString Settings::Environment::interfaceFont() const { return mInterfaceFont; } void Settings::Environment::setInterfaceFont(const QString &interfaceFont) { mInterfaceFont = interfaceFont; } QString Settings::Environment::theme() const { return mTheme; } void Settings::Environment::setTheme(const QString &theme) { mTheme = theme; } const QMap Settings::Environment::mTerminalArgsPatternMagicVariables = { {"term", "$term"}, {"integrated_term", "$integrated_term"}, {"argv", "$argv"}, {"command", "$command"}, {"unix_command", "$unix_command"}, {"dos_command", "$dos_command"}, {"lpCommandLine", "$lpCommandLine"}, {"tmpfile", "$tmpfile"}, }; Settings::Executor::Executor(Settings *settings):_Base(settings, SETTING_EXECUTOR) { } bool Settings::Executor::minimizeOnRun() const { return mMinimizeOnRun; } void Settings::Executor::setMinimizeOnRun(bool minimizeOnRun) { mMinimizeOnRun = minimizeOnRun; } bool Settings::Executor::useParams() const { return mUseParams; } void Settings::Executor::setUseParams(bool newUseParams) { mUseParams = newUseParams; } const QString &Settings::Executor::params() const { return mParams; } void Settings::Executor::setParams(const QString &newParams) { mParams = newParams; } bool Settings::Executor::redirectInput() const { return mRedirectInput; } void Settings::Executor::setRedirectInput(bool newRedirectInput) { mRedirectInput = newRedirectInput; } const QString &Settings::Executor::inputFilename() const { return mInputFilename; } void Settings::Executor::setInputFilename(const QString &newInputFilename) { mInputFilename = newInputFilename; } int Settings::Executor::competivieCompanionPort() const { return mCompetivieCompanionPort; } void Settings::Executor::setCompetivieCompanionPort(int newCompetivieCompanionPort) { mCompetivieCompanionPort = newCompetivieCompanionPort; } bool Settings::Executor::caseEditorFontOnlyMonospaced() const { return mCaseEditorFontOnlyMonospaced; } void Settings::Executor::setCaseEditorFontOnlyMonospaced(bool newCaseEditorFontOnlyMonospaced) { mCaseEditorFontOnlyMonospaced = newCaseEditorFontOnlyMonospaced; } size_t Settings::Executor::caseTimeout() const { return mCaseTimeout; } void Settings::Executor::setCaseTimeout(size_t newCaseTimeout) { mCaseTimeout = newCaseTimeout; } size_t Settings::Executor::caseMemoryLimit() const { return mCaseMemoryLimit; } void Settings::Executor::setCaseMemoryLimit(size_t newCaseMemoryLimit) { mCaseMemoryLimit = newCaseMemoryLimit; } bool Settings::Executor::convertHTMLToTextForExpected() const { return mConvertHTMLToTextForExpected; } void Settings::Executor::setConvertHTMLToTextForExpected(bool newConvertHTMLToTextForExpected) { mConvertHTMLToTextForExpected = newConvertHTMLToTextForExpected; } bool Settings::Executor::redirectStderrToToolLog() const { return mRedirectStderrToToolLog; } void Settings::Executor::setRedirectStderrToToolLog(bool newRedirectStderrToToolLog) { mRedirectStderrToToolLog = newRedirectStderrToToolLog; } ProblemCaseValidateType Settings::Executor::problemCaseValidateType() const { return mProblemCaseValidateType; } void Settings::Executor::setProblemCaseValidateType(ProblemCaseValidateType newProblemCaseValidateType) { mProblemCaseValidateType = newProblemCaseValidateType; } bool Settings::Executor::enableVirualTerminalSequence() const { return mEnableVirualTerminalSequence; } void Settings::Executor::setEnableVirualTerminalSequence(bool newEnableVirualTerminalSequence) { mEnableVirualTerminalSequence = newEnableVirualTerminalSequence; } bool Settings::Executor::convertHTMLToTextForInput() const { return mConvertHTMLToTextForInput; } void Settings::Executor::setConvertHTMLToTextForInput(bool newConvertHTMLToTextForInput) { mConvertHTMLToTextForInput = newConvertHTMLToTextForInput; } bool Settings::Executor::enableCaseLimit() const { return mEnableCaseLimit; } void Settings::Executor::setEnableCaseLimit(bool newValue) { mEnableCaseLimit = newValue; } int Settings::Executor::caseEditorFontSize() const { return mCaseEditorFontSize; } void Settings::Executor::setCaseEditorFontSize(int newCaseEditorFontSize) { mCaseEditorFontSize = newCaseEditorFontSize; } const QString &Settings::Executor::caseEditorFontName() const { return mCaseEditorFontName; } void Settings::Executor::setCaseEditorFontName(const QString &newCaseEditorFontName) { mCaseEditorFontName = newCaseEditorFontName; } bool Settings::Executor::enableCompetitiveCompanion() const { return mEnableCompetitiveCompanion; } void Settings::Executor::setEnableCompetitiveCompanion(bool newEnableCompetitiveCompanion) { mEnableCompetitiveCompanion = newEnableCompetitiveCompanion; } bool Settings::Executor::enableProblemSet() const { return mEnableProblemSet; } void Settings::Executor::setEnableProblemSet(bool newEnableProblemSet) { mEnableProblemSet = newEnableProblemSet; } void Settings::Executor::doSave() { saveValue("pause_console", mPauseConsole); #ifdef Q_OS_WIN saveValue("enable_virtual_terminal_sequence", mEnableVirualTerminalSequence); #endif saveValue("minimize_on_run", mMinimizeOnRun); saveValue("use_params",mUseParams); saveValue("params",mParams); saveValue("redirect_input",mRedirectInput); saveValue("input_filename",mInputFilename); //problem set saveValue("enable_proble_set", mEnableProblemSet); saveValue("enable_competivie_companion", mEnableCompetitiveCompanion); saveValue("competitive_companion_port", mCompetivieCompanionPort); saveValue("input_convert_html", mConvertHTMLToTextForInput); saveValue("expected_convert_html", mConvertHTMLToTextForExpected); saveValue("problem_case_validate_type", (int)mProblemCaseValidateType); saveValue("redirect_stderr_to_toollog", mRedirectStderrToToolLog); saveValue("case_editor_font_name",mCaseEditorFontName); saveValue("case_editor_font_size",mCaseEditorFontSize); saveValue("case_editor_font_only_monospaced",mCaseEditorFontOnlyMonospaced); saveValue("case_timeout_ms", mCaseTimeout); saveValue("case_memory_limit",mCaseMemoryLimit); remove("case_timeout"); saveValue("enable_case_limit", mEnableCaseLimit); } bool Settings::Executor::pauseConsole() const { return mPauseConsole; } void Settings::Executor::setPauseConsole(bool pauseConsole) { mPauseConsole = pauseConsole; } void Settings::Executor::doLoad() { mPauseConsole = boolValue("pause_console",true); #ifdef Q_OS_WIN mEnableVirualTerminalSequence = boolValue("enable_virtual_terminal_sequence", true); #endif mMinimizeOnRun = boolValue("minimize_on_run",false); mUseParams = boolValue("use_params",false); mParams = stringValue("params", ""); mRedirectInput = boolValue("redirect_input",false); mInputFilename = stringValue("input_filename",""); mEnableProblemSet = boolValue("enable_proble_set",true); mEnableCompetitiveCompanion = boolValue("enable_competivie_companion",true); mCompetivieCompanionPort = intValue("competitive_companion_port",10045); mConvertHTMLToTextForInput = boolValue("input_convert_html", false); mConvertHTMLToTextForExpected = boolValue("expected_convert_html", false); mProblemCaseValidateType =(ProblemCaseValidateType)intValue("problem_case_validate_type", (int)ProblemCaseValidateType::Exact); mRedirectStderrToToolLog = boolValue("redirect_stderr_to_toollog", false); mCaseEditorFontName = stringValue("case_editor_font_name", defaultMonoFont()); mCaseEditorFontSize = intValue("case_editor_font_size",11); mCaseEditorFontOnlyMonospaced = boolValue("case_editor_font_only_monospaced",true); int case_timeout = intValue("case_timeout", -1); if (case_timeout>0) mCaseTimeout = case_timeout*1000; else mCaseTimeout = uintValue("case_timeout_ms", 2000); //2000ms mCaseMemoryLimit = uintValue("case_memory_limit",0); // kb mEnableCaseLimit = boolValue("enable_case_limit", true); //compatibility if (boolValue("enable_time_limit", true)) { mEnableCaseLimit=true; } } Settings::Debugger::Debugger(Settings *settings):_Base(settings, SETTING_DEBUGGER) { } bool Settings::Debugger::enableDebugConsole() const { return mEnableDebugConsole; } void Settings::Debugger::setEnableDebugConsole(bool showCommandLog) { mEnableDebugConsole = showCommandLog; } bool Settings::Debugger::showDetailLog() const { return mShowDetailLog; } void Settings::Debugger::setShowDetailLog(bool showAnnotations) { mShowDetailLog = showAnnotations; } QString Settings::Debugger::fontName() const { return mFontName; } void Settings::Debugger::setFontName(const QString &fontName) { mFontName = fontName; } bool Settings::Debugger::blendMode() const { return mBlendMode; } void Settings::Debugger::setBlendMode(bool blendMode) { mBlendMode = blendMode; } bool Settings::Debugger::skipSystemLibraries() const { return mSkipSystemLibraries; } void Settings::Debugger::setSkipSystemLibraries(bool newSkipSystemLibraries) { mSkipSystemLibraries = newSkipSystemLibraries; } bool Settings::Debugger::skipProjectLibraries() const { return mSkipProjectLibraries; } void Settings::Debugger::setSkipProjectLibraries(bool newSkipProjectLibraries) { mSkipProjectLibraries = newSkipProjectLibraries; } bool Settings::Debugger::skipCustomLibraries() const { return mSkipCustomLibraries; } void Settings::Debugger::setSkipCustomLibraries(bool newSkipCustomLibraries) { mSkipCustomLibraries = newSkipCustomLibraries; } bool Settings::Debugger::openCPUInfoWhenSignaled() const { return mOpenCPUInfoWhenSignaled; } void Settings::Debugger::setOpenCPUInfoWhenSignaled(bool newOpenCPUInfoWhenSignaled) { mOpenCPUInfoWhenSignaled = newOpenCPUInfoWhenSignaled; } bool Settings::Debugger::useGDBServer() const { return mUseGDBServer; } void Settings::Debugger::setUseGDBServer(bool newUseGDBServer) { mUseGDBServer = newUseGDBServer; } int Settings::Debugger::GDBServerPort() const { return mGDBServerPort; } void Settings::Debugger::setGDBServerPort(int newGDBServerPort) { mGDBServerPort = newGDBServerPort; } int Settings::Debugger::memoryViewRows() const { return mMemoryViewRows; } void Settings::Debugger::setMemoryViewRows(int newMemoryViewRows) { mMemoryViewRows = newMemoryViewRows; } int Settings::Debugger::memoryViewColumns() const { return mMemoryViewColumns; } void Settings::Debugger::setMemoryViewColumns(int newMemoryViewColumns) { mMemoryViewColumns = newMemoryViewColumns; } bool Settings::Debugger::autosave() const { return mAutosave; } void Settings::Debugger::setAutosave(bool newAutosave) { mAutosave = newAutosave; } int Settings::Debugger::arrayElements() const { return mArrayElements; } void Settings::Debugger::setArrayElements(int newArrayElements) { mArrayElements = newArrayElements; } int Settings::Debugger::characters() const { return mCharacters; } void Settings::Debugger::setCharacters(int newCharacters) { mCharacters = newCharacters; } bool Settings::Debugger::useIntelStyle() const { return mUseIntelStyle; } void Settings::Debugger::setUseIntelStyle(bool useIntelStyle) { mUseIntelStyle = useIntelStyle; } int Settings::Debugger::fontSize() const { return mFontSize; } void Settings::Debugger::setFontSize(int fontSize) { mFontSize = fontSize; } bool Settings::Debugger::onlyShowMono() const { return mOnlyShowMono; } void Settings::Debugger::setOnlyShowMono(bool onlyShowMono) { mOnlyShowMono = onlyShowMono; } void Settings::Debugger::doSave() { saveValue("enable_debug_console", mEnableDebugConsole); saveValue("show_detail_log", mShowDetailLog); saveValue("font_name",mFontName); saveValue("only_show_mono",mOnlyShowMono); saveValue("font_size",mFontSize); saveValue("use_intel_style",mUseIntelStyle); saveValue("blend_mode",mBlendMode); saveValue("skip_system_lib", mSkipSystemLibraries); saveValue("skip_project_lib", mSkipProjectLibraries); saveValue("skip_custom_lib", mSkipCustomLibraries); saveValue("autosave",mAutosave); saveValue("open_cpu_info_when_signaled",mOpenCPUInfoWhenSignaled); saveValue("use_gdb_server", mUseGDBServer); saveValue("gdb_server_port",mGDBServerPort); saveValue("memory_view_rows",mMemoryViewRows); saveValue("memory_view_columns",mMemoryViewColumns); saveValue("array_elements",mArrayElements); saveValue("string_characters",mCharacters); } void Settings::Debugger::doLoad() { mEnableDebugConsole = boolValue("enable_debug_console",true); mShowDetailLog = boolValue("show_detail_log",false); mFontName = stringValue("font_name", defaultMonoFont()); mOnlyShowMono = boolValue("only_show_mono",true); mFontSize = intValue("font_size",14); mUseIntelStyle = boolValue("use_intel_style",false); mBlendMode = boolValue("blend_mode",true); mSkipSystemLibraries = boolValue("skip_system_lib",true); mSkipProjectLibraries = boolValue("skip_project_lib",true); mSkipCustomLibraries = boolValue("skip_custom_lib",false); mAutosave = boolValue("autosave",true); mOpenCPUInfoWhenSignaled = boolValue("open_cpu_info_when_signaled",true); #ifdef Q_OS_WIN mUseGDBServer = boolValue("use_gdb_server", false); #else mUseGDBServer = true; #endif mGDBServerPort = intValue("gdb_server_port",41234); mMemoryViewRows = intValue("memory_view_rows",16); mMemoryViewColumns = intValue("memory_view_columns",16); mArrayElements = intValue("array_elements",100); mCharacters = intValue("string_characters",300); } Settings::CodeCompletion::CodeCompletion(Settings *settings):_Base(settings, SETTING_CODE_COMPLETION) { } bool Settings::CodeCompletion::showCodeIns() const { return mShowCodeIns; } void Settings::CodeCompletion::setShowCodeIns(bool newShowCodeIns) { mShowCodeIns = newShowCodeIns; } //bool Settings::CodeCompletion::clearWhenEditorHidden() //{ // if (!mShareParser) { //#ifdef Q_OS_WIN // MEMORYSTATUSEX statex; // statex.dwLength = sizeof (statex); // GlobalMemoryStatusEx (&statex); // if (statex.ullAvailPhys < (long long int)2*1024*1024*1024) { // return true; // } //#elif defined(Q_OS_LINUX) // struct sysinfo si; // sysinfo(&si); // if (si.freeram < (long long int)2*1024*1024*1024) { // return true; // } //#endif // } // return mClearWhenEditorHidden; //} //void Settings::CodeCompletion::setClearWhenEditorHidden(bool newClearWhenEditorHidden) //{ // mClearWhenEditorHidden = newClearWhenEditorHidden; //} int Settings::CodeCompletion::minCharRequired() const { return mMinCharRequired; } void Settings::CodeCompletion::setMinCharRequired(int newMinCharRequired) { mMinCharRequired = newMinCharRequired; } bool Settings::CodeCompletion::hideSymbolsStartsWithTwoUnderLine() const { return mHideSymbolsStartsWithTwoUnderLine; } void Settings::CodeCompletion::setHideSymbolsStartsWithTwoUnderLine(bool newHideSymbolsStartsWithTwoUnderLine) { mHideSymbolsStartsWithTwoUnderLine = newHideSymbolsStartsWithTwoUnderLine; } bool Settings::CodeCompletion::shareParser() { return mShareParser; } void Settings::CodeCompletion::setShareParser(bool newShareParser) { mShareParser = newShareParser; } bool Settings::CodeCompletion::hideSymbolsStartsWithUnderLine() const { return mHideSymbolsStartsWithUnderLine; } void Settings::CodeCompletion::setHideSymbolsStartsWithUnderLine(bool newHideSymbolsStartsWithOneUnderLine) { mHideSymbolsStartsWithUnderLine = newHideSymbolsStartsWithOneUnderLine; } bool Settings::CodeCompletion::appendFunc() const { return mAppendFunc; } void Settings::CodeCompletion::setAppendFunc(bool newAppendFunc) { mAppendFunc = newAppendFunc; } bool Settings::CodeCompletion::ignoreCase() const { return mIgnoreCase; } void Settings::CodeCompletion::setIgnoreCase(bool newIgnoreCase) { mIgnoreCase = newIgnoreCase; } bool Settings::CodeCompletion::showKeywords() const { return mShowKeywords; } void Settings::CodeCompletion::setShowKeywords(bool newShowKeywords) { mShowKeywords = newShowKeywords; } bool Settings::CodeCompletion::sortByScope() const { return mSortByScope; } void Settings::CodeCompletion::setSortByScope(bool newSortByScope) { mSortByScope = newSortByScope; } bool Settings::CodeCompletion::recordUsage() const { return mRecordUsage; } void Settings::CodeCompletion::setRecordUsage(bool newRecordUsage) { mRecordUsage = newRecordUsage; } bool Settings::CodeCompletion::showCompletionWhileInput() const { return mShowCompletionWhileInput; } void Settings::CodeCompletion::setShowCompletionWhileInput(bool newShowCompletionWhileInput) { mShowCompletionWhileInput = newShowCompletionWhileInput; } bool Settings::CodeCompletion::parseGlobalHeaders() const { return mParseGlobalHeaders; } void Settings::CodeCompletion::setParseGlobalHeaders(bool newParseGlobalHeaders) { mParseGlobalHeaders = newParseGlobalHeaders; } bool Settings::CodeCompletion::parseLocalHeaders() const { return mParseLocalHeaders; } void Settings::CodeCompletion::setParseLocalHeaders(bool newParseLocalHeaders) { mParseLocalHeaders = newParseLocalHeaders; } bool Settings::CodeCompletion::enabled() const { return mEnabled; } void Settings::CodeCompletion::setEnabled(bool newEnabled) { mEnabled = newEnabled; } int Settings::CodeCompletion::height() const { return mHeight; } void Settings::CodeCompletion::setHeight(int newHeight) { mHeight = newHeight; } int Settings::CodeCompletion::width() const { return mWidth; } void Settings::CodeCompletion::setWidth(int newWidth) { mWidth = newWidth; } void Settings::CodeCompletion::doSave() { saveValue("width",mWidth); saveValue("height",mHeight); saveValue("enabled",mEnabled); saveValue("parse_local_headers",mParseLocalHeaders); saveValue("parse_global_headers",mParseGlobalHeaders); saveValue("show_completion_while_input",mShowCompletionWhileInput); saveValue("record_usage",mRecordUsage); saveValue("sort_by_scope",mSortByScope); saveValue("show_keywords",mShowKeywords); saveValue("ignore_case",mIgnoreCase); saveValue("append_func",mAppendFunc); saveValue("show_code_ins",mShowCodeIns); //saveValue("clear_when_editor_hidden",mClearWhenEditorHidden); saveValue("min_char_required",mMinCharRequired); saveValue("hide_symbols_start_with_two_underline", mHideSymbolsStartsWithTwoUnderLine); saveValue("hide_symbols_start_with_underline", mHideSymbolsStartsWithUnderLine); saveValue("share_parser",mShareParser); } void Settings::CodeCompletion::doLoad() { //Appearance mWidth = intValue("width",700); mHeight = intValue("height",400); mEnabled = boolValue("enabled",true); mParseLocalHeaders = boolValue("parse_local_headers",true); mParseGlobalHeaders = boolValue("parse_global_headers",true); mShowCompletionWhileInput = boolValue("show_completion_while_input",true); mRecordUsage = boolValue("record_usage",true); mSortByScope = boolValue("sort_by_scope",true); mShowKeywords = boolValue("show_keywords",true); mIgnoreCase = boolValue("ignore_case",true); mAppendFunc = boolValue("append_func",true); mShowCodeIns = boolValue("show_code_ins",true); mMinCharRequired = intValue("min_char_required",1); mHideSymbolsStartsWithTwoUnderLine = boolValue("hide_symbols_start_with_two_underline", true); mHideSymbolsStartsWithUnderLine = boolValue("hide_symbols_start_with_underline", true); bool shouldShare= true; // bool doClear = false; //#ifdef Q_OS_WIN // MEMORYSTATUSEX statex; // statex.dwLength = sizeof (statex); // GlobalMemoryStatusEx (&statex); // if (statex.ullAvailPhys > (long long int)32*1024*1024*1024) { // shouldShare = false; // } //// if (shouldShare) { //// SYSTEM_INFO info; //// GetSystemInfo(&info); //// if (info.dwNumberOfProcessors>8 && info.dwProcessorType) { //// doClear = true; //// } //// } //#elif defined(Q_OS_LINUX) // struct sysinfo si; // sysinfo(&si); // if (si.freeram > (long long int)24*1024*1024*1024) { // shouldShare = false; // } //#endif //mClearWhenEditorHidden = boolValue("clear_when_editor_hidden",doClear); mShareParser = boolValue("share_parser",shouldShare); } Settings::CodeFormatter::CodeFormatter(Settings *settings): _Base(settings,SETTING_CODE_FORMATTER) { } QStringList Settings::CodeFormatter::getArguments() { QStringList result; switch(mBraceStyle) { case FormatterBraceStyle::fbsDefault: break; case FormatterBraceStyle::fbsAllman: result.append("--style=allman"); break; case FormatterBraceStyle::fbsJava: result.append("--style=java"); break; case FormatterBraceStyle::fbsKR: result.append("--style=kr"); break; case FormatterBraceStyle::fbsStroustrup: result.append("--style=stroustrup"); break; case FormatterBraceStyle::fbsWitesmith: result.append("--style=whitesmith"); break; case FormatterBraceStyle::fbsVtk: result.append("--style=vtk"); break; case FormatterBraceStyle::fbsRatliff: result.append("--style=ratliff"); break; case FormatterBraceStyle::fbsGNU: result.append("--style=gnu"); break; case FormatterBraceStyle::fbsLinux: result.append("--style=linux"); break; case FormatterBraceStyle::fbsHorstmann: result.append("--style=horstmann"); break; case FormatterBraceStyle::fbs1TBS: result.append("--style=1tbs"); break; case FormatterBraceStyle::fbsGoogle: result.append("--style=google"); break; case FormatterBraceStyle::fbsMozilla: result.append("--style=mozilla"); break; case FormatterBraceStyle::fbsWebkit: result.append("--style=webkit"); break; case FormatterBraceStyle::fbsPico: result.append("--style=pico"); break; case FormatterBraceStyle::fbsLisp: result.append("--style=lisp"); break; }; switch(mIndentStyle) { case FormatterIndentType::fitTab: result.append(QString("--indent=tab=%1").arg(mTabWidth)); break; case FormatterIndentType::fitSpace: result.append(QString("--indent=spaces=%1").arg(mTabWidth)); break; } if (mAttachNamespaces) result.append("--attach-namespaces"); if (mAttachClasses) result.append("--attach-classes"); if (mAttachInlines) result.append("--attach-inlines"); if (mAttachExternC) result.append("--attach-extern-c"); if (mAttachClosingWhile) result.append("--attach-closing-while"); if (mIndentClasses) result.append("--indent-classes"); if (mIndentModifiers) result.append("--indent-modifiers"); if (mIndentSwitches) result.append("--indent-switches"); if (mIndentCases) result.append("--indent-cases"); if (mIndentNamespaces) result.append("--indent-namespaces"); if (mIndentAfterParens) result.append("--indent-after-parens"); if (mIndentContinuation!=1) result.append(QString("--indent-continuation=%1").arg(mIndentContinuation)); if (mIndentLabels) result.append("--indent-labels"); if (mIndentPreprocBlock) result.append("--indent-preproc-block"); if (mIndentPreprocCond) result.append("--indent-preproc-cond"); if (mIndentPreprocDefine) result.append("--indent-preproc-define"); if (mIndentCol1Comments) result.append("--indent-col1-comments"); if (mMinConditionalIndent!=2) result.append(QString("--min-conditional-indent=%1").arg(mMinConditionalIndent)); if (mMaxContinuationIndent!=40) result.append(QString("--max-continuation-indent=%1").arg(mMaxContinuationIndent)); if (mBreakBlocks) result.append("--break-blocks"); if (mBreakBlocksAll) result.append("--break-blocks=all"); if (mPadOper) result.append("--pad-oper"); if (mPadComma) result.append("--pad-comma"); if (mPadParen) result.append("--pad-paren"); if (mPadParenOut) result.append("--pad-paren-out"); if (mPadFirstParenOut) result.append("--pad-first-paren-out"); if (mPadParenIn) result.append("--pad-paren-in"); if (mPadHeader) result.append("--pad-header"); if (mUnpadParen) result.append("--unpad-paren"); if (mDeleteEmptyLines) result.append("--delete-empty-lines"); if (mDeleteMultipleEmptyLines) result.append("--delete-multiple-empty-lines"); if (mFillEmptyLines) result.append("--fill-empty-lines"); switch(mAlignPointerStyle) { case FormatterOperatorAlign::foaNone: break; case FormatterOperatorAlign::foaType: result.append("--align-pointer=type"); break; case FormatterOperatorAlign::foaMiddle: result.append("--align-pointer=middle"); break; case FormatterOperatorAlign::foaName: result.append("--align-pointer=name"); break; } switch(mAlignReferenceStyle) { case FormatterOperatorAlign::foaNone: break; case FormatterOperatorAlign::foaType: result.append("--align-reference=type"); break; case FormatterOperatorAlign::foaMiddle: result.append("--align-reference=middle"); break; case FormatterOperatorAlign::foaName: result.append("--align-reference=name"); break; } if (mBreakClosingBraces) result.append("--break-closing-braces"); if (mBreakElseIf) result.append("--break-elseifs"); if (mBreakOneLineHeaders) result.append("--break-one-line-headers"); if (mAddBraces) result.append("--add-braces"); if (mAddOneLineBraces) result.append("--add-one-line-braces"); if (mRemoveBraces) result.append("--remove-braces"); if (mBreakReturnType) result.append("--break-return-type"); if (mBreakReturnTypeDecl) result.append("--break-return-type-decl"); if (mAttachReturnType) result.append("--attach-return-type"); if (mAttachReturnTypeDecl) result.append("--attach-return-type-decl"); if (mKeepOneLineBlocks) result.append("--keep-one-line-blocks"); if (mKeepOneLineStatements) result.append("--keep-one-line-statements"); if (mConvertTabs) result.append("--convert-tabs"); if (mCloseTemplates) result.append("--close-templates"); if (mRemoveCommentPrefix) result.append("--remove-comment-prefix"); if (mBreakMaxCodeLength) { result.append(QString("--max-code-length=%1").arg(mMaxCodeLength)); if (mBreakAfterLogical) result.append("--break-after-logical"); } return result; } int Settings::CodeFormatter::indentStyle() const { return mIndentStyle; } void Settings::CodeFormatter::setIndentStyle(int newIndentStyle) { mIndentStyle = newIndentStyle; } int Settings::CodeFormatter::tabWidth() const { return mTabWidth; } void Settings::CodeFormatter::setTabWidth(int newTabWidth) { mTabWidth = newTabWidth; } bool Settings::CodeFormatter::attachNamespaces() const { return mAttachNamespaces; } void Settings::CodeFormatter::setAttachNamespaces(bool newAttachNamespaces) { mAttachNamespaces = newAttachNamespaces; } bool Settings::CodeFormatter::attachClasses() const { return mAttachClasses; } void Settings::CodeFormatter::setAttachClasses(bool newAttachClasses) { mAttachClasses = newAttachClasses; } bool Settings::CodeFormatter::attachInlines() const { return mAttachInlines; } void Settings::CodeFormatter::setAttachInlines(bool newAttachInlines) { mAttachInlines = newAttachInlines; } bool Settings::CodeFormatter::attachExternC() const { return mAttachExternC; } void Settings::CodeFormatter::setAttachExternC(bool newAttachExternC) { mAttachExternC = newAttachExternC; } bool Settings::CodeFormatter::attachClosingWhile() const { return mAttachClosingWhile; } void Settings::CodeFormatter::setAttachClosingWhile(bool newAttachClosingWhile) { mAttachClosingWhile = newAttachClosingWhile; } bool Settings::CodeFormatter::indentClasses() const { return mIndentClasses; } void Settings::CodeFormatter::setIndentClasses(bool newIndentClasses) { mIndentClasses = newIndentClasses; } bool Settings::CodeFormatter::indentModifiers() const { return mIndentModifiers; } void Settings::CodeFormatter::setIndentModifiers(bool newIndentModifiers) { mIndentModifiers = newIndentModifiers; } bool Settings::CodeFormatter::indentCases() const { return mIndentCases; } void Settings::CodeFormatter::setIndentCases(bool newIndentCases) { mIndentCases = newIndentCases; } bool Settings::CodeFormatter::indentNamespaces() const { return mIndentNamespaces; } void Settings::CodeFormatter::setIndentNamespaces(bool newIndentNamespaces) { mIndentNamespaces = newIndentNamespaces; } int Settings::CodeFormatter::indentContinuation() const { return mIndentContinuation; } void Settings::CodeFormatter::setIndentContinuation(int newIndentContinuation) { mIndentContinuation = newIndentContinuation; } bool Settings::CodeFormatter::indentLabels() const { return mIndentLabels; } void Settings::CodeFormatter::setIndentLabels(bool newIndentLabels) { mIndentLabels = newIndentLabels; } bool Settings::CodeFormatter::indentPreprocBlock() const { return mIndentPreprocBlock; } void Settings::CodeFormatter::setIndentPreprocBlock(bool newIndentPreprocBlock) { mIndentPreprocBlock = newIndentPreprocBlock; } bool Settings::CodeFormatter::indentPreprocCond() const { return mIndentPreprocCond; } void Settings::CodeFormatter::setIndentPreprocCond(bool newIndentPreprocCond) { mIndentPreprocCond = newIndentPreprocCond; } bool Settings::CodeFormatter::indentPreprocDefine() const { return mIndentPreprocDefine; } void Settings::CodeFormatter::setIndentPreprocDefine(bool newIndentPreprocDefine) { mIndentPreprocDefine = newIndentPreprocDefine; } bool Settings::CodeFormatter::indentCol1Comments() const { return mIndentCol1Comments; } void Settings::CodeFormatter::setIndentCol1Comments(bool newIndentCol1Comments) { mIndentCol1Comments = newIndentCol1Comments; } int Settings::CodeFormatter::minConditionalIndent() const { return mMinConditionalIndent; } void Settings::CodeFormatter::setMinConditionalIndent(int newMinConditionalIndent) { mMinConditionalIndent = newMinConditionalIndent; } int Settings::CodeFormatter::maxContinuationIndent() const { return mMaxContinuationIndent; } void Settings::CodeFormatter::setMaxContinuationIndent(int newMaxContinuationIndent) { mMaxContinuationIndent = newMaxContinuationIndent; } bool Settings::CodeFormatter::breakBlocks() const { return mBreakBlocks; } void Settings::CodeFormatter::setBreakBlocks(bool newBreakBlocks) { mBreakBlocks = newBreakBlocks; } bool Settings::CodeFormatter::breakBlocksAll() const { return mBreakBlocksAll; } void Settings::CodeFormatter::setBreakBlocksAll(bool newBreakBlocksAll) { mBreakBlocksAll = newBreakBlocksAll; } bool Settings::CodeFormatter::padOper() const { return mPadOper; } void Settings::CodeFormatter::setPadOper(bool newPadOper) { mPadOper = newPadOper; } bool Settings::CodeFormatter::padComma() const { return mPadComma; } void Settings::CodeFormatter::setPadComma(bool newPadComma) { mPadComma = newPadComma; } bool Settings::CodeFormatter::padParen() const { return mPadParen; } void Settings::CodeFormatter::setPadParen(bool newPadParen) { mPadParen = newPadParen; } bool Settings::CodeFormatter::padParenOut() const { return mPadParenOut; } void Settings::CodeFormatter::setPadParenOut(bool newPadParenOut) { mPadParenOut = newPadParenOut; } bool Settings::CodeFormatter::padFirstParenOut() const { return mPadFirstParenOut; } void Settings::CodeFormatter::setPadFirstParenOut(bool newPadFirstParenOut) { mPadFirstParenOut = newPadFirstParenOut; } bool Settings::CodeFormatter::padParenIn() const { return mPadParenIn; } void Settings::CodeFormatter::setPadParenIn(bool newPadParenIn) { mPadParenIn = newPadParenIn; } bool Settings::CodeFormatter::padHeader() const { return mPadHeader; } void Settings::CodeFormatter::setPadHeader(bool newPadHeader) { mPadHeader = newPadHeader; } bool Settings::CodeFormatter::unpadParen() const { return mUnpadParen; } void Settings::CodeFormatter::setUnpadParen(bool newUnpadParen) { mUnpadParen = newUnpadParen; } bool Settings::CodeFormatter::deleteEmptyLines() const { return mDeleteEmptyLines; } void Settings::CodeFormatter::setDeleteEmptyLines(bool newDeleteEmptyLines) { mDeleteEmptyLines = newDeleteEmptyLines; } bool Settings::CodeFormatter::deleteMultipleEmptyLines() const { return mDeleteMultipleEmptyLines; } void Settings::CodeFormatter::setDeleteMultipleEmptyLines(bool newDeleteMultipleEmptyLines) { mDeleteMultipleEmptyLines = newDeleteMultipleEmptyLines; } bool Settings::CodeFormatter::fillEmptyLines() const { return mFillEmptyLines; } void Settings::CodeFormatter::setFillEmptyLines(bool newFillEmptyLines) { mFillEmptyLines = newFillEmptyLines; } int Settings::CodeFormatter::alignPointerStyle() const { return mAlignPointerStyle; } void Settings::CodeFormatter::setAlignPointerStyle(int newAlignPointerStyle) { mAlignPointerStyle = newAlignPointerStyle; } int Settings::CodeFormatter::alignReferenceStyle() const { return mAlignReferenceStyle; } void Settings::CodeFormatter::setAlignReferenceStyle(int newAlignReferenceStyle) { mAlignReferenceStyle = newAlignReferenceStyle; } bool Settings::CodeFormatter::breakClosingBraces() const { return mBreakClosingBraces; } void Settings::CodeFormatter::setBreakClosingBraces(bool newBreakClosingBraces) { mBreakClosingBraces = newBreakClosingBraces; } bool Settings::CodeFormatter::breakElseIf() const { return mBreakElseIf; } void Settings::CodeFormatter::setBreakElseIf(bool newBreakElseIf) { mBreakElseIf = newBreakElseIf; } bool Settings::CodeFormatter::breakOneLineHeaders() const { return mBreakOneLineHeaders; } void Settings::CodeFormatter::setBreakOneLineHeaders(bool newBreakOneLineHeaders) { mBreakOneLineHeaders = newBreakOneLineHeaders; } bool Settings::CodeFormatter::addBraces() const { return mAddBraces; } void Settings::CodeFormatter::setAddBraces(bool newAddBraces) { mAddBraces = newAddBraces; } bool Settings::CodeFormatter::addOneLineBraces() const { return mAddOneLineBraces; } void Settings::CodeFormatter::setAddOneLineBraces(bool newAddOneLineBraces) { mAddOneLineBraces = newAddOneLineBraces; } bool Settings::CodeFormatter::removeBraces() const { return mRemoveBraces; } void Settings::CodeFormatter::setRemoveBraces(bool newRemoveBraces) { mRemoveBraces = newRemoveBraces; } bool Settings::CodeFormatter::breakReturnTypeDecl() const { return mBreakReturnTypeDecl; } void Settings::CodeFormatter::setBreakReturnTypeDecl(bool newBreakReturnTypeDecl) { mBreakReturnTypeDecl = newBreakReturnTypeDecl; } bool Settings::CodeFormatter::attachReturnType() const { return mAttachReturnType; } void Settings::CodeFormatter::setAttachReturnType(bool newAttachReturnType) { mAttachReturnType = newAttachReturnType; } bool Settings::CodeFormatter::attachReturnTypeDecl() const { return mAttachReturnTypeDecl; } void Settings::CodeFormatter::setAttachReturnTypeDecl(bool newAttachReturnTypeDecl) { mAttachReturnTypeDecl = newAttachReturnTypeDecl; } bool Settings::CodeFormatter::keepOneLineBlocks() const { return mKeepOneLineBlocks; } void Settings::CodeFormatter::setKeepOneLineBlocks(bool newKeepOneLineBlocks) { mKeepOneLineBlocks = newKeepOneLineBlocks; } bool Settings::CodeFormatter::keepOneLineStatements() const { return mKeepOneLineStatements; } void Settings::CodeFormatter::setKeepOneLineStatements(bool newKeepOneLineStatements) { mKeepOneLineStatements = newKeepOneLineStatements; } bool Settings::CodeFormatter::convertTabs() const { return mConvertTabs; } void Settings::CodeFormatter::setConvertTabs(bool newConvertTabs) { mConvertTabs = newConvertTabs; } bool Settings::CodeFormatter::closeTemplates() const { return mCloseTemplates; } void Settings::CodeFormatter::setCloseTemplates(bool newCloseTemplates) { mCloseTemplates = newCloseTemplates; } bool Settings::CodeFormatter::removeCommentPrefix() const { return mRemoveCommentPrefix; } void Settings::CodeFormatter::setRemoveCommentPrefix(bool newRemoveCommentPrefix) { mRemoveCommentPrefix = newRemoveCommentPrefix; } int Settings::CodeFormatter::maxCodeLength() const { return mMaxCodeLength; } void Settings::CodeFormatter::setMaxCodeLength(int newMaxCodeLength) { mMaxCodeLength = newMaxCodeLength; } bool Settings::CodeFormatter::breakAfterLogical() const { return mBreakAfterLogical; } void Settings::CodeFormatter::setBreakAfterLogical(bool newBreakAfterLogical) { mBreakAfterLogical = newBreakAfterLogical; } bool Settings::CodeFormatter::breakReturnType() const { return mBreakReturnType; } void Settings::CodeFormatter::setBreakReturnType(bool newBreakReturnType) { mBreakReturnType = newBreakReturnType; } bool Settings::CodeFormatter::breakMaxCodeLength() const { return mBreakMaxCodeLength; } void Settings::CodeFormatter::setBreakMaxCodeLength(bool newBreakMaxCodeLength) { mBreakMaxCodeLength = newBreakMaxCodeLength; } bool Settings::CodeFormatter::indentAfterParens() const { return mIndentAfterParens; } void Settings::CodeFormatter::setIndentAfterParens(bool newIndentAfterParens) { mIndentAfterParens = newIndentAfterParens; } bool Settings::CodeFormatter::indentSwitches() const { return mIndentSwitches; } void Settings::CodeFormatter::setIndentSwitches(bool newIndentSwitches) { mIndentSwitches = newIndentSwitches; } void Settings::CodeFormatter::doSave() { saveValue("brace_style",mBraceStyle); saveValue("indent_style",mIndentStyle); saveValue("tab_width",mTabWidth); saveValue("attach_namespaces",mAttachNamespaces); saveValue("attach_classes",mAttachClasses); saveValue("attach_inlines",mAttachInlines); saveValue("attach_extern_c",mAttachExternC); saveValue("attach_closing_while",mAttachClosingWhile); saveValue("indent_classes",mIndentClasses); saveValue("indent_modifiers",mIndentModifiers); saveValue("indent_switches",mIndentSwitches); saveValue("indent_cases",mIndentCases); saveValue("indent_namespaces",mIndentNamespaces); saveValue("indent_after_parents",mIndentAfterParens); saveValue("indent_continuation",mIndentContinuation); saveValue("indent_labels",mIndentLabels); saveValue("indent_preproc_block",mIndentPreprocBlock); saveValue("indent_preproc_cond",mIndentPreprocCond); saveValue("indent_preproc_define",mIndentPreprocDefine); saveValue("indent_col1_comments",mIndentCol1Comments); saveValue("min_conditional_indent",mMinConditionalIndent); saveValue("max_continuation_indent",mMaxContinuationIndent); saveValue("break_blocks",mBreakBlocks); saveValue("break_blocks_all",mBreakBlocksAll); saveValue("pad_oper",mPadOper); saveValue("pad_comma",mPadComma); saveValue("pad_paren",mPadParen); saveValue("pad_paren_out",mPadParenOut); saveValue("pad_first_paren_out",mPadFirstParenOut); saveValue("pad_parent_in",mPadParenIn); saveValue("pad_header",mPadHeader); saveValue("unpad_paren",mUnpadParen); saveValue("delete_empty_lines",mDeleteEmptyLines); saveValue("delete_multiple_empty_lines",mDeleteMultipleEmptyLines); saveValue("fill_empty_lines",mFillEmptyLines); saveValue("align_pointer_style",mAlignPointerStyle); saveValue("align_reference_style",mAlignReferenceStyle); saveValue("break_closing_braces",mBreakClosingBraces); saveValue("break_else_if",mBreakElseIf); saveValue("break_one_line_headers",mBreakOneLineHeaders); saveValue("add_braces",mAddBraces); saveValue("add_one_line_braces",mAddOneLineBraces); saveValue("remove_braces",mRemoveBraces); saveValue("break_return_type",mBreakReturnType); saveValue("break_return_type_decl",mBreakReturnTypeDecl); saveValue("attach_return_type",mAttachReturnType); saveValue("attach_return_type_decl",mAttachReturnTypeDecl); saveValue("keep_one_line_blocks",mKeepOneLineBlocks); saveValue("keep_one_line_statements",mKeepOneLineStatements); saveValue("convert_tabs",mConvertTabs); saveValue("close_templates",mCloseTemplates); saveValue("remove_comment_prefix",mRemoveCommentPrefix); saveValue("break_max_code_length",mBreakMaxCodeLength); saveValue("max_code_length",mMaxCodeLength); saveValue("break_after_logical",mBreakAfterLogical); } void Settings::CodeFormatter::doLoad() { mBraceStyle = intValue("brace_style", FormatterBraceStyle::fbsJava); mIndentStyle = intValue("indent_style",FormatterIndentType::fitTab); // 0 isspaces, 1 is tab mTabWidth = intValue("tab_width",4); mAttachNamespaces = boolValue("attach_namespaces",false); mAttachClasses = boolValue("attach_classes",false); mAttachInlines = boolValue("attach_inlines",false); mAttachExternC = boolValue("attach_extern_c",false); mAttachClosingWhile = boolValue("attach_closing_while",false); mIndentClasses = boolValue("indent_classes",false); mIndentModifiers = boolValue("indent_modifiers",false); mIndentSwitches = boolValue("indent_switches",true); mIndentCases = boolValue("indent_cases",false); mIndentNamespaces = boolValue("indent_namespaces",true); mIndentAfterParens = boolValue("indent_after_parents",false); mIndentContinuation = intValue("indent_continuation",1); mIndentLabels = boolValue("indent_labels",false); mIndentPreprocBlock = boolValue("indent_preproc_block",true); mIndentPreprocCond = boolValue("indent_preproc_cond",false); mIndentPreprocDefine = boolValue("indent_preproc_define",false); mIndentCol1Comments = boolValue("indent_col1_comments",false); mMinConditionalIndent = intValue("min_conditional_indent",1); mMaxContinuationIndent = intValue("max_continuation_indent",40); mBreakBlocks = boolValue("break_blocks",false); mBreakBlocksAll = boolValue("break_blocks_all",false); mPadOper = boolValue("pad_oper",true); mPadComma = boolValue("pad_comma",true); mPadParen = boolValue("pad_paren",false); mPadParenOut = boolValue("pad_paren_out",false); mPadFirstParenOut = boolValue("pad_first_paren_out",false); mPadParenIn = boolValue("pad_parent_in",false); mPadHeader = boolValue("pad_header",true); mUnpadParen = boolValue("unpad_paren",false); mDeleteEmptyLines = boolValue("delete_empty_lines",false); mDeleteMultipleEmptyLines = boolValue("delete_multiple_empty_lines",false); mFillEmptyLines = boolValue("fill_empty_lines",false); mAlignPointerStyle = intValue("align_pointer_style", FormatterOperatorAlign::foaNone); mAlignReferenceStyle = intValue("align_reference_style", FormatterOperatorAlign::foaNone); mBreakClosingBraces = boolValue("break_closing_braces",false); mBreakElseIf = boolValue("break_else_if",false); mBreakOneLineHeaders = boolValue("break_one_line_headers",false); mAddBraces = boolValue("add_braces",false); mAddOneLineBraces = boolValue("add_one_line_braces",false); mRemoveBraces = boolValue("remove_braces",false); mBreakReturnType = boolValue("break_return_type",false); mBreakReturnTypeDecl = boolValue("break_return_type_decl",false); mAttachReturnType = boolValue("attach_return_type",false); mAttachReturnTypeDecl = boolValue("attach_return_type_decl",false); mKeepOneLineBlocks = boolValue("keep_one_line_blocks",false); mKeepOneLineStatements = boolValue("keep_one_line_statements",false); mConvertTabs = boolValue("convert_tabs",false); mCloseTemplates = boolValue("close_templates",false); mRemoveCommentPrefix = boolValue("remove_comment_prefix",false); mBreakMaxCodeLength = boolValue("break_max_code_length",false); mMaxCodeLength = intValue("max_code_length",80); mBreakAfterLogical = boolValue("break_after_logical",false); } int Settings::CodeFormatter::braceStyle() const { return mBraceStyle; } void Settings::CodeFormatter::setBraceStyle(int newBraceStyle) { mBraceStyle = newBraceStyle; } Settings::UI::UI(Settings *settings):_Base(settings,SETTING_UI) { } const QByteArray &Settings::UI::mainWindowGeometry() const { return mMainWindowGeometry; } void Settings::UI::setMainWindowGeometry(const QByteArray &newMainWindowGeometry) { mMainWindowGeometry = newMainWindowGeometry; } int Settings::UI::bottomPanelIndex() const { return mBottomPanelIndex; } void Settings::UI::setBottomPanelIndex(int newBottomPanelIndex) { mBottomPanelIndex = newBottomPanelIndex; } int Settings::UI::leftPanelIndex() const { return mLeftPanelIndex; } void Settings::UI::setLeftPanelIndex(int newLeftPanelIndex) { mLeftPanelIndex = newLeftPanelIndex; } bool Settings::UI::classBrowserShowInherited() const { return mClassBrowserShowInherited; } void Settings::UI::setClassBrowserShowInherited(bool newClassBrowserShowInherited) { mClassBrowserShowInherited = newClassBrowserShowInherited; } bool Settings::UI::showProblem() const { return mShowProblem; } void Settings::UI::setShowProblem(bool newShowProblem) { mShowProblem = newShowProblem; } int Settings::UI::settingsDialogSplitterPos() const { return mSettingsDialogSplitterPos; } void Settings::UI::setSettingsDialogSplitterPos(int newSettingsDialogSplitterPos) { mSettingsDialogSplitterPos = newSettingsDialogSplitterPos; } int Settings::UI::newProjectDialogWidth() const { return mNewProjectDialogWidth; } void Settings::UI::setNewProjectDialogWidth(int newNewProjectDialogWidth) { mNewProjectDialogWidth = newNewProjectDialogWidth; } int Settings::UI::newProjectDialogHeight() const { return mNewProjectDialogHeight; } void Settings::UI::setNewProjectDialogHeight(int newNewProjectDialogHeight) { mNewProjectDialogHeight = newNewProjectDialogHeight; } int Settings::UI::newClassDialogWidth() const { return mNewClassDialogWidth; } void Settings::UI::setNewClassDialogWidth(int newNewClassDialogWidth) { mNewClassDialogWidth = newNewClassDialogWidth; } int Settings::UI::newClassDialogHeight() const { return mNewClassDialogHeight; } void Settings::UI::setNewClassDialogHeight(int newNewClassDialogHeight) { mNewClassDialogHeight = newNewClassDialogHeight; } int Settings::UI::newHeaderDialogHeight() const { return mNewHeaderDialogHeight; } void Settings::UI::setNewHeaderDialogHeight(int newNewFileDialogHeight) { mNewHeaderDialogHeight = newNewFileDialogHeight; } const QSize &Settings::UI::messagesTabsSize() const { return mMessagesTabsSize; } void Settings::UI::setMessagesTabsSize(const QSize &newMessagesTabsSize) { mMessagesTabsSize = newMessagesTabsSize; } int Settings::UI::debugPanelIndex() const { return mDebugPanelIndex; } void Settings::UI::setDebugPanelIndex(int newDebugPanelIndex) { mDebugPanelIndex = newDebugPanelIndex; } int Settings::UI::problemOrder() const { return mProblemOrder; } void Settings::UI::setProblemOrder(int newProblemOrder) { mProblemOrder = newProblemOrder; } bool Settings::UI::openEditorsWhenReplace() const { return mOpenEditorsWhenReplace; } void Settings::UI::setOpenEditorsWhenReplace(bool newOpenEditorsWhenReplace) { mOpenEditorsWhenReplace = newOpenEditorsWhenReplace; } int Settings::UI::bookmarkOrder() const { return mBookmarkOrder; } void Settings::UI::setBookmarkOrder(int newBookmarkOrder) { mBookmarkOrder = newBookmarkOrder; } int Settings::UI::TODOOrder() const { return mTODOOrder; } void Settings::UI::setTODOOrder(int newTODOOrder) { mTODOOrder = newTODOOrder; } int Settings::UI::searchOrder() const { return mSearchOrder; } void Settings::UI::setSearchOrder(int newSearchOrder) { mSearchOrder = newSearchOrder; } int Settings::UI::debugOrder() const { return mDebugOrder; } void Settings::UI::setDebugOrder(int newDebugOrder) { mDebugOrder = newDebugOrder; } int Settings::UI::compileLogOrder() const { return mCompileLogOrder; } void Settings::UI::setCompileLogOrder(int newCompileLogOrder) { mCompileLogOrder = newCompileLogOrder; } int Settings::UI::issuesOrder() const { return mIssuesOrder; } void Settings::UI::setIssuesOrder(int newIssuesOrder) { mIssuesOrder = newIssuesOrder; } int Settings::UI::problemSetOrder() const { return mProblemSetOrder; } void Settings::UI::setProblemSetOrder(int newProblemSetOrder) { mProblemSetOrder = newProblemSetOrder; } int Settings::UI::filesOrder() const { return mFilesOrder; } void Settings::UI::setFilesOrder(int newFilesOrder) { mFilesOrder = newFilesOrder; } int Settings::UI::structureOrder() const { return mStructureOrder; } void Settings::UI::setStructureOrder(int newStructureOrder) { mStructureOrder = newStructureOrder; } int Settings::UI::watchOrder() const { return mWatchOrder; } void Settings::UI::setWatchOrder(int newWatchOrder) { mWatchOrder = newWatchOrder; } int Settings::UI::projectOrder() const { return mProjectOrder; } void Settings::UI::setProjectOrder(int newProjectOrder) { mProjectOrder = newProjectOrder; } const QSize &Settings::UI::explorerTabsSize() const { return mExplorerTabsSize; } void Settings::UI::setExplorerTabsSize(const QSize &newExplorerTabsSize) { mExplorerTabsSize = newExplorerTabsSize; } bool Settings::UI::shrinkMessagesTabs() const { return mShrinkMessagesTabs; } void Settings::UI::setShrinkMessagesTabs(bool newShrinkMessagesTabs) { mShrinkMessagesTabs = newShrinkMessagesTabs; } bool Settings::UI::shrinkExplorerTabs() const { return mShrinkExplorerTabs; } void Settings::UI::setShrinkExplorerTabs(bool newShrinkExplorerTabs) { mShrinkExplorerTabs = newShrinkExplorerTabs; } int Settings::UI::newHeaderDialogWidth() const { return mNewHeaderDialogWidth; } void Settings::UI::setNewHeaderDialogWidth(int newNewFileDialogWidth) { mNewHeaderDialogWidth = newNewFileDialogWidth; } int Settings::UI::settingsDialogHeight() const { return mSettingsDialogHeight; } void Settings::UI::setSettingsDialogHeight(int newSettingsDialogHeight) { mSettingsDialogHeight = newSettingsDialogHeight; } int Settings::UI::settingsDialogWidth() const { return mSettingsDialogWidth; } void Settings::UI::setSettingsDialogWidth(int newSettingsDialogWidth) { mSettingsDialogWidth = newSettingsDialogWidth; } int Settings::UI::CPUDialogSplitterPos() const { return mCPUDialogSplitterPos; } void Settings::UI::setCPUDialogSplitterPos(int newCPUDialogSplitterPos) { mCPUDialogSplitterPos = newCPUDialogSplitterPos; } int Settings::UI::CPUDialogHeight() const { return mCPUDialogHeight; } void Settings::UI::setCPUDialogHeight(int newCPUDialogHeight) { mCPUDialogHeight = newCPUDialogHeight; } int Settings::UI::CPUDialogWidth() const { return mCPUDialogWidth; } void Settings::UI::setCPUDialogWidth(int newCPUDialogWidth) { mCPUDialogWidth = newCPUDialogWidth; } bool Settings::UI::showBookmark() const { return mShowBookmark; } void Settings::UI::setShowBookmark(bool newShowBookmark) { mShowBookmark = newShowBookmark; } bool Settings::UI::showTODO() const { return mShowTODO; } void Settings::UI::setShowTODO(bool newShowTODO) { mShowTODO = newShowTODO; } bool Settings::UI::showSearch() const { return mShowSearch; } void Settings::UI::setShowSearch(bool newShowSearch) { mShowSearch = newShowSearch; } bool Settings::UI::showDebug() const { return mShowDebug; } void Settings::UI::setShowDebug(bool newShowDebug) { mShowDebug = newShowDebug; } bool Settings::UI::showCompileLog() const { return mShowCompileLog; } void Settings::UI::setShowCompileLog(bool newShowCompileLog) { mShowCompileLog = newShowCompileLog; } bool Settings::UI::showIssues() const { return mShowIssues; } void Settings::UI::setShowIssues(bool newShowIssues) { mShowIssues = newShowIssues; } bool Settings::UI::showProblemSet() const { return mShowProblemSet; } void Settings::UI::setShowProblemSet(bool newShowProblemSet) { mShowProblemSet = newShowProblemSet; } bool Settings::UI::showFiles() const { return mShowFiles; } void Settings::UI::setShowFiles(bool newShowFiles) { mShowFiles = newShowFiles; } bool Settings::UI::showStructure() const { return mShowStructure; } void Settings::UI::setShowStructure(bool newShowStructure) { mShowStructure = newShowStructure; } bool Settings::UI::showWatch() const { return mShowWatch; } void Settings::UI::setShowWatch(bool newShowWatch) { mShowWatch = newShowWatch; } bool Settings::UI::showProject() const { return mShowProject; } void Settings::UI::setShowProject(bool newShowProject) { mShowProject = newShowProject; } bool Settings::UI::showToolWindowBars() const { return mShowToolWindowBars; } void Settings::UI::setShowToolWindowBars(bool newShowToolWindowBars) { mShowToolWindowBars = newShowToolWindowBars; } bool Settings::UI::showStatusBar() const { return mShowStatusBar; } void Settings::UI::setShowStatusBar(bool newShowStatusBar) { mShowStatusBar = newShowStatusBar; } bool Settings::UI::showToolbar() const { return mShowToolbar; } void Settings::UI::setShowToolbar(bool newShowToolbar) { mShowToolbar = newShowToolbar; } bool Settings::UI::classBrowserSortType() const { return mClassBrowserSortType; } void Settings::UI::setClassBrowserSortType(bool newClassBrowserSortType) { mClassBrowserSortType = newClassBrowserSortType; } bool Settings::UI::classBrowserSortAlpha() const { return mClassBrowserSortAlpha; } void Settings::UI::setClassBrowserSortAlpha(bool newClassBrowserSortAlpha) { mClassBrowserSortAlpha = newClassBrowserSortAlpha; } const QByteArray &Settings::UI::mainWindowState() const { return mMainWindowState; } void Settings::UI::setMainWindowState(const QByteArray &newMainWindowState) { mMainWindowState = newMainWindowState; } void Settings::UI::doSave() { saveValue("open_editor_when_batch_replace",mOpenEditorsWhenReplace); saveValue("main_window_state",mMainWindowState); saveValue("main_window_geometry",mMainWindowGeometry); saveValue("bottom_panel_index",mBottomPanelIndex); saveValue("left_panel_index",mLeftPanelIndex); saveValue("debug_panel_index",mDebugPanelIndex); saveValue("class_browser_sort_alphabetically",mClassBrowserSortAlpha); saveValue("class_browser_sort_by_type",mClassBrowserSortType); saveValue("class_browser_show_inherited",mClassBrowserShowInherited); saveValue("shrink_explorer_tabs",mShrinkExplorerTabs); saveValue("shrink_messages_tabs",mShrinkMessagesTabs); saveValue("explorer_tabs_size", mExplorerTabsSize); saveValue("messages_tabs_size",mMessagesTabsSize); //view saveValue("show_toolbar", mShowToolbar); saveValue("show_statusbar", mShowStatusBar); saveValue("show_tool_windowbars", mShowToolWindowBars); saveValue("show_project", mShowProject); saveValue("show_watch", mShowWatch); saveValue("show_structure", mShowStructure); saveValue("show_file", mShowFiles); saveValue("show_problem_set", mShowProblemSet); saveValue("show_issues", mShowIssues); saveValue("show_compile_log", mShowCompileLog); saveValue("show_debug", mShowDebug); saveValue("show_search", mShowSearch); saveValue("show_todo", mShowTODO); saveValue("show_bookmark", mShowBookmark); saveValue("show_problem", mShowProblem); saveValue("project_order", mProjectOrder); saveValue("watch_order", mWatchOrder); saveValue("structure_order", mStructureOrder); saveValue("files_order", mFilesOrder); saveValue("problemset_order", mProblemSetOrder); saveValue("issues_order", mIssuesOrder); saveValue("compilelog_order", mCompileLogOrder); saveValue("debug_order", mDebugOrder); saveValue("search_order", mSearchOrder); saveValue("todo_order", mTODOOrder); saveValue("bookmark_order", mBookmarkOrder); saveValue("problem_order", mProblemOrder); //dialogs saveValue("cpu_dialog_width", mCPUDialogWidth); saveValue("cpu_dialog_height", mCPUDialogHeight); saveValue("cpu_dialog_splitter", mCPUDialogSplitterPos); saveValue("settings_dialog_width", mSettingsDialogWidth); saveValue("settings_dialog_height", mSettingsDialogHeight); saveValue("settings_dialog_splitter", mSettingsDialogSplitterPos); saveValue("new_project_dialog_width", mNewProjectDialogWidth); saveValue("new_project_dialog_height", mNewProjectDialogHeight); saveValue("new_class_dialog_width", mNewClassDialogWidth); saveValue("new_class_dialog_height", mNewClassDialogHeight); saveValue("new_header_dialog_width", mNewHeaderDialogWidth); saveValue("new_header_dialog_height", mNewHeaderDialogHeight); } void Settings::UI::doLoad() { mOpenEditorsWhenReplace=boolValue("open_editor_when_batch_replace",true); mMainWindowState = value("main_window_state",QByteArray()).toByteArray(); mMainWindowGeometry = value("main_window_geometry",QByteArray()).toByteArray(); mBottomPanelIndex = intValue("bottom_panel_index",0); mLeftPanelIndex = intValue("left_panel_index",0); mDebugPanelIndex = intValue("debug_panel_index",0); mClassBrowserSortAlpha = boolValue("class_browser_sort_alphabetically",true); mClassBrowserSortType = boolValue("class_browser_sort_by_type",true); mClassBrowserShowInherited = boolValue("class_browser_show_inherited",true); mShrinkExplorerTabs = boolValue("shrink_explorer_tabs",false); mShrinkMessagesTabs = boolValue("shrink_messages_tabs",false); mExplorerTabsSize = sizeValue("explorer_tabs_size",QSize(300,600)); mMessagesTabsSize = sizeValue("messages_tabs_size",QSize(450,150)); //view mShowToolbar = boolValue("show_toolbar",true); mShowStatusBar = boolValue("show_statusbar",true); mShowToolWindowBars = boolValue("show_tool_windowbars",true); mShowProject = boolValue("show_project",true); mShowWatch = boolValue("show_watch",true); mShowStructure = boolValue("show_structure",true); mShowFiles = boolValue("show_file",true); mShowProblemSet = boolValue("show_problem_set",true); mShowIssues = boolValue("show_issues",true); mShowCompileLog = boolValue("show_compile_log",true); mShowDebug = boolValue("show_debug",true); mShowSearch = boolValue("show_search",true); mShowTODO = boolValue("show_todo",true); mShowBookmark = boolValue("show_bookmark",true); mShowProblem = boolValue("show_problem",true); mProjectOrder = intValue("project_order",1); mWatchOrder = intValue("watch_order",2); mStructureOrder = intValue("structure_order",3); mFilesOrder = intValue("files_order",0); mProblemSetOrder = intValue("problemset_order",4); mIssuesOrder = intValue("issues_order",0); mCompileLogOrder = intValue("compilelog_order",1); mDebugOrder = intValue("debug_order",2); mSearchOrder = intValue("search_order",3); mTODOOrder = intValue("todo_order",4); mBookmarkOrder = intValue("bookmark_order",5); mProblemOrder = intValue("problem_order",6); //dialogs mCPUDialogWidth = intValue("cpu_dialog_width",977*qApp->desktop()->width()/1920); mCPUDialogHeight = intValue("cpu_dialog_height",622*qApp->desktop()->height()/1080); mCPUDialogSplitterPos = intValue("cpu_dialog_splitter",500*qApp->desktop()->width()/1920); mSettingsDialogWidth = intValue("settings_dialog_width",977*qApp->desktop()->width()/1920); mSettingsDialogHeight = intValue("settings_dialog_height",622*qApp->desktop()->height()/1080); mSettingsDialogSplitterPos = intValue("settings_dialog_splitter",300*qApp->desktop()->width()/1920); mNewProjectDialogWidth = intValue("new_project_dialog_width", 900*qApp->desktop()->width()/1920); mNewProjectDialogHeight = intValue("new_project_dialog_height", 600*qApp->desktop()->height()/1080); mNewClassDialogWidth = intValue("new_class_dialog_width", 642*qApp->desktop()->width()/1920); mNewClassDialogHeight = intValue("new_class_dialog_height", 300*qApp->desktop()->height()/1080); mNewHeaderDialogWidth = intValue("new_header_dialog_width", 642*qApp->desktop()->width()/1920); mNewHeaderDialogHeight = intValue("new_header_dialog_height", 300*qApp->desktop()->height()/1080); } #ifdef ENABLE_VCS Settings::VCS::VCS(Settings *settings):_Base(settings,SETTING_VCS), mGitOk(false) { } void Settings::VCS::doSave() { saveValue("git_path",mGitPath); } void Settings::VCS::doLoad() { setGitPath(stringValue("git_path", "")); } const QString &Settings::VCS::gitPath() const { return mGitPath; } void Settings::VCS::setGitPath(const QString &newGitPath) { if (mGitPath!=newGitPath) { mGitPath = newGitPath; validateGit(); } } void Settings::VCS::validateGit() { mGitOk = false; QFileInfo fileInfo(mGitPath); if (!fileInfo.exists()) { return; } mGitOk=true; // QStringList args; // args.append("--version"); // QString output = runAndGetOutput( // fileInfo.fileName(), // fileInfo.absolutePath(), // args); // mGitOk = output.startsWith("git version"); } bool Settings::VCS::gitOk() const { return mGitOk; } void Settings::VCS::detectGitInPath() { QProcessEnvironment env = QProcessEnvironment::systemEnvironment(); QString path = env.value("PATH"); QStringList pathList = path.split(PATH_SEPARATOR); QSet searched; foreach (const QString& s, pathList){ if (searched.contains(s)) continue;; searched.insert(s); QDir dir(s); if (dir.exists(GIT_PROGRAM)) { QString oldPath = mGitPath; setGitPath(dir.filePath(GIT_PROGRAM)); validateGit(); if (mGitOk) { save(); return; } else { mGitPath = oldPath; } } } } #endif Settings::Languages::Languages(Settings *settings): _Base(settings,SETTING_LANGUAGES) { } Settings::Languages::X86ASMDialect Settings::Languages::x86DialectOfASMGenerated() const { return mX86DialectOfASMGenerated; } void Settings::Languages::setX86DialectOfASMGenerated(X86ASMDialect newX86DialectOfASMGenerated) { mX86DialectOfASMGenerated = newX86DialectOfASMGenerated; } bool Settings::Languages::indentCSwitchCaseKeywords() const { return mIndentCSwitchCaseKeywords; } void Settings::Languages::setIndentCSwitchCaseKeywords(bool newIndentCSwitchCaseKeywords) { mIndentCSwitchCaseKeywords = newIndentCSwitchCaseKeywords; } bool Settings::Languages::indentCClassMemberVisibilityKeywords() const { return mIndentCClassMemberVisibilityKeywords; } void Settings::Languages::setIndentCClassMemberVisibilityKeywords(bool newIndentCClassMemberVisibilityKeywords) { mIndentCClassMemberVisibilityKeywords = newIndentCClassMemberVisibilityKeywords; } void Settings::Languages::doSave() { //ASM saveValue("no_debug_directives_when_generate_asm",mNoDebugDirectivesWhenGenerateASM); saveValue("no_seh_directives_when_generate_asm",mNoSEHDirectivesWhenGenerateASM); saveValue("x86_dialect_of_asm_generated",(int)mX86DialectOfASMGenerated); //C/C++ // saveValue("ident_c_class_member_visibility_keywords",mIndentCClassMemberVisibilityKeywords); // saveValue("ident_c_switch_case_keywords",mIndentCSwitchCaseKeywords); } void Settings::Languages::doLoad() { mNoDebugDirectivesWhenGenerateASM = boolValue("no_debug_directives_when_generate_asm",true); mNoSEHDirectivesWhenGenerateASM = boolValue("no_seh_directives_when_generate_asm",true); mX86DialectOfASMGenerated = (X86ASMDialect)intValue("x86_dialect_of_asm_generated",(int)X86ASMDialect::ATT); //C/C++ // mIndentCClassMemberVisibilityKeywords = boolValue("ident_c_class_member_visibility_keywords",false); // mIndentCSwitchCaseKeywords = boolValue("ident_c_switch_case_keywords",false); } bool Settings::Languages::noSEHDirectivesWhenGenerateASM() const { return mNoSEHDirectivesWhenGenerateASM; } void Settings::Languages::setNoSEHDirectivesWhenGenerateASM(bool newNoSEHDirectivesWhenGenerateASM) { mNoSEHDirectivesWhenGenerateASM = newNoSEHDirectivesWhenGenerateASM; } bool Settings::Languages::noDebugDirectivesWhenGenerateASM() const { return mNoDebugDirectivesWhenGenerateASM; } void Settings::Languages::setNoDebugDirectivesWhenGenerateASM(bool newNoDebugDirectivesWhenGenerateASM) { mNoDebugDirectivesWhenGenerateASM = newNoDebugDirectivesWhenGenerateASM; } std::tuple> wrapCommandForTerminalEmulator(const QString &terminal, const QStringList &argsPattern, const QStringList &payloadArgsWithArgv0) { QStringList wrappedArgs; std::unique_ptr temproryFile; for (const QString &patternItem : argsPattern) { if (patternItem == "$term") wrappedArgs.append(terminal); else if (patternItem == "$integrated_term") wrappedArgs.append(includeTrailingPathDelimiter(pSettings->dirs().appDir())+terminal); else if (patternItem == "$argv") wrappedArgs.append(payloadArgsWithArgv0); else if (patternItem == "$command" || patternItem == "$unix_command") { // “$command” is for compatibility; previously used on multiple Unix terms QStringList escapedArgs; for (int i = 0; i < payloadArgsWithArgv0.length(); i++) { auto &arg = payloadArgsWithArgv0[i]; auto escaped = escapeArgument(arg, i == 0, EscapeArgumentRule::BourneAgainShellPretty); escapedArgs.append(escaped); } wrappedArgs.push_back(escapedArgs.join(' ')); } else if (patternItem == "$dos_command") { QStringList escapedArgs; for (int i = 0; i < payloadArgsWithArgv0.length(); i++) { auto &arg = payloadArgsWithArgv0[i]; auto escaped = escapeArgument(arg, i == 0, EscapeArgumentRule::WindowsCommandPrompt); escapedArgs.append(escaped); } wrappedArgs.push_back(escapedArgs.join(' ')); } else if (patternItem == "$lpCommandLine") { QStringList escapedArgs; for (int i = 0; i < payloadArgsWithArgv0.length(); i++) { auto &arg = payloadArgsWithArgv0[i]; auto escaped = escapeArgument(arg, i == 0, EscapeArgumentRule::WindowsCreateProcess); escapedArgs.append(escaped); } wrappedArgs.push_back(escapedArgs.join(' ')); } else if (patternItem == "$tmpfile" || patternItem == "$tmpfile.command") { // “$tmpfile” is for compatibility; previously used on macOS Terminal.app temproryFile = std::make_unique(QDir::tempPath() + "/redpanda_XXXXXX.command"); if (temproryFile->open()) { QStringList escapedArgs; for (int i = 0; i < payloadArgsWithArgv0.length(); i++) { auto &arg = payloadArgsWithArgv0[i]; auto escaped = escapeArgument(arg, i == 0, EscapeArgumentRule::BourneAgainShellPretty); escapedArgs.append(escaped); } temproryFile->write(escapedArgs.join(' ').toUtf8()); temproryFile->write("\n"); temproryFile->flush(); QFile(temproryFile->fileName()).setPermissions(QFileDevice::ReadOwner | QFileDevice::WriteOwner | QFileDevice::ExeOwner); } wrappedArgs.push_back(temproryFile->fileName()); } else if (patternItem == "$tmpfile.bat") { temproryFile = std::make_unique(QDir::tempPath() + "/redpanda_XXXXXX.bat"); if (temproryFile->open()) { QStringList escapedArgs; for (int i = 0; i < payloadArgsWithArgv0.length(); i++) { auto &arg = payloadArgsWithArgv0[i]; auto escaped = escapeArgument(arg, i == 0, EscapeArgumentRule::WindowsCommandPrompt); escapedArgs.append(escaped); } temproryFile->write(escapedArgs.join(' ').toLocal8Bit()); temproryFile->write("\r\n"); temproryFile->flush(); QFile(temproryFile->fileName()).setPermissions(QFileDevice::ReadOwner | QFileDevice::WriteOwner | QFileDevice::ExeOwner); } wrappedArgs.push_back(temproryFile->fileName()); } else wrappedArgs.push_back(patternItem); } if (wrappedArgs.empty()) return {QString(""), QStringList{}, std::move(temproryFile)}; return {wrappedArgs[0], wrappedArgs.mid(1), std::move(temproryFile)}; } std::tuple> wrapCommandForTerminalEmulator(const QString &terminal, const QString &argsPattern, const QStringList &payloadArgsWithArgv0) { return wrapCommandForTerminalEmulator(terminal, parseArguments(argsPattern, Settings::Environment::terminalArgsPatternMagicVariables(), false), payloadArgsWithArgv0); }