{-# LANGUAGE ForeignFunctionInterface #-}
{-# OPTIONS_GHC -fno-warn-orphans #-}
module Data.Text.ICU.Iterator
(
CharIterator
, fromString
, fromText
, fromUtf8
) where
import Data.ByteString (ByteString)
import Data.Int (Int32)
import Data.Text (Text, pack)
import Data.Text.ICU.Internal (CharIterator(..), UCharIterator, asOrdering,
withCharIterator)
import Foreign.Ptr (Ptr)
import System.IO.Unsafe (unsafePerformIO)
instance Eq CharIterator where
CharIterator
a == :: CharIterator -> CharIterator -> Bool
== CharIterator
b = CharIterator -> CharIterator -> Ordering
compareIter CharIterator
a CharIterator
b Ordering -> Ordering -> Bool
forall a. Eq a => a -> a -> Bool
== Ordering
EQ
instance Ord CharIterator where
compare :: CharIterator -> CharIterator -> Ordering
compare = CharIterator -> CharIterator -> Ordering
compareIter
compareIter :: CharIterator -> CharIterator -> Ordering
compareIter :: CharIterator -> CharIterator -> Ordering
compareIter CharIterator
a CharIterator
b = IO Ordering -> Ordering
forall a. IO a -> a
unsafePerformIO (IO Ordering -> Ordering)
-> ((Ptr UCharIterator -> IO Int32) -> IO Ordering)
-> (Ptr UCharIterator -> IO Int32)
-> Ordering
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Int32 -> Ordering) -> IO Int32 -> IO Ordering
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap Int32 -> Ordering
forall a. Integral a => a -> Ordering
asOrdering (IO Int32 -> IO Ordering)
-> ((Ptr UCharIterator -> IO Int32) -> IO Int32)
-> (Ptr UCharIterator -> IO Int32)
-> IO Ordering
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
CharIterator -> (Ptr UCharIterator -> IO Int32) -> IO Int32
forall a. CharIterator -> (Ptr UCharIterator -> IO a) -> IO a
withCharIterator CharIterator
a ((Ptr UCharIterator -> IO Int32) -> Ordering)
-> (Ptr UCharIterator -> IO Int32) -> Ordering
forall a b. (a -> b) -> a -> b
$ CharIterator -> (Ptr UCharIterator -> IO Int32) -> IO Int32
forall a. CharIterator -> (Ptr UCharIterator -> IO a) -> IO a
withCharIterator CharIterator
b ((Ptr UCharIterator -> IO Int32) -> IO Int32)
-> (Ptr UCharIterator -> Ptr UCharIterator -> IO Int32)
-> Ptr UCharIterator
-> IO Int32
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Ptr UCharIterator -> Ptr UCharIterator -> IO Int32
u_strCompareIter
fromString :: String -> CharIterator
fromString :: String -> CharIterator
fromString = Text -> CharIterator
CIText (Text -> CharIterator)
-> (String -> Text) -> String -> CharIterator
forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> Text
pack
{-# INLINE fromString #-}
fromText :: Text -> CharIterator
fromText :: Text -> CharIterator
fromText = Text -> CharIterator
CIText
{-# INLINE fromText #-}
fromUtf8 :: ByteString -> CharIterator
fromUtf8 :: ByteString -> CharIterator
fromUtf8 = ByteString -> CharIterator
CIUTF8
{-# INLINE fromUtf8 #-}
foreign import ccall unsafe "hs_text_icu.h __hs_u_strCompareIter" u_strCompareIter
:: Ptr UCharIterator -> Ptr UCharIterator -> IO Int32