core/src/main/java/org/apidesign/bck2brwsr/core/JavaScriptBody.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Tue, 11 Dec 2012 11:08:42 +0100
branchlazyvm
changeset 304 3090a35d970f
parent 94 19497b4312bb
permissions -rw-r--r--
No need to use reflection when Bck2Brwsr has public API
     1 /**
     2  * Back 2 Browser Bytecode Translator
     3  * Copyright (C) 2012 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
     4  *
     5  * This program is free software: you can redistribute it and/or modify
     6  * it under the terms of the GNU General Public License as published by
     7  * the Free Software Foundation, version 2 of the License.
     8  *
     9  * This program is distributed in the hope that it will be useful,
    10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
    11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    12  * GNU General Public License for more details.
    13  *
    14  * You should have received a copy of the GNU General Public License
    15  * along with this program. Look for COPYING file in the top folder.
    16  * If not, see http://opensource.org/licenses/GPL-2.0.
    17  */
    18 package org.apidesign.bck2brwsr.core;
    19 
    20 import java.lang.annotation.ElementType;
    21 import java.lang.annotation.Retention;
    22 import java.lang.annotation.RetentionPolicy;
    23 import java.lang.annotation.Target;
    24 
    25 /** Put this method on a method in case it should have a special
    26  * body in the <em>JavaScript</em>.
    27  *
    28  * @author Jaroslav Tulach <jtulach@netbeans.org>
    29  */
    30 @Retention(RetentionPolicy.CLASS)
    31 @Target({ ElementType.METHOD, ElementType.CONSTRUCTOR })
    32 public @interface JavaScriptBody {
    33     /** Names of parameters for the method. 
    34      * 
    35      * <!--
    36      * If not specified
    37      * it will be <code>arg0, arg1, arg2</code>. In case of
    38      * instance methods, the <code>arg0</code> is reference
    39      * to <code>this</code>.
    40      * -->
    41      * 
    42      * @return array of the names of parameters for the method
    43      *    in JavaScript
    44      */
    45     public String[] args();
    46     
    47     /** The actual body of the method in JavaScript. This string will be
    48      * put into generated header (ends with '{') and footer (ends with '}').
    49      */
    50     public String body();
    51 }