Skip to main content

SmartHttpConnection

Struct SmartHttpConnection 

Source
pub struct SmartHttpConnection { /* private fields */ }
Expand description

A live smart-HTTP connection: the parsed advertisement plus the context needed to issue the stateless-RPC POST. Smart HTTP is request/response, so there is no persistent duplex socket — the reader/writer accessors are not used by http_fetch, which drives the POST loop directly.

reader/writer return empty/sink streams; embedders that want to drive a custom negotiation should use http_fetch (or read the advertisement via the accessors and POST through their HttpClient).

Implementations§

Source§

impl SmartHttpConnection

Source

pub fn repo_url(&self) -> &str

The repository URL this connection targets.

Source

pub fn object_format(&self) -> &str

The server’s advertised object format (sha1 or sha256).

Source

pub fn service(&self) -> Service

The service this connection speaks.

Trait Implementations§

Source§

impl Connection for SmartHttpConnection

Source§

fn reader(&mut self) -> &mut dyn Read

The readable half of the pkt-line stream (server -> client).
Source§

fn writer(&mut self) -> &mut dyn Write

The writable half of the pkt-line stream (client -> server).
Source§

fn advertised_refs(&self) -> &[(String, ObjectId)]

The refs the server advertised on connect (excluding HEAD, the capabilities^{} carrier, and peeled ^{} lines). Empty for a protocol v2 connection, whose refs are obtained later via ls-refs.
Source§

fn capabilities(&self) -> &[String]

The capability tokens advertised by the server (from the first ref line in v0/v1, or the v2 capability block).
Source§

fn head_symref(&self) -> Option<&str>

The target of the server’s HEAD symref (e.g. refs/heads/main), if it advertised one.
Source§

fn protocol_version(&self) -> u8

The negotiated protocol version (0, 1, or 2).
Source§

fn finish_send(&mut self)

Half-close the write side of the stream, signalling end-of-input to the server (the wire equivalent of the CLI’s drop(stdin)). Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where 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 T
where 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> Same for T

Source§

type Output = T

Should always be Self
Source§

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

Source§

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 T
where U: TryFrom<T>,

Source§

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.