module Foreign.Hoppy.Generator.Std.Iterator (
IteratorMutability (..),
makeTrivialIterator,
makeForwardIterator,
makeBidirectionalIterator,
makeRandomIterator,
) where
import Data.Maybe (catMaybes, isJust)
import Foreign.Hoppy.Generator.Spec (
Class,
MethodApplicability (MNormal),
Operator (
OpAdd,
OpAddAssign,
OpArray,
OpDecPre,
OpDeref,
OpIncPre,
OpSubtract,
OpSubtractAssign),
Purity (Nonpure),
Type (TConst, TObj, TObjToHeap, TPtr, TRef, TVoid),
addReqIncludes,
classAddCtors,
classAddMethods,
ident2,
makeFnMethod,
mkConstMethod',
mkCtor,
mkMethod',
)
import Foreign.Hoppy.Generator.Spec.ClassFeature (
ClassFeature (Assignable, Copyable, Equatable),
classAddFeatures,
)
import Foreign.Hoppy.Generator.Std.Internal (includeHelper)
data IteratorMutability = Constant | Mutable
deriving (Eq, Ord, Show)
makeTrivialIterator :: IteratorMutability -> Maybe Type -> Class -> Class
makeTrivialIterator mutable valueTypeMaybe cls =
(if isJust valueTypeMaybe && mutable == Mutable
then addReqIncludes [includeHelper "iterator.hpp"]
else id) $
classAddFeatures [Assignable, Copyable, Equatable] $
classAddCtors ctors $
classAddMethods methods cls
where ctors =
[ mkCtor "new" []
]
methods =
catMaybes
[ do valueType <- valueTypeMaybe
Mutable <- Just mutable
return $ mkMethod' OpDeref "get" [] $ TRef valueType
, do valueType <- valueTypeMaybe
return $ mkConstMethod' OpDeref "getConst" [] $ TRef $ TConst valueType
, do valueType <- valueTypeMaybe
Mutable <- Just mutable
return $
makeFnMethod (ident2 "hoppy" "iterator" "put") "put"
MNormal Nonpure [TPtr $ TObj cls, valueType] TVoid
]
makeForwardIterator :: IteratorMutability -> Maybe Type -> Class -> Class
makeForwardIterator mutable valueTypeMaybe cls =
classAddMethods methods $
makeTrivialIterator mutable valueTypeMaybe cls
where methods =
[ mkMethod' OpIncPre "next" [] $ TRef $ TObj cls
]
makeBidirectionalIterator :: IteratorMutability -> Maybe Type -> Class -> Class
makeBidirectionalIterator mutability valueTypeMaybe cls =
classAddMethods methods $
makeForwardIterator mutability valueTypeMaybe cls
where methods =
[ mkMethod' OpDecPre "prev" [] $ TRef $ TObj cls
]
makeRandomIterator :: IteratorMutability -> Maybe Type -> Type -> Class -> Class
makeRandomIterator mutable valueTypeMaybe distanceType cls =
classAddMethods methods $
makeBidirectionalIterator mutable valueTypeMaybe cls
where methods =
catMaybes
[ Just $ mkMethod' OpAdd "plusNew" [distanceType] $ TObjToHeap cls
, Just $ mkMethod' OpAddAssign "add" [distanceType] $ TRef $ TObj cls
, Just $ mkMethod' OpSubtract "minusNew" [distanceType] $ TObjToHeap cls
, Just $ mkMethod' OpSubtract "difference" [TObj cls] distanceType
, Just $ mkMethod' OpSubtractAssign "subtract" [distanceType] $ TRef $ TObj cls
, do valueType <- valueTypeMaybe
Mutable <- Just mutable
return $ mkMethod' OpArray "at" [distanceType] $ TRef valueType
, do valueType <- valueTypeMaybe
return $ mkConstMethod' OpArray "atConst" [distanceType] $ TRef $ TConst valueType
]