2016-10-05 22:08:43 -04:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
2017-03-27 23:12:12 -05:00
|
|
|
namespace JKingWeb\Arsse\Db\SQLite3;
|
2016-10-05 22:08:43 -04:00
|
|
|
|
2017-03-27 23:12:12 -05:00
|
|
|
class Result implements \JKingWeb\Arsse\Db\Result {
|
2017-02-16 14:29:42 -06:00
|
|
|
protected $st;
|
|
|
|
protected $set;
|
|
|
|
protected $pos = 0;
|
|
|
|
protected $cur = null;
|
|
|
|
protected $rows = 0;
|
2017-03-09 14:48:42 -05:00
|
|
|
protected $id = 0;
|
2016-10-05 22:08:43 -04:00
|
|
|
|
2017-03-01 19:00:14 -05:00
|
|
|
// actual public methods
|
|
|
|
|
2017-03-06 16:34:38 -05:00
|
|
|
public function getValue() {
|
2017-03-01 19:00:14 -05:00
|
|
|
$this->next();
|
|
|
|
if($this->valid()) {
|
|
|
|
$keys = array_keys($this->cur);
|
|
|
|
return $this->cur[array_shift($keys)];
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2017-03-09 15:01:18 -05:00
|
|
|
public function getRow() {
|
2017-03-01 19:00:14 -05:00
|
|
|
$this->next();
|
|
|
|
return ($this->valid() ? $this->cur : null);
|
|
|
|
}
|
|
|
|
|
2017-03-31 17:42:28 -04:00
|
|
|
public function getAll(): array {
|
2017-03-06 16:34:38 -05:00
|
|
|
$out = [];
|
|
|
|
foreach($this as $row) {
|
|
|
|
$out [] = $row;
|
|
|
|
}
|
|
|
|
return $out;
|
|
|
|
}
|
|
|
|
|
2017-03-01 19:00:14 -05:00
|
|
|
public function changes() {
|
|
|
|
return $this->rows;
|
|
|
|
}
|
|
|
|
|
2017-03-09 14:48:42 -05:00
|
|
|
public function lastId() {
|
|
|
|
return $this->id;
|
|
|
|
}
|
|
|
|
|
2017-03-01 19:00:14 -05:00
|
|
|
// constructor/destructor
|
|
|
|
|
2017-03-09 14:48:42 -05:00
|
|
|
public function __construct(\SQLite3Result $result, array $changes = [0,0], Statement $statement = null) {
|
2017-02-16 14:29:42 -06:00
|
|
|
$this->st = $statement; //keeps the statement from being destroyed, invalidating the result set
|
|
|
|
$this->set = $result;
|
2017-03-09 14:48:42 -05:00
|
|
|
$this->rows = $changes[0];
|
|
|
|
$this->id = $changes[1];
|
2017-02-16 14:29:42 -06:00
|
|
|
}
|
2016-10-05 22:08:43 -04:00
|
|
|
|
2017-02-16 14:29:42 -06:00
|
|
|
public function __destruct() {
|
2017-05-04 14:42:40 -04:00
|
|
|
try{$this->set->finalize();} catch(\Throwable $e) {}
|
2017-02-16 14:29:42 -06:00
|
|
|
unset($this->set);
|
|
|
|
}
|
2016-10-05 22:08:43 -04:00
|
|
|
|
2017-03-01 19:00:14 -05:00
|
|
|
// PHP iterator methods
|
|
|
|
|
2017-02-16 14:29:42 -06:00
|
|
|
public function valid() {
|
|
|
|
$this->cur = $this->set->fetchArray(\SQLITE3_ASSOC);
|
|
|
|
return ($this->cur !== false);
|
|
|
|
}
|
2016-10-05 22:08:43 -04:00
|
|
|
|
2017-02-16 14:29:42 -06:00
|
|
|
public function next() {
|
|
|
|
$this->cur = null;
|
|
|
|
$this->pos += 1;
|
|
|
|
}
|
2016-10-17 16:49:39 -04:00
|
|
|
|
2017-02-16 14:29:42 -06:00
|
|
|
public function current() {
|
|
|
|
return $this->cur;
|
|
|
|
}
|
2016-10-17 16:49:39 -04:00
|
|
|
|
2017-02-16 14:29:42 -06:00
|
|
|
public function key() {
|
|
|
|
return $this->pos;
|
|
|
|
}
|
2016-10-17 16:49:39 -04:00
|
|
|
|
2017-02-16 14:29:42 -06:00
|
|
|
public function rewind() {
|
|
|
|
$this->pos = 0;
|
|
|
|
$this->cur = null;
|
|
|
|
$this->set->reset();
|
|
|
|
}
|
2016-10-05 22:08:43 -04:00
|
|
|
}
|