aboutsummaryrefslogtreecommitdiff
path: root/lib/patterns/patterns.tm
diff options
context:
space:
mode:
Diffstat (limited to 'lib/patterns/patterns.tm')
-rw-r--r--lib/patterns/patterns.tm47
1 files changed, 47 insertions, 0 deletions
diff --git a/lib/patterns/patterns.tm b/lib/patterns/patterns.tm
new file mode 100644
index 00000000..bab0c3dc
--- /dev/null
+++ b/lib/patterns/patterns.tm
@@ -0,0 +1,47 @@
+use ./patterns.c
+
+struct PatternMatch(text:Text, index:Int, captures:[Text])
+
+lang Pat
+ convert(text:Text -> Pat)
+ return C_code:Pat(Pattern$escape_text(@text))
+
+ convert(n:Int -> Pat)
+ return Pat.from_text("$n")
+
+extend Text
+ func matches_pattern(text:Text, pattern:Pat -> Bool)
+ return C_code:Bool(Pattern$matches(@text, @pattern))
+
+ func pattern_captures(text:Text, pattern:Pat -> [Text]?)
+ return C_code:[Text]?(Pattern$captures(@text, @pattern))
+
+ func replace_pattern(text:Text, pattern:Pat, replacement:Text, backref="@", recursive=yes -> Text)
+ return C_code:Text(Pattern$replace(@text, @pattern, @replacement, @backref, @recursive))
+
+ func translate_patterns(text:Text, replacements:{Pat=Text}, backref="@", recursive=yes -> Text)
+ return C_code:Text(Pattern$replace_all(@text, @replacements, @backref, @recursive))
+
+ func has_pattern(text:Text, pattern:Pat -> Bool)
+ return C_code:Bool(Pattern$has(@text, @pattern))
+
+ func find_patterns(text:Text, pattern:Pat -> [PatternMatch])
+ return C_code:[PatternMatch](Pattern$find_all(@text, @pattern))
+
+ func by_pattern(text:Text, pattern:Pat -> func(->PatternMatch?))
+ return C_code:func(->PatternMatch?)(Pattern$by_match(@text, @pattern))
+
+ func each_pattern(text:Text, pattern:Pat, fn:func(m:PatternMatch), recursive=yes)
+ C_code { Pattern$each(@text, @pattern, @fn, @recursive); }
+
+ func map_pattern(text:Text, pattern:Pat, fn:func(m:PatternMatch -> Text), recursive=yes -> Text)
+ return C_code:Text(Pattern$map(@text, @pattern, @fn, @recursive))
+
+ func split_pattern(text:Text, pattern:Pat -> [Text])
+ return C_code:[Text](Pattern$split(@text, @pattern))
+
+ func by_pattern_split(text:Text, pattern:Pat -> func(->Text?))
+ return C_code:func(->Text?)(Pattern$by_split(@text, @pattern))
+
+ func trim_pattern(text:Text, pattern=$Pat"{space}", left=yes, right=yes -> Text)
+ return C_code:Text(Pattern$trim(@text, @pattern, @left, @right))