HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux wordpress-ubuntu-s-2vcpu-4gb-fra1-01 5.4.0-169-generic #187-Ubuntu SMP Thu Nov 23 14:52:28 UTC 2023 x86_64
User: root (0)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/hcv/wp-content/plugins/timber-library/lib/PathHelper.php
<?php

namespace Timber;

/**
 * Class PathHelper
 *
 * Useful methods for working with file paths.
 *
 * @api
 * @since 1.11.1
 */
class PathHelper {
	/**
	 * Returns information about a file path.
	 *
	 * Unicode-friendly version of PHP’s pathinfo() function.
	 *
	 * @link  https://www.php.net/manual/en/function.pathinfo.php
	 *
	 * @api
	 * @since 1.11.1
	 *
	 * @param string $path    The path to be parsed.
	 * @param int    $options The path part to extract. One of `PATHINFO_DIRNAME`,
	 *                        `PATHINFO_BASENAME`, `PATHINFO_EXTENSION` or `PATHINFO_FILENAME`. If
	 *                        not specified, returns all available elements.
	 *
	 * @return mixed
	 */
	public static function pathinfo( $path, $options = PATHINFO_DIRNAME |
		PATHINFO_BASENAME | PATHINFO_EXTENSION | PATHINFO_FILENAME
	) {
		$info = pathinfo(
			str_replace(
				array( '%2F', '%5C' ),
				array( '/', '\\' ),
				rawurlencode( $path )
			),
			$options
		);

		if ( is_array( $info ) ) {
			// Decode all keys in the array.
			return array_map( 'rawurldecode', $info );
		} else {
			// Decode the string when requesting a single path component.
			return rawurldecode( $info );
		}
	}

	/**
	 * Returns trailing name component of path.
	 *
	 * Unicode-friendly version of the PHP basename() function.
	 *
	 * @link  https://www.php.net/manual/en/function.basename.php
	 *
	 * @api
	 * @since 1.11.1
	 *
	 * @param string $path   The path.
	 * @param string $suffix Optional. If the name component ends in suffix, this part will also be
	 *                       cut off.
	 *
	 * @return string
	 */
	public static function basename( $path, $suffix = '' ) {
		return rawurldecode(
			basename(
				str_replace( array( '%2F', '%5C' ), '/', rawurlencode( $path ) ),
				$suffix
			)
		);
	}
}