From e0e8f3fd728012e19231771651e0ee5f3212fea3 Mon Sep 17 00:00:00 2001 From: Lucas Schwiderski Date: Thu, 17 Jun 2021 15:26:12 +0200 Subject: [PATCH] doc: Improve hiding lines in examples This implements variants of `--DOC_HIDE` that allow hiding any amount of lines with just a start and end marker. Signed-off-by: Lucas Schwiderski --- tests/examples/CMakeLists.txt | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/tests/examples/CMakeLists.txt b/tests/examples/CMakeLists.txt index f7f2eb85..501a2fab 100644 --- a/tests/examples/CMakeLists.txt +++ b/tests/examples/CMakeLists.txt @@ -88,14 +88,28 @@ function(escape_string variable content escaped_content line_prefix) string(REGEX REPLACE "\n" ";" var_lines "${variable}") set(tmp_output ${content}) + set(section OFF) foreach (LINE ${var_lines}) # ;; will drop the line, but " ;" will create an empty line string(REGEX REPLACE "--DOC_NEWLINE" " " LINE "${LINE}") - if(NOT LINE MATCHES "^.*--DOC_[A-Z]+") + # Check for section start marker + if(LINE MATCHES "^.*--DOC_HIDE_START") + set(section ON) + endif() + + # Pick lines that are not specified to be hidden + if((NOT LINE MATCHES "^.*--DOC_[A-Z]+") AND (NOT section)) set(tmp_output ${tmp_output}\n${DOC_LINE_PREFIX}${line_prefix}${LINE}) endif() + + # If we found a start marker previously, look for an end marker. + # Do this after picking the lines to ensure that lines with + # `--DOC_HIDE_END` are omitted + if(section AND (LINE MATCHES "^.*--DOC_HIDE_END")) + set(section OFF) + endif() endforeach() set(${escaped_content} ${tmp_output} PARENT_SCOPE)