From 7640d1fbf5c1c775bc3278332c97f504fdbba1ab Mon Sep 17 00:00:00 2001
From: Juergen Spitzmueller <spitz@lyx.org>
Date: Tue, 18 Jul 2023 17:55:08 +0200
Subject: [PATCH] Remove bogus condition and add comments

---
 src/frontends/qt/GuiDocument.cpp      |  4 ++--
 src/frontends/qt/LaTeXHighlighter.cpp | 15 +++++++--------
 src/frontends/qt/LaTeXHighlighter.h   |  5 +----
 3 files changed, 10 insertions(+), 14 deletions(-)

diff --git a/src/frontends/qt/GuiDocument.cpp b/src/frontends/qt/GuiDocument.cpp
index 3d717610af..e8c8c19e8a 100644
--- a/src/frontends/qt/GuiDocument.cpp
+++ b/src/frontends/qt/GuiDocument.cpp
@@ -1774,8 +1774,8 @@ GuiDocument::GuiDocument(GuiView & lv)
 		pdfSupportModule->subjectLE));
 	pdfSupportModule->keywordsLE->setValidator(new NoNewLineValidator(
 		pdfSupportModule->keywordsLE));
-	(void) new LaTeXHighlighter(pdfSupportModule->optionsTE->document(), true, true, true);
-	(void) new LaTeXHighlighter(pdfSupportModule->metadataTE->document(), true, true, true);
+	(void) new LaTeXHighlighter(pdfSupportModule->optionsTE->document(), true, true);
+	(void) new LaTeXHighlighter(pdfSupportModule->metadataTE->document(), true, true);
 
 	for (int i = 0; backref_opts[i][0]; ++i)
 		pdfSupportModule->backrefCO->addItem(qt_(backref_opts_gui[i]));
diff --git a/src/frontends/qt/LaTeXHighlighter.cpp b/src/frontends/qt/LaTeXHighlighter.cpp
index c18983baa5..f4ce08fbbe 100644
--- a/src/frontends/qt/LaTeXHighlighter.cpp
+++ b/src/frontends/qt/LaTeXHighlighter.cpp
@@ -20,8 +20,8 @@ namespace lyx {
 namespace frontend {
 
 
-LaTeXHighlighter::LaTeXHighlighter(QTextDocument * parent, bool at_letter, bool keyval, bool optsnippet)
-	: QSyntaxHighlighter(parent), at_letter_(at_letter), keyval_(keyval), optsnippet_(optsnippet)
+LaTeXHighlighter::LaTeXHighlighter(QTextDocument * parent, bool at_letter, bool keyval)
+	: QSyntaxHighlighter(parent), at_letter_(at_letter), keyval_(keyval)
 {
 	auto blend = [](QColor color1, QColor color2) {
 		int r = 0.5 * (color1.red() + color2.red());
@@ -49,13 +49,12 @@ void LaTeXHighlighter::highlightBlock(QString const & text)
 	// keyval
 	if (keyval_) {
 		// Highlight key-val options. Used in some option widgets.
-		static QRegularExpression exprKeyvalkey("[^=,]+");
-		static QRegularExpression exprKeyvalgval("[^,]+{[^}]+}");
+		// 1. The keys. Might or might not have values
+		static QRegularExpression exprKeyvalkey("[^=,{]+");
+		// 2. These are grouped values such as "key1={val,val},key2=val"
+		static QRegularExpression exprKeyvalgval("[^=,{]+{[^}]+}");
+		// 3. And normal values if we don't find grouped ones
 		static QRegularExpression exprKeyvalval("[^,]+");
-		if (optsnippet_) {
-			static QRegularExpression exprKeyvalkey("^=,+");
-			static QRegularExpression exprKeyvalval("^,+");
-		}
 		QRegularExpressionMatch matchkey = exprKeyvalkey.match(text);
 		int kvindex = matchkey.capturedStart(0);
 		while (kvindex >= 0) {
diff --git a/src/frontends/qt/LaTeXHighlighter.h b/src/frontends/qt/LaTeXHighlighter.h
index 5f7108b4b4..7a80d1fa26 100644
--- a/src/frontends/qt/LaTeXHighlighter.h
+++ b/src/frontends/qt/LaTeXHighlighter.h
@@ -27,8 +27,7 @@ class LaTeXHighlighter : public QSyntaxHighlighter
 public:
 	explicit LaTeXHighlighter(QTextDocument * parent,
 				  bool at_letter = false,
-				  bool keyval = false,
-				  bool optsnippet = false);
+				  bool keyval = false);
 
 protected:
 	void highlightBlock(QString const & text) override;
@@ -44,8 +43,6 @@ private:
 	bool const at_letter_;
 	// highlight keyval options?
 	bool const keyval_;
-	// option snippet?
-	bool const optsnippet_;
 };
 
 } // namespace frontend