summaryrefslogtreecommitdiff
path: root/Userland/Libraries/LibSQL/SQLClient.cpp
blob: 8114ef8075fa4a737b96d97626ba5e9eb5a78fdd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*
 * Copyright (c) 2021, Jan de Visser <jan@de-visser.net>
 *
 * SPDX-License-Identifier: BSD-2-Clause
 */

#include <LibSQL/SQLClient.h>

namespace SQL {

SQLClient::~SQLClient()
{
}

void SQLClient::connected(int connection_id)
{
    if (on_connected)
        on_connected(connection_id);
}

void SQLClient::disconnected(int connection_id)
{
    if (on_disconnected)
        on_disconnected(connection_id);
}

void SQLClient::connection_error(int connection_id, int code, String const& message)
{
    if (on_connection_error)
        on_connection_error(connection_id, code, message);
    else
        warnln("Connection error for connection_id {}: {} ({})", connection_id, message, code);
}

void SQLClient::execution_error(int statement_id, int code, String const& message)
{
    if (on_execution_error)
        on_execution_error(statement_id, code, message);
    else
        warnln("Execution error for statement_id {}: {} ({})", statement_id, message, code);
}

void SQLClient::execution_success(int statement_id, bool has_results, int created, int updated, int deleted)
{
    if (on_execution_success)
        on_execution_success(statement_id, has_results, created, updated, deleted);
    else
        outln("{} row(s) created, {} updated, {} deleted", created, updated, deleted);
}

void SQLClient::next_result(int statement_id, Vector<String> const& row)
{
    if (on_next_result) {
        on_next_result(statement_id, row);
        return;
    }
    bool first = true;
    for (auto& column : row) {
        if (!first)
            out(", ");
        out("\"{}\"", column);
        first = false;
    }
    outln();
}

void SQLClient::results_exhausted(int statement_id, int total_rows)
{
    if (on_results_exhausted)
        on_results_exhausted(statement_id, total_rows);
    else
        outln("{} total row(s)", total_rows);
}

}