summaryrefslogtreecommitdiff
path: root/include/fud_sqlite.hpp
diff options
context:
space:
mode:
authorDominick Allen <djallen@librehumanitas.org>2024-09-26 07:46:06 -0500
committerDominick Allen <djallen@librehumanitas.org>2024-09-26 07:46:06 -0500
commit63711877057f1f89b4d1774e24fe20907a3af656 (patch)
tree57c8ed2dcd3463bc782e8be82557e33d6165718a /include/fud_sqlite.hpp
parentdbb305fa27baada32d29d6f8904bdc02ac494e13 (diff)
Add SQLite interface.
Diffstat (limited to 'include/fud_sqlite.hpp')
-rw-r--r--include/fud_sqlite.hpp138
1 files changed, 138 insertions, 0 deletions
diff --git a/include/fud_sqlite.hpp b/include/fud_sqlite.hpp
new file mode 100644
index 0000000..26e9de3
--- /dev/null
+++ b/include/fud_sqlite.hpp
@@ -0,0 +1,138 @@
+/*
+ * libfud
+ * Copyright 2024 Dominick Allen
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#ifndef FUD_SQLITE_HPP
+#define FUD_SQLITE_HPP
+
+#include <fud_result.hpp>
+#include <fud_status.hpp>
+#include <fud_string.hpp>
+#include <sqlite3.h>
+
+namespace fud {
+
+class SqliteStatement;
+
+enum class SqliteOpenMode : int
+{
+ ReadOnly = SQLITE_OPEN_READONLY,
+ ReadWrite = SQLITE_OPEN_READWRITE,
+ ReadWriteCreate = SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE
+};
+
+class SqliteDb {
+ public:
+ SqliteDb(const String& name, SqliteOpenMode mode, int extraFlags = 0);
+
+ SqliteDb(const char* name, SqliteOpenMode mode, int extraFlags = 0);
+
+ SqliteDb(const SqliteDb&) = delete;
+
+ SqliteDb(SqliteDb&& rhs);
+
+ ~SqliteDb();
+
+ SqliteDb& operator=(const SqliteDb&) = delete;
+
+ SqliteDb& operator=(SqliteDb&& rhs);
+
+ bool valid() const;
+
+ bool revalidate();
+
+ FudStatus exec(
+ const String& statement,
+ int (*callback)(void*, int, char**, char**),
+ void* context,
+ String* errorMessage);
+
+ constexpr int errorCode()
+ {
+ return m_errorCode;
+ }
+
+ constexpr sqlite3* handle() const
+ {
+ return m_dbHandle;
+ }
+
+ // private methods
+ private:
+ void initialize();
+
+ [[nodiscard]] int open();
+
+ Result<SqliteStatement, FudStatus> prepare(const String& sql);
+
+ // private data members
+ private:
+ String m_name{};
+
+ bool m_nameValid{false};
+
+ sqlite3* m_dbHandle{nullptr};
+
+ int m_errorCode{0};
+
+ SqliteOpenMode m_mode{};
+
+ int m_extraFlags{};
+};
+
+class SqliteStatement {
+ public:
+ SqliteStatement(const SqliteDb& sqliteDb, const String& input);
+
+ SqliteStatement(const SqliteStatement&) = delete;
+
+ SqliteStatement(SqliteStatement&& rhs);
+
+ ~SqliteStatement();
+
+ SqliteStatement& operator=(const SqliteStatement&) = delete;
+
+ SqliteStatement& operator=(SqliteStatement&& rhs);
+
+ bool valid() const;
+
+ sqlite3_stmt* statement();
+
+ int step();
+
+ FudStatus reset();
+
+ constexpr int errorCode()
+ {
+ return m_errorCode;
+ }
+
+ constexpr FudStatus status()
+ {
+ return m_status;
+ }
+
+ private:
+ String m_input{};
+ const char* m_tail{nullptr};
+ FudStatus m_status{FudStatus::ObjectInvalid};
+ int m_errorCode{0};
+ sqlite3_stmt* m_preparedStatement{nullptr};
+};
+
+} // namespace fud
+
+#endif