123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163 |
- <?php
- /*
- * This file is part of Composer.
- *
- * (c) Nils Adermann <naderman@naderman.de>
- * Jordi Boggiano <j.boggiano@seld.be>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Composer\DependencyResolver;
- /**
- * @author Nils Adermann <naderman@naderman.de>
- */
- class Rule
- {
- protected $disabled;
- protected $literals;
- protected $type;
- public $watch1;
- public $watch2;
- public $next1;
- public $next2;
- public function __construct(array $literals, $reason, $reasonData)
- {
- // sort all packages ascending by id
- usort($literals, array($this, 'compareLiteralsById'));
- $this->literals = $literals;
- $this->reason = $reason;
- $this->reasonData = $reasonData;
- $this->disabled = false;
- $this->watch1 = (count($this->literals) > 0) ? $literals[0]->getId() : 0;
- $this->watch2 = (count($this->literals) > 1) ? $literals[1]->getId() : 0;
- $this->type = -1;
- }
- /**
- * Checks if this rule is equal to another one
- *
- * Ignores whether either of the rules is disabled.
- *
- * @param Rule $rule The rule to check against
- * @return bool Whether the rules are equal
- */
- public function equals(Rule $rule)
- {
- if (count($this->literals) != count($rule->literals)) {
- return false;
- }
- for ($i = 0, $n = count($this->literals); $i < $n; $i++) {
- if (!$this->literals[$i]->equals($rule->literals[$i])) {
- return false;
- }
- }
- return true;
- }
- public function setType($type)
- {
- $this->type = $type;
- }
- public function getType()
- {
- return $this->type;
- }
- public function disable()
- {
- $this->disabled = true;
- }
- public function enable()
- {
- $this->disabled = false;
- }
- public function isDisabled()
- {
- return $this->disabled;
- }
- public function isEnabled()
- {
- return !$this->disabled;
- }
- public function getLiterals()
- {
- return $this->literals;
- }
- public function isAssertion()
- {
- return 1 === count($this->literals);
- }
- public function getNext(Literal $literal)
- {
- if ($this->watch1->equals($literal)) {
- return $this->next1;
- } else {
- return $this->next2;
- }
- }
- public function getOtherWatch(Literal $literal)
- {
- if ($this->watch1->equals($literal)) {
- return $this->watch2;
- } else {
- return $this->watch1;
- }
- }
- /**
- * Formats a rule as a string of the format (Literal1|Literal2|...)
- *
- * @return string
- */
- public function __toString()
- {
- $result = '(';
- foreach ($this->literals as $i => $literal) {
- if ($i != 0) {
- $result .= '|';
- }
- $result .= $literal;
- }
- $result .= ')';
- return $result;
- }
- /**
- * Comparison function for sorting literals by their id
- *
- * @param Literal $a
- * @param Literal $b
- * @return int 0 if the literals are equal, 1 if b is larger than a, -1 else
- */
- private function compareLiteralsById(Literal $a, Literal $b)
- {
- if ($a->getId() === $b->getId()) {
- return 0;
- }
- return $a->getId() < $b->getId() ? -1 : 1;
- }
- }
|