module Interpreter.Lib.String where import qualified Data.ByteString as BS import Data.Coerce import Data.Text as T import Data.Text.Encoding import Data.Vector as V import Interpreter.Common builtInDecodeUTF8Bytes :: BuiltInFnWithDoc '[ '("bytes", BS.ByteString)] builtInDecodeUTF8Bytes ((coerce -> b) :> EmptyArgs) = pure $ Just $ StringValue $ decodeUtf8 b builtInEncodeUTF8Bytes :: BuiltInFnWithDoc '[ '("string", Text)] builtInEncodeUTF8Bytes ((coerce -> b) :> EmptyArgs) = pure $ Just $ BytesValue $ encodeUtf8 b builtInConcat :: BuiltInFnWithDoc '[ '("string1", Text), '("string2", Text)] builtInConcat ((coerce -> b) :> (coerce -> d) :> EmptyArgs) = pure $ Just $ StringValue $ T.concat [b, d] builtInJoin :: BuiltInFnWithDoc '[ '("joiner", Text), '("parts", [Text])] builtInJoin ((coerce -> b) :> (coerce -> d) :> EmptyArgs) = pure $ Just $ StringValue $ T.intercalate b d builtInSplit :: BuiltInFnWithDoc '[ '("divider", Text), '("text", Text)] builtInSplit ((coerce -> b) :> (coerce -> d) :> EmptyArgs) = pure $ Just $ ArrayValue $ V.fromList $ StringValue <$> T.splitOn b d