1  /*
     2   * Copyright the original author or authors.
     3   * 
     4   * Licensed under the MOZILLA PUBLIC LICENSE, Version 1.1 (the "License");
     5   * you may not use this file except in compliance with the License.
     6   * You may obtain a copy of the License at
     7   * 
     8   *      http://www.mozilla.org/MPL/MPL-1.1.html
     9   * 
    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  
    17  import org.as2lib.core.BasicInterface;
    18  
    19  /**
    20   * {@code Aspect} represents an aspect in an Aspect-Oriented Programming language. An
    21   * aspect's sole responsibility is to group varies advices in a logical sense.
    22   * Convenient implementations of this interface also offer support to easily add
    23   * advices.
    24   *
    25   * @author Simon Wacker
    26   * @see <a href="http://www.simonwacker.com/blog/archives/000041.php">Terms and AspectJ</a>
    27   */
    28  interface org.as2lib.aop.Aspect extends BasicInterface {
    29  	
    30  	/**
    31  	 * Returns the advices that were added externally or internally to this aspect.
    32  	 * These advices will be used for the weaving process.
    33  	 * 
    34  	 * @returns the advices used by the weaver
    35  	 */
    36  	public function getAdvices(Void):Array;
    37  	
    38  }