From 704a758f69d43df8b772147bb5ebe03126335212 Mon Sep 17 00:00:00 2001 From: David Schulz Date: Tue, 5 Oct 2021 12:52:26 +0200 Subject: [PATCH] Docker: use PathListEditor for mounts Change-Id: I5ed0ebf5ecdad17c1800f15906063d3413307da3 Reviewed-by: hjk --- src/libs/utils/pathlisteditor.cpp | 1 + src/libs/utils/pathlisteditor.h | 3 +++ src/plugins/docker/dockerdevice.cpp | 26 ++++++++++++++------------ 3 files changed, 18 insertions(+), 12 deletions(-) diff --git a/src/libs/utils/pathlisteditor.cpp b/src/libs/utils/pathlisteditor.cpp index 61d215fd837..d24be4995b5 100644 --- a/src/libs/utils/pathlisteditor.cpp +++ b/src/libs/utils/pathlisteditor.cpp @@ -130,6 +130,7 @@ PathListEditor::PathListEditor(QWidget *parent) : }); addButton(tr("Delete Line"), this, [this] { deletePathAtCursor(); }); addButton(tr("Clear"), this, [this] { d->edit->clear(); }); + connect(d->edit, &QPlainTextEdit::textChanged, this, &PathListEditor::changed); } PathListEditor::~PathListEditor() diff --git a/src/libs/utils/pathlisteditor.h b/src/libs/utils/pathlisteditor.h index 07392fbe6ed..edd70336c09 100644 --- a/src/libs/utils/pathlisteditor.h +++ b/src/libs/utils/pathlisteditor.h @@ -58,6 +58,9 @@ public: void setPathList(const QString &pathString); void setFileDialogTitle(const QString &l); +signals: + void changed(); + protected: // Index after which to insert further "Add" buttons static const int lastInsertButtonIndex; diff --git a/src/plugins/docker/dockerdevice.cpp b/src/plugins/docker/dockerdevice.cpp index 11be0ce2b0d..6948552c965 100644 --- a/src/plugins/docker/dockerdevice.cpp +++ b/src/plugins/docker/dockerdevice.cpp @@ -49,17 +49,18 @@ #include #include #include +#include #include -#include #include #include +#include #include #include #include #include #include #include -#include +#include #include #include @@ -394,15 +395,13 @@ public: dockerDevice->tryCreateLocalFileAccess(); }); - m_pathsLineEdit = new QLineEdit; - m_pathsLineEdit->setText(data.repo); - m_pathsLineEdit->setToolTip(tr("Paths in this semi-colon separated list will be " - "mapped one-to-one into the Docker container.")); - m_pathsLineEdit->setText(data.mounts.join(';')); - m_pathsLineEdit->setPlaceholderText(tr("List project source directories here")); + m_pathsListEdit = new PathListEditor; + m_pathsListEdit->setToolTip(tr("Paths in this list will be mapped one-to-one into the " + "Docker container.")); + m_pathsListEdit->setPathList(data.mounts); - connect(m_pathsLineEdit, &QLineEdit::textChanged, this, [dockerDevice](const QString &text) { - dockerDevice->setMounts(text.split(';', Qt::SkipEmptyParts)); + connect(m_pathsListEdit, &PathListEditor::changed, this, [dockerDevice, this]() { + dockerDevice->setMounts(m_pathsListEdit->pathList()); }); auto logView = new QTextBrowser; @@ -443,7 +442,10 @@ public: daemonStateLabel, m_daemonReset, m_daemonState, Break(), m_runAsOutsideUser, Break(), m_usePathMapping, Break(), - tr("Paths to mount:"), m_pathsLineEdit, Break(), + Column { + new QLabel(tr("Paths to mount:")), + m_pathsListEdit, + }, Break(), Column { Space(20), Row { autoDetectButton, undoAutoDetectButton, listAutoDetectedButton, Stretch() }, @@ -463,7 +465,7 @@ private: QLabel *m_daemonState; QCheckBox *m_runAsOutsideUser; QCheckBox *m_usePathMapping; - QLineEdit *m_pathsLineEdit; + Utils::PathListEditor *m_pathsListEdit; KitDetector m_kitItemDetector; };