IronSoftware.Common 2023.11.12

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package IronSoftware.Common --version 2023.11.12                
NuGet\Install-Package IronSoftware.Common -Version 2023.11.12                
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="IronSoftware.Common" Version="2023.11.12" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add IronSoftware.Common --version 2023.11.12                
#r "nuget: IronSoftware.Common, 2023.11.12"                
#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 IronSoftware.Common as a Cake Addin
#addin nuget:?package=IronSoftware.Common&version=2023.11.12

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

IronSoftware.Internals

Components which can be shared between IronSoftware Libraries

IronSoftware.Analytics

A library for sending anonymous analytics and crash data from within Iron Software trials

Nuget Dependencies: Newtonsoft.JSON Assembly Dependencies: System.Web (Framework Nuget)

Never Obfuscate: IronSoftware.Analytics.Events.* (IronSoftware.Analytics.Events.AnalyticsEvent)

Ideas:

  • Look for a Class imported only in VB to report stats on "C#" vs. "VB" vs. "F#"

Ironsoftware.Interop

A fork of NativeLibraryLoader

  • Improved Linux and BSD support. Works for .Net 4.0 and .Net Standard 2.0
  • Also includes a console app to upgrade in InteropDotNet cs file to NativeLibraryLoader notation
  • Supports side-by-side use of 2 different versions of the same DLL

To use: I recommend using the IronNativeLibraryFactory.CreateCrossPlatformNative method to generate a NativeLibrary

  • XMLDocs Intellisense explains usage
  • Creates a NativeLibrary instance that works on Windows, Linux and Mac.
  • Supports net40, netstandard >= 2.0, netcore >= 2.0 and mono without additional configuration.
  • On Linux and mac will automatically search package managers (apt-get, yum, homebrew...) and system environment paths (LD_LIBRARY_PATH, DYLD_LIBRARY_PATH, PATH...) to find binaries
  • On Windows will automatically load MSVC runtime if those binaries are present in the path specified in CreateCrossPlatformNative which contains your DLLs. We can copy these from C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\VC\Redist\MSVC\14.24.28127\x64 and x86 respectively
  • On older Windows OSs such as Server 2012, MSVC must always be manually installed because the OS does not have all the prerequisites for the Resits approach above. A System.FileLoadException will be thrown with bit architecture-aware instructions on how to install MSVC on that OS.
  • Will automatically add x64 or x86 to binary paths if those folders are present and contain files
NativeLibrary Lept = IronNativeLibraryFactory.CreateCrossPlatformNative(new[] { "leptonica-1.78.0.dll", "liblept.so.5", "liblept.5.so", "liblept.5.dylib", "liblept.dylib" }, true, new[] { Path.GetFullPath("MyBinaryPath") });

Files Deployed Alongside:

MyBinaryPath/x64/leptonica-1.78.0.dll
// the rest are for MSVC
MyBinaryPath/x64/concrt140.dll
MyBinaryPath/x64/vccorlib140.dll
MyBinaryPath/x64/vcruntime140.dll
MyBinaryPath/x64/vcruntime140_1.dll
MyBinaryPath/x64/msvcp140.dll
MyBinaryPath/x64/msvcp140_1.dll
MyBinaryPath/x64/msvcp140_2.dll
MyBinaryPath/x64/msvcp140_codecvt_ids.dll

MyBinaryPath/x86/ ... same file names for x86

NOTE: For Linux leptonica.so.5 can also be deployed to MyBinaryPath/x64/ but this is not smart because it contains so many OS-specific dependencies in its build. Instead, install with apt-get or homebrew. This works without any configuration.

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

NuGet packages (16)

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

Package Downloads
IronSoftware.System.Drawing

IronSoftware.System.Drawing - The C# Image Library A universally compatible Bitmap format for .NET 8, .NET 7, .NET 6, and .NET 5, .NET Core on Windows, macOS, Linux, Docker, AWS, Azure, NanoServer, IIS, Mobile, Xamarin, iOS, Android, and Google Compute. Works seamlessly with popular Image and Bitmap formats such as System.Drawing.Bitmap, SkiaSharp, SixLabors.ImageSharp, Microsoft.Maui.Graphics. Implicit casting means that using this class to input and output Bitmap and image types from public API's gives full compatibility to all image type fully supported by Microsoft. Key library features include: * AnyBitmap: A universally compatible Bitmap class. Implicit casting between System.Drawing.Bitmap, System.Drawing.Image, SkiaSharp.SKBitmap, SkiaSharp.SKImage, SixLabors.ImageSharp, Microsoft.Maui.Graphics.Platform.PlatformImage to IronSoftware.Drawing.AnyBitmap * Color: A universally compatible Color class. Implicit casting between System.Drawing.Color, SkiaSharp.SKColor, SixLabors.ImageSharp.Color, SixLabors.ImageSharp.PixelFormats to IronSoftware.Drawing.Color * Rectangle: A universally compatible Rectangle class. Implicit casting between System.Drawing.Rectangle, SkiaSharp.SKRect, SkiaSharp.SKRectI, SixLabors.ImageSharp.Rectangle to IronSoftware.Drawing.Rectangle * Font: A universally compatible Font class. Implicit casting between System.Drawing.Font, SkiaSharp.SKFont, SixLabors.Fonts.Font to IronSoftware.Drawing.Font * Point: A universally compatible Point class. Implicit casting between System.Drawing.Point, SixLabors.ImageSharp.Point, SkiaSharp.SKPointI to IronSoftware.Drawing.Point * Size: A universally compatible Size class. Implicit casting between System.Drawing.Size, SixLabors.ImageSharp.Size, SkiaSharp.SKSizeI to IronSoftware.Drawing.Size IronSoftware.Drawing can be used within C#, VB.NET, F#, ASP.NET projects, MVC, Web Services, Console & Desktop Applications. Supports: * .NET 8 * .NET 7 * .NET 6 * .NET 5 * .NET Core 2.0 + * .NET Framework 4.6.2 + For general support and technical inquiries, please email us at: [email protected]

IronOcr

IronOCR is an advanced OCR (Optical Character Recognition) library for C# and .NET It provides Tesseract OCR on Mac, Windows, Linux, Azure and Docker for: * .NET Framework 4.6.2 + * .NET Standard 2.0 + * .NET Core 2.0 + * .NET 5 * .NET 6 * .NET 7 * .NET 8 * Mono for MacOS and Linux * Xamarin for MacOS IronOCR reads Text, Barcodes & QR from all major image and PDF formats using the latest Tesseract 5 engine. This library adds OCR functionality to Desktop, Console and Web applications in minutes. IronOCR's Unique Features: * Pure .Net OCR API * All OCR tasks run locally (no SAAS) * 125 languages * Barcode & QR Code reading * Corrects low quality, noisy and distorted scans * Performance tuned above and beyond any other known build of Tesseract OCR. * Reads PDFs * Reads multi-page TIFFs * Can save any OCR Scan to a searchable PDF document or XHTML Data output options include: Plain Text, Barcode Data and an OCR Result class containing paragraphs, lines, words, and characters. Language Support: 125 Languages including Arabic, Chinese, English, Finnish, French, German, Hebrew, Italian, Japanese, Korean, Portuguese, Russian, Spanish... Custom language packs can also be created. Licensing & Support available for commercial deployments. Email: [email protected] For code examples, documentation & more visit http://ironsoftware.com/csharp/ocr/

IronXL.Excel

IronXL allows developers to Read, Generate and Edit Excel (and other Spreadsheet files) in .NET Applications & websites. A fast and natural approach to work with Excel and Other Spreadsheet files in C#. For code samples, docs & more visit https://ironsoftware.com/csharp/excel/ No utilization of Office Excel Interop. Works well with .NET Framework, .NET Core and Azure. All without extra dependancies or the need to install MS Office. Key library features include: * Import Data from XLS/XLSX/CSV/TSV. * Export Work Sheets to XLS/XLSX/CSV/TSV/JSON. * Encrypt and decrypt XLSX/XLSM/XLTX files with passwords. * Work with Spreadsheets as System.Data.DataSet and System.Data.DataTable objects. * Excel Formulas recalculated every time a sheet it edited. * Intuitive Ranges setting with a WorkSheet["A1:B10"] syntax. * Sort Ranges, Columns and Rows. * Style Cells - Font, Size, Background pattern, Border, Alignment and Number formats. IronXL works well in C#, VB.NET, MVC, ASP.NET projects for Websites, Console & Desktop APPs. Works with: - .NET Core 2, 3.1 - .NET 5 - .NET 6 - .NET 7 - .NET 8 - .NET Standard 2 & 3 - .NET Framework 4.7.2 and above - Xamarin, SharePoint, Mono - Azure, AWS, Cloud hosting - Windows, Linux, macOS, Mobile Licensing & Support available for commercial deployments. Find full documentation at: https://ironsoftware.com/csharp/excel/ For support please contact us: [email protected]

BarCode.Slim

IronBarcode - The C# Barcode & QR Library Quickstart guide: https://ironsoftware.com/csharp/barcode/ IronBarcode allows developers to read & write Barcodes and QR Codes within .NET Applications & websites. Reading or writing barcodes only requires a single line of code with Iron Barcode. The .NET Barcode Library reads and writes most Barcode and QR standards. These include code 39/93/128, UPC A/E, EAN 8/13, ITF, RSS 14 / Expanded, Databar, CodaBar, Aztec, Data Matrix, MaxiCode, PDF417, MSI, Plessey, USPS, and QR. The barcode result data includes type, text, binary data, page, and image file. Barcode reading engine includes automatic image correction and barcode detection technology to take the pain out of locating and reading from imperfect scans. Multithreading, cropping, and batch scanning provides fast and accurate scanning of multi page documents. Barcode writing API checks and verifys format, length, number, checksum to automatically avoid encoding errors. Barcode writer allows for styling, resizing, margins, borders, recoloring, and adding text annotations. Write to image, PDF or HTML file. Key library features include: * Read single or multiple Barcodes and QR Codes from images or PDFs. * Image correction for skewing, orientation, noise, low resolution, contrast etc. * Create barcodes and apply to images or PDF documents. * Embed barcodes into html documents. * Style Barcodes and add annotation text. * QR Code Writing allows adding of logos, colors, and advanced QR alignment. IronBarcode can be used within C#, VB.NET, ASP .NET projects, MVC, Web Services, Console & Desktop Applications. Supports: * .NET Framework 4.6.2 + * .NET Core 2.0 + * .NET 5 * .NET 6 * .NET 7 * .NET 8 Licensing & Support available for commercial deployments. For code examples, documentation & more visit https://ironsoftware.com/csharp/barcode/ For support please email us at [email protected]

IronOcr.Linux

IronOCR is an advanced OCR (Optical Character Recognition) library for C# and .NET It provides Tesseract OCR on Mac, Windows, Linux, Azure and Docker for: * .NET Framework 4.6.2 + * .NET Standard 2.0 + * .NET Core 2.0 + * .NET 5 * .NET 6 * .NET 7 * .NET 8 * Mono for MacOS and Linux * Xamarin for MacOS IronOCR reads Text, Barcodes & QR from all major image and PDF formats using the latest Tesseract 5 engine. This library adds OCR functionality to Desktop, Console and Web applications in minutes. IronOCR's Unique Features: * Pure .Net OCR API * All OCR tasks run locally (no SAAS) * 125 languages * Barcode & QR Code reading * Corrects low quality, noisy and distorted scans * Performance tuned above and beyond any other known build of Tesseract OCR. * Reads PDFs * Reads multi-page TIFFs * Can save any OCR Scan to a searchable PDF document or XHTML Data output options include: Plain Text, Barcode Data and an OCR Result class containing paragraphs, lines, words, and characters. Language Support: 125 Languages including Arabic, Chinese, English, Finnish, French, German, Hebrew, Italian, Japanese, Korean, Portuguese, Russian, Spanish... Custom language packs can also be created. Licensing & Support available for commercial deployments. Email: [email protected] For code examples, documentation & more visit http://ironsoftware.com/csharp/ocr/

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on IronSoftware.Common:

Repository Stars
iron-software/IronSoftware.System.Drawing
An open-source System.Drawing.Common replacement for .NET 5 and above on all platforms. Bringing together System.Drawing, Maui, and ImageSharp's Bitmap, Image, Font, and Shape types via an agnostic free NuGet package.
Version Downloads Last updated
2024.9.38 55,877 10/11/2024
2024.9.27 187,412 8/26/2024
2024.1.7 773,191 2/22/2024
2024.1.5 189,280 1/29/2024
2024.1.2 120,316 1/9/2024
2024.1.1 43,357 12/26/2023
2023.11.12 516,455 10/27/2023
2023.10.2 39,613 9/26/2023
2023.9.6 237,336 9/8/2023

* Initial release