This file is indexed.

/usr/lib/ocaml/galax/optimization_walker.mli is in libgalax-ocaml-dev 1.1-13build1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
(***********************************************************************)
(*                                                                     *)
(*                                 GALAX                               *)
(*                              XQuery Engine                          *)
(*                                                                     *)
(*  Copyright 2001-2007.                                               *)
(*  Distributed only by permission.                                    *)
(*                                                                     *)
(***********************************************************************)

(* $Id: optimization_walker.mli,v 1.4 2007/03/09 19:26:33 mff Exp $ *)

(* Module: Optimization_walker
   Description:
     This module implements the generic rule-based rewriter used for
     optimization.
*)

open Error
open Namespace_builtin

open Xquery_algebra_ast
open Xquery_algebra_ast_util
open Xquery_algebra_ast_annotation_util
open Logical_algebra_types
open Compile_context
open Compile_annotate
open Processing_context
open Alg_path_struct

type optimization_rewrite_rule = 
    (logical_compile_context ->
      logical_algop_expr ->
	logical_algop_expr * bool) 

type optimization_removal_rewrite_rule =
    (logical_compile_context ->
      logical_algop_expr ->
	logical_algop_expr ->
	  logical_algop_expr * bool)

(* Generic stuff  *)
type sub_expr_kind = 
  | Dependent 
  | Independent

type ('a, 'b) child_desc = ('a, 'b) aalgop_expr * sub_expr_kind * int

val get_sub_expr    : ('a,'b) aalgop_expr -> sub_expr_kind -> ('a,'b) aalgop_sub_exprs
val make_child_desc : ('a,'b) aalgop_expr -> sub_expr_kind -> int -> ('a,'b) child_desc
val update_parent   : ('a,'b) child_desc option -> ('a,'b) aalgop_expr  -> unit
val get_op_from_sub_expr :
    ('a,'b) aalgop_expr -> sub_expr_kind -> int -> ('a,'b) aalgop_expr

(* *** Tree Walker *** *)
val descendent_walker: 
    ('a -> bool) -> 
      ('a -> 'a) -> 
	'a option -> 
	  'a -> 'a * 'a option * bool

val rewrite_apply:
    ((logical_algop_expr * sub_expr_kind * int) option ->
      logical_algop_expr ->
	logical_algop_expr) ->
	  (logical_algop_expr * sub_expr_kind * int) option ->
	    logical_algop_expr ->
	      logical_algop_expr

(* [fold_over_algop loc agg v e] recursively walks down e, applying the
   loc function to every node in the AST, then accumulating the result of
   applying the agg function to every value in the tree, from the seed
    value 'd. 
*)

val fold_over_algop  : 
    (('a,'b) aalgop_expr -> 'c) -> 
      ('d -> 'c -> 'd) -> 'd -> 
	('a,'b) aalgop_expr -> 'd


(* rewrite rule wrappers *)

val generic_wrapper: 
    (logical_compile_context ->
       logical_algop_expr ->
       logical_algop_expr * bool) ->
    bool ref ->
    logical_compile_context ->
    logical_algop_expr ->
    (logical_algop_expr * sub_expr_kind * int) option ->
    logical_algop_expr ->
    logical_algop_expr

val removal_wrapper:
    (logical_compile_context ->
       logical_algop_expr ->
       logical_algop_expr ->
       logical_algop_expr * bool) -> 
    bool ref ->
    logical_compile_context ->
    logical_algop_expr ->
    (logical_algop_expr * sub_expr_kind * int) option ->
    logical_algop_expr ->
    logical_algop_expr