javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/api/Property.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Fri, 26 Apr 2013 13:48:36 +0200
branchmodel
changeset 1023 ad9a37489365
parent 770 26513bd377b9
child 1787 ea12a3bb4b33
permissions -rw-r--r--
Deprecating the javaquery.api's knockout annotation in favour of net.java.html.json ones. Providing default context for the browser.
jaroslav@490
     1
/**
jaroslav@490
     2
 * Back 2 Browser Bytecode Translator
jaroslav@490
     3
 * Copyright (C) 2012 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
jaroslav@490
     4
 *
jaroslav@490
     5
 * This program is free software: you can redistribute it and/or modify
jaroslav@490
     6
 * it under the terms of the GNU General Public License as published by
jaroslav@490
     7
 * the Free Software Foundation, version 2 of the License.
jaroslav@490
     8
 *
jaroslav@490
     9
 * This program is distributed in the hope that it will be useful,
jaroslav@490
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
jaroslav@490
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
jaroslav@490
    12
 * GNU General Public License for more details.
jaroslav@490
    13
 *
jaroslav@490
    14
 * You should have received a copy of the GNU General Public License
jaroslav@490
    15
 * along with this program. Look for COPYING file in the top folder.
jaroslav@490
    16
 * If not, see http://opensource.org/licenses/GPL-2.0.
jaroslav@490
    17
 */
jaroslav@490
    18
package org.apidesign.bck2brwsr.htmlpage.api;
jaroslav@490
    19
jaroslav@490
    20
import java.lang.annotation.Retention;
jaroslav@490
    21
import java.lang.annotation.RetentionPolicy;
jaroslav@490
    22
import java.lang.annotation.Target;
jaroslav@770
    23
import java.util.List;
jaroslav@490
    24
jaroslav@1023
    25
/** 
jaroslav@1023
    26
 * @deprecated Replaced by new {@link net.java.html.json.Property net.java.html.json} API.
jaroslav@490
    27
 * @author Jaroslav Tulach <jtulach@netbeans.org>
jaroslav@490
    28
 */
jaroslav@490
    29
@Retention(RetentionPolicy.SOURCE)
jaroslav@490
    30
@Target({})
jaroslav@1023
    31
@Deprecated
jaroslav@490
    32
public @interface Property {
jaroslav@770
    33
    /** Name of the property. Will be used to define proper getter and setter
jaroslav@770
    34
     * in the associated class.
jaroslav@770
    35
     * 
jaroslav@770
    36
     * @return valid java identifier
jaroslav@770
    37
     */
jaroslav@490
    38
    String name();
jaroslav@770
    39
    
jaroslav@770
    40
    /** Type of the property. Can either be primitive type (like <code>int.class</code>,
jaroslav@770
    41
     * <code>double.class</code>, etc.), {@link String} or complex model
jaroslav@770
    42
     * class (defined by {@link Model} property).
jaroslav@770
    43
     * 
jaroslav@770
    44
     * @return the class of the property
jaroslav@770
    45
     */
jaroslav@490
    46
    Class<?> type();
jaroslav@770
    47
    
jaroslav@770
    48
    /** Is this property an array of the {@link #type()} or a single value?
jaroslav@770
    49
     * If the property is an array, only its getter (returning mutable {@link List} of
jaroslav@770
    50
     * the boxed {@link #type()}).
jaroslav@770
    51
     * 
jaroslav@770
    52
     * @return true, if this is supposed to be an array of values.
jaroslav@770
    53
     */
jaroslav@760
    54
    boolean array() default false;
jaroslav@490
    55
}