/**
* GRANITE DATA SERVICES
* Copyright (C) 2006-2015 GRANITE DATA SERVICES S.A.S.
*
* This file is part of the Granite Data Services Platform.
*
* Granite Data Services is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* Granite Data Services is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
* General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
* USA, or see <http://www.gnu.org/licenses/>.
*/
package org.granite.messaging.jmf.codec.std.impl;
import java.io.IOException;
import java.io.OutputStream;
import org.granite.messaging.jmf.DumpContext;
import org.granite.messaging.jmf.InputContext;
import org.granite.messaging.jmf.OutputContext;
import org.granite.messaging.jmf.codec.std.IntegerCodec;
import org.granite.messaging.jmf.codec.std.impl.util.IntegerUtil;
/**
* @author Franck WOLFF
*/
public class IntegerCodecImpl extends AbstractStandardCodec<Integer> implements IntegerCodec {
protected static final int LENGTH_BYTE_COUNT_OFFSET = 5;
public int getObjectType() {
return JMF_INTEGER_OBJECT;
}
public Class<?> getObjectClass() {
return Integer.class;
}
public int getPrimitiveType() {
return JMF_INTEGER;
}
public Class<?> getPrimitiveClass() {
return int.class;
}
public void encode(OutputContext ctx, Integer v) throws IOException {
writeIntData(ctx, JMF_INTEGER_OBJECT, v.intValue());
}
public Integer decode(InputContext ctx, int parameterizedJmfType) throws IOException {
return Integer.valueOf(readIntData(ctx, parameterizedJmfType));
}
public void encodePrimitive(OutputContext ctx, int v) throws IOException {
writeIntData(ctx, JMF_INTEGER, v);
}
public int decodePrimitive(InputContext ctx) throws IOException {
int parameterizedJmfType = ctx.safeRead();
return readIntData(ctx, parameterizedJmfType);
}
public void dump(DumpContext ctx, int parameterizedJmfType) throws IOException {
int jmfType = ctx.getSharedContext().getCodecRegistry().extractJmfType(parameterizedJmfType);
switch (jmfType) {
case JMF_INTEGER:
ctx.indentPrintLn("int: " + readIntData(ctx, parameterizedJmfType));
break;
case JMF_INTEGER_OBJECT:
ctx.indentPrintLn(Integer.class.getName() + ": " + Integer.valueOf(readIntData(ctx, parameterizedJmfType)));
break;
default:
throw newBadTypeJMFEncodingException(jmfType, parameterizedJmfType);
}
}
protected void writeIntData(OutputContext ctx, int jmfType, int v) throws IOException {
final OutputStream os = ctx.getOutputStream();
int opposite = 0x00;
if (v < 0 && v != Integer.MIN_VALUE) {
opposite = 0x80;
v = -v;
}
int count = IntegerUtil.significantIntegerBytesCount0(v);
os.write(opposite | (count << LENGTH_BYTE_COUNT_OFFSET) | jmfType);
IntegerUtil.encodeInteger(ctx, v, count);
}
protected int readIntData(InputContext ctx, int parameterizedJmfType) throws IOException {
int v = IntegerUtil.decodeInteger(ctx, (parameterizedJmfType >>> LENGTH_BYTE_COUNT_OFFSET) & 0x03);
if ((parameterizedJmfType & 0x80) != 0)
v = -v;
return v;
}
}