OriginalCircuit.BxlSharp 1.0.0

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

// Install OriginalCircuit.BxlSharp as a Cake Tool
#tool nuget:?package=OriginalCircuit.BxlSharp&version=1.0.0                

Bxl Sharp

BxlSharp is a .NET Library designed to facilitate the parsing and reading of UltraLibrarian files within .NET projects. UltraLibrarian is a file format commonly used in the electronic design automation industry for the storage and exchange of component information and library data.

This library enables the integration of UltraLibrarian file reading functionality into .NET applications, making it easy to work with component libraries or extract data from UltraLibrarian files. In particular, the library allows for the efficient handling of BXL files, which contain information on components and their associated footprints.

Installation

Installation of the library is straightforward, as it is available via NuGet.

To add the OriginalCircuit.BxlSharp library to a .NET project using the Package Manager Console, follow these steps:

  1. Open the Package Manager Console window in Visual Studio. You can do this by going to Tools > NuGet Package Manager > Package Manager Console.

  2. In the Package Manager Console window, enter the following command to install the OriginalCircuit.BxlSharp library:

    Install-Package OriginalCircuit.BxlSharp

  3. Press Enter to execute the command. The OriginalCircuit.BxlSharp library will be downloaded and added to your project.

Usage

To use the Ultralibrarian Reader .NET Library in your .NET project, you will need to include the following using statements at the top of your source file:

using OriginalCircuit.BxlSharp;
using OriginalCircuit.BxlSharp.Types;

These using statements bring the classes and types from the OriginalCircuit.BxlSharp and OriginalCircuit.BxlSharp.Types namespaces into scope, allowing you to use them in your code without having to specify the full namespace every time.

Once you have included these using statements, you can use the classes and types from the OriginalCircuit.BxlSharp and OriginalCircuit.BxlSharp.Types namespaces in your code. For example, you can use the BxlDocument class to open and read UltraLibrarian files, and the LibPin class to access information about the pins in a symbol.

Opening BXL Files

Here's an example of how to open an UltraLibrarian file:

// Open the Ultralibrarian file  
var data = await  BxlDocument.ReadFromFileAsync(fileName, BxlFileType.FromExtension);

This code opens the UltraLibrarian file with the specified fileName and returns the data as a BxlDocument object. The BxlFileType.FromExtension parameter tells the library to determine the file type based on the file extension.

Reading Pin Information From All Symbols

To read the pin information for each symbol in the UltraLibrarian file, you can use the following code:

// Loop through each symbol in the file 
foreach (var  symbol  in data.Symbols) 
{ 
    // Get the pin information for the symbol  
    var pins = symbol.Data .Where(d => d is LibPin &&
        (d as  LibPin).Name.Text.ToUpperInvariant() != "NC" && 
        (d as  LibPin).Name.Text.ToUpperInvariant() != "N/C" && 
        (d as  LibPin).Name.Text.ToUpperInvariant() != "DNC")
     .Select(d => d as  LibPin).ToList(); 
 
    //further process the pin list
 }

In this example, the Pin class is a custom class that is defined in the user's code and has a Designator and Name property. The LibPin objects are converted to Pin objects by creating a new Pin object and passing in the Designator and Name values from the LibPin object. The resulting Pin objects are then added to a List<Pin> object.

You can then use the pinList object to access the pin information for each symbol in the UltraLibrarian file.

Product Compatible and additional computed target framework versions.
.NET 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net6.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.0.0 268 12/31/2022

Initial Release