Rebel.Alliance.ObjectInfo 1.0.2

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

// Install Rebel.Alliance.ObjectInfo as a Cake Tool
#tool nuget:?package=Rebel.Alliance.ObjectInfo&version=1.0.2                

Rebel.Alliance.ObjectInfo

image

Presenting a comprehensive library to easily query the DotNet Reflection API which multi-targets .NetStandard2.0, .NetStandard2.1, and .NET 8.0

The ObjectInfo Broker queries the Reflection API and converts the data from the various internal types to string properties, so that any client can read the data without needing references to hidden or protected libraries. Thus, this library is ideal for developers developing an "Object Inspector" in Blazor for instance.

The top-level object is ObjectInfo, which contains the TypeInfo class. TypeInfo now provides comprehensive metadata about:

  • Implemented Interfaces
  • Properties (PropInfo)
  • Methods (MethodInfo)
  • Constructors (ConstructorInfo)
  • Fields (FieldInfo)
  • Events (EventInfo)
  • Generic Type Information
    • Generic Parameters
    • Generic Constraints
    • Generic Type Arguments

All member types (Type, Method, Property, Constructor, Field, and Event) contain CustomAttributes collections, providing complete metadata coverage.

ObjectInfo includes a configuration object that controls system type visibility and will be expanded to provide "slices" of the metadata when performance is an issue.

Usage (from our unit tests)

Basic Type Information

TestClass testClass = new TestClass() { Name = "Joe The Tester" };
IObjectInfoBroker objectInfoBroker = new ObjectInfoBroker();

// Get ObjectInfo object
ObjInfo expectedObjectInfo = ObjectInfoService.RetrieveObjectInfo(objectInfoBroker, testClass);

Member Navigation

// Navigate Implemented Interfaces
string? implementedInterfaceName = expectedObjectInfo!.TypeInfo!.ImplementedInterfaces!
    .FirstOrDefault(a => a.Name.Equals("ITestClass")).Name;

// Navigate Methods
string? methodInfo = expectedObjectInfo!.TypeInfo!.MethodInfos!
    .FirstOrDefault(a => a.Name.Equals("EnsureCompliance")).Name;

// Navigate Properties
string? propInfo = expectedObjectInfo!.TypeInfo!.PropInfos!
    .FirstOrDefault(a => a.Name.Equals("Name")).Name;

// Navigate Constructors
var constructor = expectedObjectInfo!.TypeInfo!.ConstructorInfos!.FirstOrDefault();

// Navigate Fields
var field = expectedObjectInfo!.TypeInfo!.FieldInfos!
    .FirstOrDefault(f => f.Name.Equals("FieldName"));

// Navigate Events
var eventInfo = expectedObjectInfo!.TypeInfo!.EventInfos!
    .FirstOrDefault(e => e.Name.Equals("EventName"));

Generic Type Information

// For generic types
var genericType = expectedObjectInfo!.TypeInfo;
if (genericType.IsGenericTypeDefinition)
{
    // Access generic parameters and constraints
    var genericParam = genericType.GenericParameters.FirstOrDefault();
    bool hasConstructorConstraint = genericParam.HasDefaultConstructorConstraint;
}

Attribute Navigation

// Navigate Type Attributes
string? typeAttrInfo = expectedObjectInfo!.TypeInfo!.CustomAttrs!
    .FirstOrDefault(a => a.Name.Equals("IsCompliant")).Name;

// Navigate Method Attributes
var methodInfo = expectedObjectInfo!.TypeInfo!.MethodInfos!
    .FirstOrDefault(a => a.Name.Equals("EnsureCompliance"));
string? methodAttrInfo = methodInfo.CustomAttrs!
    .FirstOrDefault(a => a.Name.Equals("IsCompliant")).Name;

// Navigate Property Attributes
var propInfo = expectedObjectInfo!.TypeInfo!.PropInfos!
    .FirstOrDefault(a => a.Name.Equals("Name"));
string? propAttrInfo = propInfo.CustomAttrs!
    .FirstOrDefault(a => a.Name.Equals("IsCompliant")).Name;

The library now provides complete reflection metadata access with a clean, consistent API surface, making it ideal for inspection tools, code analysis, and metadata-driven applications.

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 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. 
.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.
  • net8.0

    • No dependencies.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Rebel.Alliance.ObjectInfo:

Package Downloads
Rebel.Alliance.ObjectInfo.DeepDive

ObjectInfo.DeepDive is an advanced code analysis extension for ObjectInfo, leveraging .NET 8 and Roslyn to provide deep insights into .NET objects and codebases. It offers advanced analysis capabilities, including method body inspection, cyclomatic complexity calculation, and a flexible plugin system for custom analyzers.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.2 81 11/1/2024
1.0.1 144 9/21/2024