X-Git-Url: http://git.indexdata.com/?p=simpleserver-moved-to-github.git;a=blobdiff_plain;f=SimpleServer.pm;h=a29563434a3392389072499d78bcc18ae6be2ddb;hp=540a04bc7fde928d8afccfe0032fb27ce2c302b7;hb=6c62678bc9633a58d3da916ff7d3673cb062b33a;hpb=159d2f7d178c6870b07bb10fc8bcea009ad3e786 diff --git a/SimpleServer.pm b/SimpleServer.pm index 540a04b..a295634 100644 --- a/SimpleServer.pm +++ b/SimpleServer.pm @@ -1,5 +1,5 @@ ## -## Copyright (c) 2000, Index Data. +## Copyright (c) 2000-2004, Index Data. ## ## Permission to use, copy, modify, distribute, and sell this software and ## its documentation, in whole or in part, for any purpose, is hereby granted, @@ -25,53 +25,7 @@ ## ## -## $Log: SimpleServer.pm,v $ -## Revision 1.18 2003-09-09 20:12:38 mike -## Return diagnostics on Init failure -## -## Revision 1.17 2003/09/09 11:40:10 mike -## (Finally!) support implementation-ID -## -## Revision 1.16 2003/01/03 09:01:51 sondberg -## Version 0.07. -## -## Revision 1.15 2002/09/16 14:00:16 sondberg -## Updated Changes and added a few lines of documentation. -## -## Revision 1.14 2002/03/06 11:30:02 mike -## Add RPN structure documentation to SimpleServer.pm's POD. -## Add README to MANIFEST. -## -## Revision 1.13 2002/03/06 11:02:04 mike -## Added simple README file, derived from POD comments in SimpleServer.pm -## Fixed my (Mike Taylor's) email address -## -## Revision 1.12 2002/03/05 20:52:22 sondberg -## Version 0.05 so that we can release the thing at CPAN. -## -## Revision 1.11 2002/03/05 20:49:56 sondberg -## Added a couple of lines of documentation. -## -## Revision 1.10 2002/02/28 11:21:57 mike -## Add RPN structure to search-handler argument hash. -## -## Revision 1.9 2001/08/29 11:48:36 sondberg -## Added routines -## -## Net::Z3950::SimpleServer::ScanSuccess -## Net::Z3950::SimpleServer::ScanPartial -## -## and a bit of documentation. -## -## Revision 1.8 2001/08/29 10:29:51 sondberg -## Added some documentation of scan. -## -## Revision 1.7 2001/08/24 14:00:20 sondberg -## Added support for scan. -## -## Revision 1.6 2001/03/13 14:17:15 sondberg -## Added support for GRS-1. -## +## $Id: SimpleServer.pm,v 1.21 2004-06-04 09:57:00 sondberg Exp $ package Net::Z3950::SimpleServer; @@ -84,12 +38,7 @@ require DynaLoader; require AutoLoader; @ISA = qw(Exporter AutoLoader DynaLoader); -# Items to export into callers namespace by default. Note: do not export -# names by default without a very good reason. Use EXPORT_OK instead. -# Do not simply export all your public functions/methods/constants. -@EXPORT = qw( - -); +@EXPORT = qw( ); $VERSION = '0.08'; bootstrap Net::Z3950::SimpleServer $VERSION; @@ -246,12 +195,12 @@ After the launching of the server, all control is given away from the Perl script to the server. The server calls the registered subroutines to field incoming requests from Z39.50 clients. -A reference to an anonymous hash is passed to each handle. Some of +A reference to an anonymous hash is passed to each handler. Some of the entries of these hashes are to be considered input and others output parameters. -The Perl programmer specifies the event handles for the server by -means of the the SimpleServer object constructor +The Perl programmer specifies the event handlers for the server by +means of the SimpleServer object constructor my $z = new Net::Z3950::SimpleServer( INIT => \&my_init_handler, @@ -261,7 +210,22 @@ means of the the SimpleServer object constructor SCAN => \&my_scan_handler, FETCH => \&my_fetch_handler); -After the custom event handles are declared, the server is launched +If you want your SimpleServer to start a thread (threaded mode) to +handle each incoming Z39.50 request instead of forking a process +(forking mode), you need to register the handlers by symbol rather +than by code reference. Thus, in threaded mode, you will need to +register your handlers this way: + + my $z = new Net::Z3950::SimpleServer( + INIT => "my_package::my_init_handler", + CLOSE => "my_package::my_close_handler", + .... + .... ); + +where my_package is the Perl package in which your handler is +located. + +After the custom event handlers are declared, the server is launched by means of the method $z->launch_server("MyServer.pl", @ARGV); @@ -271,6 +235,9 @@ script (for logging purposes), while the rest of the arguments are documented in the YAZ toolkit manual: The section on application invocation: +In particular, you need to use the -T switch to start your SimpleServer +in threaded mode. + =head2 Init handler The init handler is called whenever a Z39.50 client is attempting