| 
01 /*02  * Copyright 2008-2015 the original author or authors.
 03  *
 04  * Licensed under the Apache License, Version 2.0 (the "License");
 05  * you may not use this file except in compliance with the License.
 06  * You may obtain a copy of the License at
 07  *
 08  *     http://www.apache.org/licenses/LICENSE-2.0
 09  *
 10  * Unless required by applicable law or agreed to in writing, software
 11  * distributed under the License is distributed on an "AS IS" BASIS,
 12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 13  * See the License for the specific language governing permissions and
 14  * limitations under the License.
 15  */
 16 package griffon.core.artifact;
 17
 18 import javax.annotation.Nonnull;
 19 import javax.annotation.Nullable;
 20
 21 /**
 22  * Represents a Model class in Griffon.<p>
 23  *
 24  * @author Andres Almiray
 25  * @since 2.0.0
 26  */
 27 public interface GriffonModelClass extends GriffonClass {
 28     /**
 29      * "model"
 30      */
 31     String TYPE = "model";
 32     /**
 33      * "Model"
 34      */
 35     String TRAILING = "Model";
 36
 37     /**
 38      * Matches all public properties that are not event handlers nor
 39      * have a Closure as their value.<p>
 40      *
 41      * @return an array containing the names of all model properties.
 42      */
 43     @Nonnull
 44     String[] getPropertyNames();
 45
 46     /**
 47      * Matches all public methods and closure properties whose name
 48      * matches the event handler convention, i.e, starts with "on" and
 49      * is followed by at least one uppercase character.<p>
 50      *
 51      * @return an array containing the names of all event handlers.
 52      */
 53     @Nonnull
 54     String[] getEventNames();
 55
 56     /**
 57      * Sets a value of a model property.
 58      *
 59      * @param model        the model to be affected
 60      * @param propertyName the name of the property to update
 61      * @param value        new value
 62      */
 63     void setModelPropertyValue(@Nonnull GriffonModel model, @Nonnull String propertyName, @Nullable Object value);
 64
 65     /**
 66      * Returns the value of a model property.
 67      *
 68      * @param model        the model to query
 69      * @param propertyName the name of the property to query
 70      * @return the value of the property
 71      */
 72     @Nullable
 73     Object getModelPropertyValue(@Nonnull GriffonModel model, @Nonnull String propertyName);
 74 }
 |