FSC-CNest 3.0.0

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

// Install FSC-CNest as a Cake Tool
#tool nuget:?package=FSC-CNest&version=3.0.0                

FSC-CNest

A C# framework to make coding easier

Why CNest?

CNest is a small, but powerful and crossplatform library that makes a lot of coding easier. It allows you to finish coding much faster than before.

What does CNest mean?

CNest is a library from 2020 and was created for only one reason. Nesting windows forms controls. In 2021, the second version of CNest came up. Version 2 went more the way of a framework and contained nesting windows forms features, but also some other C# features, which were developed to make coding easier. Many big codes became one-liners. Now in 2022 the first version of CNest 3 came out. It got renamed to FSC-CNest. (FSC describes is the short prefix for the developer name). FSC-Nest does not include the nesting features anymore, but the name never changed. The functionality changed at all. A lot of more features than before and it will become more with the time.

CNest features?

CNest has a lot of features ... It is compatible with windows, linux and more.

Terminal using FSC_CNest.TerminalAdvanced

The Terminal class is a one to one copy of the Console class. You can use it like before. Instead of Console.WriteLine(); you can write Terminal.WriteLine(); Why Terminal? Why remaking an existing and good working class? Terminal contains all features from Console, but also got some more advanced features. Maybe you remember a moment, when you wrote:

Console.Write("Username: ");
Console.ReadLine();

As you can see, you have 2 lines of code. The Terminal class needs only one.

Terminal.ReadLine("Username: ");

What? You're not surprised? Ok, here's a better argument for you:

Console.WriteLine("Username: ");
Console.ReadLine();
Console.WriteLine("Password: ");
Console.ReadLine();

Do you see the problem? The password is visible. Isn't that bad? Check out Terminal:

Terminal.ReadLine("Username: ");
Terminal.ReadLine("Password: ", true);

As you can see, Terminal accepts a boolean. This boolean toggles between clear text and password symbols. Even the password symbol can be changed. Default symbol: ******* Terminal contains a lot of more cool features, try it out.

Extensions: using FSC_CNest.Extensions

You are bored of a lot of methods? This extensions makes your life easier:

Convert

CNest allows you to convert any type by doing this:

string s = "999";
int i = s.To<int>();
string anotherS = i.To<string>();
...

Color

Invert() and GrayScale() are simple to use and do what they are made for. Create a color: Color c = Color.Red; And now try the new features: c = c.Invert();

Encode and decode

string s = "hello";
s = s.EncodeBase64();
s = s.DecodeBase64();
s = s.EncodeURL();
s = s.DecodeURL();

Hashes FSC_CNest.

It was never that easy to create a hash. Let's take MD5 as an example:

string s = "hello";
s = s.ToHashString("MD5");
byte b = s.ToHashBytes("MD5");

It's very easy. The use of MD5 is not a need. For all the hashes, check out the Microsoft documentation about HashAlgorithm.Create()


Crypt using FSC_CNest.Crypt

AES, a really cool way of encryption. You think it is complex? Yes, a little bit. But CNest makes it easy for you. Check out the AES class

RGB using FSC_CNest.Colors

Let's bring some color into your software. You like RGB? Don't worry, the RGB class delivers exactly what you need. Make a loop, call the Smooth RGB method and you get a smooth rainbow. It also delivers a static random color generator.

Graphics FSC_CNest.Graphics

What would you say, if you can pick a pixel from any xy-point on your screen? Now you can. ScreenActivity.PickColor(int x, int y) picks any Pixel from x and y and returns it as Color.

Hardware using FSC_CNest.Hardware

You need the possibility to create a hardware id (HWID)? Or you only want to get some computer informations? Check out Computer.GetHardwareInfo(...);. It has returns many informations of the computer, where your program is running on.

IO using FSC_CNest.IO

Did the File class a remake like Console? No, don't worry. Not everything got a remake.

Logger

IO has a logger for you. Check out the Logger class. You're bored of using multiple instances? Logger includes a singleton. Logger.Instance. Logger has three possible Logging methods: Console, File and Console + File. (Console is a windows only feature and also works on non-console applications).

PathBuilder

Yes, it sounds strange ... Why do you need a path builder? The answer is simple as always. To answer that, you need to know, what PathBuilder do.

  • Build a path.
  • Navigate forward and backwards like in a browser.
  • Check, if the needed navigation direction is possible.
  • Return the path. An example could be: You build a little file manager and you plan to include a path input. Now you want to navigate forward and backwards. PathBuilder does this for you.

PathVar

There is not much to explain. You need the AppData path? Get it. Or what about the document path? It's always annoying to use the normal way ... This small class makes it just easier ...


Text using FSC_CNest.Text

If you are interested in using some UTF8 symbols like minimize, maximize, normalize and close, then check out the Symbols class

Natives and NativesValues FSC_CNest.WindowsNatives

Not all features are made in C# only. The used native methods and some more are public available in the Native class. You need some NativeValues? Also they got their own class.



The library works crossplatform. It is very easy to use. Not all features work with every .Net / .Net Framework version and not all features are possible on other operating systems. The most features work everywhere.

You have a problem with the encoding? It is wrong? You can manipulate the encoding of the whole library: using FSC_CNest; CNestSettings class


You like this idea of framework? Feel free to tell me more about your ideas to make it better and better.

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 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 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 is compatible.  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.

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
3.0.0 318 11/8/2022 3.0.0 is deprecated because it is no longer maintained.

This is the first public release of CNest