SILENT KILLERPanel

Current Path: > > usr > share > perl5 > URI


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //usr/share/perl5/URI

NameTypeSizeLast ModifiedActions
file Directory - -
urn Directory - -
Escape.pm File 7061 bytes January 09 2018 06:42:55.
Heuristic.pm File 6524 bytes January 09 2018 06:42:55.
IRI.pm File 820 bytes January 09 2018 06:42:55.
QueryParam.pm File 4887 bytes January 09 2018 06:42:55.
Split.pm File 2379 bytes January 09 2018 06:42:55.
URL.pm File 5487 bytes January 09 2018 06:42:55.
WithBase.pm File 3857 bytes January 09 2018 06:42:55.
_foreign.pm File 133 bytes January 09 2018 06:42:55.
_generic.pm File 5848 bytes January 09 2018 06:42:55.
_idna.pm File 2105 bytes January 09 2018 06:42:55.
_ldap.pm File 3275 bytes January 09 2018 06:42:55.
_login.pm File 257 bytes January 09 2018 06:42:55.
_punycode.pm File 5648 bytes January 09 2018 06:42:55.
_query.pm File 2557 bytes January 09 2018 06:42:55.
_segment.pm File 442 bytes January 09 2018 06:42:55.
_server.pm File 3750 bytes January 09 2018 06:42:55.
_userpass.pm File 1060 bytes January 09 2018 06:42:55.
data.pm File 3417 bytes January 09 2018 06:42:55.
file.pm File 9761 bytes January 09 2018 06:42:55.
ftp.pm File 1082 bytes January 09 2018 06:42:55.
gopher.pm File 2454 bytes January 09 2018 06:42:55.
http.pm File 451 bytes January 09 2018 06:42:55.
https.pm File 170 bytes January 09 2018 06:42:55.
ldap.pm File 2950 bytes January 09 2018 06:42:55.
ldapi.pm File 467 bytes January 09 2018 06:42:55.
ldaps.pm File 170 bytes January 09 2018 06:42:55.
mailto.pm File 1302 bytes January 09 2018 06:42:55.
mms.pm File 151 bytes January 09 2018 06:42:55.
news.pm File 1480 bytes January 09 2018 06:42:55.
nntp.pm File 153 bytes January 09 2018 06:42:55.
pop.pm File 1233 bytes January 09 2018 06:42:55.
rlogin.pm File 155 bytes January 09 2018 06:42:55.
rsync.pm File 233 bytes January 09 2018 06:42:55.
rtsp.pm File 151 bytes January 09 2018 06:42:55.
rtspu.pm File 152 bytes January 09 2018 06:42:55.
sftp.pm File 124 bytes January 09 2018 06:42:55.
sip.pm File 1735 bytes January 09 2018 06:42:55.
sips.pm File 169 bytes January 09 2018 06:42:55.
snews.pm File 198 bytes January 09 2018 06:42:55.
ssh.pm File 201 bytes January 09 2018 06:42:55.
telnet.pm File 154 bytes January 09 2018 06:42:55.
tn3270.pm File 154 bytes January 09 2018 06:42:55.
urn.pm File 2201 bytes January 09 2018 06:42:55.

Reading File: //usr/share/perl5/URI/WithBase.pm

package URI::WithBase;

use strict;
use warnings;

use URI;
use Scalar::Util 'blessed';

our $VERSION = "2.20";

use overload '""' => "as_string", fallback => 1;

sub as_string;  # help overload find it

sub new
{
    my($class, $uri, $base) = @_;
    my $ibase = $base;
    if ($base && blessed($base) && $base->isa(__PACKAGE__)) {
	$base = $base->abs;
	$ibase = $base->[0];
    }
    bless [URI->new($uri, $ibase), $base], $class;
}

sub new_abs
{
    my $class = shift;
    my $self = $class->new(@_);
    $self->abs;
}

sub _init
{
    my $class = shift;
    my($str, $scheme) = @_;
    bless [URI->new($str, $scheme), undef], $class;
}

sub eq
{
    my($self, $other) = @_;
    $other = $other->[0] if blessed($other) and $other->isa(__PACKAGE__);
    $self->[0]->eq($other);
}

our $AUTOLOAD;
sub AUTOLOAD
{
    my $self = shift;
    my $method = substr($AUTOLOAD, rindex($AUTOLOAD, '::')+2);
    return if $method eq "DESTROY";
    $self->[0]->$method(@_);
}

sub can {                                  # override UNIVERSAL::can
    my $self = shift;
    $self->SUPER::can(@_) || (
      ref($self)
      ? $self->[0]->can(@_)
      : undef
    )
}

sub base {
    my $self = shift;
    my $base  = $self->[1];

    if (@_) { # set
	my $new_base = shift;
	# ensure absoluteness
	$new_base = $new_base->abs if ref($new_base) && $new_base->isa(__PACKAGE__);
	$self->[1] = $new_base;
    }
    return unless defined wantarray;

    # The base attribute supports 'lazy' conversion from URL strings
    # to URL objects. Strings may be stored but when a string is
    # fetched it will automatically be converted to a URL object.
    # The main benefit is to make it much cheaper to say:
    #   URI::WithBase->new($random_url_string, 'http:')
    if (defined($base) && !ref($base)) {
	$base = ref($self)->new($base);
	$self->[1] = $base unless @_;
    }
    $base;
}

sub clone
{
    my $self = shift;
    my $base = $self->[1];
    $base = $base->clone if ref($base);
    bless [$self->[0]->clone, $base], ref($self);
}

sub abs
{
    my $self = shift;
    my $base = shift || $self->base || return $self->clone;
    $base = $base->as_string if ref($base);
    bless [$self->[0]->abs($base, @_), $base], ref($self);
}

sub rel
{
    my $self = shift;
    my $base = shift || $self->base || return $self->clone;
    $base = $base->as_string if ref($base);
    bless [$self->[0]->rel($base, @_), $base], ref($self);
}

1;

__END__

=head1 NAME

URI::WithBase - URIs which remember their base

=head1 SYNOPSIS

 $u1 = URI::WithBase->new($str, $base);
 $u2 = $u1->abs;

 $base = $u1->base;
 $u1->base( $new_base )

=head1 DESCRIPTION

This module provides the C<URI::WithBase> class.  Objects of this class
are like C<URI> objects, but can keep their base too.  The base
represents the context where this URI was found and can be used to
absolutize or relativize the URI.  All the methods described in L<URI>
are supported for C<URI::WithBase> objects.

The methods provided in addition to or modified from those of C<URI> are:

=over 4

=item $uri = URI::WithBase->new($str, [$base])

The constructor takes an optional base URI as the second argument.
If provided, this argument initializes the base attribute.

=item $uri->base( [$new_base] )

Can be used to get or set the value of the base attribute.
The return value, which is the old value, is a URI object or C<undef>.

=item $uri->abs( [$base_uri] )

The $base_uri argument is now made optional as the object carries its
base with it.  A new object is returned even if $uri is already
absolute (while plain URI objects simply return themselves in
that case).

=item $uri->rel( [$base_uri] )

The $base_uri argument is now made optional as the object carries its
base with it.  A new object is always returned.

=back


=head1 SEE ALSO

L<URI>

=head1 COPYRIGHT

Copyright 1998-2002 Gisle Aas.

=cut

SILENT KILLER Tool