![JAR search and dependency download from the Maven repository](/logo.png)
org.brutusin.json.impl.serializers.SerializationContext Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of json-provider Show documentation
Show all versions of json-provider Show documentation
Service provider for JsonCodec SPI, based on Jackson-stack
The newest version!
/*
* Copyright 2015 Ignacio del Valle Alles [email protected].
*
* 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 org.brutusin.json.impl.serializers;
import java.io.InputStream;
import java.util.HashMap;
import java.util.Map;
/**
*
* @author Ignacio del Valle Alles [email protected]
*/
public class SerializationContext {
private static final ThreadLocal instances = new ThreadLocal() {
@Override
protected SerializationContext initialValue() {
return null;
}
};
private final Map inverseMap;
private final Map map;
private int addCounter;
private int getCounter;
public SerializationContext() {
this(null);
}
public SerializationContext(Map map) {
this.inverseMap = new HashMap();
if (map == null) {
this.map = new HashMap();
} else {
this.map = map;
for (Map.Entry entrySet : map.entrySet()) {
String key = entrySet.getKey();
InputStream value = entrySet.getValue();
this.inverseMap.put(value, key);
}
}
}
public static void setCurrentContext(SerializationContext ctx) {
instances.set(ctx);
}
public static SerializationContext getCurrentContext() {
return instances.get();
}
public static void closeCurrentContext() {
instances.remove();
}
public String addStream(InputStream stream) {
String str = inverseMap.get(stream);
if (str == null) {
str = "#" + (++addCounter) + "#" + System.identityHashCode(stream);
inverseMap.put(stream, str);
map.put(str, stream);
}
return str;
}
public InputStream getInputStreamAndRegisterCount(String id) {
getCounter++;
return map.get(id);
}
public Map getMap() {
return map;
}
public int getDeclaredStreams() {
return getCounter;
}
public void clear() {
inverseMap.clear();
map.clear();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy