/* * Copyright 2013 Nicolas Morel * * 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.github.nmorel.gwtjackson.client.deser.collection; import java.util.SortedSet; import java.util.TreeSet; import com.github.nmorel.gwtjackson.client.JsonDeserializer; /** * Default {@link JsonDeserializer} implementation for {@link SortedSet}. The deserialization process returns a {@link TreeSet}. * * @param <T> Type of the elements inside the {@link SortedSet} * @author Nicolas Morel * @version $Id: $ */ public final class SortedSetJsonDeserializer<T> extends BaseSortedSetJsonDeserializer<SortedSet<T>, T> { /** * <p>newInstance</p> * * @param deserializer {@link JsonDeserializer} used to deserialize the objects inside the {@link SortedSet}. * @param <T> Type of the elements inside the {@link SortedSet} * @return a new instance of {@link SortedSetJsonDeserializer} */ public static <T> SortedSetJsonDeserializer<T> newInstance( JsonDeserializer<T> deserializer ) { return new SortedSetJsonDeserializer<T>( deserializer ); } /** * @param deserializer {@link JsonDeserializer} used to deserialize the objects inside the {@link SortedSet}. */ private SortedSetJsonDeserializer( JsonDeserializer<T> deserializer ) { super( deserializer ); } /** {@inheritDoc} */ @Override protected SortedSet<T> newCollection() { return new TreeSet<T>(); } }