Use sqlite for cinema and DKDM recipient lists.
[dcpomatic.git] / src / lib / sqlite_table.h
1 /*
2     Copyright (C) 2024 Carl Hetherington <cth@carlh.net>
3
4     This file is part of DCP-o-matic.
5
6     DCP-o-matic is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     DCP-o-matic is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
18
19 */
20
21
22 #ifndef DCPOMATIC_SQLITE_TABLE_H
23 #define DCPOMATIC_SQLITE_TABLE_H
24
25 #include <string>
26 #include <vector>
27
28
29 class SQLiteTable
30 {
31 public:
32         SQLiteTable(std::string name)
33                 : _name(std::move(name))
34         {}
35
36         SQLiteTable(SQLiteTable const&) = default;
37         SQLiteTable(SQLiteTable&&) = default;
38
39         void add_column(std::string const& name, std::string const& type);
40
41         std::string create() const;
42         std::string insert() const;
43         std::string update(std::string const& condition) const;
44         std::string select(std::string const& condition) const;
45
46 private:
47         std::string _name;
48         std::vector<std::string> _columns;
49         std::vector<std::string> _types;
50 };
51
52
53 #endif
54