diff options
Diffstat (limited to 'src/Data/JLD/Model/URI.hs')
| -rw-r--r-- | src/Data/JLD/Model/URI.hs | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/Data/JLD/Model/URI.hs b/src/Data/JLD/Model/URI.hs new file mode 100644 index 0000000..07cf8a9 --- /dev/null +++ b/src/Data/JLD/Model/URI.hs | |||
| @@ -0,0 +1,13 @@ | |||
| 1 | module Data.JLD.Model.URI (parseUri, uriToIri) where | ||
| 2 | |||
| 3 | import Data.JLD.Prelude | ||
| 4 | |||
| 5 | import Data.RDF (IRIRef, parseIRI) | ||
| 6 | import Text.Megaparsec (MonadParsec (..), Parsec, runParser) | ||
| 7 | import Text.URI (URI, parser, render) | ||
| 8 | |||
| 9 | parseUri :: Text -> Maybe URI | ||
| 10 | parseUri = runParser (parser <* eof :: Parsec Void Text URI) "" .> either (const Nothing) Just | ||
| 11 | |||
| 12 | uriToIri :: URI -> Maybe IRIRef | ||
| 13 | uriToIri = render .> parseIRI .> either (const Nothing) Just | ||
