+
+open Netcgi1_compat.Netcgi_types;;
+
+(**********************************************************************)
+(* Create the webserver *)
+(**********************************************************************)
+
+
+let start() =
+ let (opt_list, cmdline_cfg) = Netplex_main.args() in
+
+ let use_mt = ref true in
+
+ let opt_list' =
+ [ "-mt", Arg.Set use_mt,
+ " Use multi-threading instead of multi-processing"
+ ] @ opt_list in
+
+ Arg.parse
+ opt_list'
+ (fun s -> raise (Arg.Bad ("Don't know what to do with: " ^ s)))
+ "usage: netplex [options]";
+ let parallelizer =
+ if !use_mt then
+ Netplex_mt.mt() (* multi-threading *)
+ else
+ Netplex_mp.mp() in (* multi-processing *)
+(*
+ let adder =
+ { Nethttpd_services.dyn_handler = (fun _ -> process1);
+ dyn_activation = Nethttpd_services.std_activation `Std_activation_buffered;
+ dyn_uri = None; (* not needed *)
+ dyn_translator = (fun _ -> ""); (* not needed *)
+ dyn_accept_all_conditionals = false;
+ } in
+*)
+ let do_advance =
+ { Nethttpd_services.dyn_handler = (fun _ -> advance);
+ dyn_activation = Nethttpd_services.std_activation `Std_activation_buffered;
+ dyn_uri = None; (* not needed *)
+ dyn_translator = (fun _ -> ""); (* not needed *)
+ dyn_accept_all_conditionals = false;
+ } in
+ let do_retract =
+ { Nethttpd_services.dyn_handler = (fun _ -> retract);
+ dyn_activation = Nethttpd_services.std_activation `Std_activation_buffered;
+ dyn_uri = None; (* not needed *)
+ dyn_translator = (fun _ -> ""); (* not needed *)
+ dyn_accept_all_conditionals = false;
+ } in
+ let goto_bottom =
+ { Nethttpd_services.dyn_handler = (fun _ -> gotoBottom);
+ dyn_activation = Nethttpd_services.std_activation `Std_activation_buffered;
+ dyn_uri = None; (* not needed *)
+ dyn_translator = (fun _ -> ""); (* not needed *)
+ dyn_accept_all_conditionals = false;
+ } in
+ let retrieve =
+ { Nethttpd_services.dyn_handler = (fun _ -> retrieve);
+ dyn_activation = Nethttpd_services.std_activation `Std_activation_buffered;
+ dyn_uri = None; (* not needed *)
+ dyn_translator = (fun _ -> ""); (* not needed *)
+ dyn_accept_all_conditionals = false;
+ } in
+
+ let nethttpd_factory =
+ Nethttpd_plex.nethttpd_factory
+ ~handlers:[ "advance", do_advance
+ ; "retract", do_retract
+ ; "bottom", goto_bottom
+ ; "open", retrieve ]
+ () in