boot/src/main/java/net/java/html/js/JavaScriptBody.java
author Jaroslav Tulach <jaroslav.tulach@netbeans.org>
Mon, 16 Dec 2013 17:39:56 +0100
changeset 365 5c93ad8c7a15
parent 358 80702021b851
child 513 afeea7c35a95
permissions -rw-r--r--
The work on this project started in 2013
jaroslav@123
     1
/**
jaroslav@358
     2
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
jaroslav@123
     3
 *
jaroslav@365
     4
 * Copyright 2013-2013 Oracle and/or its affiliates. All rights reserved.
jaroslav@123
     5
 *
jaroslav@358
     6
 * Oracle and Java are registered trademarks of Oracle and/or its affiliates.
jaroslav@358
     7
 * Other names may be trademarks of their respective owners.
jaroslav@123
     8
 *
jaroslav@358
     9
 * The contents of this file are subject to the terms of either the GNU
jaroslav@358
    10
 * General Public License Version 2 only ("GPL") or the Common
jaroslav@358
    11
 * Development and Distribution License("CDDL") (collectively, the
jaroslav@358
    12
 * "License"). You may not use this file except in compliance with the
jaroslav@358
    13
 * License. You can obtain a copy of the License at
jaroslav@358
    14
 * http://www.netbeans.org/cddl-gplv2.html
jaroslav@358
    15
 * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
jaroslav@358
    16
 * specific language governing permissions and limitations under the
jaroslav@358
    17
 * License.  When distributing the software, include this License Header
jaroslav@358
    18
 * Notice in each file and include the License file at
jaroslav@358
    19
 * nbbuild/licenses/CDDL-GPL-2-CP.  Oracle designates this
jaroslav@358
    20
 * particular file as subject to the "Classpath" exception as provided
jaroslav@358
    21
 * by Oracle in the GPL Version 2 section of the License file that
jaroslav@358
    22
 * accompanied this code. If applicable, add the following below the
jaroslav@358
    23
 * License Header, with the fields enclosed by brackets [] replaced by
jaroslav@358
    24
 * your own identifying information:
jaroslav@358
    25
 * "Portions Copyrighted [year] [name of copyright owner]"
jaroslav@358
    26
 *
jaroslav@358
    27
 * Contributor(s):
jaroslav@358
    28
 *
jaroslav@358
    29
 * The Original Software is NetBeans. The Initial Developer of the Original
jaroslav@358
    30
 * Software is Oracle. Portions Copyright 2013-2013 Oracle. All Rights Reserved.
jaroslav@358
    31
 *
jaroslav@358
    32
 * If you wish your version of this file to be governed by only the CDDL
jaroslav@358
    33
 * or only the GPL Version 2, indicate your decision by adding
jaroslav@358
    34
 * "[Contributor] elects to include this software in this distribution
jaroslav@358
    35
 * under the [CDDL or GPL Version 2] license." If you do not indicate a
jaroslav@358
    36
 * single choice of license, a recipient has the option to distribute
jaroslav@358
    37
 * your version of this file under either the CDDL, the GPL Version 2 or
jaroslav@358
    38
 * to extend the choice of license to its licensees as provided above.
jaroslav@358
    39
 * However, if you add GPL Version 2 code and therefore, elected the GPL
jaroslav@358
    40
 * Version 2 license, then the option applies only if the new code is
jaroslav@358
    41
 * made subject to such option by the copyright holder.
jaroslav@123
    42
 */
jaroslav@123
    43
package net.java.html.js;
jaroslav@123
    44
jaroslav@123
    45
import java.lang.annotation.ElementType;
jaroslav@123
    46
import java.lang.annotation.Retention;
jaroslav@123
    47
import java.lang.annotation.RetentionPolicy;
jaroslav@123
    48
import java.lang.annotation.Target;
jaroslav@123
    49
jaroslav@123
    50
/** Put this annotation on a method to provide its special implementation
jaroslav@123
    51
 * in JavaScript. This is a way to define <em>native</em> methods that 
jaroslav@123
    52
 * interact with the surrounding environment.
jaroslav@123
    53
 *
jaroslav@123
    54
 * @author Jaroslav Tulach <jtulach@netbeans.org>
jaroslav@123
    55
 */
jaroslav@123
    56
@Retention(RetentionPolicy.CLASS)
jaroslav@123
    57
@Target({ ElementType.METHOD, ElementType.CONSTRUCTOR })
jaroslav@123
    58
public @interface JavaScriptBody {
jaroslav@123
    59
    /** Names of parameters for the method generated method that can
jaroslav@123
    60
     * be referenced from {@link #body()}.
jaroslav@123
    61
     * 
jaroslav@123
    62
     * @return array of the names of parameters for the method
jaroslav@123
    63
     *    in JavaScript
jaroslav@123
    64
     */
jaroslav@123
    65
    public String[] args();
jaroslav@123
    66
    
jaroslav@123
    67
    /** The actual body of the method in JavaScript. This string will be
jaroslav@123
    68
     * put into generated header (last character is '{') and footer (e.g. '}').
jaroslav@123
    69
     * The body can reference provided arguments. In case of non-static
jaroslav@123
    70
     * instance method it may reference <code>this</code>. 
jaroslav@123
    71
     * 
jaroslav@123
    72
     * @return JavaScript body of a function which can access {@link #args()} and possibly
jaroslav@123
    73
     * <code>this</code>
jaroslav@123
    74
     */
jaroslav@123
    75
    public String body();
jaroslav@160
    76
jaroslav@160
    77
    /** Should a special syntax for calling back into Java object be turned on?
jaroslav@160
    78
     * The syntax begins with <b>{@code @}</b> followed by fully qualified
jaroslav@160
    79
     * package name of the class. Now followed by <b>::</b> and a method in
jaroslav@160
    80
     * the class followed by its parameters enclosed inside <b>(...)</b>.
jaroslav@160
    81
     * This is the syntax one can use to call <code>run()</code> 
jaroslav@160
    82
     * method of {@link Runnable}:
jaroslav@160
    83
     * <pre>r.@java.lang.Runnable::run()()</pre>.
jaroslav@191
    84
     * One can also call static methods. Just use:
jaroslav@191
    85
     * <pre>var ten = @java.lang.Integer::parseInt(Ljava/lang/String;)("10")</pre>
jaroslav@160
    86
     * 
jaroslav@160
    87
     * @return true, if the script should be scanned for special callback
jaroslav@160
    88
     *   syntax
jaroslav@160
    89
     */
jaroslav@160
    90
    public boolean javacall() default false;
jaroslav@123
    91
}