01: /*
02: * Copyright (c) 1998-2008 Caucho Technology -- all rights reserved
03: *
04: * This file is part of Resin(R) Open Source
05: *
06: * Each copy or derived work must preserve the copyright notice and this
07: * notice unmodified.
08: *
09: * Resin Open Source is free software; you can redistribute it and/or modify
10: * it under the terms of the GNU General Public License as published by
11: * the Free Software Foundation; either version 2 of the License, or
12: * (at your option) any later version.
13: *
14: * Resin Open Source is distributed in the hope that it will be useful,
15: * but WITHOUT ANY WARRANTY; without even the implied warranty of
16: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
17: * of NON-INFRINGEMENT. See the GNU General Public License for more
18: * details.
19: *
20: * You should have received a copy of the GNU General Public License
21: * along with Resin Open Source; if not, write to the
22: *
23: * Free Software Foundation, Inc.
24: * 59 Temple Place, Suite 330
25: * Boston, MA 02111-1307 USA
26: *
27: * @author Scott Ferguson
28: */
29:
30: package com.caucho.config.attribute;
31:
32: import java.lang.reflect.*;
33: import java.util.*;
34:
35: import com.caucho.config.*;
36: import com.caucho.config.type.*;
37: import com.caucho.util.L10N;
38: import com.caucho.xml.QName;
39:
40: public class EntryAttribute extends Attribute {
41: private final ConfigType _type;
42:
43: public EntryAttribute() {
44: _type = TypeFactory.getType(EntryHolder.class);
45: }
46:
47: /**
48: * Returns the config type of the attribute value.
49: */
50: public ConfigType getConfigType() {
51: return _type;
52: }
53:
54: /**
55: * Sets the value of the attribute
56: */
57: @Override
58: public void setValue(Object bean, QName name, Object value)
59: throws ConfigException {
60: try {
61: EntryHolder entry = (EntryHolder) value;
62:
63: ((Map) bean).put(entry.getKey(), entry.getValue());
64: } catch (Exception e) {
65: throw ConfigException.create(e);
66: }
67: }
68:
69: /**
70: * Creates the child bean.
71: */
72: @Override
73: public Object create(Object parent) throws ConfigException {
74: return _type.create(parent);
75: }
76: }
|