summaryrefslogtreecommitdiff
path: root/utils/PDDLtoSANetTranslator/PDDLParser/src/pddl4j/Domain.java
diff options
context:
space:
mode:
Diffstat (limited to 'utils/PDDLtoSANetTranslator/PDDLParser/src/pddl4j/Domain.java')
-rw-r--r--utils/PDDLtoSANetTranslator/PDDLParser/src/pddl4j/Domain.java119
1 files changed, 119 insertions, 0 deletions
diff --git a/utils/PDDLtoSANetTranslator/PDDLParser/src/pddl4j/Domain.java b/utils/PDDLtoSANetTranslator/PDDLParser/src/pddl4j/Domain.java
new file mode 100644
index 00000000000..cebc0ce72e3
--- /dev/null
+++ b/utils/PDDLtoSANetTranslator/PDDLParser/src/pddl4j/Domain.java
@@ -0,0 +1,119 @@
+/*
+ * Copyright Dept. of Mathematics & Computer Science Univ. Paris-Descartes
+ *
+ * This software is governed by the CeCILL license under French law and
+ * abiding by the rules of distribution of free software. You can use,
+ * modify and/ or redistribute the software under the terms of the CeCILL
+ * license as circulated by CEA, CNRS and INRIA at the following URL
+ * "http://www.cecill.info".
+ *
+ * As a counterpart to the access to the source code and rights to copy,
+ * modify and redistribute granted by the license, users are provided only
+ * with a limited warranty and the software's author, the holder of the
+ * economic rights, and the successive licensors have only limited
+ * liability.
+ *
+ * In this respect, the user's attention is drawn to the risks associated
+ * with loading, using, modifying and/or developing or reproducing the
+ * software by the user in light of its specific status of free software,
+ * that may mean that it is complicated to manipulate, and that also
+ * therefore means that it is reserved for developers and experienced
+ * professionals having in-depth computer knowledge. Users are therefore
+ * encouraged to load and test the software's suitability as regards their
+ * requirements in conditions enabling the security of their systems and/or
+ * data to be ensured and, more generally, to use and operate it in the
+ * same conditions as regards security.
+ *
+ * The fact that you are presently reading this means that you have had
+ * knowledge of the CeCILL license and that you accept its terms.
+ */
+
+package pddl4j;
+
+import java.io.File;
+import java.io.Serializable;
+import java.util.Iterator;
+import java.util.Set;
+
+import pddl4j.exp.AtomicFormula;
+import pddl4j.exp.action.ActionDef;
+import pddl4j.exp.term.Constant;
+import pddl4j.exp.type.Type;
+import pddl4j.exp.type.TypeSet;
+
+/**
+ * This interface defines the accessible methods from a domain.
+ *
+ * @author Damien Pellier
+ * @version 1.0
+ */
+public interface Domain extends Serializable {
+
+ /**
+ * Returns an iterator over the requirements of this pddl object.
+ *
+ * @return an iterator over the requirements of this pddl object.
+ */
+ Iterator<RequireKey> requirementsIterator();
+
+ /**
+ * Returns the set of constants associated to a specified type.
+ *
+ * @param type the type.
+ * @return the set of constants associated to a type or <code>null</code>
+ * if the type is not defined in the pddl object.
+ */
+ Set<Constant> getTypedDomain(Type type);
+
+ /**
+ * Returns the set of constants associated to a specified type.
+ *
+ * @param typeSet the type.
+ * @return the set of constants associated to a type or <code>null</code>
+ * if the type is not defined in the pddl object.
+ */
+ Set<Constant> getTypedDomain(TypeSet typeSet);
+
+ /**
+ * Returns an iterator over the types defined in this pddl object.
+ *
+ * @return an iterator over the types defined in this pddl object.
+ */
+ //Iterator<Type> typesIterator();
+
+ /**
+ * Returns an iterator over the constants defined in this pddl object.
+ *
+ * @return an iterator over the constants defined in this pddl object.
+ */
+ Iterator<Constant> constantsIterator();
+
+ /**
+ * Returns an iterator over the constants defined in this pddl object.
+ *
+ * @return an iterator over the constants defined in this pddl object.
+ */
+ Iterator<AtomicFormula> predicatesIterator();
+
+ /**
+ * Returns an iterator over the actions defined in this pddl object.
+ *
+ * @return an iterator over the actions defined in this pddl object.
+ */
+ Iterator<ActionDef> actionsIterator();
+
+ /**
+ * Returns the domain file where the PDDL object is defined.
+ *
+ * @return the domain file where the PDDL object is defined.
+ */
+ File getDomainFile();
+
+ /**
+ * Returns the name of the domain.
+ *
+ * @return the name of the domain.
+ */
+ String getDomainName();
+
+} \ No newline at end of file