blob: fbbe7680766af37d1f237e63d5e61b34b966ae25 [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
Nobuaki Sukegawa760511f2015-11-06 21:24:16 +090020from .protocol import TBinaryProtocol
21from .transport import TTransport
David Reiss6acc2692010-02-26 00:56:02 +000022
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