From 245f24890cd78304cf0fd397dda8e72b0a7fbe6b Mon Sep 17 00:00:00 2001 From: Xander Date: Tue, 8 Aug 2023 22:17:40 +0200 Subject: more refactoring and implemented exec_init --- lib/DATS/init.dats | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) (limited to 'lib/DATS/init.dats') diff --git a/lib/DATS/init.dats b/lib/DATS/init.dats index c2ae39d..206dc6f 100644 --- a/lib/DATS/init.dats +++ b/lib/DATS/init.dats @@ -26,7 +26,25 @@ in panic("Not initialized") end -implement{vt} exec_void$fwork (v) = panic("Not overloaded") +//NOTE: lot of duplicate code +implement{vt} exec_init (r) = let + val (vbox pf | p) = ref_get_viewptr{initializable vt}(r) +in + if p->initialized then + let + prval () = opt_unsome p->obj + val () = exec_void$fwork(p->obj) + prval () = opt_some p->obj + in + end + else ( + $effmask_ref(initialize(r)); + if p->initialized then + $effmask_ref(exec_void(r)) + else + panic("Not inialized"); + ) +end implement{vt} {a} exec (r) = let val (vbox pf | p) = ref_get_viewptr{initializable vt}(r) @@ -45,10 +63,6 @@ in ) end -implement{vt} {a} exec$fwork (v) = ( - (panic("Not overloaded")); - $UN.ptr0_get(the_null_ptr) -) implement{vt} initialize (r) = let val (vbox pf | p) = ref_get_viewptr{initializable vt}(r) @@ -59,10 +73,3 @@ in val () = p->initialized := initialize$fwork(p->obj) in end end - -implement{vt} initialize$fwork (v) = let - prval () = opt_none v -in - false -end - -- cgit v1.2.3