]> matita.cs.unibo.it Git - helm.git/blob - helm/ocaml/getter/http_getter.mli
getter with in memory tree of URIs
[helm.git] / helm / ocaml / getter / http_getter.mli
1 (*
2  * Copyright (C) 2003-2004:
3  *    Stefano Zacchiroli <zack@cs.unibo.it>
4  *    for the HELM Team http://helm.cs.unibo.it/
5  *
6  *  This file is part of HELM, an Hypertextual, Electronic
7  *  Library of Mathematics, developed at the Computer Science
8  *  Department, University of Bologna, Italy.
9  *
10  *  HELM is free software; you can redistribute it and/or
11  *  modify it under the terms of the GNU General Public License
12  *  as published by the Free Software Foundation; either version 2
13  *  of the License, or (at your option) any later version.
14  *
15  *  HELM is distributed in the hope that it will be useful,
16  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
17  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  *  GNU General Public License for more details.
19  *
20  *  You should have received a copy of the GNU General Public License
21  *  along with HELM; if not, write to the Free Software
22  *  Foundation, Inc., 59 Temple Place - Suite 330, Boston,
23  *  MA  02111-1307, USA.
24  *
25  *  For details, see the HELM World-Wide-Web page,
26  *  http://helm.cs.unibo.it/
27  *)
28
29 open Http_getter_types
30
31   (** {2 Loggers} *)
32
33 type logger_callback = HelmLogger.html_tag -> unit
34
35 val stdout_logger: logger_callback
36
37   (** {2 Getter Web Service interface as API *)
38
39 val help: unit -> string
40
41   (** @raise Http_getter_types.Unresolvable_URI _
42   * @raise Http_getter_types.Key_not_found _ *)
43 val resolve: string -> string (* uri -> url *)
44
45   (** @raise Http_getter_types.Key_already_in _ *)
46 val register: uri:string -> url:string -> unit
47
48   (** does not fail if given uri does not exist *)
49 val unregister: string -> unit
50
51 val update: ?logger:logger_callback -> unit -> unit
52 val getxml  : ?format:encoding -> ?patch_dtd:bool -> string -> string
53 val getxslt : ?patch_dtd:bool -> string -> string
54 val getdtd  : ?patch_dtd:bool -> string -> string
55 val clean_cache: unit -> unit
56 val list_servers: unit -> (int * string) list
57 val add_server: ?logger:logger_callback -> ?position:int -> string -> unit
58 val remove_server: ?logger:logger_callback -> int -> unit
59 val getalluris: unit -> string list
60 val getallrdfuris: [ `Forward | `Backward ] -> string list
61
62   (** @param regexp regular expression (PCRE syntax) over HELM URIs *)
63 val ls: string -> ls_item list
64
65   (** {2 Shorthands} *)
66
67 val getxml'     : UriManager.uri -> string
68 val resolve'    : UriManager.uri -> string
69 val register'   : UriManager.uri -> string -> unit
70 val unregister' : UriManager.uri -> unit
71
72   (** {2 Misc} *)
73
74 val close_maps: unit -> unit
75 val update_from_one_server: ?logger:logger_callback -> string -> unit
76 val has_server: int -> bool (* does a server with a given position exists? *)
77 val init: unit -> unit
78
79   (** cal this at exit() *)
80 val sync_dump_file: unit -> unit