Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
100.00% covered (success)
100.00%
11 / 11
100.00% covered (success)
100.00%
2 / 2
CRAP
100.00% covered (success)
100.00%
1 / 1
SqliteDriver
100.00% covered (success)
100.00%
11 / 11
100.00% covered (success)
100.00%
2 / 2
2
100.00% covered (success)
100.00%
1 / 1
 save
100.00% covered (success)
100.00%
10 / 10
100.00% covered (success)
100.00%
1 / 1
1
 quoteTableName
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
1<?php
2
3// ╔════════════════════════════════════════════════════════════╗
4// ║ MIT Licence (#Expat) - https://opensource.org/licenses/MIT ║
5// ║ Copyright 2026 Frederic Poeydomenge <dyno@phexium.com>     ║
6// ╚════════════════════════════════════════════════════════════╝
7
8declare(strict_types=1);
9
10namespace Phexium\Plugin\SqlDriver\Adapter;
11
12use Override;
13use Phexium\Plugin\SqlDriver\Internal\AbstractSqlDriver;
14use Phexium\Plugin\SqlDriver\Port\SqlDriverInterface;
15
16final class SqliteDriver extends AbstractSqlDriver implements SqlDriverInterface
17{
18    #[Override]
19    public function save(string $table, array $row): void
20    {
21        $columns = array_keys($row);
22        $placeholders = array_map(fn (int|string $col): string => sprintf(':%s', $col), $columns);
23
24        $sql = sprintf(
25            'INSERT OR REPLACE INTO %s (%s) VALUES (%s)',
26            $this->quoteTableName($table),
27            implode(', ', $columns),
28            implode(', ', $placeholders)
29        );
30
31        $stmt = $this->pdo->prepare($sql);
32        $stmt->execute($row);
33    }
34
35    #[Override]
36    protected function quoteTableName(string $tableName): string
37    {
38        return sprintf('`%s`', $tableName);
39    }
40}