⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 io.pm

📁 网页留言本,比一般的留言簿管用
💻 PM
字号:
# ======================================================================## Copyright (C) 2000-2001 Paul Kulchenko (paulclinger@yahoo.com)# SOAP::Lite is free software; you can redistribute it# and/or modify it under the same terms as Perl itself.## $Id: IO.pm,v 1.3 2001/08/11 19:09:57 paulk Exp $## ======================================================================package SOAP::Transport::IO;use strict;use vars qw($VERSION);$VERSION = eval sprintf("%d.%s", q$Name: release-0_52-public $ =~ /-(\d+)_([\d_]+)/);use IO::File;use SOAP::Lite;# ======================================================================package SOAP::Transport::IO::Server;use strict;use Carp ();use vars qw(@ISA);@ISA = qw(SOAP::Server);sub new {  my $self = shift;      unless (ref $self) {    my $class = ref($self) || $self;    $self = $class->SUPER::new(@_);  }  return $self;}sub BEGIN {  no strict 'refs';  my %modes = (in => '<', out => '>');  for my $method (keys %modes) {    my $field = '_' . $method;    *$method = sub {      my $self = shift->new;      return $self->{$field} unless @_;      my $file = shift;      if (defined $file && !ref $file && !defined fileno($file)) {        my $name = $file;        open($file = new IO::File, $modes{$method} . $name) or Carp::croak "$name: $!";      }      $self->{$field} = $file;      return $self;    }  }}sub handle {  my $self = shift->new;  $self->in(*STDIN)->out(*STDOUT) unless defined $self->in;  my $in = $self->in;  my $out = $self->out;  my $result = $self->SUPER::handle(join '', <$in>);  no strict 'refs'; print {$out} $result if defined $out;}# ======================================================================1;__END__=head1 NAMESOAP::Transport::IO - Server side IO support for SOAP::Lite=head1 SYNOPSIS  use SOAP::Transport::IO;  SOAP::Transport::IO::Server    # you may specify as parameters for new():    # -> new( in => 'in_file_name' [, out => 'out_file_name'] )    # -> new( in => IN_HANDLE      [, out => OUT_HANDLE] )    # -> new( in => *IN_HANDLE     [, out => *OUT_HANDLE] )    # -> new( in => \*IN_HANDLE    [, out => \*OUT_HANDLE] )      # -- OR --    # any combinations    # -> new( in => *STDIN, out => 'out_file_name' )    # -> new( in => 'in_file_name', => \*OUT_HANDLE )      # -- OR --    # use in() and/or out() methods    # -> in( *STDIN ) -> out( *STDOUT )      # -- OR --    # use default (when nothing specified):    #      in => *STDIN, out => *STDOUT      # don't forget, if you want to accept parameters from command line    # \*HANDLER will be understood literally, so this syntax won't work     # and server will complain      -> new(@ARGV)      # specify path to My/Examples.pm here    -> dispatch_to('/Your/Path/To/Deployed/Modules', 'Module::Name', 'Module::method')     -> handle  ;=head1 DESCRIPTION=head1 COPYRIGHTCopyright (C) 2000-2001 Paul Kulchenko. All rights reserved.This library is free software; you can redistribute it and/or modifyit under the same terms as Perl itself.=head1 AUTHORPaul Kulchenko (paulclinger@yahoo.com)=cut

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -