Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/twbs/bootstrap.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXhmikosR <xhmikosr@gmail.com>2021-01-13 10:34:52 +0300
committerXhmikosR <xhmikosr@gmail.com>2021-08-31 17:24:38 +0300
commit365d6d9fb150038f80874861a344ca39021b34c1 (patch)
tree631fbc74fc80c7c4bd67f950b1c70714a4f336a7
parent51afe026ca1c08d228cb58cbe47f8c3d61167c96 (diff)
Tweak scss-docs shortcode
-rw-r--r--site/layouts/shortcodes/scss-docs.html46
1 files changed, 28 insertions, 18 deletions
diff --git a/site/layouts/shortcodes/scss-docs.html b/site/layouts/shortcodes/scss-docs.html
index 16a906e777..3d1cd09a5d 100644
--- a/site/layouts/shortcodes/scss-docs.html
+++ b/site/layouts/shortcodes/scss-docs.html
@@ -1,33 +1,43 @@
{{- /*
Usage: `scss-docs name="name" file="file/_location.scss"`
- Prints everything between `// scss-docs-start "name"` and `// scss-docs-end "name"`
- comments in the docs.
+ Prints everything between `// scss-docs-start "name"` and `// scss-docs-end "name"`
+ comments in the docs.
- Optional parameters:
- strip-default: Remove the ` !default` flag from variable assignments - default: `true`
+ Optional parameters:
+ * strip-default: Remove the ` !default` flag from variable assignments - default: `true`
*/ -}}
{{- $name := .Get "name" -}}
{{- $file := .Get "file" -}}
{{- $strip_default := .Get "strip-default" | default "true" -}}
-{{- $start := printf "// scss-docs-start %s\n" $name -}}
-{{- $end := printf "// scss-docs-end %s" $name -}}
-{{- $regex := printf "%s(.|\n)*%s" $start $end -}}
+{{- /* If any parameters are missing, print an error and exit */ -}}
+{{- if or (not $name) (not $file) -}}
+ {{- errorf "%s: %q: Missing required parameters! Got: name=%q file=%q!" .Position .Name $name $file -}}
+{{- else -}}
+ {{- $capture_start := printf "// scss-docs-start %s\n" $name -}}
+ {{- $capture_end := printf "// scss-docs-end %s" $name -}}
+ {{- $regex := printf `%s((?:.|\n)*)%s` $capture_start $capture_end -}}
-{{- $css := readFile $file -}}
-{{- $match := findRE $regex $css 1 -}}
+ {{- /*
+ TODO: figure out why we can't do the following and get the first group (the only capturing one)...
+ $regex := printf `(?:// scss-docs-start %s\n)((?:.|\n)*)(?:\n// scss-docs-end %s)` $name $name
+ */ -}}
-{{- if (eq (len $match) 0) -}}
- {{- errorf "Got no matches for %q in %q! (called in %q)" $name $file $.Page.Path -}}
-{{- end -}}
+ {{- $match := findRE $regex (readFile $file) -}}
+ {{- $match = index $match 0 -}}
-{{- $remove_start := replace (index $match 0) $start "" -}}
-{{- $result := replace $remove_start $end "" -}}
+ {{- if not $match -}}
+ {{- errorf "%s: %q: Got no matches for name=%q in file=%q!" .Position .Name $name $file -}}
+ {{- end -}}
-{{- if (ne $strip_default "false") -}}
- {{- $result = replace $result " !default" "" -}}
-{{- end -}}
+ {{- $match = replace $match $capture_start "" -}}
+ {{- $match = replace $match $capture_end "" -}}
-{{- highlight $result "scss" "" -}}
+ {{- if (ne $strip_default "false") -}}
+ {{- $match = replace $match " !default" "" -}}
+ {{- end -}}
+
+ {{- highlight $match "scss" "" -}}
+{{- end -}}