{-# LANGUAGE DeriveDataTypeable, UnboxedTuples, MagicHash,
BangPatterns, GeneralizedNewtypeDeriving #-}
{-# OPTIONS_HADDOCK not-home #-}
module Data.JSString.Internal.Type ( JSString(..)
, empty
, empty_
, safe
, firstf
) where
import Control.DeepSeq
import Data.Coerce (coerce)
import Data.Text (Text)
import qualified Data.Text as T (empty)
import Data.String (IsString)
import Data.Aeson (ToJSON(..), FromJSON(..))
import Data.Data (Data)
import Data.Typeable (Typeable)
import Data.Semigroup (Semigroup)
import GHC.Exts (Char(..), ord#, andI#, (/=#), isTrue#)
newtype JSString = JSString Text deriving(Int -> JSString -> ShowS
[JSString] -> ShowS
JSString -> String
(Int -> JSString -> ShowS)
-> (JSString -> String) -> ([JSString] -> ShowS) -> Show JSString
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [JSString] -> ShowS
$cshowList :: [JSString] -> ShowS
show :: JSString -> String
$cshow :: JSString -> String
showsPrec :: Int -> JSString -> ShowS
$cshowsPrec :: Int -> JSString -> ShowS
Show, ReadPrec [JSString]
ReadPrec JSString
Int -> ReadS JSString
ReadS [JSString]
(Int -> ReadS JSString)
-> ReadS [JSString]
-> ReadPrec JSString
-> ReadPrec [JSString]
-> Read JSString
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [JSString]
$creadListPrec :: ReadPrec [JSString]
readPrec :: ReadPrec JSString
$creadPrec :: ReadPrec JSString
readList :: ReadS [JSString]
$creadList :: ReadS [JSString]
readsPrec :: Int -> ReadS JSString
$creadsPrec :: Int -> ReadS JSString
Read, String -> JSString
(String -> JSString) -> IsString JSString
forall a. (String -> a) -> IsString a
fromString :: String -> JSString
$cfromString :: String -> JSString
IsString, b -> JSString -> JSString
NonEmpty JSString -> JSString
JSString -> JSString -> JSString
(JSString -> JSString -> JSString)
-> (NonEmpty JSString -> JSString)
-> (forall b. Integral b => b -> JSString -> JSString)
-> Semigroup JSString
forall b. Integral b => b -> JSString -> JSString
forall a.
(a -> a -> a)
-> (NonEmpty a -> a)
-> (forall b. Integral b => b -> a -> a)
-> Semigroup a
stimes :: b -> JSString -> JSString
$cstimes :: forall b. Integral b => b -> JSString -> JSString
sconcat :: NonEmpty JSString -> JSString
$csconcat :: NonEmpty JSString -> JSString
<> :: JSString -> JSString -> JSString
$c<> :: JSString -> JSString -> JSString
Semigroup, Semigroup JSString
JSString
Semigroup JSString
-> JSString
-> (JSString -> JSString -> JSString)
-> ([JSString] -> JSString)
-> Monoid JSString
[JSString] -> JSString
JSString -> JSString -> JSString
forall a.
Semigroup a -> a -> (a -> a -> a) -> ([a] -> a) -> Monoid a
mconcat :: [JSString] -> JSString
$cmconcat :: [JSString] -> JSString
mappend :: JSString -> JSString -> JSString
$cmappend :: JSString -> JSString -> JSString
mempty :: JSString
$cmempty :: JSString
$cp1Monoid :: Semigroup JSString
Monoid, Eq JSString
Eq JSString
-> (JSString -> JSString -> Ordering)
-> (JSString -> JSString -> Bool)
-> (JSString -> JSString -> Bool)
-> (JSString -> JSString -> Bool)
-> (JSString -> JSString -> Bool)
-> (JSString -> JSString -> JSString)
-> (JSString -> JSString -> JSString)
-> Ord JSString
JSString -> JSString -> Bool
JSString -> JSString -> Ordering
JSString -> JSString -> JSString
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: JSString -> JSString -> JSString
$cmin :: JSString -> JSString -> JSString
max :: JSString -> JSString -> JSString
$cmax :: JSString -> JSString -> JSString
>= :: JSString -> JSString -> Bool
$c>= :: JSString -> JSString -> Bool
> :: JSString -> JSString -> Bool
$c> :: JSString -> JSString -> Bool
<= :: JSString -> JSString -> Bool
$c<= :: JSString -> JSString -> Bool
< :: JSString -> JSString -> Bool
$c< :: JSString -> JSString -> Bool
compare :: JSString -> JSString -> Ordering
$ccompare :: JSString -> JSString -> Ordering
$cp1Ord :: Eq JSString
Ord, JSString -> JSString -> Bool
(JSString -> JSString -> Bool)
-> (JSString -> JSString -> Bool) -> Eq JSString
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: JSString -> JSString -> Bool
$c/= :: JSString -> JSString -> Bool
== :: JSString -> JSString -> Bool
$c== :: JSString -> JSString -> Bool
Eq, Typeable JSString
DataType
Constr
Typeable JSString
-> (forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> JSString -> c JSString)
-> (forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c JSString)
-> (JSString -> Constr)
-> (JSString -> DataType)
-> (forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c JSString))
-> (forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c JSString))
-> ((forall b. Data b => b -> b) -> JSString -> JSString)
-> (forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> JSString -> r)
-> (forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> JSString -> r)
-> (forall u. (forall d. Data d => d -> u) -> JSString -> [u])
-> (forall u. Int -> (forall d. Data d => d -> u) -> JSString -> u)
-> (forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> JSString -> m JSString)
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> JSString -> m JSString)
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> JSString -> m JSString)
-> Data JSString
JSString -> DataType
JSString -> Constr
(forall b. Data b => b -> b) -> JSString -> JSString
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> JSString -> c JSString
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c JSString
forall a.
Typeable a
-> (forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> a -> c a)
-> (forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c a)
-> (a -> Constr)
-> (a -> DataType)
-> (forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c a))
-> (forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c a))
-> ((forall b. Data b => b -> b) -> a -> a)
-> (forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall u. (forall d. Data d => d -> u) -> a -> [u])
-> (forall u. Int -> (forall d. Data d => d -> u) -> a -> u)
-> (forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> Data a
forall u. Int -> (forall d. Data d => d -> u) -> JSString -> u
forall u. (forall d. Data d => d -> u) -> JSString -> [u]
forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> JSString -> r
forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> JSString -> r
forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> JSString -> m JSString
forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> JSString -> m JSString
forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c JSString
forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> JSString -> c JSString
forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c JSString)
forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c JSString)
$cJSString :: Constr
$tJSString :: DataType
gmapMo :: (forall d. Data d => d -> m d) -> JSString -> m JSString
$cgmapMo :: forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> JSString -> m JSString
gmapMp :: (forall d. Data d => d -> m d) -> JSString -> m JSString
$cgmapMp :: forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> JSString -> m JSString
gmapM :: (forall d. Data d => d -> m d) -> JSString -> m JSString
$cgmapM :: forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> JSString -> m JSString
gmapQi :: Int -> (forall d. Data d => d -> u) -> JSString -> u
$cgmapQi :: forall u. Int -> (forall d. Data d => d -> u) -> JSString -> u
gmapQ :: (forall d. Data d => d -> u) -> JSString -> [u]
$cgmapQ :: forall u. (forall d. Data d => d -> u) -> JSString -> [u]
gmapQr :: (r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> JSString -> r
$cgmapQr :: forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> JSString -> r
gmapQl :: (r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> JSString -> r
$cgmapQl :: forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> JSString -> r
gmapT :: (forall b. Data b => b -> b) -> JSString -> JSString
$cgmapT :: (forall b. Data b => b -> b) -> JSString -> JSString
dataCast2 :: (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c JSString)
$cdataCast2 :: forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c JSString)
dataCast1 :: (forall d. Data d => c (t d)) -> Maybe (c JSString)
$cdataCast1 :: forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c JSString)
dataTypeOf :: JSString -> DataType
$cdataTypeOf :: JSString -> DataType
toConstr :: JSString -> Constr
$ctoConstr :: JSString -> Constr
gunfold :: (forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c JSString
$cgunfold :: forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c JSString
gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> JSString -> c JSString
$cgfoldl :: forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> JSString -> c JSString
$cp1Data :: Typeable JSString
Data, [JSString] -> Encoding
[JSString] -> Value
JSString -> Encoding
JSString -> Value
(JSString -> Value)
-> (JSString -> Encoding)
-> ([JSString] -> Value)
-> ([JSString] -> Encoding)
-> ToJSON JSString
forall a.
(a -> Value)
-> (a -> Encoding)
-> ([a] -> Value)
-> ([a] -> Encoding)
-> ToJSON a
toEncodingList :: [JSString] -> Encoding
$ctoEncodingList :: [JSString] -> Encoding
toJSONList :: [JSString] -> Value
$ctoJSONList :: [JSString] -> Value
toEncoding :: JSString -> Encoding
$ctoEncoding :: JSString -> Encoding
toJSON :: JSString -> Value
$ctoJSON :: JSString -> Value
ToJSON, Value -> Parser [JSString]
Value -> Parser JSString
(Value -> Parser JSString)
-> (Value -> Parser [JSString]) -> FromJSON JSString
forall a.
(Value -> Parser a) -> (Value -> Parser [a]) -> FromJSON a
parseJSONList :: Value -> Parser [JSString]
$cparseJSONList :: Value -> Parser [JSString]
parseJSON :: Value -> Parser JSString
$cparseJSON :: Value -> Parser JSString
FromJSON, Typeable)
instance NFData JSString where rnf :: JSString -> ()
rnf !JSString
_ = ()
empty :: JSString
empty :: JSString
empty = Text -> JSString
coerce Text
T.empty
{-# INLINE [1] empty #-}
empty_ :: JSString
empty_ :: JSString
empty_ = Text -> JSString
coerce Text
T.empty
{-# NOINLINE empty_ #-}
safe :: Char -> Char
safe :: Char -> Char
safe c :: Char
c@(C# Char#
cc)
| Int# -> Bool
isTrue# (Int# -> Int# -> Int#
andI# (Char# -> Int#
ord# Char#
cc) Int#
0x1ff800# Int# -> Int# -> Int#
/=# Int#
0xd800#) = Char
c
| Bool
otherwise = Char
'\xfffd'
{-# INLINE [0] safe #-}
firstf :: (a -> c) -> Maybe (a,b) -> Maybe (c,b)
firstf :: (a -> c) -> Maybe (a, b) -> Maybe (c, b)
firstf a -> c
f (Just (a
a, b
b)) = (c, b) -> Maybe (c, b)
forall a. a -> Maybe a
Just (a -> c
f a
a, b
b)
firstf a -> c
_ Maybe (a, b)
Nothing = Maybe (c, b)
forall a. Maybe a
Nothing