1
0
Fork 0

Merge pull request #122 from naderman/add-rule-peformance

addRule peformance improvement
pull/118/merge
Jordi Boggiano 2011-11-21 08:06:41 -08:00
commit 3544b415a3
4 changed files with 46 additions and 7 deletions

View File

@ -19,12 +19,15 @@ use Composer\Package\PackageInterface;
*/ */
class Literal class Literal
{ {
protected $package;
protected $wanted; protected $wanted;
protected $id;
public function __construct(PackageInterface $package, $wanted) public function __construct(PackageInterface $package, $wanted)
{ {
$this->package = $package; $this->package = $package;
$this->wanted = $wanted; $this->wanted = $wanted;
$this->id = ($this->wanted ? '' : '-') . $this->package->getId();
} }
public function isWanted() public function isWanted()
@ -44,7 +47,7 @@ class Literal
public function getId() public function getId()
{ {
return ($this->wanted ? '' : '-') . $this->package->getId(); return $this->id;
} }
public function __toString() public function __toString()
@ -59,6 +62,6 @@ class Literal
public function equals(Literal $b) public function equals(Literal $b)
{ {
return $this->getId() === $b->getId(); return $this->id === $b->id;
} }
} }

View File

@ -45,6 +45,15 @@ class Rule
$this->watch2 = (count($this->literals) > 1) ? $literals[1]->getId() : 0; $this->watch2 = (count($this->literals) > 1) ? $literals[1]->getId() : 0;
$this->type = -1; $this->type = -1;
$this->ruleHash = substr(md5(implode(',', array_map(function ($l) {
return $l->getId();
}, $this->literals))), 0, 5);
}
public function getHash()
{
return $this->ruleHash;
} }
public function setId($id) public function setId($id)
@ -67,12 +76,16 @@ class Rule
*/ */
public function equals(Rule $rule) public function equals(Rule $rule)
{ {
if ($this->ruleHash !== $rule->ruleHash) {
return false;
}
if (count($this->literals) != count($rule->literals)) { if (count($this->literals) != count($rule->literals)) {
return false; return false;
} }
for ($i = 0, $n = count($this->literals); $i < $n; $i++) { for ($i = 0, $n = count($this->literals); $i < $n; $i++) {
if (!$this->literals[$i]->equals($rule->literals[$i])) { if (!$this->literals[$i]->getId() === $rule->literals[$i]->getId()) {
return false; return false;
} }
} }

View File

@ -39,6 +39,8 @@ class RuleSet implements \IteratorAggregate, \Countable
protected $ruleById; protected $ruleById;
protected $nextRuleId; protected $nextRuleId;
protected $rulesByHash;
public function __construct() public function __construct()
{ {
$this->nextRuleId = 0; $this->nextRuleId = 0;
@ -46,6 +48,8 @@ class RuleSet implements \IteratorAggregate, \Countable
foreach ($this->getTypes() as $type) { foreach ($this->getTypes() as $type) {
$this->rules[$type] = array(); $this->rules[$type] = array();
} }
$this->rulesByHash = array();
} }
public function add(Rule $rule, $type) public function add(Rule $rule, $type)
@ -64,6 +68,13 @@ class RuleSet implements \IteratorAggregate, \Countable
$rule->setId($this->nextRuleId); $rule->setId($this->nextRuleId);
$this->nextRuleId++; $this->nextRuleId++;
$hash = $rule->getHash();
if (!isset($this->rulesByHash[$hash])) {
$this->rulesByHash[$hash] = array($rule);
} else {
$this->rulesByHash[$hash][] = $rule;
}
} }
public function count() public function count()
@ -129,6 +140,20 @@ class RuleSet implements \IteratorAggregate, \Countable
return array_keys($types); return array_keys($types);
} }
public function containsEqual($rule)
{
if (isset($this->rulesByHash[$rule->getHash()])) {
$potentialDuplicates = $this->rulesByHash[$rule->getHash()];
foreach ($potentialDuplicates as $potentialDuplicate) {
if ($rule->equals($potentialDuplicate)) {
return true;
}
}
}
return false;
}
public function __toString() public function __toString()
{ {
$string = "\n"; $string = "\n";

View File

@ -229,11 +229,9 @@ class Solver
*/ */
private function addRule($type, Rule $newRule = null) { private function addRule($type, Rule $newRule = null) {
if ($newRule) { if ($newRule) {
foreach ($this->rules->getIterator() as $rule) { if ($this->rules->containsEqual($newRule)) {
if ($rule->equals($newRule)) {
return; return;
} }
}
$this->rules->add($newRule, $type); $this->rules->add($newRule, $type);
} }