Classes in this File | Line Coverage | Branch Coverage | Complexity | ||||
BindingConfiguration |
|
| 0.0;0 |
1 | /** | |
2 | * Copyright (C) 2006 Philipp Mpalampanis | |
3 | * | |
4 | * License: MPL 1.1/GPL 2.0/LGPL 2.1 | |
5 | * | |
6 | * The contents of this file are subject to the Mozilla Public License Version | |
7 | * 1.1 (the "License"); you may not use this file except in compliance with | |
8 | * the License. You may obtain a copy of the License at | |
9 | * http://www.mozilla.org/MPL/ | |
10 | * | |
11 | * Software distributed under the License is distributed on an "AS IS" basis, | |
12 | * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License | |
13 | * for the specific language governing rights and limitations under the | |
14 | * License. | |
15 | * | |
16 | * Alternatively, the contents of this file may be used under the terms of | |
17 | * either the GNU General Public License Version 2 or later (the "GPL"), or | |
18 | * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), | |
19 | * in which case the provisions of the GPL or the LGPL are applicable instead | |
20 | * of those above. If you wish to allow use of your version of this file only | |
21 | * under the terms of either the GPL or the LGPL, and not to allow others to | |
22 | * use your version of this file under the terms of the MPL, indicate your | |
23 | * decision by deleting the provisions above and replace them with the notice | |
24 | * and other provisions required by the GPL or the LGPL. If you do not delete | |
25 | * the provisions above, a recipient may use your version of this file under | |
26 | * the terms of any one of the MPL, the GPL or the LGPL. | |
27 | */ | |
28 | package net.sf.echobinding; | |
29 | ||
30 | import java.beans.PropertyChangeEvent; | |
31 | import java.beans.PropertyChangeListener; | |
32 | import java.util.*; | |
33 | ||
34 | import net.sf.echobinding.binding.BindingContext; | |
35 | ||
36 | /** | |
37 | * The <code>BindingConfiguration</code> is the root node in the data binding | |
38 | * context tree. It manages all underlaying <code>BindingContext</code>s and | |
39 | * is usally the access point for the application to the data binding facility. | |
40 | * | |
41 | * @see net.sf.echobinding.binding.BindingContext | |
42 | */ | |
43 | 3 | public class BindingConfiguration implements PropertyChangeListener { |
44 | ||
45 | 1 | private static Map<String, BindingContext> _contexts = new HashMap<String, BindingContext>(); |
46 | ||
47 | /** | |
48 | * @param contextId | |
49 | * @return the binding context for that contextId | |
50 | */ | |
51 | public static BindingContext getBindingContext(String contextId) { | |
52 | BindingContext ctx = _contexts.get( contextId ); | |
53 | if (ctx == null) | |
54 | throw new RuntimeException( "unknown binding context: " + contextId ); | |
55 | return ctx; | |
56 | } | |
57 | ||
58 | 1 | private ArrayList<PropertyChangeListener> _propertyChangeListeners = new ArrayList<PropertyChangeListener>(); |
59 | ||
60 | /** | |
61 | * @return the binding contexts as a map | |
62 | */ | |
63 | public Map<String, BindingContext> getContexts() { | |
64 | return _contexts; | |
65 | } | |
66 | ||
67 | /** | |
68 | * @param contexts | |
69 | */ | |
70 | public void setContexts(Map<String, BindingContext> contexts) { | |
71 | for (String contextName : contexts.keySet()) { | |
72 | addContext( contextName, _contexts.get( contextName ) ); | |
73 | } | |
74 | } | |
75 | ||
76 | /** | |
77 | * @param contextName | |
78 | * @param context | |
79 | * @return the configuration | |
80 | */ | |
81 | public BindingConfiguration addContext(String contextName, BindingContext context) { | |
82 | 2 | if(_contexts == null) |
83 | _contexts = new HashMap<String, BindingContext>(); | |
84 | ||
85 | 2 | registerContext(context); |
86 | 2 | _contexts.put(contextName, context); |
87 | ||
88 | 2 | return this; |
89 | } | |
90 | ||
91 | /** | |
92 | * Registers a new binding context. This is necessary for | |
93 | * receive/sending property change events from/to other contexts within this | |
94 | * configuration. | |
95 | * | |
96 | * @param context | |
97 | */ | |
98 | public void registerContext(BindingContext context) { | |
99 | ||
100 | // add configuration as a listener to the binding context | |
101 | 2 | context.removePropertyChangeListener( this ); |
102 | 2 | context.addPropertyChangeListener( this ); |
103 | ||
104 | // add context to the set of listeners | |
105 | 2 | addPropertyChangeListener( context ); |
106 | ||
107 | // context.getP | |
108 | 2 | } |
109 | ||
110 | /* | |
111 | * (non-Javadoc) | |
112 | * | |
113 | * @see java.beans.PropertyChangeListener#propertyChange(java.beans.PropertyChangeEvent) | |
114 | */ | |
115 | public void propertyChange(PropertyChangeEvent event) { | |
116 | ||
117 | 2 | PropertyChangeEvent newEvent = new PropertyChangeEvent( this, event |
118 | 1 | .getPropertyName(), event.getOldValue(), event.getNewValue() ); |
119 | 4 | for (PropertyChangeListener listener : _propertyChangeListeners) { |
120 | 2 | if (!listener.equals( event.getSource() )) |
121 | 1 | listener.propertyChange( newEvent ); |
122 | } | |
123 | 1 | } |
124 | ||
125 | /** | |
126 | * @param listener | |
127 | */ | |
128 | public void addPropertyChangeListener(PropertyChangeListener listener) { | |
129 | ||
130 | 2 | _propertyChangeListeners.add( listener ); |
131 | 2 | } |
132 | ||
133 | /** | |
134 | * @param listener | |
135 | */ | |
136 | public void removePropertyChangeListener(PropertyChangeListener listener) { | |
137 | _propertyChangeListeners.remove( listener ); | |
138 | } | |
139 | ||
140 | } |