All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jose4j.json.internal.json_simple.JSONValue Maven / Gradle / Ivy

There is a newer version: 2.4.1.Final
Show newest version
/*
 * $Id: JSONValue.java,v 1.1 2006/04/15 14:37:04 platform Exp $
 * Created on 2006-4-15
 */
package org.jose4j.json.internal.json_simple;

import java.io.IOException;
import java.io.Reader;
import java.io.StringReader;
import java.io.StringWriter;
import java.io.Writer;
import java.util.Collection;
// import java.util.List;
import java.util.Map;

import org.jose4j.json.internal.json_simple.parser.JSONParser;
import org.jose4j.json.internal.json_simple.parser.ParseException;


/**
 * @author (originally) FangYidong
 */
public class JSONValue {
	/**
	 * Parse JSON text into java object from the input source. 
	 * Please use parseWithException() if you don't want to ignore the exception.
	 * 
	 * @see org.jose4j.json.internal.json_simple.parser.JSONParser#parse(Reader)
	 * @see #parseWithException(Reader)
	 * 
	 * @param in
	 * @return Instance of the following:
	 *	org.jose4j.json.org.json.json_simple.JSONObject,
	 * 	org.jose4j.json.org.json.json_simple.JSONArray,
	 * 	java.lang.String,
	 * 	java.lang.Number,
	 * 	java.lang.Boolean,
	 * 	null
	 * 
	 * @deprecated this method may throw an {@code Error} instead of returning
	 * {@code null}; please use {@link JSONValue#parseWithException(Reader)}
	 * instead
	 */
	public static Object parse(Reader in){
		try{
			JSONParser parser=new JSONParser();
			return parser.parse(in);
		}
		catch(Exception e){
			return null;
		}
	}
	
	/**
	 * Parse JSON text into java object from the given string. 
	 * Please use parseWithException() if you don't want to ignore the exception.
	 * 
	 * @see org.jose4j.json.internal.json_simple.parser.JSONParser#parse(Reader)
	 * @see #parseWithException(Reader)
	 * 
	 * @param s
	 * @return Instance of the following:
	 *	org.jose4j.json.org.json.json_simple.JSONObject,
	 * 	org.jose4j.json.org.json.json_simple.JSONArray,
	 * 	java.lang.String,
	 * 	java.lang.Number,
	 * 	java.lang.Boolean,
	 * 	null
	 * 
	 * @deprecated this method may throw an {@code Error} instead of returning
	 * {@code null}; please use {@link JSONValue#parseWithException(String)}
	 * instead
	 */
	public static Object parse(String s){
		StringReader in=new StringReader(s);
		return parse(in);
	}
	
	/**
	 * Parse JSON text into java object from the input source.
	 * 
	 * @see org.jose4j.json.internal.json_simple.parser.JSONParser
	 * 
	 * @param in
	 * @return Instance of the following:
	 * 	org.jose4j.json.org.json.json_simple.JSONObject,
	 * 	org.jose4j.json.org.json.json_simple.JSONArray,
	 * 	java.lang.String,
	 * 	java.lang.Number,
	 * 	java.lang.Boolean,
	 * 	null
	 * 
	 * @throws IOException
	 * @throws ParseException
	 */
	public static Object parseWithException(Reader in) throws IOException, ParseException{
		JSONParser parser=new JSONParser();
		return parser.parse(in);
	}
	
	public static Object parseWithException(String s) throws ParseException{
		JSONParser parser=new JSONParser();
		return parser.parse(s);
	}
	
    /**
     * Encode an object into JSON text and write it to out.
     * 

* If this object is a Map or a List, and it's also a JSONStreamAware or a JSONAware, JSONStreamAware or JSONAware will be considered firstly. *

* DO NOT call this method from writeJSONString(Writer) of a class that implements both JSONStreamAware and (Map or List) with * "this" as the first parameter, use JSONObject.writeJSONString(Map, Writer) or JSONArray.writeJSONString(List, Writer) instead. * * @see org.jose4j.json.internal.json_simple.JSONObject#writeJSONString(Map, Writer) * @see org.jose4j.json.internal.json_simple.JSONArray#writeJSONString(Collection, Writer) * * @param value * @param out */ public static void writeJSONString(Object value, Writer out) throws IOException { if(value == null){ out.write("null"); return; } if(value instanceof String){ out.write('\"'); out.write(escape((String)value)); out.write('\"'); return; } if(value instanceof Double){ if(((Double)value).isInfinite() || ((Double)value).isNaN()) out.write("null"); else out.write(value.toString()); return; } if(value instanceof Float){ if(((Float)value).isInfinite() || ((Float)value).isNaN()) out.write("null"); else out.write(value.toString()); return; } if(value instanceof Number){ out.write(value.toString()); return; } if(value instanceof Boolean){ out.write(value.toString()); return; } if((value instanceof JSONStreamAware)){ ((JSONStreamAware)value).writeJSONString(out); return; } if((value instanceof JSONAware)){ out.write(((JSONAware)value).toJSONString()); return; } if(value instanceof Map){ JSONObject.writeJSONString((Map)value, out); return; } if(value instanceof Collection){ JSONArray.writeJSONString((Collection)value, out); return; } if(value instanceof byte[]){ JSONArray.writeJSONString((byte[])value, out); return; } if(value instanceof short[]){ JSONArray.writeJSONString((short[])value, out); return; } if(value instanceof int[]){ JSONArray.writeJSONString((int[])value, out); return; } if(value instanceof long[]){ JSONArray.writeJSONString((long[])value, out); return; } if(value instanceof float[]){ JSONArray.writeJSONString((float[])value, out); return; } if(value instanceof double[]){ JSONArray.writeJSONString((double[])value, out); return; } if(value instanceof boolean[]){ JSONArray.writeJSONString((boolean[])value, out); return; } if(value instanceof char[]){ JSONArray.writeJSONString((char[])value, out); return; } if(value instanceof Object[]){ JSONArray.writeJSONString((Object[])value, out); return; } writeJSONString(value.toString(), out); } /** * Convert an object to JSON text. *

* If this object is a Map or a List, and it's also a JSONAware, JSONAware will be considered firstly. *

* DO NOT call this method from toJSONString() of a class that implements both JSONAware and Map or List with * "this" as the parameter, use JSONObject.toJSONString(Map) or JSONArray.toJSONString(List) instead. * * @see org.jose4j.json.internal.json_simple.JSONObject#toJSONString(Map) * @see org.jose4j.json.internal.json_simple.JSONArray#toJSONString(Collection) * * @param value * @return JSON text, or "null" if value is null or it's an NaN or an INF number. */ public static String toJSONString(Object value){ final StringWriter writer = new StringWriter(); try{ writeJSONString(value, writer); return writer.toString(); } catch(IOException e){ // This should never happen for a StringWriter throw new RuntimeException(e); } } /** * Escape quotes, \, /, \r, \n, \b, \f, \t and other control characters (U+0000 through U+001F). * @param s * @return string */ public static String escape(String s){ if(s==null) return null; StringBuilder sb = new StringBuilder(); escape(s, sb); return sb.toString(); } /** * @param s - Must not be null. * @param sb */ static void escape(String s, StringBuilder sb) { final int len = s.length(); for(int i=0;i='\u0000' && ch<='\u001F') || (ch>='\u007F' && ch<='\u009F') || (ch>='\u2000' && ch<='\u20FF')){ String ss=Integer.toHexString(ch); sb.append("\\u"); for(int k=0;k<4-ss.length();k++){ sb.append('0'); } sb.append(ss.toUpperCase()); } else{ sb.append(ch); } } }//for } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy