2012-03-07 18:23:41 +00:00
|
|
|
(* Copyright 2012 Tony Garnock-Jones <tonygarnockjones@gmail.com>. *)
|
|
|
|
|
2012-05-01 21:36:38 +00:00
|
|
|
(* This file is part of Hop. *)
|
2012-03-07 18:23:41 +00:00
|
|
|
|
2012-05-01 21:36:38 +00:00
|
|
|
(* Hop is free software: you can redistribute it and/or modify it *)
|
2012-03-07 18:23:41 +00:00
|
|
|
(* under the terms of the GNU General Public License as published by the *)
|
|
|
|
(* Free Software Foundation, either version 3 of the License, or (at your *)
|
|
|
|
(* option) any later version. *)
|
|
|
|
|
2012-05-01 21:36:38 +00:00
|
|
|
(* Hop is distributed in the hope that it will be useful, but *)
|
2012-03-07 18:23:41 +00:00
|
|
|
(* WITHOUT ANY WARRANTY; without even the implied warranty of *)
|
|
|
|
(* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *)
|
|
|
|
(* General Public License for more details. *)
|
|
|
|
|
|
|
|
(* You should have received a copy of the GNU General Public License *)
|
2012-05-01 21:36:38 +00:00
|
|
|
(* along with Hop. If not, see <http://www.gnu.org/licenses/>. *)
|
2012-03-07 18:23:41 +00:00
|
|
|
|
2012-05-05 22:18:23 +00:00
|
|
|
open Lwt_unix
|
2012-03-04 18:03:38 +00:00
|
|
|
|
|
|
|
let rec accept_loop sock connection_start_fn =
|
2012-05-05 22:18:23 +00:00
|
|
|
lwt (s, peername) = accept sock in
|
|
|
|
setsockopt s Unix.TCP_NODELAY true;
|
2012-03-04 18:03:38 +00:00
|
|
|
ignore (connection_start_fn (s, peername));
|
|
|
|
accept_loop sock connection_start_fn
|
|
|
|
|
2012-04-28 13:41:10 +00:00
|
|
|
let start_net protocol_name port_number connection_start_fn =
|
2012-05-05 22:18:23 +00:00
|
|
|
let sock = socket Unix.PF_INET Unix.SOCK_STREAM 0 in
|
|
|
|
setsockopt sock Unix.SO_REUSEADDR true;
|
|
|
|
bind sock (Unix.ADDR_INET (Unix.inet_addr_any, port_number));
|
2012-03-04 18:03:38 +00:00
|
|
|
listen sock 5;
|
2012-05-01 19:37:39 +00:00
|
|
|
Server_control.milestone (protocol_name ^ " ready");
|
2012-05-05 22:18:23 +00:00
|
|
|
ignore (Log.info "Accepting connections"
|
|
|
|
[Sexp.Str protocol_name; Sexp.Str (string_of_int port_number)]);
|
2012-03-04 18:03:38 +00:00
|
|
|
accept_loop sock connection_start_fn
|