X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=stdlib%2Fprelude.gl;h=5d072eac93c67f8d4b672803407852b01a0e1f0a;hb=915b9bff547705bf9df287ffb2a057eeaec4ca02;hp=de2a42282fe8016ed6a4afc9d97abc074bd3a8a8;hpb=b29931c35b032141aaa8de370d9adbfc10705bf2;p=goals.git diff --git a/stdlib/prelude.gl b/stdlib/prelude.gl index de2a422..5d072ea 100644 --- a/stdlib/prelude.gl +++ b/stdlib/prelude.gl @@ -54,6 +54,14 @@ pure function wrap (wrapper, xs) = @{ #---------------------------------------------------------------------- # Text functions. +# 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 @@ -71,6 +79,15 @@ pure function subst (from, to, text) returning string = @{ 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. @@ -90,6 +107,21 @@ 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 +} + # Expand a wildcard into a list of filenames. # # This function is probably not "pure" since it depends on the