]> gerrit.simantics Code Review - simantics/platform.git/blob - bundles/org.simantics.scl.runtime/scl/MList.scl
fc4f941144a69950360b1895359f1d5a7a471a0e
[simantics/platform.git] / bundles / org.simantics.scl.runtime / scl / MList.scl
1 import "Prelude" as Prelude
2 import "JavaBuiltin" as Java
3 import "Iterator" as Iterator
4
5 importJava "java.util.List" where
6     data T a
7     
8     contains :: T a -> a -> <Proc> Boolean
9     size :: T a -> <Proc> Integer
10     isEmpty :: T a -> <Proc> Boolean
11     get :: T a -> Integer -> <Proc> a
12     set :: T a -> Integer -> a -> <Proc> Maybe a
13     
14     add :: T a -> a -> <Proc> ()
15     addAll :: T a -> [a] -> <Proc> ()
16     remove :: T a -> Integer -> <Proc> a
17     clear :: T a -> <Proc> ()
18     
19     @private
20     iterator :: T a -> <Proc> Iterator.T a
21
22 removeLast :: T a -> <Proc> Maybe a
23 removeLast l = if isEmpty l
24                then Nothing
25                else Just (remove l (Java.isub (size l) 1))
26
27 @inline
28 iter :: (a -> <e> ()) -> T a -> <e,Proc> ()
29 iter f s = Iterator.iter f (iterator s)
30
31 @inline
32 iterB :: (a -> <e> Boolean) -> T a -> <e,Proc> Boolean
33 iterB f s = Iterator.iterB f (iterator s)
34
35 @inline
36 fold :: (a -> b  -> <e> a) -> a -> T b -> <Proc,e> a
37 fold f init s = Iterator.fold f init (iterator s)
38
39 importJava "java.util.ArrayList" where
40     @JavaName "<init>"
41     create :: () -> <Proc> T a
42     @JavaName "<init>"
43     createC :: Integer -> <Proc> T a
44
45 fromList :: [a] -> <Proc> T a
46 fromList l = do
47     result = createC (Prelude.length l)
48     Prelude.iter (\x -> Prelude.ignore (add result x)) l
49     result
50
51 singleton :: a -> <Proc> T a
52 singleton v = do
53     result = createC 2
54     add result v
55     result
56
57 @inline
58 freeze :: T a -> <Proc> [a]
59 freeze = Java.unsafeCoerce