blob: b19f98aa8a9b8e0abe9acf06b911f2313989b7f0 [file] [log] [blame]
Bryan Duxburyb7887b82010-06-09 21:30:54 +00001#
2# Licensed to the Apache Software Foundation (ASF) under one
3# or more contributor license agreements. See the NOTICE file
4# distributed with this work for additional information
5# regarding copyright ownership. The ASF licenses this file
6# to you under the Apache License, Version 2.0 (the
7# "License"); you may not use this file except in compliance
8# with the License. You may obtain a copy of the License at
9#
10# http://www.apache.org/licenses/LICENSE-2.0
11#
12# Unless required by applicable law or agreed to in writing,
13# software distributed under the License is distributed on an
14# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15# KIND, either express or implied. See the License for the
16# specific language governing permissions and limitations
17# under the License.
18#
19
David Reiss6acc2692010-02-26 00:56:02 +000020from protocol import TBinaryProtocol
21from transport import TTransport
22
23def serialize(thrift_object, protocol_factory = TBinaryProtocol.TBinaryProtocolFactory()):
24 transport = TTransport.TMemoryBuffer()
25 protocol = protocol_factory.getProtocol(transport)
26 thrift_object.write(protocol)
27 return transport.getvalue()
28
29def deserialize(base, buf, protocol_factory = TBinaryProtocol.TBinaryProtocolFactory()):
30 transport = TTransport.TMemoryBuffer(buf)
31 protocol = protocol_factory.getProtocol(transport)
32 base.read(protocol)
33 return base
34