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