blob: 7e60f80d699b303c10d3048a04d435a2329fc557 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
module Script.Object (
ObjectId(..),
ObjectType(..),
Object(..), SomeObject(..),
toSomeObject, fromSomeObject,
destroySomeObject,
) where
import Data.Kind
import Data.Text (Text)
import Data.Typeable
import Script.Expr.Class
newtype ObjectId = ObjectId Int
class Typeable a => ObjectType m a where
type ConstructorArgs a :: Type
type ConstructorArgs a = ()
textObjectType :: proxy (m a) -> proxy a -> Text
textObjectValue :: proxy (m a) -> a -> Text
createObject :: ObjectId -> ConstructorArgs a -> m (Object m a)
destroyObject :: Object m a -> m ()
instance (Typeable m, ObjectType m a) => ExprType (Object m a) where
textExprType _ = textObjectType (Proxy @(m a)) (Proxy @a)
textExprValue = textObjectValue (Proxy @(m a)) . objImpl
data Object m a = ObjectType m a => Object
{ objId :: ObjectId
, objImpl :: a
}
data SomeObject m = forall a. ObjectType m a => SomeObject
{ sobjId :: ObjectId
, sobjImpl :: a
}
toSomeObject :: Object m a -> SomeObject m
toSomeObject Object {..} = SomeObject { sobjId = objId, sobjImpl = objImpl }
fromSomeObject :: ObjectType m a => SomeObject m -> Maybe (Object m a)
fromSomeObject SomeObject {..} = do
let objId = sobjId
objImpl <- cast sobjImpl
return Object {..}
destroySomeObject :: SomeObject m -> m ()
destroySomeObject (SomeObject oid impl) = destroyObject (Object oid impl)
|