pub struct TMultiplexedOutputProtocol<P>where
    P: TOutputProtocol,{ /* private fields */ }
Expand description

TOutputProtocol that prefixes the service name to all outgoing Thrift messages.

A TMultiplexedOutputProtocol should be used when multiple Thrift services send messages over a single I/O channel. By prefixing service identifiers to outgoing messages receivers are able to demux them and route them to the appropriate service processor. Rust receivers must use a TMultiplexedProcessor to process incoming messages, while other languages must use their corresponding multiplexed processor implementations.

For example, given a service TestService and a service call test_call, this implementation would identify messages as originating from TestService:test_call.

Examples

Create and use a TMultiplexedOutputProtocol.

use thrift::protocol::{TMessageIdentifier, TMessageType, TOutputProtocol};
use thrift::protocol::{TBinaryOutputProtocol, TMultiplexedOutputProtocol};
use thrift::transport::TTcpChannel;

let mut channel = TTcpChannel::new();
channel.open("localhost:9090").unwrap();

let protocol = TBinaryOutputProtocol::new(channel, true);
let mut protocol = TMultiplexedOutputProtocol::new("service_name", protocol);

let ident = TMessageIdentifier::new("svc_call", TMessageType::Call, 1);
protocol.write_message_begin(&ident).unwrap();

Implementations§

source§

impl<P> TMultiplexedOutputProtocol<P>where P: TOutputProtocol,

source

pub fn new(service_name: &str, wrapped: P) -> TMultiplexedOutputProtocol<P>

Create a TMultiplexedOutputProtocol that identifies outgoing messages as originating from a service named service_name and sends them over the wrapped TOutputProtocol. Outgoing messages are encoded and sent by wrapped, not by this instance.

Trait Implementations§

source§

impl<P> Debug for TMultiplexedOutputProtocol<P>where P: TOutputProtocol + Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<P> TOutputProtocol for TMultiplexedOutputProtocol<P>where P: TOutputProtocol,

source§

fn write_message_begin(&mut self, identifier: &TMessageIdentifier) -> Result<()>

Write the beginning of a Thrift message.
source§

fn write_message_end(&mut self) -> Result<()>

Write the end of a Thrift message.
source§

fn write_struct_begin(&mut self, identifier: &TStructIdentifier) -> Result<()>

Write the beginning of a Thrift struct.
source§

fn write_struct_end(&mut self) -> Result<()>

Write the end of a Thrift struct.
source§

fn write_field_begin(&mut self, identifier: &TFieldIdentifier) -> Result<()>

Write the beginning of a Thrift field.
source§

fn write_field_end(&mut self) -> Result<()>

Write the end of a Thrift field.
source§

fn write_field_stop(&mut self) -> Result<()>

Write a STOP field indicating that all the fields in a struct have been written.
source§

fn write_bytes(&mut self, b: &[u8]) -> Result<()>

Write a fixed-length byte array.
source§

fn write_bool(&mut self, b: bool) -> Result<()>

Write a bool.
source§

fn write_i8(&mut self, i: i8) -> Result<()>

Write an 8-bit signed integer.
source§

fn write_i16(&mut self, i: i16) -> Result<()>

Write a 16-bit signed integer.
source§

fn write_i32(&mut self, i: i32) -> Result<()>

Write a 32-bit signed integer.
source§

fn write_i64(&mut self, i: i64) -> Result<()>

Write a 64-bit signed integer.
source§

fn write_double(&mut self, d: f64) -> Result<()>

Write a 64-bit float.
source§

fn write_string(&mut self, s: &str) -> Result<()>

Write a fixed-length string.
source§

fn write_list_begin(&mut self, identifier: &TListIdentifier) -> Result<()>

Write the beginning of a list.
source§

fn write_list_end(&mut self) -> Result<()>

Write the end of a list.
source§

fn write_set_begin(&mut self, identifier: &TSetIdentifier) -> Result<()>

Write the beginning of a set.
source§

fn write_set_end(&mut self) -> Result<()>

Write the end of a set.
source§

fn write_map_begin(&mut self, identifier: &TMapIdentifier) -> Result<()>

Write the beginning of a map.
source§

fn write_map_end(&mut self) -> Result<()>

Write the end of a map.
source§

fn flush(&mut self) -> Result<()>

Flush buffered bytes to the underlying transport.
source§

fn write_byte(&mut self, b: u8) -> Result<()>

Write an unsigned byte. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.