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