Linux premium71.web-hosting.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
LiteSpeed
Server IP : 198.187.29.8 & Your IP : 3.15.182.56
Domains :
Cant Read [ /etc/named.conf ]
User : cleahvkv
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
ruby27 /
share /
ruby /
rexml /
Delete
Unzip
Name
Size
Permission
Date
Action
dtd
[ DIR ]
drwxr-xr-x
2024-03-03 22:47
formatters
[ DIR ]
drwxr-xr-x
2024-03-03 22:47
light
[ DIR ]
drwxr-xr-x
2024-03-03 22:47
parsers
[ DIR ]
drwxr-xr-x
2024-03-03 22:47
validation
[ DIR ]
drwxr-xr-x
2024-03-03 22:47
attlistdecl.rb
1.92
KB
-rw-r--r--
2023-03-30 12:34
attribute.rb
5.97
KB
-rw-r--r--
2023-03-30 12:34
cdata.rb
1.59
KB
-rw-r--r--
2023-03-30 12:34
child.rb
2.66
KB
-rw-r--r--
2023-03-30 12:34
comment.rb
2.12
KB
-rw-r--r--
2023-03-30 12:34
doctype.rb
7.97
KB
-rw-r--r--
2023-03-30 12:34
document.rb
9.55
KB
-rw-r--r--
2023-03-30 12:34
element.rb
44.53
KB
-rw-r--r--
2023-03-30 12:34
encoding.rb
1.16
KB
-rw-r--r--
2023-03-30 12:34
entity.rb
5.4
KB
-rw-r--r--
2023-03-30 12:34
functions.rb
12.27
KB
-rw-r--r--
2023-03-30 12:34
instruction.rb
2.14
KB
-rw-r--r--
2023-03-30 12:34
namespace.rb
1.4
KB
-rw-r--r--
2023-03-30 12:34
node.rb
2.18
KB
-rw-r--r--
2023-03-30 12:34
output.rb
553
B
-rw-r--r--
2023-03-30 12:34
parent.rb
4.27
KB
-rw-r--r--
2023-03-30 12:34
parseexception.rb
1.25
KB
-rw-r--r--
2023-03-30 12:34
quickpath.rb
9.12
KB
-rw-r--r--
2023-03-30 12:34
rexml.rb
1.29
KB
-rw-r--r--
2023-03-30 12:34
sax2listener.rb
3.61
KB
-rw-r--r--
2023-03-30 12:34
security.rb
824
B
-rw-r--r--
2023-03-30 12:34
source.rb
7.72
KB
-rw-r--r--
2023-03-30 12:34
streamlistener.rb
3.84
KB
-rw-r--r--
2023-03-30 12:34
text.rb
13.88
KB
-rw-r--r--
2023-03-30 12:34
undefinednamespaceexception.rb
244
B
-rw-r--r--
2023-03-30 12:34
xmldecl.rb
2.95
KB
-rw-r--r--
2023-03-30 12:34
xmltokens.rb
2.32
KB
-rw-r--r--
2023-03-30 12:34
xpath.rb
3.42
KB
-rw-r--r--
2023-03-30 12:34
xpath_parser.rb
29.63
KB
-rw-r--r--
2023-03-30 12:34
Save
Rename
# frozen_string_literal: false require_relative 'functions' require_relative 'xpath_parser' module REXML # Wrapper class. Use this class to access the XPath functions. class XPath include Functions # A base Hash object, supposing to be used when initializing a # default empty namespaces set, but is currently unused. # TODO: either set the namespaces=EMPTY_HASH, or deprecate this. EMPTY_HASH = {} # Finds and returns the first node that matches the supplied xpath. # element:: # The context element # path:: # The xpath to search for. If not supplied or nil, returns the first # node matching '*'. # namespaces:: # If supplied, a Hash which defines a namespace mapping. # variables:: # If supplied, a Hash which maps $variables in the query # to values. This can be used to avoid XPath injection attacks # or to automatically handle escaping string values. # # XPath.first( node ) # XPath.first( doc, "//b"} ) # XPath.first( node, "a/x:b", { "x"=>"http://doofus" } ) # XPath.first( node, '/book/publisher/text()=$publisher', {}, {"publisher"=>"O'Reilly"}) def XPath::first(element, path=nil, namespaces=nil, variables={}, options={}) raise "The namespaces argument, if supplied, must be a hash object." unless namespaces.nil? or namespaces.kind_of?(Hash) raise "The variables argument, if supplied, must be a hash object." unless variables.kind_of?(Hash) parser = XPathParser.new(**options) parser.namespaces = namespaces parser.variables = variables path = "*" unless path element = [element] unless element.kind_of? Array parser.parse(path, element).flatten[0] end # Iterates over nodes that match the given path, calling the supplied # block with the match. # element:: # The context element # path:: # The xpath to search for. If not supplied or nil, defaults to '*' # namespaces:: # If supplied, a Hash which defines a namespace mapping # variables:: # If supplied, a Hash which maps $variables in the query # to values. This can be used to avoid XPath injection attacks # or to automatically handle escaping string values. # # XPath.each( node ) { |el| ... } # XPath.each( node, '/*[@attr='v']' ) { |el| ... } # XPath.each( node, 'ancestor::x' ) { |el| ... } # XPath.each( node, '/book/publisher/text()=$publisher', {}, {"publisher"=>"O'Reilly"}) \ # {|el| ... } def XPath::each(element, path=nil, namespaces=nil, variables={}, options={}, &block) raise "The namespaces argument, if supplied, must be a hash object." unless namespaces.nil? or namespaces.kind_of?(Hash) raise "The variables argument, if supplied, must be a hash object." unless variables.kind_of?(Hash) parser = XPathParser.new(**options) parser.namespaces = namespaces parser.variables = variables path = "*" unless path element = [element] unless element.kind_of? Array parser.parse(path, element).each( &block ) end # Returns an array of nodes matching a given XPath. def XPath::match(element, path=nil, namespaces=nil, variables={}, options={}) parser = XPathParser.new(**options) parser.namespaces = namespaces parser.variables = variables path = "*" unless path element = [element] unless element.kind_of? Array parser.parse(path,element) end end end