silverstripe-fulltextsearch/code/utils/CombinationsArrayIterator.php

85 lines
1.8 KiB
PHP
Raw Normal View History

<?php
2017-04-21 12:27:01 +12:00
namespace SilverStripe\FullTextSearch\Utils;
2017-04-21 12:27:01 +12:00
use Iterator;
2015-11-21 19:19:20 +13:00
class CombinationsArrayIterator implements Iterator
{
protected $arrays;
protected $keys;
protected $numArrays;
2015-11-21 19:19:20 +13:00
protected $isValid = false;
protected $k = 0;
2015-11-21 19:19:20 +13:00
public function __construct($args)
{
$this->arrays = array();
$this->keys = array();
2015-11-21 19:19:20 +13:00
$keys = array_keys($args);
$values = array_values($args);
2015-11-21 19:19:20 +13:00
foreach ($values as $i => $arg) {
if (is_array($arg) && count($arg)) {
$this->arrays[] = $arg;
$this->keys[] = $keys[$i];
}
}
2015-11-21 19:19:20 +13:00
$this->numArrays = count($this->arrays);
$this->rewind();
}
2015-11-21 19:19:20 +13:00
public function rewind()
{
if (!$this->numArrays) {
$this->isValid = false;
} else {
$this->isValid = true;
$this->k = 0;
for ($i = 0; $i < $this->numArrays; $i++) {
reset($this->arrays[$i]);
}
}
}
2015-11-21 19:19:20 +13:00
public function valid()
{
return $this->isValid;
}
2015-11-21 19:19:20 +13:00
public function next()
{
$this->k++;
2015-11-21 19:19:20 +13:00
for ($i = 0; $i < $this->numArrays; $i++) {
if (next($this->arrays[$i]) === false) {
if ($i == $this->numArrays-1) {
$this->isValid = false;
} else {
reset($this->arrays[$i]);
}
} else {
break;
}
}
}
2015-11-21 19:19:20 +13:00
public function current()
{
$res = array();
for ($i = 0; $i < $this->numArrays; $i++) {
$res[$this->keys[$i]] = current($this->arrays[$i]);
}
return $res;
}
2015-11-21 19:19:20 +13:00
public function key()
{
return $this->k;
}
}