mtanksl.Bencode
1.1.0
dotnet add package mtanksl.Bencode --version 1.1.0
NuGet\Install-Package mtanksl.Bencode -Version 1.1.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="mtanksl.Bencode" Version="1.1.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="mtanksl.Bencode" Version="1.1.0" />
<PackageReference Include="mtanksl.Bencode" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add mtanksl.Bencode --version 1.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: mtanksl.Bencode, 1.1.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package mtanksl.Bencode@1.1.0
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=mtanksl.Bencode&version=1.1.0
#tool nuget:?package=mtanksl.Bencode&version=1.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
B-encode.net
An implementation in C# of B-encode format that is used by the peer-to-peer file sharing system BitTorrent.
Specification
From Wikipedia:
- Byte Strings are encoded as
<length>:<bytes> - Integers are encoded as
i<integer>e - Lists are encoded as
l<elements>e - Dictionaries are encoded as
d<pairs>e
Creating with LINQ
BElement value =
new BDictionary(
new BPair("key 1", ""),
new BPair("key 3", 9223372036854775807L),
new BPair("key 2", "Hello World"),
new BPair("key 4", new BList("", "Hello World", 9223372036854775807L) ) );
How to serialize an object
string bencode = BencodeConvert.SerializeObject(value);
// "d5:key 10:5:key 211:Hello World5:key 3i9223372036854775807e5:key 4l0:11:Hello Worldi9223372036854775807eee"
or
using (var stream = File.OpenWrite("...") )
{
using (var writer = new BencodeWriter(stream) )
{
var serializer = new BencodeSerializer();
serializer.Serialize(writer, value);
}
}
How to deserialize an object
BElement value = (BElement)BencodeConvert.DeserializeObject(bencode);
or
using (var stream = File.OpenRead("...") )
{
using (var reader = new BencodeReader(stream) )
{
var serializer = new BencodeSerializer();
var value = (BElement)serializer.Deserialize(reader);
//...
}
}
Querying with LINQ
string helloWorld = (string)value["key 4"][1];
// "Hello World"
(See the Tests project for more examples)
Custom Converter
Create a custom converter by implementing an interface
public class MyDto : IBencodeSerializable
{
public void Read(BencodeReader reader, Type type, BencodeSerializer serializer) { ... }
public void Write(BencodeWriter writer, Type type, BencodeSerializer serializer) { ... }
}
or by implementing a base class
public class MyConverter : BencodeConverter
{
public override bool CanConvert(Type type) { ... }
public override object Read(BencodeReader reader, Type type, BencodeSerializer serializer) { ... }
public override void Write(BencodeWriter writer, object value, Type type, BencodeSerializer serializer) { ... }
}
then using in the settings
new BencodeSerializerSettings() { Converters = new List<BencodeConverter>() { new DateTimeConverter() } }
or in the class attribute
[BencodeObject(ItemConverterType = typeof(TorrentConverter))]
or in the property attribute
[BencodeProperty(ItemConverterType = typeof(DateTimeConverter))]
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.1.0 | 137 | 10/25/2025 |