/* Wotonomy: OpenStep design patterns for pure Java applications. Copyright (C) 2001 Intersect Software Corporation This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; if not, see http://www.gnu.org */ package net.wotonomy.foundation; import java.util.List; import java.util.Map; /** * NSKeyValueCodingAdditions defines an interface for classes * that need to have more control over the wotonomy's bulk * property copying and cloning facilities.

* * @author michael@mpowers.net * @author $Author: cgruber $ * @version $Revision: 893 $ */ public interface NSKeyValueCodingAdditions extends NSKeyValueCoding { /** * Returns the value for the specified key path, which is * a series of keys delimited by ".", for example: * "createTime.year.length". */ Object valueForKeyPath( String aKeyPath ); /** * Sets the value for the specified key path, which is * a series of keys delimited by ".", for example: * "createTime.year.length". * The value is set for the last object referenced by * the key path. */ void takeValueForKeyPath( Object aValue, String aKeyPath ); /** * Returns a Map of the specified keys to their values, * each of which might be obtained by calling valueForKey. */ NSDictionary valuesForKeys( List aKeyList ); /** * Takes the keys from the specified map as properties * and applies the corresponding values, each of which * might be set by calling takeValueForKey. */ void takeValuesFromDictionary( Map aMap ); /** * Static utility methods that * call the appropriate method if the object implements * NSKeyValueCodingAdditions, otherwise calls the method * on DefaultImplementation. */ public class Utility { /** * Calls the appropriate method if the object implements * NSKeyValueCodingAdditions, otherwise calls the method * on DefaultImplementation. */ public static void takeValuesFromDictionary( Object object, Map dictionary) { if (object instanceof NSKeyValueCodingAdditions) { ((NSKeyValueCodingAdditions)object).takeValuesFromDictionary(dictionary); } else { DefaultImplementation.takeValuesFromDictionary(object, dictionary); } } /** * Calls the appropriate method if the object implements * NSKeyValueCodingAdditions, otherwise calls the method * on DefaultImplementation. */ public static void takeValueForKeyPath( Object object, Object aValue, String aKeyPath) { if (object instanceof NSKeyValueCodingAdditions) { ((NSKeyValueCodingAdditions)object).takeValueForKeyPath(aValue, aKeyPath); } else { DefaultImplementation.takeValueForKeyPath(object, aValue, aKeyPath); } } /** * Calls the appropriate method if the object implements * NSKeyValueCodingAdditions, otherwise calls the method * on DefaultImplementation. */ public static NSDictionary valuesForKeys( Object object, List keys) { if (object instanceof NSKeyValueCodingAdditions) { return ((NSKeyValueCodingAdditions)object).valuesForKeys(keys); } else { return DefaultImplementation.valuesForKeys(object, keys); } } /** * Calls the appropriate method if the object implements * NSKeyValueCodingAdditions, otherwise calls the method * on DefaultImplementation. */ public static Object valueForKeyPath( Object object, String aKeyPath) { if (object instanceof NSKeyValueCodingAdditions) { return ((NSKeyValueCodingAdditions)object).valueForKeyPath(aKeyPath); } else { return DefaultImplementation.valueForKeyPath(object, aKeyPath); } } } /** * Provides a reflection-based implementation for classes that * don't implement NSKeyValueCodingAdditions. */ public class DefaultImplementation { /** * Provides a reflection-based implementation for classes that * don't implement NSKeyValueCodingAdditions. */ public static void takeValuesFromDictionary( Object object, Map dictionary) { throw new RuntimeException( "Not implemented yet." ); } /** * Provides a reflection-based implementation for classes that * don't implement NSKeyValueCodingAdditions. */ public static void takeValueForKeyPath( Object object, Object aValue, String aKeyPath) { // currently, NSKeyValueCoding.takeValueForKey accepts paths NSKeyValueCoding.DefaultImplementation.takeValueForKey( object, aValue, aKeyPath ); } /** * Provides a reflection-based implementation for classes that * don't implement NSKeyValueCodingAdditions. */ public static NSDictionary valuesForKeys( Object object, List keys) { throw new RuntimeException( "Not implemented yet." ); } /** * Provides a reflection-based implementation for classes that * don't implement NSKeyValueCodingAdditions. */ public static Object valueForKeyPath( Object object, String aKeyPath) { // currently, NSKeyValueCoding.valueForKey accepts paths return NSKeyValueCoding.DefaultImplementation.valueForKey( object, aKeyPath ); } } } /* * $Log$ * Revision 1.2 2006/02/16 13:15:00 cgruber * Check in all sources in eclipse-friendly maven-enabled packages. * * Revision 1.2 2003/01/18 23:30:42 mpowers * WODisplayGroup now compiles. * * Revision 1.1 2003/01/17 14:40:49 mpowers * Adding files to fix build. * * Revision 1.3 2001/12/10 15:25:11 mpowers * Now properly extending NSKeyValueCoding. * * Revision 1.2 2001/04/28 14:12:23 mpowers * Refactored cloning/copying into KeyValueCodingUtilities. * * Revision 1.1 2001/03/29 03:29:49 mpowers * Now using KeyValueCoding and Support instead of Introspector. * * Revision 1.2 2001/03/28 16:12:30 mpowers * Documented interface. * * Revision 1.1 2001/03/27 23:25:05 mpowers * Contributing interface, no docs yet. * * */