|
Server : LiteSpeed System : Linux server51.dnsbootclub.com 4.18.0-553.62.1.lve.el8.x86_64 #1 SMP Mon Jul 21 17:50:35 UTC 2025 x86_64 User : nandedex ( 1060) PHP Version : 8.1.33 Disable Function : NONE Directory : /home/nandedex/www/wp-content/plugins/better-amp/includes/functions/ |
<?php
if ( ! function_exists( 'better_amp_remove_query_string' ) ) {
/**
* Remove anything after question mark
*
* Example: betterstudio.com/?publisher=great
* becomes: betterstudio.com/
*
* @param string $string
*
* @since 1.0.0
*
* @return string
*/
function better_amp_remove_query_string( $string ) {
if ( preg_match( '/([^\?]+)\?/', $string, $matches ) ) {
return $matches[1];
}
return $string;
}
}
if ( ! function_exists( 'better_amp_filter_attributes' ) ) {
/**
* Filter AMP element attributes
*
* @param array $attributes key-value paired attributes list
* @param array $valid_attributes valid attributes key
* @param string $tag_name optional. amp tag-name
*
* @since 1.0.0
*
* @return array filtered attributes
*/
function better_amp_filter_attributes( $attributes, $valid_attributes, $tag_name = '' ) {
$attributes = wp_array_slice_assoc( $attributes, $valid_attributes );
return apply_filters( 'better-amp/htmldom/filter-attributes', $attributes, $tag_name, $valid_attributes );
}
}
if ( ! function_exists( 'bf_remove_class_filter' ) ) {
/**
* TODO remove this filter after adding BF to BetterAMP
*
* Remove Class Filter Without Access to Class Object
*
* In order to use the core WordPress remove_filter() on a filter added with the callback
* to a class, you either have to have access to that class object, or it has to be a call
* to a static method. This method allows you to remove filters with a callback to a class
* you don't have access to.
*
* Works with WordPress 1.2+ (4.7+ support added 9-19-2016)
* Updated 2-27-2017 to use internal WordPress removal for 4.7+ (to prevent PHP warnings output)
*
* @param string $tag Filter to remove
* @param string $class_name Class name for the filter's callback
* @param string $method_name Method name for the filter's callback
* @param int $priority Priority of the filter (default 10)
*
*
* Copyright: https://gist.github.com/tripflex/c6518efc1753cf2392559866b4bd1a53
*
* @return bool Whether the function is removed.
*/
function bf_remove_class_filter( $tag, $class_name = '', $method_name = '', $priority = 10 ) {
global $wp_filter;
// Check that filter actually exists first
if ( ! isset( $wp_filter[ $tag ] ) ) {
return false;
}
/**
* If filter config is an object, means we're using WordPress 4.7+ and the config is no longer
* a simple array, rather it is an object that implements the ArrayAccess interface.
*
* To be backwards compatible, we set $callbacks equal to the correct array as a reference (so $wp_filter is updated)
*
* @see https://make.wordpress.org/core/2016/09/08/wp_hook-next-generation-actions-and-filters/
*/
if ( is_object( $wp_filter[ $tag ] ) && isset( $wp_filter[ $tag ]->callbacks ) ) {
// Create $fob object from filter tag, to use below
$fob = $wp_filter[ $tag ];
$callbacks = &$wp_filter[ $tag ]->callbacks;
} else {
$callbacks = &$wp_filter[ $tag ];
}
// Exit if there aren't any callbacks for specified priority
if ( ! isset( $callbacks[ $priority ] ) || empty( $callbacks[ $priority ] ) ) {
return false;
}
// Loop through each filter for the specified priority, looking for our class & method
foreach ( (array) $callbacks[ $priority ] as $filter_id => $filter ) {
// Filter should always be an array - array( $this, 'method' ), if not goto next
if ( ! isset( $filter['function'] ) || ! is_array( $filter['function'] ) ) {
continue;
}
// If first value in array is not an object, it can't be a class
if ( ! is_object( $filter['function'][0] ) ) {
continue;
}
// Method doesn't match the one we're looking for, goto next
if ( $filter['function'][1] !== $method_name ) {
continue;
}
// Method matched, now let's check the Class
if ( get_class( $filter['function'][0] ) === $class_name ) {
// WordPress 4.7+ use core remove_filter() since we found the class object
if ( isset( $fob ) ) {
// Handles removing filter, reseting callback priority keys mid-iteration, etc.
$fob->remove_filter( $tag, $filter['function'], $priority );
} else {
// Use legacy removal process (pre 4.7)
unset( $callbacks[ $priority ][ $filter_id ] );
// and if it was the only filter in that priority, unset that priority
if ( empty( $callbacks[ $priority ] ) ) {
unset( $callbacks[ $priority ] );
}
// and if the only filter for that tag, set the tag to an empty array
if ( empty( $callbacks ) ) {
$callbacks = array();
}
// Remove this filter from merged_filters, which specifies if filters have been sorted
unset( $GLOBALS['merged_filters'][ $tag ] );
}
return true;
}
}
return false;
} // bf_remove_class_filter
}
if ( ! function_exists( 'bf_remove_class_action' ) ) {
/**
* TODO remove this filter after adding BF to BetterAMP
*
* Remove Class Action Without Access to Class Object
*
* In order to use the core WordPress remove_action() on an action added with the callback
* to a class, you either have to have access to that class object, or it has to be a call
* to a static method. This method allows you to remove actions with a callback to a class
* you don't have access to.
*
* Works with WordPress 1.2+ (4.7+ support added 9-19-2016)
*
* @param string $tag Action to remove
* @param string $class_name Class name for the action's callback
* @param string $method_name Method name for the action's callback
* @param int $priority Priority of the action (default 10)
*
* Copyright: https://gist.github.com/tripflex/c6518efc1753cf2392559866b4bd1a53
*
* @return bool Whether the function is removed.
*/
function bf_remove_class_action( $tag, $class_name = '', $method_name = '', $priority = 10 ) {
return bf_remove_class_filter( $tag, $class_name, $method_name, $priority );
}
}
if ( ! function_exists( 'better_amp_transpile_text_to_pattern' ) ) {
/**
* Transpile the given string to valid PCRE pattern.
*
* @param string $text The formatted text.
* @param string $delimiter Pattern delimiter.
*
* @since 1.9.8
* @return string
*/
function better_amp_transpile_text_to_pattern( $text, $delimiter = '#' ) {
$pattern = preg_replace( '/ ( (?<!\\\) \* ) /x', '@@CAPTURE@@', $text );
$pattern = preg_quote( $pattern, $delimiter );
$pattern = str_replace( '@@CAPTURE@@', '[^/]+', $pattern );
return $pattern;
}
}
if ( ! function_exists( 'mb_parse_url' ) ) {
/**
* Parse a URL and return its components.
*
* @param string $url
* @param int $component
*
* @since 1.9.13
* @return array|string|false
*/
function mb_parse_url( $url, $component = - 1 ) {
$encodedUrl = preg_replace_callback( '%[^:/@?&=#]+%usD', function ( $matches ) {
return urlencode( $matches[0] );
}, $url );
$parts = parse_url( $encodedUrl, $component );
if ( $parts === false ) {
throw new \InvalidArgumentException( 'Malformed URL: ' . $url );
}
if ( ! empty( $parts ) && is_array( $parts ) ) {
$parts = array_map( 'urldecode', $parts );
}
return $parts;
}
}