001 /* ==================================================================== 002 * The Apache Software License, Version 1.1 003 * 004 * Copyright (c) 2003 The Apache Software Foundation. All rights 005 * reserved. 006 * 007 * Redistribution and use in source and binary forms, with or without 008 * modification, are permitted provided that the following conditions 009 * are met: 010 * 011 * 1. Redistributions of source code must retain the above copyright 012 * notice, this list of conditions and the following disclaimer. 013 * 014 * 2. Redistributions in binary form must reproduce the above copyright 015 * notice, this list of conditions and the following disclaimer in 016 * the documentation and/or other materials provided with the 017 * distribution. 018 * 019 * 3. The end-user documentation included with the redistribution, 020 * if any, must include the following acknowledgment: 021 * "This product includes software developed by the 022 * Apache Software Foundation (http://www.apache.org/)." 023 * Alternately, this acknowledgment may appear in the software itself, 024 * if and wherever such third-party acknowledgments normally appear. 025 * 026 * 4. The names "The Jakarta Project", "Commons", and "Apache Software 027 * Foundation" must not be used to endorse or promote products derived 028 * from this software without prior written permission. For written 029 * permission, please contact apache@apache.org. 030 * 031 * 5. Products derived from this software may not be called "Apache", 032 * nor may "Apache" appear in their name, without prior written 033 * permission of the Apache Software Foundation. 034 * 035 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 036 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 037 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 038 * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR 039 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 040 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 041 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF 042 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 043 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 044 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 045 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 046 * SUCH DAMAGE. 047 * ==================================================================== 048 * 049 * This software consists of voluntary contributions made by many 050 * individuals on behalf of the Apache Software Foundation. For more 051 * information on the Apache Software Foundation, please see 052 * <http://www.apache.org/>. 053 * 054 */ 055 package org.jpu.patterns.factory; 056 057 import java.util.Arrays; 058 059 /** 060 * Used by clients of {@link IPrototypeFactory} to pass options adjusting 061 * its behavior. 062 */ 063 public class FactoryOptions implements Cloneable { 064 public Object clone() { 065 try { 066 return super.clone(); 067 } 068 catch( CloneNotSupportedException e ) { 069 throw new PrototypeFactoryRuntimeException(e); 070 } 071 } 072 public static FactoryOptions makeNew(FactoryOptions o) { 073 return (o == null) ? new FactoryOptions() : (FactoryOptions)o.clone(); 074 } 075 public static FactoryOptions defaultIfNull(FactoryOptions o) { 076 if ( o == null ) { 077 o = new FactoryOptions(); 078 } 079 return o; 080 } 081 public FactoryOptions setCopy(boolean b) { 082 copy = b; 083 return this; 084 } 085 public boolean getCopy() { 086 return copy; 087 } 088 089 /** 090 * Sets the 'throwExc' attribute to the given value. This 091 * attribute specifies whether or not a {@link NoSuchPrototypeException} 092 * should be thrown if a prototype is requested by a key under which no 093 * prototype has been registered. If this attribute is <code>false</code>, 094 * the method called to request the object will return <code>null</code> 095 * instead of throwing an exception. 096 * <p> 097 * 'throwExc' is <code>true</code> by default. 098 */ 099 public FactoryOptions setThrowExc(boolean b) { 100 throwExc = b; 101 return this; 102 } 103 104 /** 105 * Returns the 'throwExc' attribute. See {@link #setThrowExc}. 106 */ 107 public boolean getThrowExc() { 108 return throwExc; 109 } 110 111 /** 112 * Sets the 'userData' attribute to the given value. User data is an array of 113 * <code>Object</code>'s used to parameterize instantiations done by 114 * the factory. These parameters are ignored by the classes in 115 * {@link org.jpu.patterns.factory} but may be referenced either 116 * by strategies registered with the factory by clients, or by 117 * subclasses that override method accepting a {@link FactoryOptions} 118 * parameter. 119 * <p> 120 * Typically, 'userData' would be used in conjunction with 121 * {@link IPrototypeFactory.IInstantiator}'s for prototype classes 122 * whose constructors require one or more parameters. 123 * <p> 124 * 'userData' is <code>null</code> by default. 125 */ 126 public FactoryOptions setUserData(Object[] m) { 127 userdata = m; 128 return this; 129 } 130 131 /** 132 * Returns the 'userData' attribute. See {@link #setUserData}. 133 */ 134 public Object[] getUserData() { 135 return userdata; 136 } 137 public String toString() { 138 return "copy=" + copy + ", throwExc=" + throwExc; 139 } 140 public boolean copy = true; 141 public boolean throwExc = true; 142 public Object[] userdata = null; 143 } 144 145 146 147