Universal.Common 8.3.3

dotnet add package Universal.Common --version 8.3.3                
NuGet\Install-Package Universal.Common -Version 8.3.3                
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="Universal.Common" Version="8.3.3" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Universal.Common --version 8.3.3                
#r "nuget: Universal.Common, 8.3.3"                
#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.
// Install Universal.Common as a Cake Addin
#addin nuget:?package=Universal.Common&version=8.3.3

// Install Universal.Common as a Cake Tool
#tool nuget:?package=Universal.Common&version=8.3.3                

Universal.Common

Support utilities and extensions meant to extend the default functionality from the base class library.

Classes

BinaryReader

Endianness-aware implementation of System.IO.BinaryReader, allowing to read primitive types from a stream in big-endian or little-endian byte order.

using (var stream = new FileStream("file.bin", FileMode.Open, FileAccess.Read))
{
    // Create a BinaryReader with big-endian byte order
    using (var reader = new BinaryReader(stream, Endian.Big))
    {
        // Read an Int32 in big-endian order
        int value = reader.ReadInt32();
    }
}

BinaryWriter

Endianness-aware implementation of System.IO.BinaryWriter, allowing to write primitive types to a stream in big-endian or little-endian byte order.

using (var stream = new FileStream("file.bin", FileMode.Create, FileAccess.Write))
{
    // Create a BinaryWriter with big-endian byte order
    using (var writer = new BinaryWriter(stream, Endian.Big))
    {
        // Write an Int32 in big-endian order
        writer.Write(1234567890);
    }
}

BitSequence

Utility for as-is bit manipulations.

BitSequence bs1 = new BitSequence("10001010"); // Binary representation in string.
BitSequence bs2 = new BitSequence(new bool[] { true, false, true }); // As booleans.
BitSequence bs3 = bs1 & "11110000"; // Bitwise and, implicit conversion from binary representation string.

BitStream

Utility to perform bit-level operations on System.IO.Stream.

using (BitStream bitStream = new BitStream(stream)) 
{
    uint value = bitStream.ReadUInt32(4); // Reads 4 bits from the stream and interprets it as an unsigned integer, padding if necessary.
}

MediaType

Represents MIME types and provides functionality for working with media types in various contexts.

Constructor
MediaType mediaType = new MediaType("application/json");
MediaType Detection

The MediaType class provides several static methods to create MediaType instances from different sources:

  1. FromExtension
MediaType mediaType = MediaType.FromExtension(".json");
// Returns a MediaType instance for "application/json"

Creates a MediaType instance based on a file extension (with or without the leading dot).

  1. FromByteArray
byte[] fileBytes = File.ReadAllBytes("sample.png");
MediaType mediaType = MediaType.FromByteArray(fileBytes);
// Returns a MediaType instance for "image/png"

Detects the media type based on the file signature in the byte array.

  1. FromStream
using (FileStream stream = File.OpenRead("sample.jpg"))
{
    MediaType mediaType = MediaType.FromStream(stream);
    // Returns a MediaType instance for "image/jpeg"
}

Detects the media type based on the file signature read from the stream.

These methods allow for flexible media type detection from various sources, making it easier to work with files and data streams in different formats.

SemanticVersion

Implements version numbers that follow the Semantic Versioning 2.0.0 specification (https://semver.org/). Supports major, minor, and patch version components along with pre-release identifiers and build metadata.

// Basic version
var version = new SemanticVersion(1, 2, 3); // 1.2.3

// Version with pre-release and build metadata
var version = new SemanticVersion(1, 2, 3, "alpha.1", "build.123"); // 1.2.3-alpha.1+build.123

// Parse from string
SemanticVersion version = SemanticVersion.Parse("2.0.0-rc.1+build.123");

// Version comparison follows SemVer rules
Assert.IsTrue(SemanticVersion.Parse("1.0.0-alpha") < SemanticVersion.Parse("1.0.0"));
Assert.IsTrue(SemanticVersion.Parse("1.0.0-alpha.1") < SemanticVersion.Parse("1.0.0-alpha.2"));

StreamSegment

Represents a segment of a Stream that is itself a stream. This allows you to work with a specific portion of a stream as if it were a separate stream.

using (var stream = new FileStream("file.bin", FileMode.Open, FileAccess.Read))
{
    // Create a StreamSegment that represents the first 1024 bytes of the stream
    using (var segment = new StreamSegment(stream, 0, 1024))
    {
        // Read the first 1024 bytes of the stream
        byte buffer = new byte;
        segment.Read(buffer, 0, 1024);
    }
}

UriBuilder

Derived from System.UriBuilder, this class provides a fluent API to configure segments and queries.

UriBuilder uriBuilder = new UriBuilder("http://www.myhost.com");
uriBuilder
    .AddSegments("api", "Product", 1)
    .AddQuery("key", "value");
// "https://www.myhost.com/api/Product/1?key=value"

ZigZag

Static class that encodes arrays to matrices and vice-versa.

int[,] matrix = new int[,] { { 0, 1 }, { 2, 3 } };
int[] array = ZigZag.ToArray(matrix); // [0, 1, 2, 3]
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  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 is compatible.  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. 
.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 is compatible. 
.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.
  • .NETStandard 2.1

    • No dependencies.
  • net6.0

    • No dependencies.
  • net8.0

    • No dependencies.

NuGet packages (33)

Showing the top 5 NuGet packages that depend on Universal.Common:

Package Downloads
Universal.Common.Reflection

Class library for performing advanced operations with types, dynamic objects, expressions, and reflection.

Universal.Common.Net.Http

Class library to build clients and work with HTTP web services.

Universal.Common.Serialization

Class library with base objects that provide serializable to and from XML and JSON strings and binary serialization using the native binary formatter.

Universal.Android

Class library for accelerating Xamarin.Android development. Note: If you encounter layout inflation exceptions (could be masked as NotFoundException, or some issue with text_color_secondary.xml etc), make sure you define colorControlNormal and use a style with that attribute defined.

Universal.Common.Mathematics

Class library implementing advanced mathematical algorithms, transforms, and time series manipulations. Implementations favour simplicity and correctness.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
8.3.3 57 2/22/2025
8.3.2 51 2/22/2025
8.3.1 83 2/16/2025
8.3.0 68 2/15/2025
8.2.5 736 10/17/2024
8.2.4.1 535 7/15/2024
8.2.4 15,470 9/25/2023
8.2.3 616 6/8/2023
8.2.2 2,536 11/23/2022
8.2.1 388 11/22/2022
8.2.0 9,868 9/14/2022
8.1.2 21,299 10/24/2021
8.1.1 466 10/23/2021
8.1.0 472 10/23/2021
8.0.0 13,165 10/13/2021
7.7.1 7,195 8/24/2021
7.7.0 406 8/24/2021
7.6.2 450 8/19/2021
7.6.1 13,029 6/17/2021
7.6.0 2,102 6/3/2021
7.5.7 2,731 4/30/2021
7.5.6 447 4/29/2021
7.5.5 692 4/13/2021
7.5.4 4,497 3/31/2021
7.5.3 5,786 3/21/2021
7.5.2 1,300 3/15/2021
7.5.1 886 2/16/2021
7.5.0 25,680 2/5/2021
7.4.6 494 2/2/2021
7.4.5.1 1,986 1/15/2021
7.4.5 1,117 1/13/2021
7.4.4 1,667 1/7/2021
7.4.3 2,014 12/16/2020
7.4.2.1 563 12/15/2020
7.4.2 531 12/9/2020
7.4.1 5,455 11/26/2020
7.4.0 525 11/26/2020
7.3.5 2,807 11/23/2020
7.3.4 1,781 11/11/2020
7.3.3 558 11/11/2020
7.3.2 1,345 11/1/2020
7.3.1.1 4,699 10/19/2020
7.3.1 539 10/15/2020
7.3.0 539 10/15/2020
7.2.2 3,501 9/29/2020
7.2.1 675 9/29/2020
7.2.0 546 9/29/2020
7.1.1.1 608 9/28/2020
7.1.1 644 9/25/2020
7.1.0 1,783 9/2/2020
7.0.0 6,229 8/24/2020
6.4.7 623 8/21/2020
6.4.6 615 8/21/2020
6.4.5 19,967 5/21/2020
6.4.4 1,886 5/12/2020
6.4.3 2,077 4/23/2020
6.4.2 570 4/20/2020
6.4.1.2 18,122 3/20/2020
6.4.1.1 629 3/20/2020
6.4.1 618 3/20/2020
6.4.0 5,889 2/25/2020
6.3.5 1,235 2/21/2020
6.3.4 685 2/21/2020
6.3.3 3,685 2/11/2020
6.3.2 683 2/11/2020
6.3.1.1 7,193 1/23/2020
6.3.0 4,230 12/18/2019
6.2.7 2,115 12/17/2019
6.2.6 1,309 12/4/2019
6.2.5 817 12/4/2019
6.2.4 3,446 12/1/2019
6.2.3 10,399 10/25/2019
6.2.2 3,506 10/8/2019
6.2.1 1,063 10/7/2019
6.2.0.1 5,392 9/25/2019
6.2.0 1,784 9/20/2019
6.1.5 3,158 9/16/2019
6.1.4.1 1,689 9/9/2019
6.1.4 2,122 9/3/2019
6.1.3 639 9/2/2019
6.1.2 830 8/28/2019
6.1.1 7,575 7/9/2019
6.1.0.1 28,976 7/5/2019
6.1.0 16,892 5/7/2019
6.0.6 1,824 5/3/2019
6.0.5 1,339 5/2/2019
6.0.4 4,721 4/24/2019
6.0.3 999 4/24/2019
6.0.2 7,804 3/22/2019
6.0.1.2 2,379 3/12/2019
6.0.1.1 857 3/12/2019
6.0.1 865 3/11/2019
6.0.0 1,644 3/6/2019
5.3.6 797 3/5/2019
5.3.5 765 3/5/2019
5.3.4 1,850 3/4/2019
5.3.3 1,468 2/28/2019
5.3.2 1,287 2/27/2019
5.3.1.1 889 2/25/2019
5.3.1 778 2/25/2019
5.3.0 738 2/25/2019
5.2.1 3,333 2/16/2019
5.2.0.1 3,835 2/7/2019
5.1.8 815 2/7/2019
5.1.7.1 1,050 1/30/2019
5.1.7 819 1/30/2019
5.1.6.1 834 1/24/2019
5.1.6 802 1/23/2019
5.1.5 805 1/23/2019
5.1.4.2 859 1/18/2019
5.1.3 1,558 1/14/2019
5.1.2 7,638 1/8/2019
5.1.1.1 834 1/8/2019
5.1.1 821 1/6/2019
5.1.0 1,397 1/2/2019
5.0.2 852 12/31/2018
5.0.1.1 838 12/31/2018
5.0.1 827 12/31/2018
5.0.0.1 965 12/14/2018
5.0.0 2,127 12/10/2018
4.2.5 892 11/23/2018
4.2.4 913 11/23/2018
4.2.3.1 878 11/22/2018
4.2.3 862 11/22/2018
4.2.2.2 1,131 11/19/2018
4.2.2.1 8,154 10/2/2018
4.2.2 952 10/1/2018
4.2.1.2 969 10/1/2018
4.2.1.1 947 9/27/2018
4.2.1 881 9/26/2018
4.2.0.5 943 9/26/2018
4.2.0.4 925 9/25/2018
4.2.0.3 949 9/25/2018
4.2.0.2 974 9/25/2018
4.2.0.1 929 9/25/2018
4.2.0 1,062 9/24/2018
4.1.0 901 9/21/2018
4.0.0.6 943 9/18/2018
4.0.0.5 977 9/18/2018
4.0.0.4 951 9/17/2018
4.0.0.3 3,272 9/7/2018
4.0.0.2 1,222 9/4/2018
4.0.0.1 1,326 9/4/2018
4.0.0 4,121 8/30/2018
3.2.0 2,827 8/28/2018
3.1.0 949 8/28/2018
3.0.6 2,530 8/27/2018
3.0.5 932 8/27/2018
3.0.4 962 8/27/2018
3.0.3 973 8/24/2018
3.0.2 1,162 8/24/2018
3.0.1.2 945 8/23/2018
3.0.1.1 993 8/21/2018
3.0.1 964 8/21/2018
3.0.0 1,881 8/16/2018
2.2.1 1,038 8/15/2018
2.2.0 988 8/14/2018
2.1.0 986 8/13/2018
2.0.2 1,013 8/7/2018
2.0.1 1,266 5/10/2018
2.0.0 1,852 4/26/2018
1.5.3.7 3,083 1/27/2018
1.5.3.6 1,150 1/15/2018
1.5.3.5 1,126 1/8/2018
1.5.3.4 1,128 1/3/2018
1.5.3.3 1,148 1/3/2018
1.5.3.2 1,136 12/27/2017
1.5.3.1 1,162 12/25/2017
1.5.3 1,097 12/25/2017
1.5.2 1,118 12/24/2017
1.5.1 1,137 12/23/2017
1.5.0 1,091 12/22/2017
1.4.7 984 12/2/2017
1.4.6 2,613 11/28/2017
1.4.5 1,172 11/28/2017
1.4.0 1,245 11/12/2017
1.3.5 3,905 11/8/2017
1.3.4 1,239 11/8/2017
1.3.3 1,303 11/2/2017
1.3.2 1,233 11/2/2017
1.3.1 1,275 9/12/2017
1.3.0 1,186 8/26/2017
1.2.1 1,072 8/23/2017
1.2.0 1,142 8/17/2017
1.1.1 1,069 8/17/2017
1.1.0 1,070 8/17/2017
1.0.0 1,886 8/12/2017

Added new SemanticVersion type.