// This file is part of BOINC. // https://boinc.berkeley.edu // Copyright (C) 2024 University of California // // BOINC is free software; you can redistribute it and/or modify it // under the terms of the GNU Lesser General Public License // as published by the Free Software Foundation, // either version 3 of the License, or (at your option) any later version. // // BOINC is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. // See the GNU Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public License // along with BOINC. If not, see . #include "Generator.h" #include "ControlConditionTable.h" ControlConditionTable::ControlConditionTable( const std::vector& controls) noexcept : controls(controls) {} bool ControlConditionTable::generate(MSIHANDLE hDatabase) { std::cout << "Generating ControlConditionTable..." << std::endl; std::vector conditions; for (const auto& control : controls) { for (const auto& condition : control.get_conditions()) { conditions.emplace_back(condition); } } const auto sql_create = "CREATE TABLE `ControlCondition` " "(`Dialog_` CHAR(72) NOT NULL, `Control_` CHAR(50) NOT NULL, " "`Action` CHAR(50) NOT NULL, " "`Condition` CHAR(255) NOT NULL " "PRIMARY KEY Dialog_, Control_, Action, Condition)"; const auto sql_insert = "INSERT INTO `ControlCondition` " "(`Dialog_`, `Control_`, `Action`, `Condition`) VALUES (?, ?, ?, ?)"; return Generator::generate(hDatabase, sql_create, sql_insert, conditions); }