{-# LANGUAGE DeriveDataTypeable, ForeignFunctionInterface, ScopedTypeVariables #-}
module Data.Text.ICU.Collate.Pure
(
Collator
, collator
, collatorWith
, collatorFromRules
, collatorFromRulesWith
, collate
, collateIter
, rules
, sortKey
, uca
) where
import qualified Control.Exception as E
import Control.Monad (forM_)
import Data.ByteString (ByteString)
import Data.Text (Text)
import Data.Text.ICU.Error.Internal (ParseError(..))
import Data.Text.ICU.Collate.Internal (Collator(..))
import Data.Text.ICU.Internal (CharIterator, LocaleName(..))
import System.IO.Unsafe (unsafePerformIO)
import qualified Data.Text.ICU.Collate as IO
collator :: LocaleName -> Collator
collator :: LocaleName -> Collator
collator LocaleName
loc = forall a. IO a -> a
unsafePerformIO forall a b. (a -> b) -> a -> b
$ MCollator -> Collator
C forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
`fmap` LocaleName -> IO MCollator
IO.open LocaleName
loc
collatorWith :: LocaleName -> [IO.Attribute] -> Collator
collatorWith :: LocaleName -> [Attribute] -> Collator
collatorWith LocaleName
loc [Attribute]
atts = forall a. IO a -> a
unsafePerformIO forall a b. (a -> b) -> a -> b
$ do
MCollator
mc <- LocaleName -> IO MCollator
IO.open LocaleName
loc
forall (t :: * -> *) (m :: * -> *) a b.
(Foldable t, Monad m) =>
t a -> (a -> m b) -> m ()
forM_ [Attribute]
atts forall a b. (a -> b) -> a -> b
$ MCollator -> Attribute -> IO ()
IO.setAttribute MCollator
mc
forall (m :: * -> *) a. Monad m => a -> m a
return (MCollator -> Collator
C MCollator
mc)
collatorFromRules :: Text -> Either ParseError Collator
collatorFromRules :: Text -> Either ParseError Collator
collatorFromRules Text
rul = Text -> [Attribute] -> Either ParseError Collator
collatorFromRulesWith Text
rul []
collatorFromRulesWith :: Text -> [IO.Attribute] -> Either ParseError Collator
collatorFromRulesWith :: Text -> [Attribute] -> Either ParseError Collator
collatorFromRulesWith Text
rul [Attribute]
atts = forall a. IO a -> a
unsafePerformIO forall a b. (a -> b) -> a -> b
$
(forall a b. b -> Either a b
Right forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
`fmap` IO Collator
openAndSetAtts)
forall e a. Exception e => IO a -> (e -> IO a) -> IO a
`E.catch` \(ParseError
err::ParseError) -> forall (m :: * -> *) a. Monad m => a -> m a
return (forall a b. a -> Either a b
Left ParseError
err)
where
openAndSetAtts :: IO Collator
openAndSetAtts = do
MCollator
mc <- Text -> Maybe Bool -> Maybe Strength -> IO MCollator
IO.openRules Text
rul forall a. Maybe a
Nothing forall a. Maybe a
Nothing
forall (t :: * -> *) (m :: * -> *) a b.
(Foldable t, Monad m) =>
t a -> (a -> m b) -> m ()
forM_ [Attribute]
atts forall a b. (a -> b) -> a -> b
$ MCollator -> Attribute -> IO ()
IO.setAttribute MCollator
mc
forall (m :: * -> *) a. Monad m => a -> m a
return (MCollator -> Collator
C MCollator
mc)
rules :: Collator -> Text
rules :: Collator -> Text
rules (C MCollator
c) = forall a. IO a -> a
unsafePerformIO forall a b. (a -> b) -> a -> b
$ MCollator -> IO Text
IO.getRules MCollator
c
collate :: Collator -> Text -> Text -> Ordering
collate :: Collator -> Text -> Text -> Ordering
collate (C MCollator
c) Text
a Text
b = forall a. IO a -> a
unsafePerformIO forall a b. (a -> b) -> a -> b
$ MCollator -> Text -> Text -> IO Ordering
IO.collate MCollator
c Text
a Text
b
{-# INLINE collate #-}
collateIter :: Collator -> CharIterator -> CharIterator -> Ordering
collateIter :: Collator -> CharIterator -> CharIterator -> Ordering
collateIter (C MCollator
c) CharIterator
a CharIterator
b = forall a. IO a -> a
unsafePerformIO forall a b. (a -> b) -> a -> b
$ MCollator -> CharIterator -> CharIterator -> IO Ordering
IO.collateIter MCollator
c CharIterator
a CharIterator
b
{-# INLINE collateIter #-}
sortKey :: Collator -> Text -> ByteString
sortKey :: Collator -> Text -> ByteString
sortKey (C MCollator
c) = forall a. IO a -> a
unsafePerformIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. MCollator -> Text -> IO ByteString
IO.sortKey MCollator
c
{-# INLINE sortKey #-}
uca :: Collator
uca :: Collator
uca = LocaleName -> Collator
collator LocaleName
Root
{-# NOINLINE uca #-}