1
1
Fork 0
mirror of https://code.mensbeam.com/MensBeam/Arsse.git synced 2025-01-23 03:20:33 +00:00
Arsse/lib/Db/SQLite3/Result.php

84 lines
1.8 KiB
PHP
Raw Normal View History

<?php
declare(strict_types=1);
2017-03-27 23:12:12 -05:00
namespace JKingWeb\Arsse\Db\SQLite3;
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;
protected $id = 0;
2017-03-01 19:00:14 -05:00
// actual public methods
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;
}
public function getRow() {
2017-03-01 19:00:14 -05:00
$this->next();
return ($this->valid() ? $this->cur : null);
}
public function getAll(): array {
$out = [];
foreach($this as $row) {
$out [] = $row;
}
return $out;
}
2017-03-01 19:00:14 -05:00
public function changes() {
return $this->rows;
}
public function lastId() {
return $this->id;
}
2017-03-01 19:00:14 -05:00
// constructor/destructor
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;
$this->rows = $changes[0];
$this->id = $changes[1];
2017-02-16 14:29:42 -06:00
}
2017-02-16 14:29:42 -06:00
public function __destruct() {
try{$this->set->finalize();} catch(\Throwable $e) {}
2017-02-16 14:29:42 -06:00
unset($this->set);
}
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);
}
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();
}
}