blob: 3e7c319aa746f0c3767a17b82b07184b24eb798a [file] [log] [blame]
// Copyright (C) 2012 The Android Open Source Project
//
// 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.gerrit.json;
import com.google.gson.FieldNamingPolicy;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import java.sql.Timestamp;
/** Standard output format used by an API call. */
public enum OutputFormat {
/**
* The output is a human readable text format. It may also be regular enough to be machine
* readable. Whether or not the text format is machine readable and will be committed to as a long
* term format that tools can build upon is specific to each API call.
*/
TEXT,
/**
* Pretty-printed JSON format. This format uses whitespace to make the output readable by a human,
* but is also machine readable with a JSON library. The structure of the output is a long term
* format that tools can rely upon.
*/
JSON,
/**
* Same as {@link #JSON}, but with unnecessary whitespace removed to save generation time and copy
* costs. Typically JSON_COMPACT format is used by a browser based HTML client running over the
* network.
*/
JSON_COMPACT;
/** @return true when the format is either JSON or JSON_COMPACT. */
public boolean isJson() {
return this == JSON_COMPACT || this == JSON;
}
/** @return a new Gson instance configured according to the format. */
public GsonBuilder newGsonBuilder() {
if (!isJson()) {
throw new IllegalStateException(String.format("%s is not JSON", this));
}
GsonBuilder gb =
new GsonBuilder()
.setFieldNamingPolicy(FieldNamingPolicy.LOWER_CASE_WITH_UNDERSCORES)
.registerTypeAdapter(Timestamp.class, new SqlTimestampDeserializer())
.registerTypeAdapterFactory(new EnumTypeAdapterFactory());
if (this == OutputFormat.JSON) {
gb.setPrettyPrinting();
}
return gb;
}
/** @return a new Gson instance configured according to the format. */
public Gson newGson() {
return newGsonBuilder().create();
}
}