(**************************************************************************) (* *) (* OCaml *) (* *) (* Xavier Leroy, projet Cristal, INRIA Rocquencourt *) (* *) (* Copyright 1996 Institut National de Recherche en Informatique et *) (* en Automatique. *) (* *) (* All rights reserved. This file is distributed under the terms of *) (* the GNU Lesser General Public License version 2.1, with the *) (* special exception on linking described in the file LICENSE. *) (* *) (**************************************************************************) (* Translation from typed abstract syntax to lambda terms, for the core language *) open Asttypes open Typedtree open Lambda open Debuginfo.Scoped_location val pure_module : module_expr -> let_kind val transl_exp: scopes:scopes -> expression -> lambda val transl_apply: scopes:scopes -> ?tailcall:tailcall_attribute -> ?inlined:inline_attribute -> ?specialised:specialise_attribute -> lambda -> (arg_label * expression option) list -> scoped_location -> lambda val transl_let: scopes:scopes -> ?in_structure:bool -> rec_flag -> value_binding list -> lambda -> lambda val transl_extension_constructor: scopes:scopes -> Env.t -> Path.t option -> extension_constructor -> lambda val transl_scoped_exp : scopes:scopes -> expression -> lambda type error = Free_super_var | Unreachable_reached exception Error of Location.t * error open Format val report_error: formatter -> error -> unit (* Forward declaration -- to be filled in by Translmod.transl_module *) val transl_module : (scopes:scopes -> module_coercion -> Path.t option -> module_expr -> lambda) ref val transl_object : (scopes:scopes -> Ident.t -> string list -> class_expr -> lambda) ref