blob: 8a58d89df5cb043ea32b7c2ebff5449d0c5047df [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
Bryan Duxbury69720412012-01-03 17:32:30 +000023
24def serialize(thrift_object,
25 protocol_factory=TBinaryProtocol.TBinaryProtocolFactory()):
David Reiss6acc2692010-02-26 00:56:02 +000026 transport = TTransport.TMemoryBuffer()
27 protocol = protocol_factory.getProtocol(transport)
28 thrift_object.write(protocol)
29 return transport.getvalue()
30
Bryan Duxbury69720412012-01-03 17:32:30 +000031
32def deserialize(base,
33 buf,
34 protocol_factory=TBinaryProtocol.TBinaryProtocolFactory()):
David Reiss6acc2692010-02-26 00:56:02 +000035 transport = TTransport.TMemoryBuffer(buf)
36 protocol = protocol_factory.getProtocol(transport)
37 base.read(protocol)
38 return base