{- | In principle you can traverse through a lazy storable vector using repeated calls to @viewL@. However this needs a bit of pointer arrangement and allocation. This data structure makes the inner loop faster, that consists of traversing through a chunk. -} module Data.StorableVector.Lazy.Pointer ( Pointer, cons, viewL, switchL, ) where import Data.StorableVector.Lazy.PointerPrivate (Pointer(..), viewL, switchL, ) import qualified Data.StorableVector.Lazy as VL import Foreign.Storable (Storable) {-# INLINE cons #-} cons :: Storable a => VL.Vector a -> Pointer a cons :: forall a. Storable a => Vector a -> Pointer a cons = forall a. Storable a => Vector a -> Pointer a VL.pointer