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