Struct tower_lsp::Server

source ·
pub struct Server<I, O, L = ClientSocket> { /* private fields */ }
Expand description

Server for processing requests and responses on standard I/O or TCP.

Implementations§

source§

impl<I, O, L> Server<I, O, L>where I: AsyncRead + Unpin, O: AsyncWrite, L: Loopback, <L::ResponseSink as Sink<Response>>::Error: Error,

source

pub fn new(stdin: I, stdout: O, socket: L) -> Self

Creates a new Server with the given stdin and stdout handles.

source

pub fn concurrency_level(self, max: usize) -> Self

Sets the server concurrency limit to max.

This setting specifies how many incoming requests may be processed concurrently. Setting this value to 1 forces all requests to be processed sequentially, thereby implicitly disabling support for the $/cancelRequest notification.

If not explicitly specified, max defaults to 4.

Preference over standard tower middleware

The ConcurrencyLimit and Buffer middlewares provided by tower rely on tokio::spawn in common usage, while this library aims to be executor agnostic and to support exotic targets currently incompatible with tokio, such as WASM. As such, Server includes its own concurrency facilities that don’t require a global executor to be present.

source

pub async fn serve<T>(self, service: T)where T: Service<Request, Response = Option<Response>> + Send + 'static, T::Error: Into<Box<dyn Error + Send + Sync>>, T::Future: Send,

Spawns the service with messages read through stdin and responses written to stdout.

Trait Implementations§

source§

impl<I: Debug, O: Debug, L: Debug> Debug for Server<I, O, L>

source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<I, O, L> RefUnwindSafe for Server<I, O, L>where I: RefUnwindSafe, L: RefUnwindSafe, O: RefUnwindSafe,

§

impl<I, O, L> Send for Server<I, O, L>where I: Send, L: Send, O: Send,

§

impl<I, O, L> Sync for Server<I, O, L>where I: Sync, L: Sync, O: Sync,

§

impl<I, O, L> Unpin for Server<I, O, L>where I: Unpin, L: Unpin, O: Unpin,

§

impl<I, O, L> UnwindSafe for Server<I, O, L>where I: UnwindSafe, L: UnwindSafe, O: UnwindSafe,

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> 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, 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<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