|  | // Copyright (c) 2006- Facebook | 
|  | // Distributed under the Thrift Software License | 
|  | // | 
|  | // See accompanying file LICENSE or visit the Thrift site at: | 
|  | // http://developers.facebook.com/thrift/ | 
|  |  | 
|  | package com.facebook.thrift; | 
|  |  | 
|  | import java.io.ByteArrayOutputStream; | 
|  | import java.io.UnsupportedEncodingException; | 
|  |  | 
|  | import com.facebook.thrift.protocol.TBinaryProtocol; | 
|  | import com.facebook.thrift.protocol.TProtocol; | 
|  | import com.facebook.thrift.protocol.TProtocolFactory; | 
|  | import com.facebook.thrift.transport.TIOStreamTransport; | 
|  | import com.facebook.thrift.transport.TTransport; | 
|  |  | 
|  | /** | 
|  | * Generic utility for easily serializing objects into a byte array or Java | 
|  | * String. | 
|  | * | 
|  | * @author Mark Slee <mcslee@facebook.com> | 
|  | */ | 
|  | public class TSerializer { | 
|  |  | 
|  | /** | 
|  | * This is the byte array that data is actually serialized into | 
|  | */ | 
|  | private final ByteArrayOutputStream baos_ = new ByteArrayOutputStream(); | 
|  |  | 
|  | /** | 
|  | * This transport wraps that byte array | 
|  | */ | 
|  | private final TIOStreamTransport transport_ = new TIOStreamTransport(baos_); | 
|  |  | 
|  | /** | 
|  | * Internal protocol used for serializing objects. | 
|  | */ | 
|  | private TProtocol protocol_; | 
|  |  | 
|  | /** | 
|  | * Create a new TSerializer that uses the TBinaryProtocol by default. | 
|  | */ | 
|  | public TSerializer() { | 
|  | this(new TBinaryProtocol.Factory()); | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Create a new TSerializer. It will use the TProtocol specified by the | 
|  | * factory that is passed in. | 
|  | * | 
|  | * @param protocolFactory Factory to create a protocol | 
|  | */ | 
|  | public TSerializer(TProtocolFactory protocolFactory) { | 
|  | protocol_ = protocolFactory.getProtocol(transport_); | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Serialize the Thrift object into a byte array. The process is simple, | 
|  | * just clear the byte array output, write the object into it, and grab the | 
|  | * raw bytes. | 
|  | * | 
|  | * @param base The object to serialize | 
|  | * @return Serialized object in byte[] format | 
|  | */ | 
|  | public byte[] serialize(TBase base) throws TException { | 
|  | baos_.reset(); | 
|  | base.write(protocol_); | 
|  | return baos_.toByteArray(); | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Serialize the Thrift object into a Java string, using a specified | 
|  | * character set for encoding. | 
|  | * | 
|  | * @param base The object to serialize | 
|  | * @param charset Valid JVM charset | 
|  | * @return Serialized object as a String | 
|  | */ | 
|  | public String toString(TBase base, String charset) throws TException { | 
|  | try { | 
|  | return new String(serialize(base), charset); | 
|  | } catch (UnsupportedEncodingException uex) { | 
|  | throw new TException("JVM DOES NOT SUPPORT ENCODING: " + charset); | 
|  | } | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Serialize the Thrift object into a Java string, using the default JVM | 
|  | * charset encoding. | 
|  | * | 
|  | * @param base The object to serialize | 
|  | * @return Serialized object as a String | 
|  | */ | 
|  | public String toString(TBase base) throws TException { | 
|  | return new String(serialize(base)); | 
|  | } | 
|  | } | 
|  |  |