From 1f29bddcbbf1f8f8c6ea322907cd19591808400a Mon Sep 17 00:00:00 2001 From: Adrien Dupuis <61695653+adriendupuis@users.noreply.github.com> Date: Wed, 11 Dec 2024 14:43:52 +0100 Subject: [PATCH] code_samples_usage.php: Handle --8<-- syntax (#2578) (cherry picked from commit 3c096b14053b678f02c683fa805dc0f098d84429) --- tools/code_samples/code_samples_usage.php | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/tools/code_samples/code_samples_usage.php b/tools/code_samples/code_samples_usage.php index e1844fdcec..66cd8a1ebe 100644 --- a/tools/code_samples/code_samples_usage.php +++ b/tools/code_samples/code_samples_usage.php @@ -133,7 +133,8 @@ function getBlockContents(array $block): array $rawBlockCodeLines = []; $oneBasedBlockCodeLines = []; $includedFilesLines = []; - foreach ($block as $blockSourceLine) { + $skip = false; + foreach ($block as $blockSourceLineIndex => $blockSourceLine) { if (preg_match('@```.* hl_lines="([^"]+)"@', $blockSourceLine, $matches)) { $rawHighlightedLines = explode(' ', $matches[1]); foreach ($rawHighlightedLines as $rawHighlightedLine) { @@ -171,7 +172,17 @@ function getBlockContents(array $block): array $solvedLine = str_replace($matchString, implode(PHP_EOL . $matches['glue'][$matchIndex], $sample) . PHP_EOL, $solvedLine); } $rawBlockCodeLines = array_merge($rawBlockCodeLines, explode(PHP_EOL, $solvedLine)); - } elseif (!str_contains($blockSourceLine, '```')) { + } elseif (str_contains($blockSourceLine, '--8<--')) { + if (!$skip) { + $includedFilePath = trim($block[$blockSourceLineIndex+1]); + $includedFilesLines[$includedFilePath] = file($includedFilePath, FILE_IGNORE_NEW_LINES); + if (!is_array($includedFilesLines[$includedFilePath])) { + throw new RuntimeException("The following included file can't be opened: $includedFilePath"); + } + $rawBlockCodeLines = array_merge($rawBlockCodeLines, $includedFilesLines[$includedFilePath]); + } + $skip = !$skip; + } elseif (!str_contains($blockSourceLine, '```') && !$skip) { $rawBlockCodeLines[] = $blockSourceLine; } }