All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.permazen.change.Change Maven / Gradle / Ivy

There is a newer version: 5.1.0
Show newest version

/*
 * Copyright (C) 2015 Archie L. Cobbs. All rights reserved.
 */

package io.permazen.change;

import com.google.common.base.Preconditions;

import io.permazen.JObject;
import io.permazen.JTransaction;

/**
 * Object change notification.
 *
 * @param  the type of the object that changed
 */
public abstract class Change {

    private final T jobj;

    /**
     * Constructor.
     *
     * @param jobj Java model object that changed
     * @throws IllegalArgumentException if {@code jobj} is null
     */
    protected Change(T jobj) {
        Preconditions.checkArgument(jobj != null, "null jobj");
        this.jobj = jobj;
    }

    /**
     * Get the Java model object containing the field that changed.
     *
     * 

* Although not declared as such to allow flexibility in Java model types, the returned object * will always be a {@link JObject} instance. * * @return the changed object */ public T getObject() { return this.jobj; } /** * Get the Java model object containing the field that changed. * *

* This is a convenience method, equivalent to: *

* (JObject)getObject() *
* * @return the changed object as a {@link JObject} */ public JObject getJObject() { return (JObject)this.jobj; } /** * Apply visitor pattern. Invokes the method of {@code target} corresponding to this instance's type. * * @param target visitor pattern target * @param visitor return type * @return value returned by the selected method of {@code target} */ public abstract R visit(ChangeSwitch target); /** * Apply this change to the given object in the given transaction. * * @param jobj the target object to which to apply this change * @param jtx the transaction in which to apply this change * @throws NullPointerException if {@code jtx} or {@code jobj} is null * @throws io.permazen.core.DeletedObjectException if {@code jobj} does not exist in {@code jtx} * @throws io.permazen.core.UnknownFieldException if {@code jobj} has a schema version that * does not contain the affected field, or in which the affected field has a different type * @throws RuntimeException if there is some other incompatibility between this change and the target object, * for example, setting a list element at an index that is out of bounds * @throws io.permazen.kv.StaleTransactionException if {@code jtx} is no longer usable */ public abstract void apply(JTransaction jtx, JObject jobj); /** * Apply this change to the object associated with this instance in the given transaction. * *

* This is a convenience method, equivalent to: *

* apply(jtx, this.getJObject()); *
* * @param jtx transaction in which to apply this change * @throws IllegalArgumentException if {@code jtx} is null */ public void apply(JTransaction jtx) { Preconditions.checkArgument(jtx != null, "null jtx"); this.apply(jtx, this.getJObject()); } /** * Apply this change to the transaction associated with the current thread. * *

* This is a convenience method, equivalent to: *

* apply(JTransaction.getCurrent()) *
* * @throws IllegalStateException if there is no {@link JTransaction} associated with the current thread */ public void apply() { this.apply(JTransaction.getCurrent()); } /** * Apply this change to the specified object. * *

* This is a convenience method, equivalent to: *

* apply(obj.getTransaction(), jobj); *
* * @param jobj object to which to apply this change * @throws IllegalStateException if there is no {@link JTransaction} associated with {@code jobj} * @throws IllegalArgumentException if {@code jobj} is null */ public void apply(JObject jobj) { Preconditions.checkArgument(jobj != null, "null jobj"); this.apply(jobj.getTransaction(), jobj); } // Object @Override public boolean equals(Object obj) { if (obj == this) return true; if (obj == null || obj.getClass() != this.getClass()) return false; final Change that = (Change)obj; return this.jobj.equals(that.jobj); } @Override public int hashCode() { return this.jobj.hashCode(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy