{-# Language CPP, MagicHash #-}

{- |
  Module      :  Codec.Binary.UTF8.Light.Helper
  Copyright   :  (c) Francesco Ariis 2022
  License     :  BSD3
  Maintainer  :  Francesco Ariis <fa-ml@ariis.it>
  Stability   :  provisional
  Portability :  portable

  Lightweight UTF8 handling, helper functions.
-}

module Codec.Binary.UTF8.Light.Helper (
            c2w, w2c, i2w, w2i, cwrd, wh, toW8
) where

import GHC.Exts (Int(I#), Char(C#))
import GHC.Word
  (Word8(W8#), Word32(W32#))
import GHC.Prim
  (Word#, Word32#
  ,ord#,chr#,word2Int#,int2Word#
  ,intToInt32#,int2Word#,int32ToInt#,int32ToWord32#
  ,wordToWord8#,wordToWord32#,word32ToWord#,word32ToInt32#)

-----------------------------------------------------------------------------
-- Helper functions for GHC ≥ 9.2

{-# INLINE w2c #-}
w2c :: Word32 -> Char
w2c :: Word32 -> Char
w2c (W32# Word32#
w) = Char# -> Char
C#(Int# -> Char#
chr#(Word# -> Int#
word2Int#(Word32# -> Word#
word32ToWord# Word32#
w)))

{-# INLINE c2w #-}
c2w :: Char -> Word32
c2w :: Char -> Word32
c2w (C# Char#
c) = Word32# -> Word32
W32#(Int32# -> Word32#
int32ToWord32#(Int# -> Int32#
intToInt32#(Char# -> Int#
ord# Char#
c)))

{-# INLINE i2w #-}
i2w :: Int -> Word32
i2w :: Int -> Word32
i2w (I# Int#
i) = Word32# -> Word32
W32#(Word# -> Word32#
wordToWord32#(Int# -> Word#
int2Word# Int#
i))

{-# INLINE w2i #-}
w2i :: Word32 -> Int
w2i :: Word32 -> Int
w2i (W32# Word32#
w) = Int# -> Int
I#(Int32# -> Int#
int32ToInt#(Word32# -> Int32#
word32ToInt32# Word32#
w))

{-# INLINE wh #-}
wh :: Word32# -> Word8
wh :: Word32# -> Word8
wh Word32#
w = Word8# -> Word8
W8#(Word# -> Word8#
wordToWord8#(Word32# -> Word#
word32ToWord# Word32#
w))

{-# INLINE toW8 #-}
toW8 :: Word# -> Word8
toW8 :: Word# -> Word8
toW8 Word#
w = Word8# -> Word8
W8#((Word# -> Word8#
wordToWord8# Word#
w))

{-# INLINE cwrd #-}
cwrd :: Word32# -> Word#
cwrd :: Word32# -> Word#
cwrd Word32#
w = Word32# -> Word#
word32ToWord# Word32#
w