commit 478d59f5ddd1cda62883e4ef7ae06d5ad4ea9f72 Author: Juergen Spitzmueller <sp...@lyx.org> Date: Sat Oct 5 14:15:19 2024 +0200
Adhere to semantic background color with default branches This fixes color mismatched when "use system colors" is checked See https://marc.info/?l=lyx-users&m=172797086718347 (cherry picked from commit 1f7e8d3ffeb399ec4c02285f024d51b3a695f4c7) --- src/BranchList.cpp | 10 ++++++---- src/insets/InsetBranch.cpp | 4 ++++ status.24x | 2 ++ 3 files changed, 12 insertions(+), 4 deletions(-) diff --git a/src/BranchList.cpp b/src/BranchList.cpp index fc61065a4b..e37b255bf6 100644 --- a/src/BranchList.cpp +++ b/src/BranchList.cpp @@ -109,12 +109,14 @@ void Branch::setColors(string const & lmcol, string const & dmcol) string lmcolor = lmcolor_; string dmcolor = dmcolor_; if (lmcolor == "none") - lmcolor = lcolor.getX11HexName(Color_background); - else if (lmcolor.size() != 7 || lmcolor[0] != '#') + lmcolor = "background"; + // if we have background color, keep semantic value, as system colors might vary + else if (lmcolor != "background" && (lmcolor.size() != 7 || lmcolor[0] != '#')) lmcolor = lcolor.getX11HexName(lcolor.getFromLyXName(lmcolor)); if (dmcolor == "none") - dmcolor = lcolor.getX11HexName(Color_background, true); - else if (dmcolor.size() != 7 || dmcolor[0] != '#') + dmcolor = "background"; + // if we have background color, keep semantic value, as system colors might vary + else if (dmcolor != "background" && (dmcolor.size() != 7 || dmcolor[0] != '#')) dmcolor = lcolor.getX11HexName(lcolor.getFromLyXName(dmcolor), true); // FIXME UNICODE diff --git a/src/insets/InsetBranch.cpp b/src/insets/InsetBranch.cpp index 229e1bc37e..c979429984 100644 --- a/src/insets/InsetBranch.cpp +++ b/src/insets/InsetBranch.cpp @@ -156,6 +156,10 @@ ColorCode InsetBranch::backgroundColor(PainterInfo const & pi) const // FIXME UNICODE string const branchcol = "branch" + branch_id + to_utf8(params_.branch); ColorCode c = lcolor.getFromLyXName(branchcol); + // if we have background color, set to semantic value, as system colors + // might vary + if (lcolor.getX11HexName(c, (theApp() && theApp()->isInDarkMode())) == "background") + c = Color_background; if (c == Color_none) c = Color_error; return c; diff --git a/status.24x b/status.24x index f2bc03ad67..43ac7fac7c 100644 --- a/status.24x +++ b/status.24x @@ -66,6 +66,8 @@ What's new - Allow negative offset values in Horizontal Line dialog (bug 13102). +- Adhere to semantic background color with default branches. + * INTERNALS -- lyx-cvs mailing list lyx-cvs@lists.lyx.org http://lists.lyx.org/mailman/listinfo/lyx-cvs