src/Configuration.h
branchv_0
changeset 0 c205f5d06418
child 2 362f2689cb87
--- /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 <http://www.gnu.org/licenses/>.
+ */
+#pragma once
+
+#include <relpipe/writer/AttributeMetadata.h>
+#include <relpipe/writer/typedefs.h>
+
+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<DefinitionRecipe> definitions;
+
+	/**
+	 * If empty, output relation will have same metadata as the input relation.
+	 */
+	std::vector<relpipe::writer::AttributeMetadata> 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<RelationConfiguration> 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<DefinitionRecipe> definitions;
+
+	virtual ~Configuration() {
+	}
+};
+
+}
+}
+}
\ No newline at end of file