| 
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
 20 /**
 21  * Represents a Service class in Griffon.<p>
 22  *
 23  * @author Andres Almiray
 24  * @since 2.0.0
 25  */
 26 public interface GriffonServiceClass extends GriffonClass {
 27     /**
 28      * "service"
 29      */
 30     String TYPE = "service";
 31     /**
 32      * "Service"
 33      */
 34     String TRAILING = "Service";
 35
 36     /**
 37      * Matches all public methods and all properties that
 38      * have a Closure as value.<p>
 39      *
 40      * @return an array containing the names of all service methods.
 41      */
 42     @Nonnull
 43     String[] getServiceNames();
 44
 45     /**
 46      * Matches all public methods and closure properties whose name
 47      * matches the event handler convention, i.e, starts with "on" and
 48      * is followed by at least one uppercase character.<p>
 49      *
 50      * @return an array containing the names of all event handlers.
 51      */
 52     @Nonnull
 53     String[] getEventNames();
 54 }
 |