X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=stdlib%2Fprelude.gl;h=836b5c419b059a96949ab01102ab55755d5baf50;hb=ff4a8c81429495ae914d0dbeef9dbb50b2b1a00c;hp=e2d04007c1b895958ccb884fed40ba18da972f86;hpb=580298444204f92785a7ac78c4529e95e3cba40d;p=goals.git diff --git a/stdlib/prelude.gl b/stdlib/prelude.gl index e2d0400..836b5c4 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,6 +59,16 @@ 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 @@ -67,11 +82,37 @@ pure function join (xs, ys) returning strings = @{ for f in %xs %ys; do echo "$f"; done } +# Last element of a list. +pure function last (xs) returning string = @{ + for f in %xs; do + r="$f" + done + echo "$r" +} + +# n'th element of a list. +pure function nth (n, xs) returning string = @{ + i=0 + r= + for f in %xs; do + if [ $i -eq %n ]; then r="$f"; fi + ((++i)) + done + echo "$r" +} + # Sort + uniq a list. pure function sort (xs) returning strings = @{ for f in %xs; do echo "$f"; done | sort -u } +# Split a string into a list. +# https://superuser.com/a/1066541 +pure function split (s) returning strings = @{ + s=%s + eval 'for f in '$s'; do echo "$f"; done' +} + # Substitute. pure function subst (from, to, text) returning string = @{ # We need to replace any / characters in ‘to’ with escaped ones. @@ -93,12 +134,12 @@ pure function tail (xs) returning strings = @{ # Base name. pure function basename (name) returning string = @{ - basename %name + basename -- %name } # Directory name. pure function dirname (name) returning string = @{ - dirname %name + dirname -- %name } # File extension. @@ -107,6 +148,16 @@ pure function extension (name) returning string = @{ 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