/* * Copyright (c) 2012 Google Inc. * * 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. */ package com.google.api.client.extensions.android.json; import com.google.api.client.json.JsonFactory; import com.google.api.client.json.JsonGenerator; import com.google.api.client.util.Beta; import android.annotation.TargetApi; import android.util.JsonWriter; import java.io.IOException; import java.math.BigDecimal; import java.math.BigInteger; /** * {@link Beta} <br/> * Low-level JSON serializer implementation based on GSON. * * <p> * Implementation is not thread-safe. * </p> * * @author Yaniv Inbar */ @TargetApi(11) @Beta class AndroidJsonGenerator extends JsonGenerator { private final JsonWriter writer; private final AndroidJsonFactory factory; AndroidJsonGenerator(AndroidJsonFactory factory, JsonWriter writer) { this.factory = factory; this.writer = writer; // lenient to allow top-level values of any type writer.setLenient(true); } @Override public void flush() throws IOException { writer.flush(); } @Override public void close() throws IOException { writer.close(); } @Override public JsonFactory getFactory() { return factory; } @Override public void writeBoolean(boolean state) throws IOException { writer.value(state); } @Override public void writeEndArray() throws IOException { writer.endArray(); } @Override public void writeEndObject() throws IOException { writer.endObject(); } @Override public void writeFieldName(String name) throws IOException { writer.name(name); } @Override public void writeNull() throws IOException { writer.nullValue(); } @Override public void writeNumber(int v) throws IOException { writer.value(v); } @Override public void writeNumber(long v) throws IOException { writer.value(v); } @Override public void writeNumber(BigInteger v) throws IOException { writer.value(v); } @Override public void writeNumber(double v) throws IOException { writer.value(v); } @Override public void writeNumber(float v) throws IOException { writer.value(v); } @Override public void writeNumber(BigDecimal v) throws IOException { writer.value(v); } /** * Hack to support numbers encoded as a string for JsonWriter. Unfortunately, JsonWriter doesn't * provide a way to print an arbitrary-precision number given a String and instead expects the * number to extend Number. So this lets us bypass that problem by overriding the toString() * implementation of Number to use our string. Note that this is not actually a valid Number. */ static final class StringNumber extends Number { private static final long serialVersionUID = 1L; private final String encodedValue; StringNumber(String encodedValue) { this.encodedValue = encodedValue; } @Override public double doubleValue() { return 0; } @Override public float floatValue() { return 0; } @Override public int intValue() { return 0; } @Override public long longValue() { return 0; } @Override public String toString() { return encodedValue; } } @Override public void writeNumber(String encodedValue) throws IOException { writer.value(new StringNumber(encodedValue)); } @Override public void writeStartArray() throws IOException { writer.beginArray(); } @Override public void writeStartObject() throws IOException { writer.beginObject(); } @Override public void writeString(String value) throws IOException { writer.value(value); } @Override public void enablePrettyPrint() throws IOException { writer.setIndent(" "); } }