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/errors.ml

48 lines
1 KiB
OCaml
Raw Normal View History

open Ast
open Lexing
exception LexerErrorC of char
exception LexerErrorS of string
exception SemanticsError of string * Lexing.position
let err msg pos =
Printf.eprintf
"Error on line %d col %d: %s.\n"
pos.pos_lnum
(pos.pos_cnum - pos.pos_bol)
msg;
exit 1
;;
let rec string_of_type_t = function
2022-12-10 17:25:10 +01:00
| Magic_t -> "magic"
| Void_t -> "void"
| Int_t -> "int"
| Bool_t -> "bool"
2022-12-11 03:35:52 +01:00
| Str_t -> "str"
| Func_t (r, a) ->
(if List.length a > 1 then "(" else "")
^ String.concat ", " (List.map string_of_type_t a)
^ (if List.length a > 1 then ")" else "")
^ " -> "
^ string_of_type_t r
;;
let errt expected given pos =
raise
(SemanticsError
( Printf.sprintf
"Expected %s but given %s"
2022-12-22 19:15:42 +01:00
(String.concat ", " (List.map string_of_type_t expected))
(String.concat ", " (List.map string_of_type_t given))
, pos ))
;;
let warn msg (pos : Lexing.position) =
Printf.eprintf
"Warning on line %d col %d: %s.\n"
pos.pos_lnum
(pos.pos_cnum - pos.pos_bol)
msg
;;