import org.exolab.castor.xml.ValidationException;
import org.vamsas.objects.core.VamsasDocument;
/**
- * Implements the Vamsas object ID machinery for translating
- * between non-volatile XML IDs and object references. Use the
+ * Implements the Vamsas Vobject ID machinery for translating
+ * between non-volatile XML IDs and Vobject references. Use the
* marshalling and unmarshalling methods in this class in order
* to avoid validation exceptions when marshalling new objects
* into the vamsas document.
* java.lang.Object, java.lang.Object)
*/
public void fieldAdded(String fieldName, Object parent, Object child) {
+ if (parent instanceof Vobject && child instanceof Vobject) {
+ if (((Vobject) child).V_parent==null) {
+ // System.err.println("Setting parent of "+fieldName);
+ ((Vobject) child).setV_parent((Vobject) parent);
+ }
+ }
}
/*
/*
* Check if the object has an 'id' field - if it does, copy the value into
- * the VorbaId field of object, and add the object to the VorbaId hash.
+ * the VorbaId field of Vobject, and add the Vobject to the VorbaId hash.
*
* @see org.exolab.castor.xml.UnmarshalListener#unmarshalled(java.lang.Object)
*/
public void unmarshalled(Object newobj) {
- if (newobj instanceof object) {
- object nobj = (object) newobj;
+ if (newobj instanceof Vobject) {
+ Vobject nobj = (Vobject) newobj;
nobj.set__stored_in_document(true);
Field fd = null;
try {
if (nobj.isRegisterable()) {
// look for the id field (should be an NCName string)
nobj.__vorba = vorbafactory;
- fd = nobj.getClass().getField("id");
+ fd = nobj.getClass().getDeclaredField("_id");
String idstring;
if (fd.get(nobj) != null) {
idstring = (String) fd.get(nobj);
sync=false; // document is out of sync - ids have been created.
java.util.Iterator newobj = unrefed.listIterator();
while (newobj.hasNext()) {
- object o = (object) newobj.next();
+ Vobject o = (Vobject) newobj.next();
// forces registration and id field update.
VorbaId id = o.getVorbaId();
if (!objrefs.containsKey(id)) {
return sync;
}
/**
- * Unmarshals a vamsasDocument object from a stream, registers
+ * Unmarshals a vamsasDocument Vobject from a stream, registers
* unregistered objects, records existing VorbaIds, and completes
- * the org.vamsas.client.object housekeeping fields.
+ * the org.vamsas.client.Vobject housekeeping fields.
* For a valid unmarshalling, the array of returned objects also includes
* a <return>sync</return> parameter which is true if new VorbaIds
* were created. If sync is false, then the caller should ensure that the
* TODO: ensure that provenance is correct for newly registered objects
* @param instream - the XML input stream
* @param factory - the SimpleClient's properly configured VorbaId factory to make new references.
- * @param root the root element's org.vamsas.objects.core object.
- * @return null or {(Object) VamsasDocument object, (Object) Hashtable of object references, (Object) Boolean(sync) }
+ * @param root the root element's org.vamsas.objects.core Vobject.
+ * @return null or {(Object) VamsasDocument Vobject, (Object) Hashtable of Vobject references, (Object) Boolean(sync) }
*/
public static Object[] getVamsasObjects(Reader instream,
- IVorbaIdFactory factory, object root) {
+ IVorbaIdFactory factory, Vobject root) {
Unmarshaller unmarshaller = new Unmarshaller(root);
unmarshaller.setIDResolver(new IDResolver() {
public Object resolve(String id) {
while (instream.ready()) {
Object obj = unmarshaller.unmarshal(instream);
boolean sync=ensure_references(unrefed, objrefs);
- if (!(obj instanceof object))
+ if (!(obj instanceof Vobject))
return null;
return new Object[] { obj, objrefs, new Boolean(sync)};
}