Struct mz_pgwire::codec::Cursor

source ·
struct Cursor<'a> {
    buf: &'a [u8],
}
Expand description

Decodes data within pgwire messages.

The API provided is very similar to bytes::Buf, but operations return errors rather than panicking. This is important for safety, as we don’t want to crash if the user sends us malformed pgwire messages.

There are also some special-purpose methods, like Cursor::read_cstr, that are specific to pgwire messages.

Fields§

§buf: &'a [u8]

Implementations§

source§

impl<'a> Cursor<'a>

source

fn new(buf: &'a [u8]) -> Cursor<'_>

Constructs a new Cursor from a byte slice. The cursor will begin decoding from the beginning of the slice.

source

fn peek_byte(&self) -> Result<u8, Error>

Returns the next byte without advancing the cursor.

source

fn read_byte(&mut self) -> Result<u8, Error>

Returns the next byte, advancing the cursor by one byte.

source

fn read_cstr(&mut self) -> Result<&'a str, Error>

Returns the next null-terminated string. The null character is not included the returned string. The cursor is advanced past the null- terminated string.

If there is no null byte remaining in the string, returns CodecError::StringNoTerminator. If the string is not valid UTF-8, returns an io::Error with an error kind of io::ErrorKind::InvalidInput.

NOTE(benesch): it is possible that returning a string here is wrong, and we should be returning bytes, so that we can support messages that are not UTF-8 encoded. At the moment, we’ve not discovered a need for this, though, and using proper strings is convenient.

source

fn read_i16(&mut self) -> Result<i16, Error>

Reads the next 16-bit signed integer, advancing the cursor by two bytes.

source

fn read_i32(&mut self) -> Result<i32, Error>

Reads the next 32-bit signed integer, advancing the cursor by four bytes.

source

fn read_u32(&mut self) -> Result<u32, Error>

Reads the next 32-bit unsigned integer, advancing the cursor by four bytes.

source

fn read_format(&mut self) -> Result<Format, Error>

Reads the next 16-bit format code, advancing the cursor by two bytes.

source

fn advance(&mut self, n: usize)

Advances the cursor by n bytes.

Trait Implementations§

source§

impl<'a> Debug for Cursor<'a>

source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<'a> RefUnwindSafe for Cursor<'a>

§

impl<'a> Send for Cursor<'a>

§

impl<'a> Sync for Cursor<'a>

§

impl<'a> Unpin for Cursor<'a>

§

impl<'a> UnwindSafe for Cursor<'a>

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> FutureExt for T

source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> Pointable for T

source§

const ALIGN: usize = mem::align_of::<T>()

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<P, R> ProtoType<R> for Pwhere R: RustType<P>,

source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
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.
source§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more