NAME

HTML::Object::XPath::Function - HTML Object XPath Functions

SYNOPSIS

use HTML::Object::XPath::Function;
my $func = HTML::Object::XPath::Function->new || 
    die( HTML::Object::XPath::Function->error, "\n" );

VERSION

v0.1.0

DESCRIPTION

This module implements various XPath functions described below.

CONSTRUCTOR

Provided with a XPath object, a function name and function parameters and this will instantiate a new HTML::Object::Function object and return it.

METHODS

as_string

Returns a string representation of this function object.

as_xml

Returns a xml representation of this function object.

boolean

Provided with a node object and a list of parameters and this will return the first parameter as a boolean object. It will raise an exception if there are more than one arguments provided.

ceiling

Provided with a node object and an optional parameter, and this will return the ceiling of the string value of the node or that of the parameter provided, if any.

It returns its value as a new number object. It will raise an exception if more than one parameter was provided.

concat

Provided with a node object and a list of 2 parameters or more and this will return a new literal object from the concatenation of each parameter string value.

contains

Provided with a node object and a list of exactly 2 parameters and this will return true if the first parameter match the second one as a regular expression, or returns false otherwise.

count

Provided with a node object and a node set and this will return the size of the node set as a number

evaluate

Provided with a node object and this will evaluate the node using each parameter set during object instantiation and add the result for each in a new array.

It will then return the execution of the function name on the node passing it the list of previously collected results.

false

Returns false and it will raise an exception if any arguments was provided.

floor

Provided with a node object and an optional parameter, and this will return the floor of the string value of the node or that of the parameter provided, if any.

It returns its value as a new number object. It will raise an exception if more than one parameter was provided.

id

Provided with a node object and 1 parameter, and this will return a new node set of element object who match the id found in the node provided.

lang

Provided with a node object and 1 parameter, and this will return true if the node lang, if any at all, match the one provide as a parameter, otherwise it returns false.

last

This takes no argument and returns the size, as a number of the nodes in the context set in XPath.

local_name

Provided with a node object and optionally some parameter and this will return the local name of the node, or that of the first parameter provided, if any, as a literal object

name

Provided with a node object and optionally some parameter and this will return the name of the node, or that of the first parameter provided, if any, as a literal object

namespace_uri

This is an unsupported function and it will raise an exception when called.

new_literal

Returns a new literal object passing it whatever arguments was provided.

new_nodeset

Returns a new node set object passing it whatever arguments was provided.

new_number

Returns a new number object passing it whatever arguments was provided.

normalize_space

Provided with a node object and optionally some parameter and this will take the string value of the node, or that of the first parameter, if any at al, and remove any leading or trailing spaces as well as replacing multiple spaces by just one space, and return the new string as a literal object

not

Provided with a node object and one parameter and this will return true if the value of the first parameter is not true, or false otherwise.

number

Provided with a node object and optionally one parameter and this will return the node string value, or that of the parameter provided, if any, as a new number object

position

Returns th context position as a number. It will raise an exception if any parameter was provided.

round

starts_with

Provided with a node object and two parameters and this will return true if the string value of the second parameter is at the beginning of the first parameter, or false otherwise.

string

Provided with a node object and one parameter and this returns the parameter string value as a new literal object

It will raise an exception if more than one parameter was provided.

string_length

Provided with a node object and optionally one parameter and this will return the size, as a number, of the string value of the node or that of the parameter if any was provided.

substring

Provided with a node object and two or three parameters and this returns the substring of of the first parameter as a value, at offset specified by the second parameter, and optionally for a length defined by a third parameter, if any. If no third parameter is provided, then it will be until the end of the string.

It returns the substring as a new literal object. It will raise an exception if less than 2 or more than 3 parameters were provided.

substring_after

Provided with a node object and two parameters and this will return the string that follows the string value of the second parameter in the first one up to its end.

It returns the substring as a new literal object. It will raise an exception if less or more than 2 parameters were provided.

substring_before

Provided with a node object and two parameters and this will return the string that precede the string value of the second parameter in the first one up to its start.

It returns the substring as a new literal object. It will raise an exception if less or more than 2 parameters were provided.

sum

Provided with a node object and a parameters that must be a node set and this will return the cumulative string value of each node as a number.

It returns the resulting total as a new number object|HTML::Object::XPath::Number>. It will raise an exception if the parameter provided is not a HTML::Object::XPath::NodeSet object.

translate

Provided with a node object and three parameters, and this will search in the first parameter for any occurrence of characters found in the second parameter and replace them with their alternative at the exact same position in string in the third parameter.

It returns the substring as a new literal object. It will raise an exception if less or more than 3 parameters were provided.

true

Returns true and it will raise an exception if any arguments was provided.

AUTHOR

Jacques Deguest <jack@deguest.jp>

SEE ALSO

HTML::Object::XPath, HTML::Object::XPath::Boolean, HTML::Object::XPath::Expr, HTML::Object::XPath::Function, HTML::Object::XPath::Literal, HTML::Object::XPath::LocationPath, HTML::Object::XPath::NodeSet, HTML::Object::XPath::Number, HTML::Object::XPath::Root, HTML::Object::XPath::Step, HTML::Object::XPath::Variable

COPYRIGHT & LICENSE

Copyright(c) 2021 DEGUEST Pte. Ltd.

All rights reserved

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.