Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/clovyr/string-fromto

Conversions between common string types, as well as Base16/Base32/Base64
https://github.com/clovyr/string-fromto

base16 base32 base64 bytestring conversion haskell text

Last synced: about 2 months ago
JSON representation

Conversions between common string types, as well as Base16/Base32/Base64

Awesome Lists containing this project

README

        

# 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

```haskell
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

[Hackage](https://hackage.haskell.org/package/string-fromto)

## License

[BSD3](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:

```haskell
stringTypeAToStringTypeB :: a -> b
```

For example:

```haskell

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.)