Nerdbank.Streams 2.11.74

Specialized .NET Stream classes

Enhanced streams for communication in-proc or across the Internet.

Features

  1. SimplexStream is meant to allow two parties to communicate one direction. Anything written to the stream can subsequently be read from it. You can share this Stream with any two parties (in the same AppDomain) and one can send messages to the other.
  2. FullDuplexStream creates a pair of bidirectional streams for in-proc two-way communication; it also creates a single bidirectional stream from two unidirectional streams.
  3. MultiplexingStream allows you to split any bidirectional .NET Stream into many sub-streams (called channels). This allows two parties to establish just one transport stream (e.g. named pipe or web socket) and use it for many independent protocols. For example, one might set up JSON-RPC on one channel and use other channels for efficient binary transfers.
  4. AsStream() wraps a WebSocket, System.IO.Pipelines.PipeReader, System.IO.Pipelines.PipeWriter, or System.IO.Pipelines.IDuplexPipe with a System.IO.Stream for reading and/or writing.
  5. UsePipe() enables reading from and writing to a Stream or WebSocket using the PipeReader and PipeWriter APIs.
  6. Stream.ReadSlice(long) creates a sub-stream that ends after a given number of bytes.
  7. PipeReader.ReadSlice(long) creates a sub-PipeReader that ends after a given number of bytes.
  8. MonitoringStream wraps another Stream and raises events for all I/O calls so you can monitor and/or trace the data as it goes by.
  9. WriteSubstream and ReadSubstream allow you to serialize data of an unknown length as part of a larger stream, and later deserialize it such in reading the substream, you cannot read more bytes than were written to it.
  10. Sequence<T> is a builder for ReadOnlySequence<T>.
  11. PrefixingBufferWriter<T> wraps another IBufferWriter<T> to allow for prefixing some header to the next written buffer, which may be arbitrarily long.
  12. BufferTextWriter is a TextWriter-derived type that can write directly to any IBufferWriter<byte>, making it more reusable than StreamWriter and thus allows for alloc-free writing across many writers.
  13. SequenceTextReader is a TextReader-derived type that can read directly from any ReadOnlySequence<byte>, making it more reusable than StreamReader and thus allows for alloc-free reading across many sequences.
  14. DuplexPipe is a trivial implementation of IDuplexPipe.
  15. Stream.ReadBlockAsync guarantees to fill the supplied buffer except under certain documented conditions, instead of the regular ReadAsync guarantee of supplying at least 1 byte.

Showing the top 20 packages that depend on Nerdbank.Streams.

Packages Downloads
MessagePack
Extremely Fast MessagePack(MsgPack) Serializer for C#(.NET, .NET Core, Unity, Xamarin).
11
MessagePack
Extremely Fast MessagePack(MsgPack) Serializer for C#(.NET, .NET Core, Unity, Xamarin).
10
MessagePack
Extremely Fast MessagePack(MsgPack) Serializer for C#(.NET, .NET Core, Unity, Xamarin).
9

https://github.com/AArnott/Nerdbank.Streams/releases/tag/v2.11.74

Version Downloads Last updated
2.11.79 4 08/24/2024
2.11.74 10 06/05/2024
2.11.72 8 05/05/2024
2.10.72 12 10/15/2023
2.10.69 16 07/27/2023
2.10.66 12 07/27/2023
2.10.37-alpha 14 07/27/2023
2.10.22-alpha 14 07/27/2023
2.9.116 11 06/16/2023
2.9.112 15 07/27/2023
2.9.109 14 06/27/2023
2.9.91-alpha 13 07/27/2023
2.9.87-alpha 12 06/16/2023
2.9.71-alpha 15 06/16/2023
2.9.47-alpha 15 07/27/2023
2.9.45-alpha 11 06/17/2023
2.8.65 16 07/27/2023
2.8.61 12 06/17/2023
2.8.57 13 06/16/2023
2.8.54 11 07/27/2023
2.8.50 12 07/27/2023
2.8.46 10 07/27/2023
2.8.22-alpha 12 07/27/2023
2.7.74 10 07/27/2023
2.7.62-alpha 10 07/27/2023
2.6.81 13 07/27/2023
2.6.78 10 07/27/2023
2.6.77 10 07/27/2023
2.6.37-alpha 15 07/27/2023
2.5.76 10 07/27/2023
2.5.72 13 06/27/2023
2.5.70 11 07/27/2023
2.5.65 9 07/27/2023
2.5.60 10 07/27/2023
2.5.58 10 07/27/2023
2.5.57-alpha 13 06/16/2023
2.5.50-alpha 13 07/27/2023
2.5.19-alpha 14 06/15/2023
2.4.73 13 07/27/2023
2.4.67 12 07/27/2023
2.4.60 11 07/27/2023
2.4.59 13 07/27/2023
2.4.57 14 07/27/2023
2.4.50 15 07/14/2023
2.4.48 14 07/27/2023
2.4.46 15 07/14/2023
2.4.37 12 07/13/2023
2.4.32 9 07/27/2023
2.4.30-alpha 11 07/27/2023
2.4.27-alpha 12 07/27/2023
2.4.20-alpha 12 07/27/2023
2.4.12-alpha 13 06/26/2023
2.3.32 13 07/27/2023
2.3.30 13 07/27/2023
2.3.26 11 07/27/2023
2.3.25-alpha 11 07/27/2023
2.3.23-alpha 12 07/27/2023
2.3.21-alpha 12 07/27/2023
2.3.18-alpha 50 07/27/2023
2.2.43 11 07/27/2023
2.2.42 9 07/27/2023
2.2.38 11 07/27/2023
2.2.26 7 07/27/2023
2.2.24-rc 11 07/27/2023
2.2.5-alpha 12 07/27/2023
2.1.37 14 07/27/2023
2.1.28-beta 11 07/27/2023
2.1.23-beta 9 07/27/2023
2.1.11-alpha 13 07/27/2023
2.1.9-alpha 11 07/27/2023
2.1.6-alpha 13 07/27/2023
2.1.4-alpha 10 07/27/2023
2.1.2-alpha 14 07/27/2023
2.0.228 14 07/27/2023
2.0.225 14 07/27/2023
2.0.214 10 07/27/2023
2.0.206 14 07/27/2023
2.0.202-rc 13 07/27/2023
2.0.198-beta 15 07/27/2023
2.0.188-beta 10 07/27/2023
2.0.165-beta 13 07/27/2023
2.0.163-beta 13 07/27/2023
2.0.152-beta 12 07/27/2023
2.0.112-rc 17 07/27/2023
2.0.95-beta 15 07/27/2023
2.0.91-beta 11 07/27/2023
2.0.83-beta 12 07/27/2023
2.0.67-beta 11 07/27/2023
2.0.61-beta 10 07/27/2023
2.0.54-beta 12 07/27/2023
2.0.20-beta 11 07/27/2023
2.0.2-beta 13 07/27/2023