У меня проблема с исправлением предупреждения, которое дает мне компилятор OCaml.
В основном я анализирую выражение, которое может быть составлено с помощью Bool
, Int
и Float
.
У меня есть таблица символов, которая отслеживает все символы, объявленные с их типом:
type ast_type = Bool | Int | Float
and variables = (string, int*ast_type) Hashtbl.t;
, где int
- индекс, используемый позже в массиве всех переменных.
У меня есть конкретный тип, представляющий значение в переменной:
type value =
| BOOL of bool
| INT of int
| FLOAT of float
| UNSET
and var_values = value array
Я пытаюсь определить поведение ссылки на переменную внутри логического выражения, так что я делаю это
- проверьте, что переменная объявлена
- проверьте, что переменная имеет тип bool
, чтобы сделать это, у меня есть этот код (s
- имя переменной):
| GVar s ->
begin
try
let (i,t) = Hashtbl.find variables s in
if (t != Bool) then
raise (SemanticException (BoolExpected,s))
else
(fun s -> let BOOL v = Array.get var_values i in v)
with
Not_found -> raise (SemanticException (VarUndefined,s))
end
Проблема в том, что мои проверки гарантируют, что элемент, взятый из var_values
, будет иметь тип BOOL of bool
, но, конечно, это ограничение не замечено компилятором, который предупреждает меня:
Предупреждение P: это сопоставление с образцом не является исчерпывающим.Вот пример значения, которое не совпадает: (FLOAT _ | INT _ | UNSET)
Как я должен решить такие проблемы?Заранее спасибо