Fetching contributors…
Cannot retrieve contributors at this time
73 lines (54 sloc) 2.65 KB
Copyright © 2011 MLstate
This file is part of OPA.
OPA is free software: you can redistribute it and/or modify it under the
terms of the GNU Affero General Public License, version 3, as published by
the Free Software Foundation.
OPA is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for
more details.
You should have received a copy of the GNU Affero General Public License
along with OPA. If not, see <>.
Some utils related to Pass Tracking for OPA.
(** This module defines some utils for branching compilers working on
OpaAst (SurfaceAst) with the pass tracking system developed in
passlib, in [PassHandler] and [PassTracker]
In particular, it defines, given a [SurfaceAst.code] extractor some :
+ [printers]
+ [trackers]
Any language should implement a module named [LangTracker],
[LangCheck], etc...
@see "passlib/" for a global overview of the Pass
(** {6 Printers} *)
(** Regroup some of common printer of the module [Printer] in one list .
The ignored argument is for an optimal branching with PassHandler.
+ code
TODO: some more flexibility in passhandler options so that we can
export in this list douzen of specific printers without risking
that they will all be printed with a --print-all.
val printers_uids : ('env -> (SurfaceAst.uids, [< SurfaceAst.all_directives ]) SurfaceAst.code) -> 'opt -> (PassHandler.printer_id * 'env PassHandler.printer) list
val printers_nonuid : ('env -> (SurfaceAst.nonuid, [< SurfaceAst.all_directives ]) SurfaceAst.code) -> 'opt -> (PassHandler.printer_id * 'env PassHandler.printer) list
module Printer :
Regular ast printer:
print the full code using the Pretty Printer of the language
and insering multiple new lines so that meld can better do
the correspondancy between values.
val code_uids : (SurfaceAst.uids, [< SurfaceAst.all_directives ]) SurfaceAst.code PassHandler.printer
val code_nonuid : (SurfaceAst.nonuid, [< SurfaceAst.all_directives ]) SurfaceAst.code PassHandler.printer
val size : ('ident, [< SurfaceAst.all_directives ]) SurfaceAst.code PassHandler.printer
(** {6 Trackers} *)
(** Regroup all the trackers of the module [Tracker] in one list .
The ignored argument is for an optimal branching with PassHandler.*)
val trackers : ('env -> ('a, 'b) SurfaceAst.code) -> 'opt -> (PassHandler.tracker_id * 'env PassHandler.tracker) list
module Tracker : sig end