net.minidev.json.mapper.AMapper Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of json-smart Show documentation
Show all versions of json-smart Show documentation
JSON (JavaScript Object Notation) is a lightweight data-interchange format. It is easy for humans to read and write. It is easy for machines to parse and generate. It is based on a subset of the JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999. JSON is a text format that is completely language independent but uses conventions that are familiar to programmers of the C-family of languages, including C, C++, C#, Java, JavaScript, Perl, Python, and many others. These properties make JSON an ideal data-interchange language.
package net.minidev.json.mapper;
/*
* Copyright 2011 JSON-SMART authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.io.IOException;
import java.lang.reflect.Type;
import net.minidev.json.parser.ParseException;
/**
* Default datatype mapper use by Json-smart ton store data.
*
* @author uriel Chemouni
*
* @param
*/
public abstract class AMapper {
private static String ERR_MSG = "Invalid or non Implemented status";
/**
* called when json-smart parser meet an object key
*/
public AMapper> startObject(String key) throws ParseException, IOException {
throw new RuntimeException(ERR_MSG);
}
/**
* called when json-smart parser start an array.
*
* @param key the destination key name, or null.
*/
public AMapper> startArray(String key) throws ParseException, IOException {
throw new RuntimeException(ERR_MSG);
}
/**
* called when json-smart done parssing a value
*/
public void setValue(Object current, String key, Object value) throws ParseException, IOException {
throw new RuntimeException(ERR_MSG);
}
/**
* -------------
*/
public Object getValue(Object current, String key) {
throw new RuntimeException(ERR_MSG);
}
// Object current,
public Type getType(String key) {
throw new RuntimeException(ERR_MSG);
}
/**
* add a value in an array json object.
*/
public void addValue(Object current, Object value) throws ParseException, IOException {
throw new RuntimeException(ERR_MSG);
}
/**
* use to instantiate a new object that will be used as an object
*/
public Object createObject() {
throw new RuntimeException(ERR_MSG);
}
/**
* use to instantiate a new object that will be used as an array
*/
public Object createArray() {
throw new RuntimeException(ERR_MSG);
}
/**
* Allow a mapper to converte a temprary structure to the final data format.
*
* example: convert an List to an int[]
*/
@SuppressWarnings("unchecked")
public T convert(Object current) {
return (T) current;
}
}