(***********************************************************************) (* *) (* Caml Special Light *) (* *) (* Xavier Leroy, projet Cristal, INRIA Rocquencourt *) (* *) (* Copyright 1995 Institut National de Recherche en Informatique et *) (* Automatique. Distributed only by permission. *) (* *) (***********************************************************************) (* $Id$ *) (* Second intermediate language (machine independent) *) type machtype_component = Addr | Int | Float type machtype = machtype_component array val typ_void: machtype val typ_addr: machtype val typ_int: machtype val typ_float: machtype val size_component: machtype_component -> int val size_machtype: machtype -> int type comparison = Ceq | Cne | Clt | Cle | Cgt | Cge val negate_comparison: comparison -> comparison val swap_comparison: comparison -> comparison type memory_chunk = Byte_unsigned | Byte_signed | Sixteen_unsigned | Sixteen_signed | Word type operation = Capply of machtype | Cextcall of string * machtype * bool | Cproj of int * int | Cload of machtype | Cloadchunk of memory_chunk | Calloc | Cstore | Cstorechunk of memory_chunk | Caddi | Csubi | Cmuli | Cdivi | Cmodi | Cand | Cor | Cxor | Clsl | Clsr | Casr | Ccmpi of comparison | Cadda | Csuba | Ccmpa of comparison | Caddf | Csubf | Cmulf | Cdivf | Cfloatofint | Cintoffloat | Ccmpf of comparison | Craise | Ccheckbound type expression = Cconst_int of int | Cconst_float of string | Cconst_symbol of string | Cconst_pointer of int | Cvar of Ident.t | Clet of Ident.t * expression * expression | Cassign of Ident.t * expression | Ctuple of expression list | Cop of operation * expression list | Csequence of expression * expression | Cifthenelse of expression * expression * expression | Cswitch of expression * int array * expression array | Cloop of expression | Ccatch of expression * expression | Cexit | Ctrywith of expression * Ident.t * expression type fundecl = { fun_name: string; fun_args: (Ident.t * machtype) list; fun_body: expression; fun_fast: bool } type data_item = Cdefine_symbol of string | Cdefine_label of int | Cint8 of int | Cint16 of int | Cint of int | Cintlit of string | Cfloat of string | Csymbol_address of string | Clabel_address of int | Cstring of string | Cskip of int | Calign of int type phrase = Cfunction of fundecl | Cdata of data_item list