json/src/main/java/org/netbeans/html/json/spi/Transfer.java
author Jaroslav Tulach <jtulach@netbeans.org>
Tue, 26 Aug 2014 18:13:30 +0200
changeset 838 bdc3d696dd4a
parent 790 json/src/main/java/org/apidesign/html/json/spi/Transfer.java@30f20d9c0986
child 886 88d62267a0b5
permissions -rw-r--r--
During the API review process (bug 246133) the reviewers decided that in order to include html4j to NetBeans Platform, we need to stop using org.apidesign namespace and switch to NetBeans one. Repackaging all SPI packages into org.netbeans.html.smthng.spi.
jaroslav@23
     1
/**
jaroslav@358
     2
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
jaroslav@23
     3
 *
jaroslav@551
     4
 * Copyright 2013-2014 Oracle and/or its affiliates. All rights reserved.
jaroslav@23
     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@23
     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@23
    42
 */
jtulach@838
    43
package org.netbeans.html.json.spi;
jaroslav@23
    44
jaroslav@60
    45
import java.io.IOException;
jaroslav@60
    46
import java.io.InputStream;
jtulach@838
    47
import org.netbeans.html.context.spi.Contexts.Builder;
jaroslav@60
    48
jaroslav@534
    49
/** A {@link Builder service provider interface} responsible for 
jaroslav@23
    50
 * conversion of JSON objects to Java ones and vice-versa.
jaroslav@23
    51
 *
jtulach@790
    52
 * @author Jaroslav Tulach
jaroslav@23
    53
 */
jaroslav@23
    54
public interface Transfer {
jaroslav@23
    55
    /**
jaroslav@23
    56
     * Called to inspect properties of an object (usually a JSON or JavaScript
jaroslav@23
    57
     * wrapper).
jaroslav@23
    58
     *
jaroslav@23
    59
     * @param obj the object to inspect
jaroslav@23
    60
     * @param props the names of properties to check on the object
jaroslav@23
    61
     * <code>obj</code>
jaroslav@23
    62
     * @param values array of the same length as <code>props</code> should be
jaroslav@23
    63
     * filled by values of properties on the <code>obj</code>. If a property is
jaroslav@23
    64
     * not defined, a <code>null</code> value should be stored in the array
jaroslav@23
    65
     */
jaroslav@23
    66
    public void extract(Object obj, String[] props, Object[] values);
jaroslav@23
    67
    
jaroslav@60
    68
    /** Reads content of a stream and creates its JSON representation.
jaroslav@60
    69
     * The returned object is implementation dependant. It however needs
jaroslav@60
    70
     * to be acceptable as first argument of {@link #extract(java.lang.Object, java.lang.String[], java.lang.Object[]) extract}
jtulach@746
    71
     * method. If the stream contains representation or a JSON array,
jtulach@746
    72
     * an Object[] should be returned - each of its members should, by itself
jtulach@746
    73
     * be acceptable argument to 
jtulach@746
    74
     * the {@link #extract(java.lang.Object, java.lang.String[], java.lang.Object[]) extract} method.
jaroslav@60
    75
     * 
jaroslav@60
    76
     * @param is input stream to read data from
jaroslav@60
    77
     * @return an object representing the JSON data
jaroslav@60
    78
     * @throws IOException if something goes wrong
jaroslav@60
    79
     */
jaroslav@60
    80
    public Object toJSON(InputStream is) throws IOException;
jaroslav@60
    81
    
jaroslav@24
    82
    /** Starts the JSON or JSONP query. 
jaroslav@24
    83
     * 
jaroslav@24
    84
     * @param call description of the call to make
jaroslav@24
    85
     */
jaroslav@24
    86
    public void loadJSON(JSONCall call);
jaroslav@24
    87
    
jaroslav@23
    88
}