-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlinearLib.idr
123 lines (87 loc) · 3.21 KB
/
linearLib.idr
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
import System.FFI
import PrimIO
import Prelude
import Control.Linear.LIO
import Control.App
import Control.App.Console
import System.FFI
import PrimIO
import Prelude
import Control.Linear.LIO
import Control.Monad.State.State
import Control.Monad.State
import Data.Fin
import Data.Nat
%foreign "C:getPointer, libsmall"
getPointer : PrimIO (Ptr Int)
%foreign "C:getArray, libsmall"
getArray : Int -> PrimIO (Ptr Int)
%foreign "C:freePointer, libsmall"
freePointer : (1 mem : Ptr Int) -> PrimIO ()
%foreign "C:readNumber, libsmall"
readPointer : (1 mem : Ptr Int) -> PrimIO Int
%foreign "C:readPointerOffset, libsmall"
readPointerOffset : Int -> (1 mem : Ptr Int) -> PrimIO Int
%foreign "C:writePointer, libsmall"
writePointer : (1 _ : Ptr Int) -> Int -> PrimIO (Ptr Int)
%foreign "C:writeOffset, libsmall"
writeOffset : Int -> (1 mem : Ptr Int) -> Int -> PrimIO ()
MyPtr = L IO {use=1} (Ptr Int)
export
alloc : L {use=1} IO (Ptr Int)
alloc = do
x <- (liftIO1 {io=L IO} (fromPrim getPointer))
pure1 x
export
write : Int -> (1 _ : Ptr Int) -> MyPtr
write int ptr = do
x <- liftIO1 {io=L IO} (fromPrim (writePointer ptr int))
pure1 x
read' : (Ptr Int) -> L IO {use=1} (Res Int (\_ => Ptr Int))
read' ptr = do
x <- (liftIO1 {io=L IO} (fromPrim (readPointer ptr)))
pure1 (x # ptr)
export
read : (1 mem : Ptr Int) -> L IO {use=1} (Res Int (\_ => Ptr Int))
read = assert_linear read'
export
readNum : (1 _ : Ptr Int) -> L IO Int
readNum ptr = liftIO1 {io=L IO} (fromPrim (readPointer ptr))
export
free : (1 _ : Ptr Int) -> L IO {use=Unrestricted} ()
free ptr = do
x <- (liftIO1 {io=L IO} (fromPrim (freePointer ptr)))
case x of
() => pure ()
-- Need to make Arr constructor private
export
data MyVect : (Nat) -> Type where
Arr : (size : Nat) -> (1 _ : Ptr Int) -> MyVect (S size)--(S len)
%name MyVect arr, arr1, arr2
export
createArr : (size : Nat) -> L IO {use=1} (MyVect (S size))-- -> L IO {use=1} (MyVect size)
createArr (size) = do--(S size) = do
x <- liftIO1 {io=L IO} (fromPrim (getArray (cast (S size))))
pure1 (Arr size x)
conv : (Fin m) -> Int
conv = cast . finToInteger
getIndex' : (index : Fin m) -> (MyVect m) -> L IO {use=1} (Res Int (\_ => MyVect m))
getIndex' index (Arr size ptr) = do
x <- liftIO1 {io=L IO} (fromPrim $ readPointerOffset (conv index) ptr)
pure1 (x # (Arr size ptr))
export
getIndex : (index : Fin m) -> (1 mem : (MyVect m)) -> L IO {use=1} (Res Int (\_ => MyVect m))
getIndex index = assert_linear (getIndex' index)
writeArr' : Int -> (index : Fin m) -> (MyVect m) -> L IO {use=1} (MyVect m)
writeArr' toWrite index (Arr size ptr) = do
liftIO1 {io = L IO} (fromPrim (writeOffset (conv index) ptr toWrite))
pure1 (Arr size ptr)
export
writeArr : Int -> (index : Fin m) -> (1 mem : MyVect m) -> L IO {use=1} (MyVect m)
writeArr toWrite index = assert_linear (writeArr' toWrite index)
export
freeArr : (1 mem : MyVect m) -> L IO ()
freeArr (Arr s ptr) = liftIO1 {io = L IO} (fromPrim $ freePointer ptr)
export
runLin : (Applicative io, LinearBind io) => (1 _ : L io a) -> io a
runLin = Control.Linear.LIO.run