diff options
author | Zufu Liu <unknown> | 2021-06-05 09:06:18 +1000 |
---|---|---|
committer | Zufu Liu <unknown> | 2021-06-05 09:06:18 +1000 |
commit | ce48887227040647c41adf1d28942f0b1e4c2a3f (patch) | |
tree | f37c123a433dbf50171e20488f7854501e63cdae /src/Document.cxx | |
parent | e7b174363b7e318fa40e3cb407ed55bff5fbbd4a (diff) | |
download | scintilla-mirror-ce48887227040647c41adf1d28942f0b1e4c2a3f.tar.gz |
Avoid extra processing as value_or doesn't evaluate lazily.
Diffstat (limited to 'src/Document.cxx')
-rw-r--r-- | src/Document.cxx | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/Document.cxx b/src/Document.cxx index 6531ad264..c3fcf10c3 100644 --- a/src/Document.cxx +++ b/src/Document.cxx @@ -525,7 +525,7 @@ static bool IsSubordinate(FoldLevel levelStart, FoldLevel levelTry) noexcept { } Sci::Line Document::GetLastChild(Sci::Line lineParent, std::optional<FoldLevel> level, Sci::Line lastLine) { - const FoldLevel levelStart = level.value_or(LevelNumberPart(GetFoldLevel(lineParent))); + const FoldLevel levelStart = LevelNumberPart(level ? *level : GetFoldLevel(lineParent)); const Sci::Line maxLine = LinesTotal(); const Sci::Line lookLastLine = (lastLine != -1) ? std::min(LinesTotal() - 1, lastLine) : -1; Sci::Line lineMaxSubord = lineParent; @@ -538,7 +538,7 @@ Sci::Line Document::GetLastChild(Sci::Line lineParent, std::optional<FoldLevel> lineMaxSubord++; } if (lineMaxSubord > lineParent) { - if (level > LevelNumberPart(GetFoldLevel(lineMaxSubord + 1))) { + if (levelStart > LevelNumberPart(GetFoldLevel(lineMaxSubord + 1))) { // Have chewed up some whitespace that belongs to a parent so seek back if (LevelIsWhitespace(GetFoldLevel(lineMaxSubord))) { lineMaxSubord--; |