Conversions between common string types, as well as Base16/Base32/Base64
Have you ever found yourself frustrated that you're spending 15-30% of your time in Haskell converting between string types, remembering which module has the toStrict
function, importing Data.Text.Encoding and Data.Text.Lazy.Encoding qualified, spending time thinking about how to do Base64 encoding, etc.? Or tried to use one of the (excellent) typeclass-based string conversion libraries, only to find yourself adding awkward type signatures to avoid type-inferencing ambiguities?
This package exports a collection of functions that follow a simple pattern:
stringTypeAToStringTypeB :: a -> b
This way, if you import Data.String.FromTo
unqualified, or as part of your Prelude, all you have to think about is which type you want to convert into which other type.
For convenience, this package also exposes conversions between Base16, Base32, and Base64-encoded strings.
string-fromto
A collection of predictably-named functions (e.g. byteStringToString) that convert between the common string types, as well as to and from Base16, Base32, and Base64.
Usage
import Data.String.FromTo -- or imported as part of your Prelude
str :: String
str = "Hi, I'm a string"
text :: Text
text = stringToText str
encoded :: ByteString
encoded = textToBase64ByteString text
decoded :: Either String Text
decoded = base64ByteStringToText encoded
Documentation
License
Motivation
Have you ever found yourself frustrated that you're spending 15-30% of your time in Haskell converting between string types, remembering which module has the toStrict
function, importing Data.Text.Encoding and Data.Text.Lazy.Encoding qualified, spending time thinking about how to do Base64 encoding, etc.? Or tried to use one of the (excellent) typeclass-based string conversion libraries, only to find yourself adding awkward type signatures to avoid type-inferencing ambiguities?
This library exports a collection of functions that follow a simple pattern:
stringTypeAToStringTypeB :: a -> b
For example:
stringToByteString :: String -> ByteString
stringToLazyByteString :: String -> Lazy.ByteString
base64ByteStringToText :: ByteString -> Either String Text
This way, if you import this module unqualified, or as part of your Prelude, all you have to think about is which type you want to convert into which other type.
(Note that not every possible permutation has a function, just each one we've ever needed. If you need one that's not included, please submit a pull request to add it.)