{-# LANGUAGE BlockArguments #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE GeneralizedNewtypeDeriving #-}
{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE ViewPatterns #-}

-- | Specialized and inlined @V2 Word32@.

module Geomancy.UVec3
  ( UVec3
  , uvec3
  , withUVec3
  , pattern WithUVec3
  , convert
  , fromTuple
  , dot

  , Packed(..)
  , packed
  ) where

import Control.DeepSeq (NFData(rnf))
import Data.Coerce (Coercible, coerce)
import Data.MonoTraversable (Element, MonoFunctor(..), MonoPointed(..))
import Data.Word (Word32)
import Foreign (Storable(..))
import Foreign.Ptr.Diff (peekDiffOff, pokeDiffOff)
import GHC.Ix (Ix(..))

import Geomancy.Elementwise (Elementwise(..))
import Graphics.Gl.Block (Block(..))

data UVec3 = UVec3
  {-# UNPACK #-} !Word32
  {-# UNPACK #-} !Word32
  {-# UNPACK #-} !Word32
  deriving (UVec3 -> UVec3 -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UVec3 -> UVec3 -> Bool
$c/= :: UVec3 -> UVec3 -> Bool
== :: UVec3 -> UVec3 -> Bool
$c== :: UVec3 -> UVec3 -> Bool
Eq, Eq UVec3
UVec3 -> UVec3 -> Bool
UVec3 -> UVec3 -> Ordering
UVec3 -> UVec3 -> UVec3
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 :: UVec3 -> UVec3 -> UVec3
$cmin :: UVec3 -> UVec3 -> UVec3
max :: UVec3 -> UVec3 -> UVec3
$cmax :: UVec3 -> UVec3 -> UVec3
>= :: UVec3 -> UVec3 -> Bool
$c>= :: UVec3 -> UVec3 -> Bool
> :: UVec3 -> UVec3 -> Bool
$c> :: UVec3 -> UVec3 -> Bool
<= :: UVec3 -> UVec3 -> Bool
$c<= :: UVec3 -> UVec3 -> Bool
< :: UVec3 -> UVec3 -> Bool
$c< :: UVec3 -> UVec3 -> Bool
compare :: UVec3 -> UVec3 -> Ordering
$ccompare :: UVec3 -> UVec3 -> Ordering
Ord, Int -> UVec3 -> ShowS
[UVec3] -> ShowS
UVec3 -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UVec3] -> ShowS
$cshowList :: [UVec3] -> ShowS
show :: UVec3 -> String
$cshow :: UVec3 -> String
showsPrec :: Int -> UVec3 -> ShowS
$cshowsPrec :: Int -> UVec3 -> ShowS
Show)

{-# INLINE uvec3 #-}
uvec3 :: Word32 -> Word32 -> Word32 -> UVec3
uvec3 :: Word32 -> Word32 -> Word32 -> UVec3
uvec3 = Word32 -> Word32 -> Word32 -> UVec3
UVec3

{-# INLINE withUVec3 #-}
withUVec3
  :: UVec3
  -> (Word32 -> Word32 -> Word32 -> r)
  -> r
withUVec3 :: forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 (UVec3 Word32
a Word32
b Word32
c) Word32 -> Word32 -> Word32 -> r
f = Word32 -> Word32 -> Word32 -> r
f Word32
a Word32
b Word32
c

pattern WithUVec3 :: Word32 -> Word32 -> Word32 -> UVec3
pattern $mWithUVec3 :: forall {r}.
UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> ((# #) -> r) -> r
WithUVec3 a b c <- ((`withUVec3` (,,)) -> (a, b, c))
{-# COMPLETE WithUVec3 #-}

{-# INLINE convert #-}
convert :: Coercible v UVec3 => (Word32 -> a) -> (a -> a -> a -> r) -> v -> r
convert :: forall v a r.
Coercible v UVec3 =>
(Word32 -> a) -> (a -> a -> a -> r) -> v -> r
convert Word32 -> a
f a -> a -> a -> r
t v
v =
  forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 (coerce :: forall a b. Coercible a b => a -> b
coerce v
v) \Word32
a Word32
b Word32
c ->
    a -> a -> a -> r
t (Word32 -> a
f Word32
a) (Word32 -> a
f Word32
b) (Word32 -> a
f Word32
c)

{-# INLINE fromTuple #-}
fromTuple :: (Word32, Word32, Word32) -> UVec3
fromTuple :: (Word32, Word32, Word32) -> UVec3
fromTuple (Word32
a, Word32
b, Word32
c) = Word32 -> Word32 -> Word32 -> UVec3
uvec3 Word32
a Word32
b Word32
c

{-# INLINE dot #-}
dot :: UVec3 -> UVec3 -> Word32
dot :: UVec3 -> UVec3 -> Word32
dot (UVec3 Word32
l1 Word32
l2 Word32
l3) (UVec3 Word32
r1 Word32
r2 Word32
r3) =
  Word32
l1 forall a. Num a => a -> a -> a
* Word32
r1 forall a. Num a => a -> a -> a
+ Word32
l2 forall a. Num a => a -> a -> a
* Word32
r2 forall a. Num a => a -> a -> a
+ Word32
l3 forall a. Num a => a -> a -> a
* Word32
r3

instance NFData UVec3 where
  rnf :: UVec3 -> ()
rnf UVec3{} = ()

type instance Element UVec3 = Word32

instance MonoFunctor UVec3 where
  {-# INLINE omap #-}
  omap :: (Element UVec3 -> Element UVec3) -> UVec3 -> UVec3
omap Element UVec3 -> Element UVec3
f UVec3
v =
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
v \Word32
x Word32
y Word32
z ->
      Word32 -> Word32 -> Word32 -> UVec3
uvec3 (Element UVec3 -> Element UVec3
f Word32
x) (Element UVec3 -> Element UVec3
f Word32
y) (Element UVec3 -> Element UVec3
f Word32
z)

instance MonoPointed UVec3 where
  {-# INLINE opoint #-}
  opoint :: Element UVec3 -> UVec3
opoint Element UVec3
x = Word32 -> Word32 -> Word32 -> UVec3
uvec3 Element UVec3
x Element UVec3
x Element UVec3
x

instance Elementwise UVec3 where
  {-# INLINE emap2 #-}
  emap2 :: (Element UVec3 -> Element UVec3 -> Element UVec3)
-> UVec3 -> UVec3 -> UVec3
emap2 Element UVec3 -> Element UVec3 -> Element UVec3
f UVec3
p0 UVec3
p1 =
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p0 \Word32
x0 Word32
y0 Word32
z0 ->
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p1 \Word32
x1 Word32
y1 Word32
z1 ->
      Word32 -> Word32 -> Word32 -> UVec3
uvec3
        (Element UVec3 -> Element UVec3 -> Element UVec3
f Word32
x0 Word32
x1)
        (Element UVec3 -> Element UVec3 -> Element UVec3
f Word32
y0 Word32
y1)
        (Element UVec3 -> Element UVec3 -> Element UVec3
f Word32
z0 Word32
z1)

  {-# INLINE emap3 #-}
  emap3 :: (Element UVec3 -> Element UVec3 -> Element UVec3 -> Element UVec3)
-> UVec3 -> UVec3 -> UVec3 -> UVec3
emap3 Element UVec3 -> Element UVec3 -> Element UVec3 -> Element UVec3
f UVec3
p0 UVec3
p1 UVec3
p2 =
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p0 \Word32
x0 Word32
y0 Word32
z0 ->
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p1 \Word32
x1 Word32
y1 Word32
z1 ->
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p2 \Word32
x2 Word32
y2 Word32
z2 ->
      Word32 -> Word32 -> Word32 -> UVec3
uvec3
        (Element UVec3 -> Element UVec3 -> Element UVec3 -> Element UVec3
f Word32
x0 Word32
x1 Word32
x2)
        (Element UVec3 -> Element UVec3 -> Element UVec3 -> Element UVec3
f Word32
y0 Word32
y1 Word32
y2)
        (Element UVec3 -> Element UVec3 -> Element UVec3 -> Element UVec3
f Word32
z0 Word32
z1 Word32
z2)

  {-# INLINE emap4 #-}
  emap4 :: (Element UVec3
 -> Element UVec3
 -> Element UVec3
 -> Element UVec3
 -> Element UVec3)
-> UVec3 -> UVec3 -> UVec3 -> UVec3 -> UVec3
emap4 Element UVec3
-> Element UVec3 -> Element UVec3 -> Element UVec3 -> Element UVec3
f UVec3
p0 UVec3
p1 UVec3
p2 UVec3
p3 =
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p0 \Word32
x0 Word32
y0 Word32
z0 ->
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p1 \Word32
x1 Word32
y1 Word32
z1 ->
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p2 \Word32
x2 Word32
y2 Word32
z2 ->
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p3 \Word32
x3 Word32
y3 Word32
z3 ->
      Word32 -> Word32 -> Word32 -> UVec3
uvec3
        (Element UVec3
-> Element UVec3 -> Element UVec3 -> Element UVec3 -> Element UVec3
f Word32
x0 Word32
x1 Word32
x2 Word32
x3)
        (Element UVec3
-> Element UVec3 -> Element UVec3 -> Element UVec3 -> Element UVec3
f Word32
y0 Word32
y1 Word32
y2 Word32
y3)
        (Element UVec3
-> Element UVec3 -> Element UVec3 -> Element UVec3 -> Element UVec3
f Word32
z0 Word32
z1 Word32
z2 Word32
z3)

  {-# INLINE emap5 #-}
  emap5 :: (Element UVec3
 -> Element UVec3
 -> Element UVec3
 -> Element UVec3
 -> Element UVec3
 -> Element UVec3)
-> UVec3 -> UVec3 -> UVec3 -> UVec3 -> UVec3 -> UVec3
emap5 Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
f UVec3
p0 UVec3
p1 UVec3
p2 UVec3
p3 UVec3
p4 =
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p0 \Word32
x0 Word32
y0 Word32
z0 ->
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p1 \Word32
x1 Word32
y1 Word32
z1 ->
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p2 \Word32
x2 Word32
y2 Word32
z2 ->
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p3 \Word32
x3 Word32
y3 Word32
z3 ->
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
p4 \Word32
x4 Word32
y4 Word32
z4 ->
      Word32 -> Word32 -> Word32 -> UVec3
uvec3
        (Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
f Word32
x0 Word32
x1 Word32
x2 Word32
x3 Word32
x4)
        (Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
f Word32
y0 Word32
y1 Word32
y2 Word32
y3 Word32
y4)
        (Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
-> Element UVec3
f Word32
z0 Word32
z1 Word32
z2 Word32
z3 Word32
z4)

-- XXX: That's another nasty instance...
instance Num UVec3 where
  {-# INLINE (+) #-}
  UVec3 Word32
l1 Word32
l2 Word32
l3 + :: UVec3 -> UVec3 -> UVec3
+ UVec3 Word32
r1 Word32
r2 Word32
r3 =
    Word32 -> Word32 -> Word32 -> UVec3
UVec3
      (Word32
l1 forall a. Num a => a -> a -> a
+ Word32
r1)
      (Word32
l2 forall a. Num a => a -> a -> a
+ Word32
r2)
      (Word32
l3 forall a. Num a => a -> a -> a
+ Word32
r3)

  {-# INLINE (-) #-}
  UVec3 Word32
l1 Word32
l2 Word32
l3 - :: UVec3 -> UVec3 -> UVec3
- UVec3 Word32
r1 Word32
r2 Word32
r3 =
    Word32 -> Word32 -> Word32 -> UVec3
UVec3
      (Word32
l1 forall a. Num a => a -> a -> a
- Word32
r1)
      (Word32
l2 forall a. Num a => a -> a -> a
- Word32
r2)
      (Word32
l3 forall a. Num a => a -> a -> a
- Word32
r3)

  {-# INLINE (*) #-}
  UVec3 Word32
l1 Word32
l2 Word32
l3 * :: UVec3 -> UVec3 -> UVec3
* UVec3 Word32
r1 Word32
r2 Word32
r3 =
    Word32 -> Word32 -> Word32 -> UVec3
UVec3
      (Word32
l1 forall a. Num a => a -> a -> a
* Word32
r1)
      (Word32
l2 forall a. Num a => a -> a -> a
* Word32
r2)
      (Word32
l3 forall a. Num a => a -> a -> a
* Word32
r3)

  {-# INLINE abs #-}
  abs :: UVec3 -> UVec3
abs UVec3
x = UVec3
x

  {-# INLINE signum #-}
  signum :: UVec3 -> UVec3
signum UVec3
v3 = forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
v3 \Word32
a Word32
b Word32
c ->
    Word32 -> Word32 -> Word32 -> UVec3
uvec3 (forall a. Num a => a -> a
signum Word32
a) (forall a. Num a => a -> a
signum Word32
b) (forall a. Num a => a -> a
signum Word32
c)

  {-# INLINE fromInteger #-}
  fromInteger :: Integer -> UVec3
fromInteger Integer
x = Word32 -> Word32 -> Word32 -> UVec3
UVec3 Word32
x' Word32
x' Word32
x'
    where
      x' :: Word32
x' = forall a. Num a => Integer -> a
fromInteger Integer
x

instance Storable UVec3 where
  {-# INLINE sizeOf #-}
  sizeOf :: UVec3 -> Int
sizeOf UVec3
_ = Int
16

  {-# INLINE alignment #-}
  alignment :: UVec3 -> Int
alignment UVec3
_ = Int
8

  {-# INLINE poke #-}
  poke :: Ptr UVec3 -> UVec3 -> IO ()
poke Ptr UVec3
ptr UVec3
v3 =
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
v3 \Word32
a Word32
b Word32
c -> do
      forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr UVec3
ptr  Int
0 Word32
a
      forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr UVec3
ptr  Int
4 Word32
b
      forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr UVec3
ptr  Int
8 Word32
c

  {-# INLINE peek #-}
  peek :: Ptr UVec3 -> IO UVec3
peek Ptr UVec3
ptr = Word32 -> Word32 -> Word32 -> UVec3
uvec3
    forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr UVec3
ptr  Int
0
    forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr UVec3
ptr  Int
4
    forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr UVec3
ptr  Int
8

newtype Packed = Packed { Packed -> UVec3
unPacked :: UVec3 }
  deriving (Packed -> Packed -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: Packed -> Packed -> Bool
$c/= :: Packed -> Packed -> Bool
== :: Packed -> Packed -> Bool
$c== :: Packed -> Packed -> Bool
Eq, Eq Packed
Packed -> Packed -> Bool
Packed -> Packed -> Ordering
Packed -> Packed -> Packed
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 :: Packed -> Packed -> Packed
$cmin :: Packed -> Packed -> Packed
max :: Packed -> Packed -> Packed
$cmax :: Packed -> Packed -> Packed
>= :: Packed -> Packed -> Bool
$c>= :: Packed -> Packed -> Bool
> :: Packed -> Packed -> Bool
$c> :: Packed -> Packed -> Bool
<= :: Packed -> Packed -> Bool
$c<= :: Packed -> Packed -> Bool
< :: Packed -> Packed -> Bool
$c< :: Packed -> Packed -> Bool
compare :: Packed -> Packed -> Ordering
$ccompare :: Packed -> Packed -> Ordering
Ord, Int -> Packed -> ShowS
[Packed] -> ShowS
Packed -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [Packed] -> ShowS
$cshowList :: [Packed] -> ShowS
show :: Packed -> String
$cshow :: Packed -> String
showsPrec :: Int -> Packed -> ShowS
$cshowsPrec :: Int -> Packed -> ShowS
Show, Packed -> ()
forall a. (a -> ()) -> NFData a
rnf :: Packed -> ()
$crnf :: Packed -> ()
NFData, Integer -> Packed
Packed -> Packed
Packed -> Packed -> Packed
forall a.
(a -> a -> a)
-> (a -> a -> a)
-> (a -> a -> a)
-> (a -> a)
-> (a -> a)
-> (a -> a)
-> (Integer -> a)
-> Num a
fromInteger :: Integer -> Packed
$cfromInteger :: Integer -> Packed
signum :: Packed -> Packed
$csignum :: Packed -> Packed
abs :: Packed -> Packed
$cabs :: Packed -> Packed
negate :: Packed -> Packed
$cnegate :: Packed -> Packed
* :: Packed -> Packed -> Packed
$c* :: Packed -> Packed -> Packed
- :: Packed -> Packed -> Packed
$c- :: Packed -> Packed -> Packed
+ :: Packed -> Packed -> Packed
$c+ :: Packed -> Packed -> Packed
Num)

{-# INLINE packed #-}
packed :: Word32 -> Word32 -> Word32 -> Packed
packed :: Word32 -> Word32 -> Word32 -> Packed
packed Word32
a Word32
b Word32
c = UVec3 -> Packed
Packed (Word32 -> Word32 -> Word32 -> UVec3
uvec3 Word32
a Word32
b Word32
c)

instance Storable Packed where
  {-# INLINE sizeOf #-}
  sizeOf :: Packed -> Int
sizeOf Packed
_ = Int
12

  {-# INLINE alignment #-}
  alignment :: Packed -> Int
alignment Packed
_ = Int
8

  {-# INLINE poke #-}
  poke :: Ptr Packed -> Packed -> IO ()
poke Ptr Packed
ptr (Packed UVec3
v3) =
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
v3 \Word32
a Word32
b Word32
c -> do
      forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr Packed
ptr Int
0 Word32
a
      forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr Packed
ptr Int
4 Word32
b
      forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr Packed
ptr Int
8 Word32
c

  {-# INLINE peek #-}
  peek :: Ptr Packed -> IO Packed
peek Ptr Packed
ptr = Word32 -> Word32 -> Word32 -> Packed
packed
    forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr Packed
ptr Int
0
    forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr Packed
ptr Int
4
    forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr Packed
ptr Int
8

instance Block UVec3 where
  type PackedSize UVec3 = 12
  alignment140 :: forall (proxy :: * -> *). proxy UVec3 -> Int
alignment140 proxy UVec3
_  = Int
16
  sizeOf140 :: forall (proxy :: * -> *). proxy UVec3 -> Int
sizeOf140 proxy UVec3
_     = Int
16
  alignment430 :: forall (proxy :: * -> *). proxy UVec3 -> Int
alignment430    = forall b (proxy :: * -> *). Block b => proxy b -> Int
alignment140
  sizeOf430 :: forall (proxy :: * -> *). proxy UVec3 -> Int
sizeOf430       = forall b (proxy :: * -> *). Block b => proxy b -> Int
sizeOf140
  isStruct :: forall (proxy :: * -> *). proxy UVec3 -> Bool
isStruct proxy UVec3
_      = Bool
False
  read140 :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a UVec3 -> m UVec3
read140     = forall (m :: * -> *) b a.
(MonadIO m, Storable b) =>
Ptr a -> Diff a b -> m b
peekDiffOff
  write140 :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a UVec3 -> UVec3 -> m ()
write140    = forall (m :: * -> *) b a.
(MonadIO m, Storable b) =>
Ptr a -> Diff a b -> b -> m ()
pokeDiffOff
  read430 :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a UVec3 -> m UVec3
read430     = forall b (m :: * -> *) a.
(Block b, MonadIO m) =>
Ptr a -> Diff a b -> m b
read140
  write430 :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a UVec3 -> UVec3 -> m ()
write430    = forall b (m :: * -> *) a.
(Block b, MonadIO m) =>
Ptr a -> Diff a b -> b -> m ()
write140
  readPacked :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a UVec3 -> m UVec3
readPacked  = forall b (m :: * -> *) a.
(Block b, MonadIO m) =>
Ptr a -> Diff a b -> m b
read140
  writePacked :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a UVec3 -> UVec3 -> m ()
writePacked = forall b (m :: * -> *) a.
(Block b, MonadIO m) =>
Ptr a -> Diff a b -> b -> m ()
write140
  {-# INLINE alignment140 #-}
  {-# INLINE sizeOf140 #-}
  {-# INLINE alignment430 #-}
  {-# INLINE sizeOf430 #-}
  {-# INLINE isStruct #-}
  {-# INLINE read140 #-}
  {-# INLINE write140 #-}
  {-# INLINE read430 #-}
  {-# INLINE write430 #-}
  {-# INLINE readPacked #-}
  {-# INLINE writePacked #-}

instance Block Packed where
  type PackedSize Packed = 12
  alignment140 :: forall (proxy :: * -> *). proxy Packed -> Int
alignment140 proxy Packed
_  = Int
16
  sizeOf140 :: forall (proxy :: * -> *). proxy Packed -> Int
sizeOf140 proxy Packed
_     = Int
16
  alignment430 :: forall (proxy :: * -> *). proxy Packed -> Int
alignment430    = forall b (proxy :: * -> *). Block b => proxy b -> Int
alignment140
  sizeOf430 :: forall (proxy :: * -> *). proxy Packed -> Int
sizeOf430       = forall b (proxy :: * -> *). Block b => proxy b -> Int
sizeOf140
  isStruct :: forall (proxy :: * -> *). proxy Packed -> Bool
isStruct proxy Packed
_      = Bool
False
  read140 :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a Packed -> m Packed
read140     = forall (m :: * -> *) b a.
(MonadIO m, Storable b) =>
Ptr a -> Diff a b -> m b
peekDiffOff
  write140 :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a Packed -> Packed -> m ()
write140    = forall (m :: * -> *) b a.
(MonadIO m, Storable b) =>
Ptr a -> Diff a b -> b -> m ()
pokeDiffOff
  read430 :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a Packed -> m Packed
read430     = forall b (m :: * -> *) a.
(Block b, MonadIO m) =>
Ptr a -> Diff a b -> m b
read140
  write430 :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a Packed -> Packed -> m ()
write430    = forall b (m :: * -> *) a.
(Block b, MonadIO m) =>
Ptr a -> Diff a b -> b -> m ()
write140
  readPacked :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a Packed -> m Packed
readPacked  = forall b (m :: * -> *) a.
(Block b, MonadIO m) =>
Ptr a -> Diff a b -> m b
read140
  writePacked :: forall (m :: * -> *) a.
MonadIO m =>
Ptr a -> Diff a Packed -> Packed -> m ()
writePacked = forall b (m :: * -> *) a.
(Block b, MonadIO m) =>
Ptr a -> Diff a b -> b -> m ()
write140
  {-# INLINE alignment140 #-}
  {-# INLINE sizeOf140 #-}
  {-# INLINE alignment430 #-}
  {-# INLINE sizeOf430 #-}
  {-# INLINE isStruct #-}
  {-# INLINE read140 #-}
  {-# INLINE write140 #-}
  {-# INLINE read430 #-}
  {-# INLINE write430 #-}
  {-# INLINE readPacked #-}
  {-# INLINE writePacked #-}

instance Ix UVec3 where
  {-# INLINE range #-}
  range :: (UVec3, UVec3) -> [UVec3]
range (UVec3
l, UVec3
u) =
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
l \Word32
l1 Word32
l2 Word32
l3 ->
      forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
u \Word32
u1 Word32
u2 Word32
u3 ->
        Word32 -> Word32 -> Word32 -> UVec3
uvec3
          forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall a. Ix a => (a, a) -> [a]
range (Word32
l1, Word32
u1)
          forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall a. Ix a => (a, a) -> [a]
range (Word32
l2, Word32
u2)
          forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall a. Ix a => (a, a) -> [a]
range (Word32
l3, Word32
u3)

  {-# INLINE unsafeIndex #-}
  unsafeIndex :: (UVec3, UVec3) -> UVec3 -> Int
unsafeIndex (UVec3
l, UVec3
u) UVec3
i =
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
l \Word32
l1 Word32
l2 Word32
l3 ->
      forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
u \Word32
u1 Word32
u2 Word32
u3 ->
        forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
i \Word32
i1 Word32
i2 Word32
i3 ->
          forall a. Ix a => (a, a) -> a -> Int
unsafeIndex (Word32
l3, Word32
u3) Word32
i3 forall a. Num a => a -> a -> a
+ forall a. Ix a => (a, a) -> Int
unsafeRangeSize (Word32
l3, Word32
u3) forall a. Num a => a -> a -> a
* (
          forall a. Ix a => (a, a) -> a -> Int
unsafeIndex (Word32
l2, Word32
u2) Word32
i2 forall a. Num a => a -> a -> a
+ forall a. Ix a => (a, a) -> Int
unsafeRangeSize (Word32
l2, Word32
u2) forall a. Num a => a -> a -> a
* (
          forall a. Ix a => (a, a) -> a -> Int
unsafeIndex (Word32
l1, Word32
u1) Word32
i1))

  {-# INLINE inRange #-}
  inRange :: (UVec3, UVec3) -> UVec3 -> Bool
inRange (UVec3
l, UVec3
u) UVec3
i =
    forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
l \Word32
l1 Word32
l2 Word32
l3 ->
      forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
u \Word32
u1 Word32
u2 Word32
u3 ->
        forall r. UVec3 -> (Word32 -> Word32 -> Word32 -> r) -> r
withUVec3 UVec3
i \Word32
i1 Word32
i2 Word32
i3 ->
          forall a. Ix a => (a, a) -> a -> Bool
inRange (Word32
l1, Word32
u1) Word32
i1 Bool -> Bool -> Bool
&&
          forall a. Ix a => (a, a) -> a -> Bool
inRange (Word32
l2, Word32
u2) Word32
i2 Bool -> Bool -> Bool
&&
          forall a. Ix a => (a, a) -> a -> Bool
inRange (Word32
l3, Word32
u3) Word32
i3