This repository has been archived on 2022-12-27. You can view files and clone it, but cannot push or open issues or pull requests.
compilateurMIPS/ast.ml

87 lines
1.4 KiB
OCaml
Raw Normal View History

2022-12-08 21:30:39 +01:00
type type_t =
2022-12-09 22:20:05 +01:00
| Void_t
2022-12-08 21:30:39 +01:00
| Int_t
| Bool_t
2022-12-09 14:45:59 +01:00
| Func_t of type_t * type_t list
2022-12-08 19:55:22 +01:00
2022-12-06 20:39:15 +01:00
module Syntax = struct
2022-12-08 19:55:22 +01:00
type ident = string
2022-12-08 21:30:39 +01:00
type value =
2022-12-09 22:20:05 +01:00
| Void
2022-12-08 21:30:39 +01:00
| Int of int
| Bool of bool
2022-12-08 19:55:22 +01:00
2022-12-06 20:39:15 +01:00
type expr =
2022-12-08 19:55:22 +01:00
| Val of
{ value : value
; pos : Lexing.position
}
| Var of
{ name : ident
; pos : Lexing.position
}
2022-12-09 14:45:59 +01:00
| Call of
{ func : ident
; args : expr list
; pos : Lexing.position
}
2022-12-08 19:55:22 +01:00
type instr =
| Decl of
{ name : ident
; type_t : type_t
2022-12-06 22:22:48 +01:00
; pos : Lexing.position
}
2022-12-08 19:55:22 +01:00
| Assign of
{ var : ident
; expr : expr
; pos : Lexing.position
}
| Do of
{ expr : expr
; pos : Lexing.position
}
2022-12-09 14:14:33 +01:00
| Return of
{ expr : expr
; pos : Lexing.position
}
2022-12-08 19:55:22 +01:00
type block = instr list
type def =
| Func of
{ func : ident
; type_t : type_t
; args : ident list
; code : block
; pos : Lexing.position
}
type prog = def list
2022-12-06 20:39:15 +01:00
end
module IR = struct
2022-12-08 19:55:22 +01:00
type ident = string
2022-12-08 21:30:39 +01:00
type value =
2022-12-09 22:20:05 +01:00
| Void
2022-12-08 21:30:39 +01:00
| Int of int
| Bool of bool
2022-12-08 19:55:22 +01:00
type expr =
| Val of value
| Var of ident
2022-12-09 14:45:59 +01:00
| Call of ident * expr list
2022-12-08 19:55:22 +01:00
type instr =
| Decl of ident
| Assign of ident * expr
| Do of expr
2022-12-09 14:14:33 +01:00
| Return of expr
2022-12-08 19:55:22 +01:00
type block = instr list
type def = Func of ident * ident list * block
type prog = def list
2022-12-06 20:39:15 +01:00
end