Skip to content

Commit

Permalink
use prelude
Browse files Browse the repository at this point in the history
  • Loading branch information
zapashcanon committed Jul 18, 2024
1 parent ce702fa commit ced18a5
Show file tree
Hide file tree
Showing 74 changed files with 1,256 additions and 1,147 deletions.
13 changes: 7 additions & 6 deletions dune-project
Original file line number Diff line number Diff line change
Expand Up @@ -43,16 +43,17 @@
(>= 20220210)))
(dune-site :build)
;; runtime
(integers
(>= 0.5.1))
bos
cmdliner
conf-clang
sedlex
digestif
(integers
(>= 0.5.1))
ocaml_intrinsics
uutf
bos
prelude
sedlex
(smtml (>= 0.2.0))
digestif
uutf
xmlm
(processor (>= 0.1))
;; doc
Expand Down
8 changes: 4 additions & 4 deletions example/define_host_function/dune
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
(executable
(name extern)
(libraries owi)
(modules extern))
(modules extern)
(libraries owi))

(executable
(name extern_mem)
(libraries owi)
(modules extern_mem))
(modules extern_mem)
(libraries owi))

(mdx
(libraries owi fpath)
Expand Down
3 changes: 2 additions & 1 deletion example/lib/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,14 @@
Given a file `quickstart.wat`, here's how to parse and run this file:

```ocaml
# open Prelude;;
# open Owi;;
# let filename = Fpath.v "quickstart.wat";;
val filename : Fpath.t = <abstr>
# let m =
match Parse.Text.Module.from_file filename with
| Ok script -> script
| Error e -> Result.failwith e;;
| Error e -> assert false;;
val m : Text.modul =
...
# let module_to_run, link_state =
Expand Down
2 changes: 1 addition & 1 deletion example/lib/dune
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
(mdx
(libraries fpath owi)
(libraries fpath owi prelude)
(deps %{bin:owi} quickstart.wat)
(files README.md))
11 changes: 6 additions & 5 deletions owi.opam
Original file line number Diff line number Diff line change
Expand Up @@ -21,15 +21,16 @@ depends: [
"ocaml" {>= "5.1"}
"menhir" {build & >= "20220210"}
"dune-site" {build}
"integers" {>= "0.5.1"}
"bos"
"cmdliner"
"conf-clang"
"sedlex"
"digestif"
"integers" {>= "0.5.1"}
"ocaml_intrinsics"
"uutf"
"bos"
"prelude"
"sedlex"
"smtml" {>= "0.2.0"}
"digestif"
"uutf"
"xmlm"
"processor" {>= "0.1"}
"odoc" {with-doc}
Expand Down
12 changes: 7 additions & 5 deletions src/ast/binary_encoder.ml
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ let write_bytes_8 buf i =

let rec write_u64 buf i =
let b = Int64.to_int (Int64.logand i 0x7fL) in
if 0L <= i && i < 128L then write_byte buf b
if Int64.le 0L i && Int64.lt i 128L then write_byte buf b
else begin
write_byte buf (b lor 0x80);
write_u64 buf (Int64.shift_right_logical i 7)
Expand All @@ -48,7 +48,7 @@ let write_string buf str =

let rec write_s64 buf i =
let b = Int64.to_int (Int64.logand i 0x7fL) in
if -64L <= i && i < 64L then write_byte buf b
if Int64.le (-64L) i && Int64.lt i 64L then write_byte buf b
else begin
write_byte buf (b lor 0x80);
write_s64 buf (Int64.shift_right i 7)
Expand Down Expand Up @@ -524,7 +524,8 @@ let write_locals buf locals =
(fun compressed (_so, local_type) ->
let c = get_char_valtype local_type in
match compressed with
| (ch, cnt) :: compressed when ch = c -> (c, cnt + 1) :: compressed
| (ch, cnt) :: compressed when Char.equal ch c ->
(c, cnt + 1) :: compressed
| compressed -> (c, 1) :: compressed )
[] locals
in
Expand Down Expand Up @@ -769,9 +770,10 @@ let encode (modul : Binary.modul) =
Buffer.contents buf

let write_file filename content =
let _dir, filename = Fpath.split_base filename in
let filename, _ext = Fpath.split_ext filename in
let filename = Fpath.filename filename in
let filename = filename ^ ".wasm" in
let filename = Fpath.add_ext ".wasm" filename in
let filename = Fpath.to_string filename in
let oc = Out_channel.open_bin filename in
Out_channel.output_string oc content;
Out_channel.close oc
Expand Down
22 changes: 14 additions & 8 deletions src/ast/binary_to_text.ml
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,8 @@ let from_types (types : Types.binary Types.rec_type Named.t) :
let t = convert_rec_type t in
(i, MType t) :: acc )
types []
|> List.sort compare |> List.map snd
|> List.sort (fun (i1, _t1) (i2, _t2) -> Int.compare i1 i2)
|> List.map snd

let from_global (global : (Binary.global, binary global_type) Runtime.t Named.t)
: Text.module_field list =
Expand All @@ -145,7 +146,8 @@ let from_global (global : (Binary.global, binary global_type) Runtime.t Named.t)
let desc = Import_global (assigned_name, convert_global_type desc) in
(i, MImport { modul; name; desc }) :: acc )
global []
|> List.sort compare |> List.map snd
|> List.sort (fun (i1, _t1) (i2, _t2) -> Int.compare i1 i2)
|> List.map snd

let from_table (table : (binary table, binary table_type) Runtime.t Named.t) :
Text.module_field list =
Expand All @@ -159,7 +161,8 @@ let from_table (table : (binary table, binary table_type) Runtime.t Named.t) :
let desc = Import_table (assigned_name, convert_table_type desc) in
(i, MImport { modul; name; desc }) :: acc )
table []
|> List.sort compare |> List.map snd
|> List.sort (fun (i1, _t1) (i2, _t2) -> Int.compare i1 i2)
|> List.map snd

let from_mem (mem : (mem, limits) Runtime.t Named.t) : Text.module_field list =
Named.fold
Expand All @@ -170,7 +173,8 @@ let from_mem (mem : (mem, limits) Runtime.t Named.t) : Text.module_field list =
let desc = Import_mem (assigned_name, desc) in
(i, MImport { modul; name; desc }) :: acc )
mem []
|> List.sort compare |> List.map snd
|> List.sort (fun (i1, _t1) (i2, _t2) -> Int.compare i1 i2)
|> List.map snd

let from_func (func : (binary func, binary block_type) Runtime.t Named.t) :
Text.module_field list =
Expand All @@ -187,23 +191,26 @@ let from_func (func : (binary func, binary block_type) Runtime.t Named.t) :
let desc = Import_func (assigned_name, convert_block_type desc) in
(i, MImport { modul; name; desc }) :: acc )
func []
|> List.sort compare |> List.map snd
|> List.sort (fun (i1, _t1) (i2, _t2) -> Int.compare i1 i2)
|> List.map snd

let from_elem (elem : Binary.elem Named.t) : Text.module_field list =
Named.fold
(fun i (elem : Binary.elem) acc ->
let elem = convert_elem elem in
(i, MElem elem) :: acc )
elem []
|> List.sort compare |> List.map snd
|> List.sort (fun (i1, _t1) (i2, _t2) -> Int.compare i1 i2)
|> List.map snd

let from_data (data : Binary.data Named.t) : Text.module_field list =
Named.fold
(fun i (data : Binary.data) acc ->
let data = convert_data data in
(i, MData data) :: acc )
data []
|> List.sort compare |> List.map snd
|> List.sort (fun (i1, _t1) (i2, _t2) -> Int.compare i1 i2)
|> List.map snd

let from_exports (exports : Binary.exports) : Text.module_field list =
let global =
Expand Down Expand Up @@ -244,7 +251,6 @@ let from_start = function None -> [] | Some n -> [ MStart (Raw n) ]

let modul
{ Binary.id; types; global; table; mem; func; elem; data; start; exports } =
ignore types;
let fields =
from_types types @ from_global global @ from_table table @ from_mem mem
@ from_func func @ from_elem elem @ from_data data @ from_exports exports
Expand Down
7 changes: 0 additions & 7 deletions src/ast/binary_types.ml
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,6 @@
open Types
open Syntax

let equal_func_types (a : binary func_type) (b : binary func_type) : bool =
let remove_param (pt, rt) =
let pt = List.map (fun (_id, vt) -> (None, vt)) pt in
(pt, rt)
in
remove_param a = remove_param b

type tbl = (string, int) Hashtbl.t Option.t

let convert_heap_type tbl = function
Expand Down
2 changes: 0 additions & 2 deletions src/ast/binary_types.mli
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,6 @@ open Types

type tbl = (string, int) Hashtbl.t Option.t

val equal_func_types : binary func_type -> binary func_type -> bool

val convert_val_type : tbl -> text val_type -> binary val_type Result.t

val convert_heap_type : tbl -> text heap_type -> binary heap_type Result.t
Expand Down
66 changes: 33 additions & 33 deletions src/ast/text.ml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
(* Copyright © 2021-2024 OCamlPro *)
(* Written by the Owi programmers *)

open Format
open Fmt
open Types

let symbolic v = Text v
Expand All @@ -20,7 +20,7 @@ type global =
}

let pp_global fmt (g : global) =
pp fmt "(global%a %a %a)" pp_id_opt g.id pp_global_type g.typ pp_expr g.init
pf fmt "(global%a %a %a)" pp_id_opt g.id pp_global_type g.typ pp_expr g.init

type data_mode =
| Data_passive
Expand All @@ -29,7 +29,7 @@ type data_mode =
let pp_data_mode fmt = function
| Data_passive -> ()
| Data_active (i, e) ->
pp fmt "(memory %a) (offset %a)" pp_indice_opt i pp_expr e
pf fmt "(memory %a) (offset %a)" pp_indice_opt i pp_expr e

type data =
{ id : string option
Expand All @@ -38,7 +38,7 @@ type data =
}

let pp_data fmt (d : data) =
pp fmt {|(data%a %a %S)|} pp_id_opt d.id pp_data_mode d.mode d.init
pf fmt {|(data%a %a %S)|} pp_id_opt d.id pp_data_mode d.mode d.init

type elem_mode =
| Elem_passive
Expand All @@ -47,11 +47,11 @@ type elem_mode =

let pp_elem_mode fmt = function
| Elem_passive -> ()
| Elem_declarative -> pp fmt "declare"
| Elem_declarative -> pf fmt "declare"
| Elem_active (i, e) -> (
match i with
| None -> pp fmt "(offset %a)" pp_expr e
| Some i -> pp fmt "(table %a) (offset %a)" pp_indice i pp_expr e )
| None -> pf fmt "(offset %a)" pp_expr e
| Some i -> pf fmt "(table %a) (offset %a)" pp_indice i pp_expr e )

type elem =
{ id : string option
Expand All @@ -60,12 +60,12 @@ type elem =
; mode : elem_mode
}

let pp_elem_expr fmt e = pp fmt "(item %a)" pp_expr e
let pp_elem_expr fmt e = pf fmt "(item %a)" pp_expr e

let pp_elem fmt (e : elem) =
pp fmt "@[<hov 2>(elem%a %a %a %a)@]" pp_id_opt e.id pp_elem_mode e.mode
pf fmt "@[<hov 2>(elem%a %a %a %a)@]" pp_id_opt e.id pp_elem_mode e.mode
pp_ref_type e.typ
(pp_list ~pp_sep:pp_newline pp_elem_expr)
(list ~sep:pp_newline pp_elem_expr)
e.init

type module_field =
Expand Down Expand Up @@ -98,8 +98,8 @@ type modul =
}

let pp_modul fmt (m : modul) =
pp fmt "(module%a@\n @[<v>%a@]@\n)" pp_id_opt m.id
(pp_list ~pp_sep:pp_newline pp_module_field)
pf fmt "(module%a@\n @[<v>%a@]@\n)" pp_id_opt m.id
(list ~sep:pp_newline pp_module_field)
m.fields

type action =
Expand All @@ -108,8 +108,8 @@ type action =

let pp_action fmt = function
| Invoke (mod_name, name, c) ->
pp fmt {|(invoke%a "%s" %a)|} pp_id_opt mod_name name pp_consts c
| Get _ -> pp fmt "<action_get TODO>"
pf fmt {|(invoke%a "%s" %a)|} pp_id_opt mod_name name pp_consts c
| Get _ -> pf fmt "<action_get TODO>"

type result_const =
| Literal of text const
Expand All @@ -118,23 +118,23 @@ type result_const =

let pp_result_const fmt = function
| Literal c -> pp_const fmt c
| Nan_canon n -> pp fmt "float%a.const nan:canonical" pp_nn n
| Nan_arith n -> pp fmt "float%a.const nan:arithmetic" pp_nn n
| Nan_canon n -> pf fmt "f%a.const nan:canonical" pp_nn n
| Nan_arith n -> pf fmt "f%a.const nan:arithmetic" pp_nn n

type result =
| Result_const of result_const
| Result_extern_ref
| Result_func_ref

let pp_result fmt = function
| Result_const c -> pp fmt "(%a)" pp_result_const c
| Result_const c -> pf fmt "(%a)" pp_result_const c
| Result_func_ref | Result_extern_ref -> Log.err "not yet implemented"

let pp_result_bis fmt = function
| Result_const c -> pp fmt "%a" pp_result_const c
| Result_const c -> pf fmt "%a" pp_result_const c
| Result_extern_ref | Result_func_ref -> Log.err "not yet implemented"

let pp_results fmt r = pp_list ~pp_sep:pp_space pp_result_bis fmt r
let pp_results fmt r = list ~sep:sp pp_result_bis fmt r

type assertion =
| Assert_return of action * result list
Expand All @@ -151,31 +151,31 @@ type assertion =

let pp_assertion fmt = function
| Assert_return (a, l) ->
pp fmt "(assert_return %a %a)" pp_action a pp_results l
pf fmt "(assert_return %a %a)" pp_action a pp_results l
| Assert_exhaustion (a, msg) ->
pp fmt "(assert_exhaustion %a %s)" pp_action a msg
| Assert_trap (a, f) -> pp fmt {|(assert_trap %a "%s")|} pp_action a f
pf fmt "(assert_exhaustion %a %s)" pp_action a msg
| Assert_trap (a, f) -> pf fmt {|(assert_trap %a "%s")|} pp_action a f
| Assert_trap_module (m, f) ->
pp fmt {|(assert_trap_module %a "%s")|} pp_modul m f
pf fmt {|(assert_trap_module %a "%s")|} pp_modul m f
| Assert_invalid (m, msg) ->
pp fmt "(assert_invalid@\n @[<v>%a@]@\n @[<v>%S@]@\n)" pp_modul m msg
pf fmt "(assert_invalid@\n @[<v>%a@]@\n @[<v>%S@]@\n)" pp_modul m msg
| Assert_unlinkable (m, msg) ->
pp fmt "(assert_unlinkable@\n @[<v>%a@]@\n @[<v>%S@]@\n)" pp_modul m msg
pf fmt "(assert_unlinkable@\n @[<v>%a@]@\n @[<v>%S@]@\n)" pp_modul m msg
| Assert_malformed (m, msg) ->
pp fmt "(assert_malformed (module binary@\n @[<v>%a@])@\n @[<v>%S@]@\n)"
pf fmt "(assert_malformed (module binary@\n @[<v>%a@])@\n @[<v>%S@]@\n)"
pp_modul m msg
| Assert_malformed_quote (ls, msg) ->
pp fmt "(assert_malformed_quote@\n @[<v>%S@]@\n @[<v>%S@]@\n)" ls msg
pf fmt "(assert_malformed_quote@\n @[<v>%S@]@\n @[<v>%S@]@\n)" ls msg
| Assert_invalid_quote (ls, msg) ->
pp fmt "(assert_invalid_quote@\n @[<v>%S@]@\n @[<v>%S@]@\n)" ls msg
pf fmt "(assert_invalid_quote@\n @[<v>%S@]@\n @[<v>%S@]@\n)" ls msg
| Assert_malformed_binary (ls, msg) ->
pp fmt "(assert_malformed_binary@\n @[<v>%S@]@\n @[<v>%S@]@\n)" ls msg
pf fmt "(assert_malformed_binary@\n @[<v>%S@]@\n @[<v>%S@]@\n)" ls msg
| Assert_invalid_binary (ls, msg) ->
pp fmt "(assert_invalid_binary@\n @[<v>%S@]@\n @[<v>%S@]@\n)" ls msg
pf fmt "(assert_invalid_binary@\n @[<v>%S@]@\n @[<v>%S@]@\n)" ls msg

type register = string * string option

let pp_register fmt (s, _name) = pp fmt "(register %s)" s
let pp_register fmt (s, _name) = pf fmt "(register %s)" s

type cmd =
| Module of modul
Expand All @@ -187,8 +187,8 @@ let pp_cmd fmt = function
| Module m -> pp_modul fmt m
| Assert a -> pp_assertion fmt a
| Register (s, name) -> pp_register fmt (s, name)
| Action _a -> pp fmt "<action>"
| Action _a -> pf fmt "<action>"

type script = cmd list

let pp_script fmt l = pp_list ~pp_sep:pp_newline pp_cmd fmt l
let pp_script fmt l = list ~sep:pp_newline pp_cmd fmt l
Loading

0 comments on commit ced18a5

Please sign in to comment.