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

org.eclipse.persistence.internal.sessions.DirectToFieldChangeRecord Maven / Gradle / Ivy

There is a newer version: 4.0.2
Show newest version
/*
 * Copyright (c) 1998, 2018 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0,
 * or the Eclipse Distribution License v. 1.0 which is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
 */

// Contributors:
//     Oracle - initial API and implementation from Oracle TopLink
package org.eclipse.persistence.internal.sessions;


/**
 * 

* Purpose: To record the changes for attributes that can be represented as DirectToField */ public class DirectToFieldChangeRecord extends ChangeRecord implements org.eclipse.persistence.sessions.changesets.DirectToFieldChangeRecord { protected Object newValue; protected transient Object oldValue; /** * This default constructor. */ public DirectToFieldChangeRecord() { super(); } /** * This constructor returns a changeRecord representing the DirectToField mapping. */ public DirectToFieldChangeRecord(ObjectChangeSet owner) { this.owner = owner; } /** * ADVANCED: * Returns the new value assigned during the change. */ public Object getNewValue() { return newValue; } /** * INTERNAL: * This method will be used to merge one record into another. */ public void mergeRecord(ChangeRecord mergeFromRecord, UnitOfWorkChangeSet mergeToChangeSet, UnitOfWorkChangeSet mergeFromChangeSet) { this.newValue = ((DirectToFieldChangeRecord)mergeFromRecord).getNewValue(); } /** * ADVANCED: * Sets the new value assigned during the change. */ public void setNewValue(Object newValue) { this.newValue = newValue; } /** * INTERNAL: * used by the record to update the new value ignores the value in the default implementation */ public void updateChangeRecordWithNewValue(Object newValue) { setNewValue(newValue); } /** * INTERNAL: * This method will be used to update the objectsChangeSets references */ public void updateReferences(UnitOfWorkChangeSet mergeToChangeSet, UnitOfWorkChangeSet mergeFromChangeSet) { } /** * ADVANCED: * Return the old value of the attribute represented by this ChangeRecord. */ public Object getOldValue() { return oldValue; } /** * INTERNAL: * Set the old value of the attribute represented by this ChangeRecord. */ public void setOldValue(Object oldValue) { this.oldValue = oldValue; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy