--- /dev/null
+%%
+%% Licensed to the Apache Software Foundation (ASF) under one
+%% or more contributor license agreements. See the NOTICE file
+%% distributed with this work for additional information
+%% regarding copyright ownership. The ASF licenses this file
+%% to you under the Apache License, Version 2.0 (the
+%% "License"); you may not use this file except in compliance
+%% with the License. You may obtain a copy of the License at
+%%
+%% http://www.apache.org/licenses/LICENSE-2.0
+%%
+%% Unless required by applicable law or agreed to in writing,
+%% software distributed under the License is distributed on an
+%% "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+%% KIND, either express or implied. See the License for the
+%% specific language governing permissions and limitations
+%% under the License.
+%%
+
+%% Signature specifications for transport implementations.
+
+-ifndef(THRIFT_TRANSPORT_IMPL_INCLUDED).
+-define(THRIFT_TRANSPORT_IMPL_INCLUDED, true).
+
+-spec write(state(), iolist() | binary()) -> ok | {error, _Reason}.
+-spec read(state(), non_neg_integer()) -> {ok, binary()} | {error, _Reason}.
+-spec flush(state()) -> ok | {error, _Reason}.
+-spec close(state()) -> ok | {error, _Reason}.
+
+
+-endif.
%% State
-record(b64_transport, {wrapped}).
+-type state() :: #b64_transport{}.
+-include("thrift_transport_impl.hrl").
new(Wrapped) ->
State = #b64_transport{wrapped = Wrapped},
-record(buffered_transport, {wrapped, % a thrift_transport
write_buffer % iolist()
}).
+-type state() :: pid().
+-include("thrift_transport_impl.hrl").
+
%%====================================================================
%% API
close_on_close = false,
sync_every = infinity,
sync_tref}).
+-type state() :: #dl_transport{}.
+-include("thrift_transport_impl.hrl").
%% Create a transport attached to an already open log.
-record(t_file_transport, {device,
should_close = true,
mode = write}).
+-type state() :: #t_file_transport{}.
+-include("thrift_transport_impl.hrl").
%%%% CONSTRUCTION %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
read_buffer, % iolist()
write_buffer % iolist()
}).
+-type state() :: pid().
+-include("thrift_transport_impl.hrl").
%%====================================================================
%% API
http_options, % see http(3)
extra_headers % [{str(), str()}, ...]
}).
+-type state() :: pid().
+-include("thrift_transport_impl.hrl").
%%====================================================================
%% API
-export([write/2, read/2, flush/1, close/1]).
-record(memory_buffer, {buffer}).
+-type state() :: #memory_buffer{}.
+-include("thrift_transport_impl.hrl").
%%====================================================================
%% API
-record(data, {socket,
recv_timeout=infinity}).
+-type state() :: #data{}.
+-include("thrift_transport_impl.hrl").
new(Socket) ->
new(Socket, []).
{ok, #transport{module = Module,
data = Data}}.
-%% Data :: iolist()
+-spec write(#transport{}, iolist() | binary()) -> ok | {error, _Reason}.
write(Transport, Data) ->
Module = Transport#transport.module,
Module:write(Transport#transport.data, Data).
+-spec read(#transport{}, non_neg_integer()) -> {ok, binary()} | {error, _Reason}.
read(Transport, Len) when is_integer(Len) ->
Module = Transport#transport.module,
Module:read(Transport#transport.data, Len).
+-spec flush(#transport{}) -> ok | {error, _Reason}.
flush(#transport{module = Module, data = Data}) ->
Module:flush(Data).
+-spec close(#transport{}) -> ok | {error, _Reason}.
close(#transport{module = Module, data = Data}) ->
Module:close(Data).