Cephei.Tools 2.5.0

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

// Install Cephei.Tools as a Cake Tool
#tool nuget:?package=Cephei.Tools&version=2.5.0                

Cephei C# (.Net) Libraries Version 2, created and maintained by Irving Decarlo.

What is CS-Libraries2?

The original CS-Libraries project was initially created for my own personal use back in 2019. However, I was an inexperienced C# developer back then, so the original library fell short from my expectations.

Hence, in late 2020, I scrapped the original library and rewrote everything from scratch, thus dawning this current new version, the CS-Libraries2 project.

CS-Libraries2 is a collection of general-purpose high-level .Net libraries. All of the libraries in the project are written and compiled for .Net Standard 2.1.

Remarks

CS-Libraries2 was made for my own personal use and therefore will be modified according to my own needs.

It is worth noting that retroactive compatibility is not guaranteed - in fact, modifications made in any of the libraries may be incompatible with code created for former versions, whether fully or partially.

To better understand when a new version is compatible or not, refer to the following section: Versioning.

Versioning

Versioning in CS-Libraries2 emphasises more on how compatible the new version is compared to its predecessor rather than in the amount of changes made. A new version may contain multiple changes while being fully compatible, whereas others with a much lesser changelog may not be fully functional with code written for a previous version.

All libraries follow the standard 4-number version format (x.x.x.x).

In order to keep track of how compatible the new version is, the libraries under CS-Libraries2 are in accordance to the following rule:

Major Versions (X.x.x.x): Library Rewritten from Scratch

When a library is updated to a new Major version, it means that it was rewritten from scratch. Therefore, the new version is to be considered fully incompatible with any previous versions.

Minor Versions (x.X.x.x): Update with Partial Incompatibilities

When a library is updated to a new Minor version, it means that the update is expected to be partially incompatible with a previous version. Work may be required to adjust existing code to the new version.

Release Versions (x.x.X.x): Update with No Incompatibilities

When a library is updated to a new Release version, it means that the update is expected to be fully compatible with a previous version. No changes in already existing code will have to be made. Release versions often include new functionalities.

Build Versions (x.x.x.X): Patches and Bugfixes

When a library is updated to a new Build version, it means that patches and bugfixes were implemented which do not break compatibility with the previous version. It does not often include new functionalities.

How can I Contribute?

Even though I much appreciate the willingness to contribute to this repository, it was made for my personal use. Therefore, I need it to remain accessible to me at all times without modifications.

If there are changes that you'd like implemented or if you have found bugs, feel free to open a new issue in the repository and I will have a look at it.

You may also clone this repository to one of your own and make the modifications you'd like. If that's the case, please do modify the Project files of the library you'll modify and replace my name and Cephei with your own. I will not take responsibility for libraries based on my own that do not belong to this repository.

Thank you!

Product 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. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen 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.1

    • No dependencies.

NuGet packages (4)

Showing the top 4 NuGet packages that depend on Cephei.Tools:

Package Downloads
Cephei.Collections

Library for collection functions.

Cephei.Objects

Library for objects and object enhancements.

Cephei.Commands

Library for commands.

Cephei.Files.DA

Library for 2DA (two-dimensional array) file functions.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.5.0 374 12/14/2024

v2.5, 24-08-26
* Extensions
*- Removed int.GetNumberOfDigits();
*+ Added TimeSpan.GetYears() and DateTime.GetYears(DateTime).

v2.4, 24-08-06
* Extensions
*- All string-related extension methods were migrated to Cephei.Strings;
*- All directory-related extension methods were migrated to Cephei.Files.
- The Tool class was removed.

v2.3.1, 23-07-22
* Extensions
*+ Added CreateDirectoryForPath() and GetAndCreateDirectoryPath().

v2.3, 23-02-05
* Target runtime changed to .Net Standard 2.1;
* Extensions
*+ Added T.SafeEquals(U);
*+ Added string.SafeCopyTo(int, char[], int, int);
*+ Added StringBuilder.TryAppend(char).
* Tools
*+ Added Max(params T) and Min(params T);
** Corrected Backspace(int, bool)'s summary.

v2.2.1, 22-06-27
* Extensions
** string.ToBool(ICollection{string}, ICollection{string}, bool?) changed to T.ToBool(ICollection{T}, ICollection{T}, bool?).
*+ Added double.GetNumberOfDigits() and int.GetNumberOfDigits().

v2.2, 21-11-09
* Extensions
*+ Added KeyValuePair<> and DictionaryEntry.ToPairString;
*+ Added short.Clamp and byte.Clamp.
- SIPrefixes
-- Branched off to Numericals.

v2.1, 21-06-03
* All classes and extension methods related to collections branched off to Collections.

v2.0.3, 21-05-25
* Extensions
*+ Added ToReadOnly(IDictionary), GetDictionaryValues and GetDictionaryKeys.

v2.0.2, 21-05-24
+ Added the MultiEnumerator, CastEnumerator and AbstractMultiEnumerator classes.
* Extensions
*+ Added GetEnumerators, DisposeAll(IDisposables) and ResetAll(IEnumerators).
* EmptyEnumerator
*+ Added a generic EmptyEnumerator, implementing IEnumerator<T>.

v2.0.1 21-05-15
* Extensions
*+Added IEnumerator<T>.CopyTo(T[], index);
+ MonoEnumerator.