core/src/main/java/org/apidesign/bck2brwsr/core/JavaScriptPrototype.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Thu, 13 Dec 2012 23:20:47 +0100
changeset 316 8da329789435
parent 239 8ceee38f5840
permissions -rw-r--r--
Providing JavaScript specific implementations of Hashtable and Vector. Those should likely be faster for the JavaScript VM than interpreting bytecode. This is the way to get the best of JavaScript and yet provide reasonably well working implementation in Java.
     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 /** Controls how JavaScript inheritance should be handled.
    26  * @author Jaroslav Tulach <jtulach@netbeans.org>
    27  */
    28 @Retention(RetentionPolicy.CLASS)
    29 @Target({ ElementType.TYPE })
    30 public @interface JavaScriptPrototype {
    31     /** Expression that identifies the function where all methods
    32      * should be added into. If this attribute is unspecified
    33      * all methods are added to the same object specified by
    34      * {@link #prototype()}.
    35      * 
    36      * @return name of function to contain methods found in given class
    37      */
    38     String container() default "";
    39     /** Expression that defines the way to construct prototype for this
    40      * class.
    41      * @return expression to construct prototype
    42      */
    43     String prototype();
    44 }