/*
* Copyright 2008-present MongoDB, 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.mongodb.util;
import java.util.List;
Objects of type ClassMapBasedObjectSerializer are constructed to perform instance specific object to JSON serialization schemes.
This class is not thread safe
Author: breinero
/**
* <p>Objects of type ClassMapBasedObjectSerializer are constructed to perform instance specific object to JSON serialization schemes.</p>
*
* <p>This class is not thread safe</p>
*
* @author breinero
*/
@SuppressWarnings("deprecation")
class ClassMapBasedObjectSerializer extends AbstractObjectSerializer {
Assign a ObjectSerializer to perform a type specific serialization scheme
Params: - c – this object's type serves as a key in the serialization map. ClassMapBasedObjectSerializer uses
org.bson.util.ClassMap and not only checks if 'c' is a key in the Map, but also walks the up superclass and
interface graph of 'c' to find matches. This means that it is only necessary assign ObjectSerializers to base
classes. @see org.bson.util.ClassMap
- serializer – performs the serialization mapping specific to the @param key type
/**
* Assign a ObjectSerializer to perform a type specific serialization scheme
*
* @param c this object's type serves as a key in the serialization map. ClassMapBasedObjectSerializer uses
* org.bson.util.ClassMap and not only checks if 'c' is a key in the Map, but also walks the up superclass and
* interface graph of 'c' to find matches. This means that it is only necessary assign ObjectSerializers to base
* classes. @see org.bson.util.ClassMap
* @param serializer performs the serialization mapping specific to the @param key type
*/
@SuppressWarnings("rawtypes")
void addObjectSerializer(final Class c, final ObjectSerializer serializer) {
_serializers.put(c, serializer);
}
Params: - obj – the object to be serialized
- buf – StringBuilder containing the JSON representation of the object
/**
* @param obj the object to be serialized
* @param buf StringBuilder containing the JSON representation of the object
*/
@Override
public void serialize(final Object obj, final StringBuilder buf) {
Object objectToSerialize = obj;
objectToSerialize = com.mongodb.Bytes.applyEncodingHooks(objectToSerialize);
if (objectToSerialize == null) {
buf.append(" null ");
return;
}
ObjectSerializer serializer = null;
List<Class<?>> ancestors;
ancestors = org.bson.util.ClassMap.getAncestry(objectToSerialize.getClass());
for (final Class<?> ancestor : ancestors) {
serializer = _serializers.get(ancestor);
if (serializer != null) {
break;
}
}
if (serializer == null && objectToSerialize.getClass().isArray()) {
serializer = _serializers.get(Object[].class);
}
if (serializer == null) {
throw new RuntimeException("json can't serialize type : " + objectToSerialize.getClass());
}
serializer.serialize(objectToSerialize, buf);
}
private final org.bson.util.ClassMap<ObjectSerializer> _serializers = new org.bson.util.ClassMap<ObjectSerializer>();
}