{-# LANGUAGE CPP #-}
{-# OPTIONS_GHC -Wno-unrecognised-pragmas #-}
{-# HLINT ignore "Use fewer imports" #-}
module Unicode.Internal.Bits.Scripts
(
lookupWord8AsInt#
, lookupWord16AsInt#
, nextInt8#
, nextInt32#
, unpackCString#
) where
#include "MachDeps.h"
import GHC.Exts (
Addr#,
Int#,
indexWord16OffAddr#,
indexWord8OffAddr#,
word2Int#,
)
#ifdef WORDS_BIGENDIAN
import GHC.Exts (
byteSwap16#,
byteSwap32#,
indexWord32OffAddr#,
narrow16Word#,
narrow32Word#,
word2Int#,
)
#if MIN_VERSION_base(4,16,0)
import GHC.Exts (word16ToWord#, word32ToWord#)
#endif
#else
import GHC.Exts (indexInt32OffAddr#)
#if MIN_VERSION_base(4,16,0)
import GHC.Exts (int32ToInt#)
#endif
#endif
#if MIN_VERSION_base(4,15,0)
import GHC.Exts (unpackCString#)
#else
import GHC.CString (unpackCString#)
#endif
#if MIN_VERSION_base(4,16,0)
import GHC.Exts (word8ToWord#, word16ToWord#)
#endif
lookupWord8AsInt#
:: Addr#
-> Int#
-> Int#
lookupWord8AsInt# :: Addr# -> Int# -> Int#
lookupWord8AsInt# Addr#
addr# Int#
index# = Word# -> Int#
word2Int#
#if MIN_VERSION_base(4,16,0)
(Word8# -> Word#
word8ToWord# (Addr# -> Int# -> Word8#
indexWord8OffAddr# Addr#
addr# Int#
index#))
#else
(indexWord8OffAddr# addr# index#)
#endif
lookupWord16AsInt#
:: Addr#
-> Int#
-> Int#
lookupWord16AsInt# :: Addr# -> Int# -> Int#
lookupWord16AsInt# Addr#
addr# Int#
k# = Word# -> Int#
word2Int# Word#
word##
where
#ifdef WORDS_BIGENDIAN
#if MIN_VERSION_base(4,16,0)
word## = narrow16Word# (byteSwap16# (word16ToWord# (indexWord16OffAddr# addr# k#)))
#else
word## = narrow16Word# (byteSwap16# (indexWord16OffAddr# addr# k#))
#endif
#elif MIN_VERSION_base(4,16,0)
word## :: Word#
word## = Word16# -> Word#
word16ToWord# (Addr# -> Int# -> Word16#
indexWord16OffAddr# Addr#
addr# Int#
k#)
#else
word## = indexWord16OffAddr# addr# k#
#endif
nextInt8# :: Addr# -> Int#
nextInt8# :: Addr# -> Int#
nextInt8# Addr#
addr# = Word# -> Int#
word2Int#
#if MIN_VERSION_base(4,16,0)
(Word8# -> Word#
word8ToWord# (Addr# -> Int# -> Word8#
indexWord8OffAddr# Addr#
addr# Int#
0#))
#else
(indexWord8OffAddr# addr# 0#)
#endif
nextInt32#
:: Addr#
-> Int#
nextInt32# :: Addr# -> Int#
nextInt32# Addr#
addr# =
#ifdef WORDS_BIGENDIAN
#if MIN_VERSION_base(4,16,0)
word2Int# (narrow32Word# (byteSwap32# (word32ToWord# (indexWord32OffAddr# addr# 0#))))
#else
word2Int# (narrow32Word# (byteSwap32# (indexWord32OffAddr# addr# 0#)))
#endif
#elif MIN_VERSION_base(4,16,0)
Int32# -> Int#
int32ToInt# (Addr# -> Int# -> Int32#
indexInt32OffAddr# Addr#
addr# Int#
0#)
#else
indexInt32OffAddr# addr# 0#
#endif