X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;ds=sidebyside;f=stdlib%2Fprelude.gl;h=d8e523ab539581ba52f89d13faa4c7dafe9dfac7;hb=6049de701cea350b3f474e4c1ff16836baa8e2fb;hp=a73ef1afe0cc809e181338883c88da651106c29c;hpb=3c093ea6370b1f07664ded6e8c6aad301a8e2cb5;p=goals.git diff --git a/stdlib/prelude.gl b/stdlib/prelude.gl index a73ef1a..d8e523a 100644 --- a/stdlib/prelude.gl +++ b/stdlib/prelude.gl @@ -40,6 +40,11 @@ tactic *exists (filename) = @{ #---------------------------------------------------------------------- # Basic functions. +function error (msg) = @{ + echo %msg >&2 + exit 1 +} + # Wrap list of strings in a call or tactic. pure function wrap (wrapper, xs) = @{ echo '[' @@ -54,14 +59,84 @@ pure function wrap (wrapper, xs) = @{ #---------------------------------------------------------------------- # Text functions. +# Filter a list by regexp. +pure function filter (pat, xs) returning strings = @{ + for f in %xs; do echo "$f"; done | grep -E -- %pat +} + +# Filter out a list by regexp. +pure function filter-out (pat, xs) returning strings = @{ + for f in %xs; do echo "$f"; done | grep -v -E -- %pat +} + +# Head of a list. +pure function head (xs) returning string = @{ + for f in %xs; do + echo "$f" + exit 0 + done +} + +# Join two lists. +pure function join (xs, ys) returning strings = @{ + for f in %xs %ys; do echo "$f"; done +} + # Sort + uniq a list. pure function sort (xs) returning strings = @{ for f in %xs; do echo "$f"; done | sort -u } +# Substitute. +pure function subst (from, to, text) returning string = @{ + # We need to replace any / characters in ‘to’ with escaped ones. + to="$( echo -n %to | sed 's,/,\\/,g' )" + echo %text | sed -E s/%from/$to/g +} + +# Tail of a list. +pure function tail (xs) returning strings = @{ + drop=1 + for f in %xs; do + if [ -z "$drop" ]; then echo "$f"; fi + drop= + done +} + #---------------------------------------------------------------------- # File functions. +# Base name. +pure function basename (name) returning string = @{ + basename -- %name +} + +# Directory name. +pure function dirname (name) returning string = @{ + dirname -- %name +} + +# File extension. +pure function extension (name) returning string = @{ + name=%name + echo "${name##*.}" +} + +# Read a file. +function read (filename) returning string = @{ + cat -- %filename +} + +# Read a file as a list of lines. +function readlines (filename) returning strings = @{ + cat -- %filename +} + +# Real path. +function realpath (filename) returning string = @{ + realpath -- %filename +} + # Expand a wildcard into a list of filenames. # # This function is probably not "pure" since it depends on the