boot/src/main/java/net/java/html/js/JavaScriptBody.java
author Jaroslav Tulach <jaroslav.tulach@netbeans.org>
Fri, 07 Feb 2014 07:44:34 +0100
changeset 551 7ca2253fa86d
parent 549 11198031c76a
child 570 0e831501e072
permissions -rw-r--r--
Updating copyright headers to mention current year
jaroslav@123
     1
/**
jaroslav@358
     2
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
jaroslav@123
     3
 *
jaroslav@551
     4
 * Copyright 2013-2014 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@551
    30
 * Software is Oracle. Portions Copyright 2013-2014 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@513
    52
 * interact with the surrounding JavaScript environment. Check the list
jaroslav@513
    53
 * <a href="package-summary.html">use-cases</a> to see real world
jaroslav@513
    54
 * use of this annotation.
jaroslav@549
    55
 * <p>
jaroslav@549
    56
 * Visit an <a target="_blank" href="http://dew.apidesign.org/dew/#7102188">on-line demo</a>
jaroslav@549
    57
 * to play with {@link JavaScriptBody} annotation for real.
jaroslav@123
    58
 *
jaroslav@123
    59
 * @author Jaroslav Tulach <jtulach@netbeans.org>
jaroslav@123
    60
 */
jaroslav@123
    61
@Retention(RetentionPolicy.CLASS)
jaroslav@123
    62
@Target({ ElementType.METHOD, ElementType.CONSTRUCTOR })
jaroslav@123
    63
public @interface JavaScriptBody {
jaroslav@123
    64
    /** Names of parameters for the method generated method that can
jaroslav@123
    65
     * be referenced from {@link #body()}.
jaroslav@123
    66
     * 
jaroslav@123
    67
     * @return array of the names of parameters for the method
jaroslav@123
    68
     *    in JavaScript
jaroslav@123
    69
     */
jaroslav@123
    70
    public String[] args();
jaroslav@123
    71
    
jaroslav@123
    72
    /** The actual body of the method in JavaScript. This string will be
jaroslav@123
    73
     * put into generated header (last character is '{') and footer (e.g. '}').
jaroslav@123
    74
     * The body can reference provided arguments. In case of non-static
jaroslav@123
    75
     * instance method it may reference <code>this</code>. 
jaroslav@123
    76
     * 
jaroslav@123
    77
     * @return JavaScript body of a function which can access {@link #args()} and possibly
jaroslav@123
    78
     * <code>this</code>
jaroslav@123
    79
     */
jaroslav@123
    80
    public String body();
jaroslav@160
    81
jaroslav@160
    82
    /** Should a special syntax for calling back into Java object be turned on?
jaroslav@160
    83
     * The syntax begins with <b>{@code @}</b> followed by fully qualified
jaroslav@160
    84
     * package name of the class. Now followed by <b>::</b> and a method in
jaroslav@160
    85
     * the class followed by its parameters enclosed inside <b>(...)</b>.
jaroslav@160
    86
     * This is the syntax one can use to call <code>run()</code> 
jaroslav@160
    87
     * method of {@link Runnable}:
jaroslav@160
    88
     * <pre>r.@java.lang.Runnable::run()()</pre>.
jaroslav@191
    89
     * One can also call static methods. Just use:
jaroslav@191
    90
     * <pre>var ten = @java.lang.Integer::parseInt(Ljava/lang/String;)("10")</pre>
jaroslav@160
    91
     * 
jaroslav@160
    92
     * @return true, if the script should be scanned for special callback
jaroslav@160
    93
     *   syntax
jaroslav@160
    94
     */
jaroslav@160
    95
    public boolean javacall() default false;
jaroslav@123
    96
}