]> matita.cs.unibo.it Git - helm.git/blob - helm/DEVEL/ocaml-http/examples/webfsd.ml
ocaml 3.09 transition
[helm.git] / helm / DEVEL / ocaml-http / examples / webfsd.ml
1
2 (*
3   OCaml HTTP - do it yourself (fully OCaml) HTTP daemon
4
5   Copyright (C) <2002-2004> Stefano Zacchiroli <zack@cs.unibo.it>
6
7   This program is free software; you can redistribute it and/or modify
8   it under the terms of the GNU General Public License as published by
9   the Free Software Foundation; either version 2 of the License, or
10   (at your option) any later version.
11
12   This program 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.
16
17   You should have received a copy of the GNU General Public License
18   along with this program; if not, write to the Free Software
19   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
20 *)
21
22 open Http_types
23
24 let def_port = 80
25 let def_addr = "0.0.0.0"
26 let def_root = Sys.getcwd ()
27
28 let port = ref def_port
29 let addr = ref def_addr
30 let root = ref def_root
31 let argspec =
32   [ "-p", Arg.Int (fun p -> port := p),
33       "TCP port on which listen, default: " ^ string_of_int !port;
34     "-a", Arg.String (fun a -> addr := a),
35       "IP address on which listen, default: " ^ !addr;
36     "-r", Arg.String (fun r -> root := r),
37       "DocumentRoot, default: current working directory";
38   ]
39
40 let _ =
41   Arg.parse argspec (fun _ -> ()) "";
42   let spec =
43     { Http_daemon.default_spec with
44         address = !addr;
45         port = !port;
46         root_dir = Some !root
47     }
48   in
49   Http_daemon.Trivial.main spec
50