01: /*
02: * The contents of this file are subject to the terms of the Common Development
03: * and Distribution License (the License). You may not use this file except in
04: * compliance with the License.
05: *
06: * You can obtain a copy of the License at http://www.netbeans.org/cddl.html
07: * or http://www.netbeans.org/cddl.txt.
08: *
09: * When distributing Covered Code, include this CDDL Header Notice in each file
10: * and include the License file at http://www.netbeans.org/cddl.txt.
11: * If applicable, add the following below the CDDL Header, with the fields
12: * enclosed by brackets [] replaced by your own identifying information:
13: * "Portions Copyrighted [year] [name of copyright owner]"
14: *
15: * The Original Software is NetBeans. The Initial Developer of the Original
16: * Software is Sun Microsystems, Inc. Portions Copyright 1997-2007 Sun
17: * Microsystems, Inc. All Rights Reserved.
18: */
19:
20: /**
21: *
22: */package org.netbeans.modules.bpel.model.api.events;
23:
24: import org.netbeans.modules.bpel.model.api.BpelEntity;
25:
26: /**
27: * @author ads
28: */
29: public class ArrayUpdateEvent<T extends BpelEntity> extends ChangeEvent {
30:
31: private static final long serialVersionUID = -952921787574357005L;
32:
33: /**
34: * Constructor for ArrayUpdateEvent with source ref.
35: *
36: * @param source
37: * source of event.
38: * @param parent
39: * parent container which caused by array changing.
40: * @param name
41: * name of tag ( not always have sense. F.e. sequence contains
42: * activitis with its own tags and we cannot put the same name
43: * for each activity. But f.e. for VariableContainer it will be
44: * "variable" ).
45: * @param oldArray Old array value.
46: * @param newArray New array value.
47: */
48: public ArrayUpdateEvent(Object source, BpelEntity parent,
49: String name, T[] oldArray, T[] newArray) {
50: super (source, parent, name);
51: myOldArray = oldArray;
52: myNewArray = newArray;
53: }
54:
55: /**
56: * Constructor for ArrayUpdateEvent without source ref.
57: *
58: * @param parent
59: * parent container which caused by array changing.
60: * @param name
61: * name of tag - see comments for previous CTOR.
62: * @param oldArray Old array value.
63: * @param newArray New array value.
64: */
65: public ArrayUpdateEvent(BpelEntity parent, String name,
66: T[] oldArray, T[] newArray) {
67: this (Thread.currentThread(), parent, name, oldArray, newArray);
68: }
69:
70: /**
71: * @return array before event appeared.
72: */
73: public T[] getOldArray() {
74: return myOldArray;
75: }
76:
77: /**
78: * @return array after changing.
79: */
80: public T[] getNewArray() {
81: return myNewArray;
82: }
83:
84: private T[] myOldArray;
85:
86: private T[] myNewArray;
87: }
|