summaryrefslogtreecommitdiff
path: root/elki/src/main/java/de/lmu/ifi/dbs/elki/utilities/optionhandling/constraints/ParameterConstraint.java
diff options
context:
space:
mode:
authorAndrej Shadura <andrewsh@debian.org>2019-03-09 22:30:41 +0000
committerAndrej Shadura <andrewsh@debian.org>2019-03-09 22:30:41 +0000
commit38212b3127e90751fb39cda34250bc11be62b76c (patch)
treedc1397346030e9695bd763dddc93b3be527cd643 /elki/src/main/java/de/lmu/ifi/dbs/elki/utilities/optionhandling/constraints/ParameterConstraint.java
parent337087b668d3a54f3afee3a9adb597a32e9f7e94 (diff)
Import Upstream version 0.7.0
Diffstat (limited to 'elki/src/main/java/de/lmu/ifi/dbs/elki/utilities/optionhandling/constraints/ParameterConstraint.java')
-rw-r--r--elki/src/main/java/de/lmu/ifi/dbs/elki/utilities/optionhandling/constraints/ParameterConstraint.java62
1 files changed, 62 insertions, 0 deletions
diff --git a/elki/src/main/java/de/lmu/ifi/dbs/elki/utilities/optionhandling/constraints/ParameterConstraint.java b/elki/src/main/java/de/lmu/ifi/dbs/elki/utilities/optionhandling/constraints/ParameterConstraint.java
new file mode 100644
index 00000000..99009941
--- /dev/null
+++ b/elki/src/main/java/de/lmu/ifi/dbs/elki/utilities/optionhandling/constraints/ParameterConstraint.java
@@ -0,0 +1,62 @@
+package de.lmu.ifi.dbs.elki.utilities.optionhandling.constraints;
+
+/*
+ This file is part of ELKI:
+ Environment for Developing KDD-Applications Supported by Index-Structures
+
+ Copyright (C) 2015
+ Ludwig-Maximilians-Universität München
+ Lehr- und Forschungseinheit für Datenbanksysteme
+ ELKI Development Team
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU Affero 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 Affero General Public License for more details.
+
+ You should have received a copy of the GNU Affero General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+import de.lmu.ifi.dbs.elki.utilities.optionhandling.ParameterException;
+
+/**
+ * <p/>
+ * Interface for specifying parameter constraints.
+ * </p>
+ * <p/>
+ * Each class specifying a constraint addressing only one parameter should implement this interface.
+ * The constraint value for testing the parameter should be defined as private attribute and should be initialized in the
+ * respective constructor of the class, i.e. it is a parameter of the constructor. The proper constraint
+ * test should be implemented in the method {@link #test(Object) test(T)}.
+ * </p>
+ *
+ * @author Steffi Wanka
+ * @param <T> the type of the parameter the constraint applies to
+ */
+public interface ParameterConstraint<T> {
+ /**
+ * Checks if the value {@code t} of the parameter to be tested fulfills the parameter constraint.
+ * If not, a parameter exception is thrown.
+ *
+ * @param t Value to be checked whether or not it fulfills the underlying
+ * parameter constraint.
+ * @throws ParameterException if the parameter to be tested does not
+ * fulfill the parameter constraint
+ */
+ public abstract void test(T t) throws ParameterException;
+
+ /**
+ * Returns a description of this constraint.
+ *
+ * @param parameterName the name of the parameter this constraint is used for
+ * @return a description of this constraint
+ */
+ public abstract String getDescription(String parameterName);
+
+}