aboutsummaryrefslogtreecommitdiffhomepage
path: root/test/external/metalang99/optimization_tips.md
diff options
context:
space:
mode:
authorlemon <lsof@mailbox.org>2026-02-23 20:36:05 +0100
committerlemon <lsof@mailbox.org>2026-02-23 20:36:05 +0100
commit052144cabb126efe925a96f8a0597a0f2005d206 (patch)
tree4fd87244b9eef018b30e90fdff24c5b1a145a85e /test/external/metalang99/optimization_tips.md
parent4e9020dfb847d80475415f9f5914efaa50238767 (diff)
add metalang99 testsuite (preprocessor stress testing)
Diffstat (limited to 'test/external/metalang99/optimization_tips.md')
-rw-r--r--test/external/metalang99/optimization_tips.md24
1 files changed, 24 insertions, 0 deletions
diff --git a/test/external/metalang99/optimization_tips.md b/test/external/metalang99/optimization_tips.md
new file mode 100644
index 0000000..261cbe8
--- /dev/null
+++ b/test/external/metalang99/optimization_tips.md
@@ -0,0 +1,24 @@
+# Optimization tips
+
+_This document describes a few optimization tips when using Metalang99._
+
+Generally speaking, the fewer reduction steps you perform, the faster you become. A reduction step is a concept defined formally by the [specification]. Here is its informal (and imprecise) description:
+
+ - Every `v(...)` is a reduction step.
+ - Every `ML99_call(op, ...)` induces as many reduction steps as required to evaluate `op` and `...`.
+
+To perform fewer reduction steps, you can:
+
+ - use `ML99_callUneval`,
+ - use plain macros (e.g., `ML99_CAT` instead of `ML99_cat`),
+ - use optimized versions (e.g., `ML99_listMapInPlace`),
+ - use tuples/variadics instead of lists,
+ - call a macro as `<X>_IMPL(...)`, if all the arguments are already evaluated.
+
+<details>
+ <summary>Be careful with the last trick!</summary>
+
+I strongly recommend to use the last trick only if `X` is defined locally to a caller so that you can control the correctness of expansion. For example, `X` can become painted blue, it can emit unexpected commas, the `#` and `##` operators can block expansion of parameters, and a plenty of other nasty things.
+</details>
+
+[specification]: spec/spec.pdf