(*
* Copyright 2005-2010, Ecole des Mines de Nantes, University of Copenhagen
* Yoann Padioleau, Julia Lawall, Rene Rydhof Hansen, Henrik Stuart, Gilles Muller, Nicolas Palix
* This file is part of Coccinelle.
*
* Coccinelle is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, according to version 2 of the License.
*
* Coccinelle 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Coccinelle. If not, see .
*
* The authors reserve the right to distribute this or future versions of
* Coccinelle under other licenses.
*)
(*
* Copyright 2005-2010, Ecole des Mines de Nantes, University of Copenhagen
* Yoann Padioleau, Julia Lawall, Rene Rydhof Hansen, Henrik Stuart, Gilles Muller, Nicolas Palix
* This file is part of Coccinelle.
*
* Coccinelle is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, according to version 2 of the License.
*
* Coccinelle 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Coccinelle. If not, see .
*
* The authors reserve the right to distribute this or future versions of
* Coccinelle under other licenses.
*)
module Ast0 = Ast0_cocci
module Ast = Ast_cocci
type ('a,'n) inout = 'a -> ('n * 'a)
type 'n all_functions =
{ident : (Ast0.ident,'n) inout;
expression : (Ast0.expression,'n) inout;
typeC : (Ast0.typeC,'n) inout;
declaration : (Ast0.declaration,'n) inout;
initialiser : (Ast0.initialiser,'n) inout;
initialiser_list : (Ast0.initialiser_list,'n) inout;
parameter : (Ast0.parameterTypeDef,'n) inout;
parameter_list : (Ast0.parameter_list,'n) inout;
statement : (Ast0.statement,'n) inout;
case_line : (Ast0.case_line,'n) inout;
top_level : (Ast0.top_level,'n) inout;
expression_dots : (Ast0.expression Ast0.dots,'n) inout;
statement_dots : (Ast0.statement Ast0.dots,'n) inout;
declaration_dots : (Ast0.declaration Ast0.dots,'n) inout;
case_line_dots : (Ast0.case_line Ast0.dots,'n) inout;
anything : (Ast0.anything,'n) inout}
(* ----------------------------------------------------------------------- *)
(* combiner *)
type ('a,'n) combiner_inout = 'a -> 'n
type 'n combiner_rec_functions =
{combiner_rec_ident : (Ast0.ident,'n) combiner_inout;
combiner_rec_expression : (Ast0.expression,'n) combiner_inout;
combiner_rec_typeC : (Ast0.typeC,'n) combiner_inout;
combiner_rec_declaration : (Ast0.declaration,'n) combiner_inout;
combiner_rec_initialiser : (Ast0.initialiser,'n) combiner_inout;
combiner_rec_initialiser_list :
(Ast0.initialiser_list,'n) combiner_inout;
combiner_rec_parameter : (Ast0.parameterTypeDef,'n) combiner_inout;
combiner_rec_parameter_list : (Ast0.parameter_list,'n) combiner_inout;
combiner_rec_statement : (Ast0.statement,'n) combiner_inout;
combiner_rec_case_line : (Ast0.case_line,'n) combiner_inout;
combiner_rec_top_level : (Ast0.top_level,'n) combiner_inout;
combiner_rec_expression_dots :
(Ast0.expression Ast0.dots,'n) combiner_inout;
combiner_rec_statement_dots :
(Ast0.statement Ast0.dots,'n) combiner_inout;
combiner_rec_declaration_dots :
(Ast0.declaration Ast0.dots,'n) combiner_inout;
combiner_rec_case_line_dots :
(Ast0.case_line Ast0.dots,'n) combiner_inout;
combiner_rec_anything : (Ast0.anything,'n) combiner_inout}
type ('mc,'n) cmcode = 'n -> 'mc Ast0.mcode -> 'n
type ('mc,'n) flat_cmcode = 'mc Ast0.mcode -> 'n
type ('cd,'n) ccode = 'n combiner_rec_functions -> ('cd -> 'n) -> 'cd -> 'n
type 'n combiner_functions =
{combiner_meta_mcode : (Ast.meta_name,'n) cmcode;
combiner_string_mcode : (string,'n) cmcode;
combiner_const_mcode : (Ast.constant,'n) cmcode;
combiner_assign_mcode : (Ast.assignOp,'n) cmcode;
combiner_fix_mcode : (Ast.fixOp,'n) cmcode;
combiner_unary_mcode : (Ast.unaryOp,'n) cmcode;
combiner_binary_mcode : (Ast.binaryOp,'n) cmcode;
combiner_cv_mcode : (Ast.const_vol,'n) cmcode;
combiner_sign_mcode : (Ast.sign,'n) cmcode;
combiner_struct_mcode : (Ast.structUnion,'n) cmcode;
combiner_storage_mcode : (Ast.storage,'n) cmcode;
combiner_inc_mcode : (Ast.inc_file,'n) cmcode;
combiner_dotsexprfn : (Ast0.expression Ast0.dots,'n) ccode;
combiner_dotsinitfn : (Ast0.initialiser Ast0.dots,'n) ccode;
combiner_dotsparamfn : (Ast0.parameterTypeDef Ast0.dots,'n) ccode;
combiner_dotsstmtfn : (Ast0.statement Ast0.dots,'n) ccode;
combiner_dotsdeclfn : (Ast0.declaration Ast0.dots,'n) ccode;
combiner_dotscasefn : (Ast0.case_line Ast0.dots,'n) ccode;
combiner_identfn : (Ast0.ident,'n) ccode;
combiner_exprfn : (Ast0.expression,'n) ccode;
combiner_tyfn : (Ast0.typeC,'n) ccode;
combiner_initfn : (Ast0.initialiser,'n) ccode;
combiner_paramfn : (Ast0.parameterTypeDef,'n) ccode;
combiner_declfn : (Ast0.declaration,'n) ccode;
combiner_stmtfn : (Ast0.statement,'n) ccode;
combiner_casefn : (Ast0.case_line,'n) ccode;
combiner_topfn : (Ast0.top_level,'n) ccode}
(* ----------------------------------------------------------------------- *)
(* rebuilder *)
type 'a rebuilder_inout = 'a -> 'a
type rebuilder_rec_functions =
{rebuilder_rec_ident : Ast0.ident rebuilder_inout;
rebuilder_rec_expression : Ast0.expression rebuilder_inout;
rebuilder_rec_typeC : Ast0.typeC rebuilder_inout;
rebuilder_rec_declaration : Ast0.declaration rebuilder_inout;
rebuilder_rec_initialiser : Ast0.initialiser rebuilder_inout;
rebuilder_rec_initialiser_list :
Ast0.initialiser_list rebuilder_inout;
rebuilder_rec_parameter : Ast0.parameterTypeDef rebuilder_inout;
rebuilder_rec_parameter_list : Ast0.parameter_list rebuilder_inout;
rebuilder_rec_statement : Ast0.statement rebuilder_inout;
rebuilder_rec_case_line : Ast0.case_line rebuilder_inout;
rebuilder_rec_top_level : Ast0.top_level rebuilder_inout;
rebuilder_rec_expression_dots :
Ast0.expression Ast0.dots rebuilder_inout;
rebuilder_rec_statement_dots :
Ast0.statement Ast0.dots rebuilder_inout;
rebuilder_rec_declaration_dots :
Ast0.declaration Ast0.dots rebuilder_inout;
rebuilder_rec_case_line_dots :
Ast0.case_line Ast0.dots rebuilder_inout;
rebuilder_rec_anything : Ast0.anything rebuilder_inout}
type 'mc rmcode = 'mc Ast0.mcode rebuilder_inout
type 'cd rcode =
rebuilder_rec_functions -> ('cd rebuilder_inout) -> 'cd rebuilder_inout
type rebuilder_functions =
{rebuilder_meta_mcode : Ast_cocci.meta_name rmcode;
rebuilder_string_mcode : string rmcode;
rebuilder_const_mcode : Ast.constant rmcode;
rebuilder_assign_mcode : Ast.assignOp rmcode;
rebuilder_fix_mcode : Ast.fixOp rmcode;
rebuilder_unary_mcode : Ast.unaryOp rmcode;
rebuilder_binary_mcode : Ast.binaryOp rmcode;
rebuilder_cv_mcode : Ast.const_vol rmcode;
rebuilder_sign_mcode : Ast.sign rmcode;
rebuilder_struct_mcode : Ast.structUnion rmcode;
rebuilder_storage_mcode : Ast.storage rmcode;
rebuilder_inc_mcode : Ast.inc_file rmcode;
rebuilder_dotsexprfn : Ast0.expression Ast0.dots rcode;
rebuilder_dotsinitfn : Ast0.initialiser Ast0.dots rcode;
rebuilder_dotsparamfn : Ast0.parameterTypeDef Ast0.dots rcode;
rebuilder_dotsstmtfn : Ast0.statement Ast0.dots rcode;
rebuilder_dotsdeclfn : Ast0.declaration Ast0.dots rcode;
rebuilder_dotscasefn : Ast0.case_line Ast0.dots rcode;
rebuilder_identfn : Ast0.ident rcode;
rebuilder_exprfn : Ast0.expression rcode;
rebuilder_tyfn : Ast0.typeC rcode;
rebuilder_initfn : Ast0.initialiser rcode;
rebuilder_paramfn : Ast0.parameterTypeDef rcode;
rebuilder_declfn : Ast0.declaration rcode;
rebuilder_stmtfn : Ast0.statement rcode;
rebuilder_casefn : Ast0.case_line rcode;
rebuilder_topfn : Ast0.top_level rcode}
(* ----------------------------------------------------------------------- *)
(* combiner_rebuilder *)
type ('mc,'a) rcmcode = 'a -> 'mc Ast0.mcode -> ('a * 'mc Ast0.mcode)
type ('cd,'a) rccode =
'a all_functions -> ('cd -> ('a * 'cd)) -> 'cd -> ('a * 'cd)
type 'n combiner_rebuilder_functions =
{combiner_rebuilder_meta_mcode : (Ast_cocci.meta_name,'n) rcmcode;
combiner_rebuilder_string_mcode : (string,'n) rcmcode;
combiner_rebuilder_const_mcode : (Ast.constant,'n) rcmcode;
combiner_rebuilder_assign_mcode : (Ast.assignOp,'n) rcmcode;
combiner_rebuilder_fix_mcode : (Ast.fixOp,'n) rcmcode;
combiner_rebuilder_unary_mcode : (Ast.unaryOp,'n) rcmcode;
combiner_rebuilder_binary_mcode : (Ast.binaryOp,'n) rcmcode;
combiner_rebuilder_cv_mcode : (Ast.const_vol,'n) rcmcode;
combiner_rebuilder_sign_mcode : (Ast.sign,'n) rcmcode;
combiner_rebuilder_struct_mcode : (Ast.structUnion,'n) rcmcode;
combiner_rebuilder_storage_mcode : (Ast.storage,'n) rcmcode;
combiner_rebuilder_inc_mcode : (Ast.inc_file,'n) rcmcode;
combiner_rebuilder_dotsexprfn : (Ast0.expression Ast0.dots,'n) rccode;
combiner_rebuilder_dotsinitfn : (Ast0.initialiser Ast0.dots,'n) rccode;
combiner_rebuilder_dotsparamfn :
(Ast0.parameterTypeDef Ast0.dots,'n) rccode;
combiner_rebuilder_dotsstmtfn : (Ast0.statement Ast0.dots,'n) rccode;
combiner_rebuilder_dotsdeclfn : (Ast0.declaration Ast0.dots,'n) rccode;
combiner_rebuilder_dotscasefn : (Ast0.case_line Ast0.dots,'n) rccode;
combiner_rebuilder_identfn : (Ast0.ident,'n) rccode;
combiner_rebuilder_exprfn : (Ast0.expression,'n) rccode;
combiner_rebuilder_tyfn : (Ast0.typeC,'n) rccode;
combiner_rebuilder_initfn : (Ast0.initialiser,'n) rccode;
combiner_rebuilder_paramfn : (Ast0.parameterTypeDef,'n) rccode;
combiner_rebuilder_declfn : (Ast0.declaration,'n) rccode;
combiner_rebuilder_stmtfn : (Ast0.statement,'n) rccode;
combiner_rebuilder_casefn : (Ast0.case_line,'n) rccode;
combiner_rebuilder_topfn : (Ast0.top_level,'n) rccode}