aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/vcsbase
diff options
context:
space:
mode:
authorAndre Hartmann <aha_1980@gmx.de>2020-02-16 14:03:47 +0100
committerAndré Hartmann <aha_1980@gmx.de>2020-02-16 19:13:53 +0000
commit4cbb24906f3057a345998510bb3b732e71fd2169 (patch)
tree9875e9613bc4b33d6febb3f79a47c1ac87d2918a /src/plugins/vcsbase
parentd0a11322f4499e57dc1a6b2ec15755d3b48c0622 (diff)
Git: Allow clicking references in VcsOutputWindow
Fixes: QTCREATORBUG-16477 Change-Id: If1f36bec0826a3116e5261a270cd63a1536e13f5 Reviewed-by: Orgad Shaneh <orgads@gmail.com>
Diffstat (limited to 'src/plugins/vcsbase')
-rw-r--r--src/plugins/vcsbase/vcsoutputformatter.cpp31
-rw-r--r--src/plugins/vcsbase/vcsoutputformatter.h5
-rw-r--r--src/plugins/vcsbase/vcsoutputwindow.cpp8
-rw-r--r--src/plugins/vcsbase/vcsoutputwindow.h3
4 files changed, 39 insertions, 8 deletions
diff --git a/src/plugins/vcsbase/vcsoutputformatter.cpp b/src/plugins/vcsbase/vcsoutputformatter.cpp
index 7a283acd83..2b0aa92029 100644
--- a/src/plugins/vcsbase/vcsoutputformatter.cpp
+++ b/src/plugins/vcsbase/vcsoutputformatter.cpp
@@ -30,17 +30,24 @@
namespace VcsBase {
-VcsOutputFormatter::VcsOutputFormatter() : m_urlRegexp("https?://\\S*") {}
+VcsOutputFormatter::VcsOutputFormatter() :
+ m_urlRegexp("https?://\\S*"),
+ m_referenceRegexp("(v[0-9]+\\.[0-9]+\\.[0-9]+[\\-A-Za-z0-9]*)" // v0.1.2-beta3
+ "|([0-9a-f]{6,}(?:\\.\\.[0-9a-f]{6,})?)") // 789acf or 123abc..456cde
+{
+}
void VcsOutputFormatter::appendMessage(const QString &text, Utils::OutputFormat format)
{
- QString out = text;
- const QRegularExpressionMatch match = m_urlRegexp.match(text);
- if (match.hasMatch()) {
+ const QRegularExpressionMatch urlMatch = m_urlRegexp.match(text);
+ const QRegularExpressionMatch referenceMatch = m_referenceRegexp.match(text);
+
+ auto append = [this](const QRegularExpressionMatch &match,
+ QString text, Utils::OutputFormat format) {
const QTextCharFormat normalFormat = charFormat(format);
OutputFormatter::appendMessage(text.left(match.capturedStart()), format);
QTextCursor tc = plainTextEdit()->textCursor();
- QStringRef url = match.capturedRef();
+ QStringView url = match.capturedView();
int end = match.capturedEnd();
while (url.rbegin()->isPunct()) {
url.chop(1);
@@ -50,14 +57,22 @@ void VcsOutputFormatter::appendMessage(const QString &text, Utils::OutputFormat
tc.insertText(url.toString(), linkFormat(normalFormat, url.toString()));
tc.movePosition(QTextCursor::End, QTextCursor::MoveAnchor);
OutputFormatter::appendMessage(text.mid(end), format);
- } else {
+ };
+
+ if (urlMatch.hasMatch())
+ append(urlMatch, text, format);
+ else if (referenceMatch.hasMatch())
+ append(referenceMatch, text, format);
+ else
OutputFormatter::appendMessage(text, format);
- }
}
void VcsOutputFormatter::handleLink(const QString &href)
{
- QDesktopServices::openUrl(QUrl(href));
+ if (href.startsWith("http://") || href.startsWith("https://"))
+ QDesktopServices::openUrl(QUrl(href));
+ else if (!href.isEmpty())
+ emit referenceClicked(href);
}
}
diff --git a/src/plugins/vcsbase/vcsoutputformatter.h b/src/plugins/vcsbase/vcsoutputformatter.h
index fd38ffa627..d1c99b0087 100644
--- a/src/plugins/vcsbase/vcsoutputformatter.h
+++ b/src/plugins/vcsbase/vcsoutputformatter.h
@@ -31,14 +31,19 @@ namespace VcsBase {
class VcsOutputFormatter : public Utils::OutputFormatter
{
+ Q_OBJECT
public:
VcsOutputFormatter();
~VcsOutputFormatter() override = default;
void appendMessage(const QString &text, Utils::OutputFormat format) override;
void handleLink(const QString &href) override;
+signals:
+ void referenceClicked(const QString &reference);
+
private:
const QRegularExpression m_urlRegexp;
+ const QRegularExpression m_referenceRegexp;
};
}
diff --git a/src/plugins/vcsbase/vcsoutputwindow.cpp b/src/plugins/vcsbase/vcsoutputwindow.cpp
index 6891dac3ed..e468adcc30 100644
--- a/src/plugins/vcsbase/vcsoutputwindow.cpp
+++ b/src/plugins/vcsbase/vcsoutputwindow.cpp
@@ -102,6 +102,7 @@ public:
void appendLines(const QString &s, const QString &repository = QString());
void appendLinesWithStyle(const QString &s, VcsOutputWindow::MessageStyle style,
const QString &repository = QString());
+ VcsOutputFormatter *formatter();
protected:
void contextMenuEvent(QContextMenuEvent *event) override;
@@ -247,6 +248,11 @@ void OutputWindowPlainTextEdit::appendLinesWithStyle(const QString &s,
}
}
+VcsOutputFormatter *OutputWindowPlainTextEdit::formatter()
+{
+ return m_formatter;
+}
+
void OutputWindowPlainTextEdit::setFormat(VcsOutputWindow::MessageStyle style)
{
m_formatter->setBoldFontEnabled(style == VcsOutputWindow::Command);
@@ -305,6 +311,8 @@ VcsOutputWindow::VcsOutputWindow()
connect(this, &IOutputPane::resetZoom, &d->widget, &Core::OutputWindow::resetZoom);
connect(TextEditor::TextEditorSettings::instance(), &TextEditor::TextEditorSettings::behaviorSettingsChanged,
this, updateBehaviorSettings);
+ connect(d->widget.formatter(), &VcsOutputFormatter::referenceClicked,
+ VcsOutputWindow::instance(), &VcsOutputWindow::referenceClicked);
}
static QString filterPasswordFromUrls(const QString &input)
diff --git a/src/plugins/vcsbase/vcsoutputwindow.h b/src/plugins/vcsbase/vcsoutputwindow.h
index 749e824c38..b609827363 100644
--- a/src/plugins/vcsbase/vcsoutputwindow.h
+++ b/src/plugins/vcsbase/vcsoutputwindow.h
@@ -76,6 +76,9 @@ public:
Message, // A blue message text (e.g. "command has finished successfully")
};
+signals:
+ void referenceClicked(const QString &reference);
+
public slots:
static void setRepository(const QString &);
static void clearRepository();