All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.caucho.config.gen.AspectGenerator Maven / Gradle / Ivy

There is a newer version: 4.0.66
Show newest version
/*
 * Copyright (c) 1998-2012 Caucho Technology -- all rights reserved
 *
 * This file is part of Resin(R) Open Source
 *
 * Each copy or derived work must preserve the copyright notice and this
 * notice unmodified.
 *
 * Resin Open Source is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * Resin Open Source is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
 * of NON-INFRINGEMENT.  See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License
 * along with Resin Open Source; if not, write to the
 *
 *   Free Software Foundation, Inc.
 *   59 Temple Place, Suite 330
 *   Boston, MA 02111-1307  USA
 *
 * @author Scott Ferguson
 */
package com.caucho.config.gen;

import java.io.IOException;
import java.util.HashMap;

import javax.enterprise.inject.spi.AnnotatedMethod;

import com.caucho.inject.Module;
import com.caucho.java.JavaWriter;

/**
 * Represents a filter for invoking a method
 * 
 * 
 * [method-prologue]
 * MyType foo(args)
 * {
 *   [pre-try]
 *   try {
 *     [pre-call]
 *     value = [call]
 *     [post-call]
 *     return value;
 *   } catch (ApplicationException e) {
 *     [application-exception]
 *     throw e;
 *   } catch (RuntimeException e) {
 *     [system-exception]
 *     throw e;
 *   } finally {
 *     [finally]
 *   }
 *   [post-finally]
 * }
 * 
*/ @Module public interface AspectGenerator { /** * Returns the underlying method. */ public AnnotatedMethod getMethod(); /** * Top-level generator. */ public void generate(JavaWriter out, HashMap prologueMap) throws IOException; /** * Generates the static class prologue */ public void generateBeanPrologue(JavaWriter out, HashMap map) throws IOException; /** * Generates initialization in the constructor */ public void generateBeanConstructor(JavaWriter out, HashMap map) throws IOException; /** * Generates initialization in the proxy constructor */ public void generateProxyConstructor(JavaWriter out, HashMap map) throws IOException; /** * Generates inject code after the constructor */ public void generateInject(JavaWriter out, HashMap map) throws IOException; /** * Generates @PostConstruct code */ public void generatePostConstruct(JavaWriter out, HashMap map) throws IOException; /** * Generates @PreDestroy code */ public void generatePreDestroy(JavaWriter out, HashMap map) throws IOException; /** * Generates epilogue */ public void generateEpilogue(JavaWriter out, HashMap map) throws IOException; /** * Generates any destroy lifecycle code. */ public void generateDestroy(JavaWriter out, HashMap map) throws IOException; // // method call interception // /** * Generates the static class prologue */ public void generateMethodPrologue(JavaWriter out, HashMap map) throws IOException; // // async dispatch method // public void generateAsync(JavaWriter out) throws IOException; /** * Generates code before the try block *
   * retType myMethod(...)
   * {
   *   [pre-try]
   *   try {
   *     ...
   * }
   * 
*/ public void generatePreTry(JavaWriter out) throws IOException; /** * Generates code before the call, in the try block. *
   * retType myMethod(...)
   * {
   *   try {
   *     [pre-call]
   *     value = bean.myMethod(...);
   *     ...
   * }
   * 
*/ public void generatePreCall(JavaWriter out) throws IOException; /** * Generates the method interception code */ public void generateCall(JavaWriter out) throws IOException; /** * Generates code after the call, before the return. *
   * retType myMethod(...)
   * {
   *   try {
   *     ...
   *     value = bean.myMethod(...);
   *     [post-call]
   *     return value;
   *   } finally {
   *     ...
   *   }
   * }
   * 
*/ public void generatePostCall(JavaWriter out) throws IOException; /** * Returns true if the application exception can be thrown. */ public boolean isApplicationExceptionThrown(); /** * Generates application (checked) exception code for * the method. */ public void generateApplicationException(JavaWriter out, Class exn) throws IOException; /** * Generates system (runtime) exception code for * the method. */ public void generateSystemException(JavaWriter out, Class exn) throws IOException; /** * Generates finally code for the method *
   * retType myMethod(...)
   * {
   *   try {
   *     ...
   *     value = bean.myMethod(...);
   *     ...
   *     return value;
   *   } finally {
   *     [finally]
   *   }
   * }
   * 
*/ public void generateFinally(JavaWriter out) throws IOException; /** * Generates finally code for the method *
   * retType myMethod(...)
   * {
   *   try {
   *     ...
   *     value = bean.myMethod(...);
   *     ...
   *     return value;
   *   } finally {
   *     ...
   *   }
   *   [post-finally]
   * }
   * 
*/ public void generatePostFinally(JavaWriter out) throws IOException; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy