TuPrologTerm.java
/*
* #%L
* prolobjectlink-jpi-tuprolog
* %%
* Copyright (C) 2019 Prolobjectlink Project
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 2.1 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 Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* <http://www.gnu.org/licenses/lgpl-2.1.html>.
* #L%
*/
package io.github.prolobjectlink.prolog.tuprolog;
import static io.github.prolobjectlink.prolog.PrologTermType.OBJECT_TYPE;
import java.util.List;
import alice.tuprolog.Double;
import alice.tuprolog.Float;
import alice.tuprolog.Int;
import alice.tuprolog.Long;
import alice.tuprolog.Number;
import alice.tuprolog.Operator;
import alice.tuprolog.OperatorManager;
import alice.tuprolog.Prolog;
import alice.tuprolog.Struct;
import alice.tuprolog.Term;
import alice.tuprolog.Var;
import io.github.prolobjectlink.prolog.AbstractTerm;
import io.github.prolobjectlink.prolog.PrologProvider;
import io.github.prolobjectlink.prolog.PrologTerm;
/**
*
* @author Jose Zalacain
* @since 1.0
*/
abstract class TuPrologTerm extends AbstractTerm implements PrologTerm {
protected Term value;
private static final Prolog prolog = new Prolog();
public TuPrologTerm(int type, PrologProvider provider) {
super(type, provider);
}
public TuPrologTerm(int type, PrologProvider provider, Term value) {
super(type, provider);
this.value = value;
}
public final boolean isAtom() {
return value.isAtom();
}
public final boolean isNumber() {
return value instanceof Number;
}
public final boolean isFloat() {
return value instanceof Float;
}
public final boolean isDouble() {
return value instanceof Double;
}
public final boolean isInteger() {
return value instanceof Int;
}
public final boolean isLong() {
return value instanceof Long;
}
public final boolean isVariable() {
return value instanceof Var;
}
public final boolean isList() {
return value.isList();
}
public final boolean isStructure() {
if (!isAtom() && !isList()) {
return value instanceof Struct;
}
return false;
}
public final boolean isNil() {
if (!isVariable() && !isNumber()) {
return hasIndicator("nil", 0);
}
return false;
}
public final boolean isEmptyList() {
return value.isEmptyList();
}
public final boolean isEvaluable() {
if (value instanceof Struct) {
OperatorManager om = prolog.getOperatorManager();
List<Operator> ol = om.getOperators();
for (Operator operator : ol) {
if (!getFunctor().equals(".") && operator.name.equals(getFunctor())) {
return true;
}
}
}
return false;
}
public final boolean isAtomic() {
return value.isAtomic();
}
public final boolean isCompound() {
return value.isCompound();
}
public final boolean isTrueType() {
return getObject().equals(true);
}
public final boolean isFalseType() {
return getObject().equals(false);
}
public final boolean isNullType() {
return getObject() == null;
}
public final boolean isVoidType() {
return getObject() == void.class;
}
public final boolean isObjectType() {
return getType() == OBJECT_TYPE;
}
public final boolean isReference() {
return isObjectType();
}
public final boolean isVariableBound() {
return isVariable() && value.getTerm() != value;
}
public final boolean isVariableNotBound() {
return isVariable() && value.getTerm() == value;
}
public final PrologTerm getTerm() {
return toTerm(value.getTerm(), PrologTerm.class);
}
public final boolean unify(PrologTerm term) {
return value.match(fromTerm(term, Term.class));
}
public final int compareTo(PrologTerm o) {
Term thisTerm = value;
Term otherTerm = fromTerm(o, Term.class);
if (this == o || thisTerm.isEqual(otherTerm)) {
return 0;
} else if (thisTerm.isGreater(otherTerm)) {
return 1;
}
return -1;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + type;
// Term not implement hashCode()
result = prime * result + ((value == null) ? 0 : value.toString().hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (!(obj instanceof TuPrologTerm))
return false;
TuPrologTerm other = (TuPrologTerm) obj;
if (value == null) {
if (other.value != null)
return false;
} else if (value.toString().equals(other.value.toString())) {
return true;
} else if (!value.unify(prolog, other.value)) {
return false;
}
return true;
}
@Override
public String toString() {
return "" + value + "";
}
}