From a46f45a257ec93e011b99634e834101db3f5707c Mon Sep 17 00:00:00 2001 From: Liu Zhangjian Date: Tue, 17 Dec 2024 14:01:50 +0800 Subject: [PATCH] fix: [python] Python interpreter Some python interpreters are not visible in the `Project Properties Dialog` Log: fix issue --- .../properties/configpropertywidget.cpp | 35 +++++++++---------- 1 file changed, 16 insertions(+), 19 deletions(-) diff --git a/src/plugins/python/python/project/properties/configpropertywidget.cpp b/src/plugins/python/python/project/properties/configpropertywidget.cpp index 8482c3883..e61e3fbf2 100644 --- a/src/plugins/python/python/project/properties/configpropertywidget.cpp +++ b/src/plugins/python/python/project/properties/configpropertywidget.cpp @@ -22,7 +22,7 @@ class DetailPropertyWidgetPrivate friend class DetailPropertyWidget; DComboBox *pyVersionComboBox { nullptr }; DComboBox *executeFileComboBox { nullptr }; - DCheckBox *runInTerminal {nullptr}; + DCheckBox *runInTerminal { nullptr }; }; DetailPropertyWidget::DetailPropertyWidget(QWidget *parent) @@ -95,22 +95,22 @@ QList findAll(QString pattern, QString str, bool Greedy) return strList; } -QStringList getPythonAllVersion() +ToolChainData::Params getSystemPython() { - QDir dir("/usr/bin"); - QStringList filter { "Python*.*" }; - dir.setNameFilters(filter); - QStringList pythonList = dir.entryList(); - - QString pattern = "((\\d)|(\\d+.\\d+))($|\\s)"; - QStringList versions = findAll(pattern, pythonList.join(" "), true); + ToolChainData tcData; + QString retMsg; + if (!tcData.readToolChainData(retMsg)) { + qWarning() << retMsg; + return {}; + } - return versions; + const auto &toolChains = tcData.getToolChanins(); + return toolChains.value(kPython); } void DetailPropertyWidget::initData() { - QVariant interpreterConfig = OptionManager::getInstance()->getValue(option::CATEGORY_PYTHON, {"Interpreter"}); + QVariant interpreterConfig = OptionManager::getInstance()->getValue(option::CATEGORY_PYTHON, "Interpreter"); QVariantList variantList = interpreterConfig.toMap().value("customInterpreters").toList(); QList customInterpreters; @@ -122,16 +122,13 @@ void DetailPropertyWidget::initData() customInterpreters.append(interpreter); } - auto systemPythonVersions = getPythonAllVersion(); + const auto &systemPython = getSystemPython(); int index = 0; - for (auto version : systemPythonVersions) { - ToolChainData::ToolChainParam param; - param.name = QString("python%1").arg(version); - param.path = "/usr/bin/" + param.name; - QString text = param.name + "(" + param.path + ")"; + for (const auto &python : systemPython) { + QString text = python.name + "(" + python.path + ")"; d->pyVersionComboBox->insertItem(index, text); - d->pyVersionComboBox->setItemData(index, QVariant::fromValue(param), Qt::UserRole + 1); - if (param.path == globalToolPath) + d->pyVersionComboBox->setItemData(index, QVariant::fromValue(python), Qt::UserRole + 1); + if (python.path == globalToolPath) d->pyVersionComboBox->setCurrentIndex(index); index++; }