Helper MemberFieldSet

Jan Burse, created Jul 30. 2019
package jekpro.tools.foreign;
import jekpro.model.inter.Engine;
import jekpro.model.molec.Display;
import jekpro.model.molec.EngineMessage;
import jekpro.model.pretty.AbstractSource;
import jekpro.reference.reflect.SpecialForeign;
import jekpro.tools.array.Types;
import jekpro.tools.term.SkelAtom;
import jekpro.tools.term.SkelCompound;
import java.lang.reflect.Field;
import java.lang.reflect.Member;
/**
* <p>Specialization of a delegate for a field setter.</p>
* <p/>
* Warranty & Liability
* To the extent permitted by applicable law and unless explicitly
* otherwise agreed upon, XLOG Technologies GmbH makes no warranties
* regarding the provided information. XLOG Technologies GmbH assumes
* no liability that any problems might be solved with the information
* provided by XLOG Technologies GmbH.
* <p/>
* Rights & License
* All industrial property rights regarding the information - copyright
* and patent rights in particular - are the sole property of XLOG
* Technologies GmbH. If the company was not the originator of some
* excerpts, XLOG Technologies GmbH has at least obtained the right to
* reproduce, change and translate the information.
* <p/>
* Reproduction is restricted to the whole unaltered document. Reproduction
* of the information is only allowed for non-commercial uses. Selling,
* giving away or letting of the execution of the library is prohibited.
* The library can be distributed as part of your applications and libraries
* for execution provided this comment remains unchanged.
* <p/>
* Restrictions
* Only to be distributed with programs that add significant and primary
* functionality to the library. Not to be distributed with additional
* software intended to replace any components of the library.
* <p/>
* Trademarks
* Jekejeke is a registered trademark of XLOG Technologies GmbH.
*/
final class MemberFieldSet extends AbstractMember {
private static final String OP_FOREIGN_SETTER = "foreign_setter";
private final Field field;
private final String fastname;
private final Class[] fastpartys;
/**
* <p>Create field predicate.</p>
*
* @param f The field.
*/
MemberFieldSet(Field f) {
field = f;
fastname = "set_" + field.getName();
fastpartys = new Class[]{field.getType()};
}
/**
* <p>Retrieve the proxy that is wrapped.</p>
*
* @return The proxy.
*/
public Member getProxy() {
return field;
}
/******************************************************************/
/* Accessible Protocol */
/******************************************************************/
/**
* <p>Retrieve the modifier flags as an int.</p>
*
* @return The modifier flags as an int.
*/
public int getModifiers() {
return field.getModifiers();
}
/**
* <p>Retrieve the return type as Java class.</p>
*
* @return The return type as Java class.
*/
public Class getReturnType() {
return Void.TYPE;
}
/**
* <p>Retrieve the parameter types as Java classes.</p>
*
* @return The parameter types as Java classes.
*/
public Class[] getParameterTypes() {
return fastpartys;
}
/**
* <p>Retrieve the declaring Java class.</p>
*
* @return The declaring Java class.
*/
public Class getDeclaringClass() {
return field.getDeclaringClass();
}
/******************************************************************/
/* Execution Service */
/******************************************************************/
/**
* <p>Logically evaluate a term in a list of goals for the first time.</p>
* <p>The term is passed via the skel and display of the engine.</p>
* <p>The continuation is passed via the r and u of the engine.</p>
* <p>The new continuation is returned via the skel and display of the engine.</p>
*
* @param en The interpreter.
* @return True if the term succeeded, otherwise false.
* @throws EngineMessage FFI error.
*/
public final boolean moniFirst(Engine en)
throws EngineMessage {
Object temp = en.skel;
Display ref = en.display;
Object obj = convertRecv(temp, ref);
Object[] help = ((SkelCompound) temp).args;
Object arg = Types.denormProlog(encodeparas[0], help[help.length - 1], ref);
invokeSetter(obj, arg);
return true;
}
/**
* <p>Invoke the method.</p>
*
* @param obj The receiver.
* @param arg The argument.
* @throws EngineMessage FFI error.
*/
final void invokeSetter(Object obj, Object arg)
throws EngineMessage {
try {
field.set(obj, arg);
} catch (Exception x) {
throw Types.mapException(x, field);
} catch (Error x) {
throw Types.mapError(x);
}
}
/***************************************************************/
/* Special Predicates */
/***************************************************************/
/**
* <p>Compute a hash code.</p>
*
* @return The hash code of this delegate.
*/
public int hashCode() {
return field.hashCode();
}
/**
* <p>Compare with another delegate.</p>
*
* @param o The other delegate.
* @return True if this delegate equals the other delegate, otherwise false.
*/
public boolean equals(Object o) {
if (!(o instanceof MemberFieldSet))
return false;
MemberFieldSet dpfs = (MemberFieldSet) o;
return field.equals(dpfs.field);
}
/**
* <p>Generate the spec of this delegate.</p>
*
* @param source The source, non null.
* @return The spec.
* @throws EngineMessage FFI error.
*/
public Object toSpec(AbstractSource source)
throws EngineMessage {
return new SkelCompound(new SkelAtom(OP_FOREIGN_SETTER),
SpecialForeign.classToName(field.getDeclaringClass(), source),
new SkelAtom(field.getName()));
}
/***************************************************************/
/* Foreign Predicates */
/***************************************************************/
/**
* <p>Retrieve a name guess.</p>
*
* @return The name guess, or null.
*/
public String getFun() {
return fastname;
}
/**
* <p>Convert the delegate to a string.</p>
*
* @return The string.
*/
public String toString() {
return field.toString() + " (setter)";
}
}

Comments