]> matita.cs.unibo.it Git - helm.git/blob - helm/DEVEL/ocaml-http/examples/oo_daemon.ml
The order IS significative. Changing the order (in one of the last commits)
[helm.git] / helm / DEVEL / ocaml-http / examples / oo_daemon.ml
1
2 (*
3   OCaml HTTP - do it yourself (fully OCaml) HTTP daemon
4
5   Copyright (C) <2002> 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_daemon;;
23 open Http_response;;
24
25   (* the simple way *)
26 let d = new daemon ~addr:"127.0.0.1" ~port:9999 () in
27 while true do
28   let (req, conn) = d#getRequest in (* wait for valid request *)
29   conn#respond_with (new response ~body:"foo\n" ());
30   conn#close
31 done
32
33 (*
34   (* the hard way *)
35 let d = new daemon ~addr:"127.0.0.1" ~port:9999 () in
36 while true do
37   let conn = d#accept in (* wait for client connection *)
38   (match conn#getRequest with
39   | None -> ()  (* invalid request received *)
40   | Some req -> conn#respond_with (new response ~body:"foo\n" ()));
41   conn#close (* close socket *)
42 done
43 *)
44