Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Newer
Older
100644 33 lines (25 sloc) 1.322 kB
fccc685 Initial open-source release
MLstate authored
1 (*
2 Copyright © 2011 MLstate
3
4 This file is part of OPA.
5
6 OPA is free software: you can redistribute it and/or modify it under the
7 terms of the GNU Affero General Public License, version 3, as published by
8 the Free Software Foundation.
9
10 OPA is distributed in the hope that it will be useful, but WITHOUT ANY
11 WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for
13 more details.
14
15 You should have received a copy of the GNU Affero General Public License
16 along with OPA. If not, see <http://www.gnu.org/licenses/>.
17 *)
18 (**
19 This pass implements the simplification of magic functions
20 in the case when they are used with a known type
21
22 For instance, [compare:int -> int -> int] will be replaced by [compare_int]
23 *)
24
25 (** Type of an environnment for this passes. This environnement is a
26 map wich contains bindings beetween the ident to specialize and
27 the list of [(ty, expr)] where [expr] is a specialized expression
28 for ident and [ty] its type *)
29 type info = { strict : bool ; specialize : (QmlAst.ty * QmlAst.expr) list }
30 type env = info IdentMap.t
31
32 val process_code : ?specialized_env:env -> QmlTypes.gamma -> QmlAst.annotmap -> QmlAst.code -> QmlAst.annotmap * QmlAst.code
Something went wrong with that request. Please try again.