1 (* Copyright (C) 2004-2005, HELM Team.
3 * This file is part of HELM, an Hypertextual, Electronic
4 * Library of Mathematics, developed at the Computer Science
5 * Department, University of Bologna, Italy.
7 * HELM is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
12 * HELM is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with HELM; if not, write to the Free Software
19 * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
22 * For details, see the HELM World-Wide-Web page,
23 * http://helm.cs.unibo.it/
30 inherit Interpretations.g_status
31 method disambiguate_db: db
34 class virtual status :
38 inherit Interpretations.status
39 method set_disambiguate_db: db -> 'self
40 method set_disambiguate_status: #g_status -> 'self
43 (* val eval_with_new_aliases:
44 #status as 'status -> ('status -> 'a) ->
45 ((Stdpp.location * DisambiguateTypes.domain_item) * GrafiteAst.alias_spec) list * 'a
48 val get_interpr : db -> GrafiteAst.alias_spec DisambiguateTypes.InterprEnv.t
52 (Stdpp.location * GrafiteAst.alias_spec) list -> 'status
54 val add_to_disambiguation_univ:
56 (DisambiguateTypes.domain_item * GrafiteAst.alias_spec) list -> 'status
59 #NCic.status -> NUri.uri list ->
60 (DisambiguateTypes.domain_item * GrafiteAst.alias_spec) list
62 (* args: print function, message (may be empty), status *)
63 val dump_aliases: (string -> unit) -> string -> #status -> unit
65 exception BaseUriNotSetYet
67 val disambiguate_nterm :
69 NCic.term option -> NCic.context -> NCic.metasenv -> NCic.substitution ->
70 NotationPt.term Disambiguate.disambiguator_input ->
71 NCic.metasenv * NCic.substitution * 'status * NCic.term
73 val disambiguate_nobj :
74 #status as 'status -> ?baseuri:string ->
75 (NotationPt.term NotationPt.obj) Disambiguate.disambiguator_input ->
79 NotationPt.term Disambiguate.disambiguator_input option *
80 (string * NCic.term) list * NCic.term option
82 val disambiguate_npattern:
83 #NCic.status -> GrafiteAst.npattern Disambiguate.disambiguator_input -> pattern
85 val disambiguate_cic_appl_pattern:
87 NotationPt.argument_pattern list ->
88 NotationPt.cic_appl_pattern -> NotationPt.cic_appl_pattern