mirror of
https://github.com/RGBCube/serenity
synced 2025-05-25 16:55:07 +00:00

Derivatives of Core::Object should be constructed through ClassName::construct(), to avoid handling ref-counted objects with refcount zero. Fixing the visibility means that misuses like this are more difficult.
44 lines
1.1 KiB
C++
44 lines
1.1 KiB
C++
/*
|
|
* Copyright (c) 2021, Jan de Visser <jan@de-visser.net>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/NonnullRefPtr.h>
|
|
#include <AK/String.h>
|
|
#include <LibCore/Object.h>
|
|
#include <LibSQL/AST/AST.h>
|
|
#include <LibSQL/SQLResult.h>
|
|
#include <SQLServer/DatabaseConnection.h>
|
|
#include <SQLServer/Forward.h>
|
|
|
|
namespace SQLServer {
|
|
|
|
class SQLStatement final : public Core::Object {
|
|
C_OBJECT(SQLStatement)
|
|
|
|
public:
|
|
~SQLStatement() override = default;
|
|
|
|
static RefPtr<SQLStatement> statement_for(int statement_id);
|
|
int statement_id() const { return m_statement_id; }
|
|
String const& sql() const { return m_sql; }
|
|
DatabaseConnection* connection() { return dynamic_cast<DatabaseConnection*>(parent()); }
|
|
void execute();
|
|
|
|
private:
|
|
SQLStatement(DatabaseConnection&, String sql);
|
|
Optional<SQL::SQLError> parse();
|
|
void next();
|
|
void report_error(SQL::SQLError);
|
|
|
|
int m_statement_id;
|
|
String m_sql;
|
|
size_t m_index { 0 };
|
|
RefPtr<SQL::AST::Statement> m_statement { nullptr };
|
|
RefPtr<SQL::SQLResult> m_result { nullptr };
|
|
};
|
|
|
|
}
|