2009-11-21 04:35:26 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* base include file for SimpleTest
|
|
|
|
* @package SimpleTest
|
|
|
|
* @version $Id: compatibility.php 1723 2008-04-08 00:34:10Z lastcraft $
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Static methods for compatibility between different
|
|
|
|
* PHP versions.
|
|
|
|
* @package SimpleTest
|
|
|
|
*/
|
|
|
|
class SimpleTestCompatibility {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a copy whether in PHP5 or PHP4.
|
|
|
|
* @param object $object Thing to copy.
|
|
|
|
* @return object A copy.
|
|
|
|
* @access public
|
|
|
|
* @static
|
|
|
|
*/
|
2012-04-12 12:06:47 +12:00
|
|
|
static function copy($object) {
|
2022-04-14 13:12:59 +12:00
|
|
|
if (version_compare(phpversion() ?? '', '5') >= 0) {
|
2009-11-21 04:35:26 +00:00
|
|
|
eval('$copy = clone $object;');
|
|
|
|
return $copy;
|
|
|
|
}
|
|
|
|
return $object;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Identity test. Drops back to equality + types for PHP5
|
|
|
|
* objects as the === operator counts as the
|
|
|
|
* stronger reference constraint.
|
|
|
|
* @param mixed $first Test subject.
|
|
|
|
* @param mixed $second Comparison object.
|
|
|
|
* @return boolean True if identical.
|
|
|
|
* @access public
|
|
|
|
* @static
|
|
|
|
*/
|
|
|
|
function isIdentical($first, $second) {
|
2022-04-14 13:12:59 +12:00
|
|
|
if (version_compare(phpversion() ?? '', '5') >= 0) {
|
2009-11-21 04:35:26 +00:00
|
|
|
return SimpleTestCompatibility::_isIdenticalType($first, $second);
|
|
|
|
}
|
|
|
|
if ($first != $second) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return ($first === $second);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Recursive type test.
|
|
|
|
* @param mixed $first Test subject.
|
|
|
|
* @param mixed $second Comparison object.
|
|
|
|
* @return boolean True if same type.
|
|
|
|
* @access private
|
|
|
|
* @static
|
|
|
|
*/
|
|
|
|
function _isIdenticalType($first, $second) {
|
|
|
|
if (gettype($first) != gettype($second)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (is_object($first) && is_object($second)) {
|
|
|
|
if (get_class($first) != get_class($second)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return SimpleTestCompatibility::_isArrayOfIdenticalTypes(
|
|
|
|
get_object_vars($first),
|
|
|
|
get_object_vars($second));
|
|
|
|
}
|
|
|
|
if (is_array($first) && is_array($second)) {
|
|
|
|
return SimpleTestCompatibility::_isArrayOfIdenticalTypes($first, $second);
|
|
|
|
}
|
|
|
|
if ($first !== $second) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Recursive type test for each element of an array.
|
|
|
|
* @param mixed $first Test subject.
|
|
|
|
* @param mixed $second Comparison object.
|
|
|
|
* @return boolean True if identical.
|
|
|
|
* @access private
|
|
|
|
* @static
|
|
|
|
*/
|
|
|
|
function _isArrayOfIdenticalTypes($first, $second) {
|
2022-04-14 13:12:59 +12:00
|
|
|
if (array_keys($first ?? []) != array_keys($second ?? [])) {
|
2009-11-21 04:35:26 +00:00
|
|
|
return false;
|
|
|
|
}
|
2022-04-14 13:12:59 +12:00
|
|
|
foreach (array_keys($first ?? []) as $key) {
|
2009-11-21 04:35:26 +00:00
|
|
|
$is_identical = SimpleTestCompatibility::_isIdenticalType(
|
|
|
|
$first[$key],
|
|
|
|
$second[$key]);
|
|
|
|
if (! $is_identical) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test for two variables being aliases.
|
|
|
|
* @param mixed $first Test subject.
|
|
|
|
* @param mixed $second Comparison object.
|
|
|
|
* @return boolean True if same.
|
|
|
|
* @access public
|
|
|
|
* @static
|
|
|
|
*/
|
|
|
|
function isReference(&$first, &$second) {
|
2022-04-14 13:12:59 +12:00
|
|
|
if (version_compare(phpversion() ?? '', '5', '>=') && is_object($first)) {
|
2009-11-21 04:35:26 +00:00
|
|
|
return ($first === $second);
|
|
|
|
}
|
|
|
|
if (is_object($first) && is_object($second)) {
|
|
|
|
$id = uniqid("test");
|
|
|
|
$first->$id = true;
|
|
|
|
$is_ref = isset($second->$id);
|
|
|
|
unset($first->$id);
|
|
|
|
return $is_ref;
|
|
|
|
}
|
|
|
|
$temp = $first;
|
|
|
|
$first = uniqid("test");
|
|
|
|
$is_ref = ($first === $second);
|
|
|
|
$first = $temp;
|
|
|
|
return $is_ref;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test to see if an object is a member of a
|
|
|
|
* class hiearchy.
|
|
|
|
* @param object $object Object to test.
|
|
|
|
* @param string $class Root name of hiearchy.
|
|
|
|
* @return boolean True if class in hiearchy.
|
|
|
|
* @access public
|
|
|
|
* @static
|
|
|
|
*/
|
|
|
|
function isA($object, $class) {
|
2022-04-14 13:12:59 +12:00
|
|
|
if (version_compare(phpversion() ?? '', '5') >= 0) {
|
|
|
|
if (! class_exists($class ?? '', false)) {
|
2009-11-21 04:35:26 +00:00
|
|
|
if (function_exists('interface_exists')) {
|
2022-04-14 13:12:59 +12:00
|
|
|
if (! interface_exists($class ?? '', false)) {
|
2009-11-21 04:35:26 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
eval("\$is_a = \$object instanceof $class;");
|
|
|
|
return $is_a;
|
|
|
|
}
|
|
|
|
if (function_exists('is_a')) {
|
2022-04-14 13:12:59 +12:00
|
|
|
return is_a($object, $class ?? '');
|
2009-11-21 04:35:26 +00:00
|
|
|
}
|
2022-04-14 13:12:59 +12:00
|
|
|
return ((strtolower($class ?? '') == get_class($object))
|
|
|
|
or (is_subclass_of($object, $class ?? '')));
|
2009-11-21 04:35:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a socket timeout for each chunk.
|
|
|
|
* @param resource $handle Socket handle.
|
|
|
|
* @param integer $timeout Limit in seconds.
|
|
|
|
* @access public
|
|
|
|
* @static
|
|
|
|
*/
|
|
|
|
function setTimeout($handle, $timeout) {
|
|
|
|
if (function_exists('stream_set_timeout')) {
|
2022-04-14 13:12:59 +12:00
|
|
|
stream_set_timeout($handle, $timeout ?? 0, 0);
|
2009-11-21 04:35:26 +00:00
|
|
|
} elseif (function_exists('socket_set_timeout')) {
|
2022-04-14 13:12:59 +12:00
|
|
|
socket_set_timeout($handle, $timeout ?? 0, 0);
|
2009-11-21 04:35:26 +00:00
|
|
|
} elseif (function_exists('set_socket_timeout')) {
|
|
|
|
set_socket_timeout($handle, $timeout, 0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-04-12 12:06:47 +12:00
|
|
|
?>
|