diff -r 000000000000 -r c205f5d06418 src/Configuration.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/Configuration.h Sat Jul 27 18:41:13 2019 +0200 @@ -0,0 +1,100 @@ +/** + * Relational pipes + * Copyright © 2019 František Kučera (Frantovo.cz, GlobalCode.info) + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ +#pragma once + +#include +#include + +namespace relpipe { +namespace tr { +namespace sql { + +class DefinitionRecipe { +public: + + virtual ~DefinitionRecipe() { + } + + relpipe::writer::string_t name; + relpipe::writer::string_t type; + relpipe::writer::string_t value; +}; + +class RelationConfiguration { +public: + + virtual ~RelationConfiguration() { + } + + relpipe::writer::string_t relation; + relpipe::writer::string_t sqlBeforeRecords; + relpipe::writer::string_t sqlAfterRecords; + relpipe::writer::string_t sqlForEach; + + /** + * If true, additional relation will be generated: mapping between relpipe attribute names and SQL variable names + */ + bool debugVariableMapping = false; + + /** + * If true, SQL code will be executed, but no output will be generated. + */ + bool drop = false; + + /** + * Variable definitions for this relation. + * Can be used as a safe way for passing parameters from the outside environment. + * See also Configuration::definitions (can be overridden by relation's definitions) + */ + std::vector definitions; + + /** + * If empty, output relation will have same metadata as the input relation. + */ + std::vector writerMetadata; + + /** + * Whether original attributes should be appended to those specified using --output-attribute + */ + bool inputAttributesAppend = false; + + /** + * Whether original attributes should be prepended to those specified using --output-attribute + */ + bool inputAttributesPrepend = false; +}; + +class Configuration { +public: + + std::vector relationConfigurations; + + /** + * Global definitions for all relations. + * Can be used as a safe way for passing parameters from the outside environment. + * See also RelationConfiguration::definitions + */ + std::vector definitions; + + virtual ~Configuration() { + } +}; + +} +} +} \ No newline at end of file