001    // Copyright 2010, 2011, 2012 The Apache Software Foundation
002    //
003    // Licensed under the Apache License, Version 2.0 (the "License");
004    // you may not use this file except in compliance with the License.
005    // You may obtain a copy of the License at
006    //
007    // http://www.apache.org/licenses/LICENSE-2.0
008    //
009    // Unless required by applicable law or agreed to in writing, software
010    // distributed under the License is distributed on an "AS IS" BASIS,
011    // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
012    // See the License for the specific language governing permissions and
013    // limitations under the License.
014    
015    package org.apache.tapestry5.internal.transform;
016    
017    import org.apache.tapestry5.Binding;
018    import org.apache.tapestry5.annotations.Parameter;
019    import org.apache.tapestry5.internal.InternalComponentResources;
020    import org.apache.tapestry5.ioc.services.TypeCoercer;
021    import org.apache.tapestry5.plastic.FieldConduit;
022    
023    /**
024     * A facade around {@link Binding} and {@link InternalComponentResources} that is used to instrument
025     * fields with the {@link Parameter} annotation. Extends {@link FieldConduit} so that
026     * the get() method implicitly coerces the value to the field's type.
027     * <p/>
028     * {@link #get(Object, org.apache.tapestry5.plastic.InstanceContext)} will read from the underlying {@link Binding} and used the {@link TypeCoercer} coerce the value to the
029     * parameter field's type. get() also includes a null value check (as per {@link Parameter#allowNull()}.
030     * <p/>
031     * {@link #set(Object, org.apache.tapestry5.plastic.InstanceContext, Object)} pushes the value into the binding.
032     *
033     * @since 5.2.0
034     */
035    public interface ParameterConduit extends FieldConduit<Object>
036    {
037        /**
038         * Determines if the parameter is actually bound.
039         *
040         * @return true if bound
041         */
042        boolean isBound();
043    
044        /**
045         * Resets the conduit, clearing any <em>temporarily</em> cached data (from a non-invariant {@link Binding}).
046         */
047        void reset();
048    }