/var/www/hkosl.com/demo_google/application/vendor/sebastian/comparator/src/Factory.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
<?php
/*
 * This file is part of the Comparator package.
 *
 * (c) Sebastian Bergmann <sebastian@phpunit.de>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace SebastianBergmann\Comparator;

/**
 * Factory for comparators which compare values for equality.
 */
class Factory
{
    
/**
     * @var Comparator[]
     */
    
private $comparators = array();

    
/**
     * @var Factory
     */
    
private static $instance;

    
/**
     * Constructs a new factory.
     */
    
public function __construct()
    {
        
$this->register(new TypeComparator);
        
$this->register(new ScalarComparator);
        
$this->register(new NumericComparator);
        
$this->register(new DoubleComparator);
        
$this->register(new ArrayComparator);
        
$this->register(new ResourceComparator);
        
$this->register(new ObjectComparator);
        
$this->register(new ExceptionComparator);
        
$this->register(new SplObjectStorageComparator);
        
$this->register(new DOMNodeComparator);
        
$this->register(new MockObjectComparator);
        
$this->register(new DateTimeComparator);
    }

    
/**
     * @return Factory
     */
    
public static function getInstance()
    {
        if (
self::$instance === null) {
            
self::$instance = new self;
        }

        return 
self::$instance;
    }

    
/**
     * Returns the correct comparator for comparing two values.
     *
     * @param  mixed      $expected The first value to compare
     * @param  mixed      $actual   The second value to compare
     * @return Comparator
     */
    
public function getComparatorFor($expected$actual)
    {
        foreach (
$this->comparators as $comparator) {
            if (
$comparator->accepts($expected$actual)) {
                return 
$comparator;
            }
        }
    }

    
/**
     * Registers a new comparator.
     *
     * This comparator will be returned by getInstance() if its accept() method
     * returns TRUE for the compared values. It has higher priority than the
     * existing comparators, meaning that its accept() method will be tested
     * before those of the other comparators.
     *
     * @param Comparator $comparator The registered comparator
     */
    
public function register(Comparator $comparator)
    {
        
array_unshift($this->comparators$comparator);

        
$comparator->setFactory($this);
    }

    
/**
     * Unregisters a comparator.
     *
     * This comparator will no longer be returned by getInstance().
     *
     * @param Comparator $comparator The unregistered comparator
     */
    
public function unregister(Comparator $comparator)
    {
        foreach (
$this->comparators as $key => $_comparator) {
            if (
$comparator === $_comparator) {
                unset(
$this->comparators[$key]);
            }
        }
    }
}