# $Id: http.pm,v 2.103 2008/05/23 21:30:10 abigail Exp $
package Regexp::Common::URI::http;
use strict;
local $^W = 1;
use Regexp::Common qw /pattern clean no_defaults/;
use Regexp::Common::URI qw /register_uri/;
use Regexp::Common::URI::RFC2396 qw /$host $port $path_segments $query/;
use vars qw /$VERSION/;
($VERSION) = q $Revision: 2.103 $ =~ /[\d.]+/g;
my $http_uri = "(?k:(?k:http)://(?k:$host)(?::(?k:$port))?" .
"(?k:/(?k:(?k:$path_segments)(?:[?](?k:$query))?))?)";
register_uri HTTP => $http_uri;
pattern name => [qw (URI HTTP), "-scheme=http"],
create => sub {
my $scheme = $_ [1] -> {-scheme};
my $uri = $http_uri;
$uri =~ s/http/$scheme/;
$uri;
}
;
1;
__END__
=pod
=head1 NAME
Regexp::Common::URI::http -- Returns a pattern for HTTP URIs.
=head1 SYNOPSIS
use Regexp::Common qw /URI/;
while (<>) {
/$RE{URI}{HTTP}/ and print "Contains an HTTP URI.\n";
}
=head1 DESCRIPTION
=head2 $RE{URI}{HTTP}{-scheme}
Provides a regex for an HTTP URI as defined by RFC 2396 (generic syntax)
and RFC 2616 (HTTP).
If C<< -scheme => I
>> is specified the pattern I
is used as the scheme.
By default I
is C. C and C are reasonable
alternatives.
The syntax for an HTTP URI is:
"http:" "//" host [ ":" port ] [ "/" path [ "?" query ]]
Under C<{-keep}>, the following are returned:
=over 4
=item $1
The entire URI.
=item $2
The scheme.
=item $3
The host (name or address).
=item $4
The port (if any).
=item $5
The absolute path, including the query and leading slash.
=item $6
The absolute path, including the query, without the leading slash.
=item $7
The absolute path, without the query or leading slash.
=item $8
The query, without the question mark.
=back
=head1 REFERENCES
=over 4
=item B<[RFC 2396]>
Berners-Lee, Tim, Fielding, R., and Masinter, L.: I. August 1998.
=item B<[RFC 2616]>
Fielding, R., Gettys, J., Mogul, J., Frystyk, H., Masinter, L.,
Leach, P. and Berners-Lee, Tim: I.
June 1999.
=back
=head1 HISTORY
$Log: http.pm,v $
Revision 2.103 2008/05/23 21:30:10 abigail
Changed email address
Revision 2.102 2008/05/23 21:28:02 abigail
Changed license
Revision 2.101 2004/06/09 21:42:48 abigail
POD nits
Revision 2.100 2003/02/10 21:06:41 abigail
http URI
=head1 SEE ALSO
L for other supported URIs.
=head1 AUTHOR
Damian Conway (damian@conway.org)
=head1 MAINTAINANCE
This package is maintained by Abigail S<(I)>.
=head1 BUGS AND IRRITATIONS
Bound to be plenty.
=head1 COPYRIGHT
This software is Copyright (c) 2001 - 2008, Damian Conway and Abigail.
This module is free software, and maybe used under any of the following
licenses:
1) The Perl Artistic License. See the file COPYRIGHT.AL.
2) The Perl Artistic License 2.0. See the file COPYRIGHT.AL2.
3) The BSD Licence. See the file COPYRIGHT.BSD.
4) The MIT Licence. See the file COPYRIGHT.MIT.
=cut