| name | description |
|---|---|
dotnet-inspect |
This skill should be used when inspecting .NET assemblies, exploring NuGet package APIs, searching for types across frameworks, comparing API versions, or checking package vulnerabilities. Triggers on "what methods does X have", "find types like Y", "compare versions", "check for vulnerabilities", "explore this package", or any .NET API exploration task. |
CLI tool for inspecting .NET assemblies and NuGet packages.
dotnet-inspect <package>[@version] # Package metadata
dotnet-inspect api <type> --package <pkg> # API from package
dotnet-inspect api --platform <assembly> # API from installed SDK
dotnet-inspect platform # List installed frameworks
dotnet-inspect find <pattern> # Search types in runtime
dotnet-inspect assembly path/to/file.dll # Local assembly
dotnet-inspect diff <type> --package # Version comparison
dotnet-inspect type <type> --package <pkg> # Type shape with hierarchy| Goal | Command |
|---|---|
| Find a type by name | dotnet-inspect find "*Pattern*" |
| See what's in a package | dotnet-inspect api --package <pkg> |
| Get type details with members | dotnet-inspect type <type> --package <pkg> |
| Check specific method overloads | dotnet-inspect api <type> --package <pkg> -m <method> -v:d |
| Compare a type between versions | dotnet-inspect diff <type> --package <pkg>@v1..v2 |
| Compare entire packages | Use api -v:q on both versions, compare counts |
| Check for vulnerabilities | dotnet-inspect <package>@<version> |
| See interfaces a type implements | dotnet-inspect api <type> --package <pkg> --interfaces |
When the location of a type is unknown:
# Step 1: Find the type
dotnet-inspect find "JsonSerializer" --framework runtime
# Shows: System.Text.Json.JsonSerializer in System.Text.Json.dll
# Step 2: Get overview with type command
dotnet-inspect type JsonSerializer --platform System.Text.Json
# Step 3: Drill into specific members
dotnet-inspect api JsonSerializer --platform System.Text.Json -m Serialize -v:d# Check package metadata and vulnerabilities
dotnet-inspect [email protected]
# List available versions
dotnet-inspect System.Text.Json --versions -n 10
# Audit assemblies for SourceLink/determinism
dotnet-inspect assembly --package System.Text.Json --tfm net8.0 --auditThe diff command compares a specific type between versions. It requires a valid type name.
# Step 1: Find valid type names in the package first
dotnet-inspect find "*" --package [email protected] -n 20
# Step 2: Diff a specific type between versions
dotnet-inspect diff Config --package [email protected]
dotnet-inspect diff JsonSerializer --package [email protected]Important: The diff command fails if the type doesn't exist in either version. Always use find first to discover valid type names.
To compare entire packages between versions (not just one type):
# Step 1: List all types in each version (run in parallel for efficiency)
dotnet-inspect api --package [email protected] -v:q
dotnet-inspect api --package [email protected] -v:qThe -v:q output shows summary counts at the top:
**Types:** 144
**Methods:** 603
**Properties:** 277
Compare these counts to quickly see the scope of changes.
# Step 2: Diff key types that exist in both versions (run in parallel)
dotnet-inspect diff Config --package [email protected]
dotnet-inspect diff IEndpoint --package [email protected]
dotnet-inspect diff HttpClientExtensions --package [email protected]Identifying added/removed types: Compare the type lists from both -v:q outputs. Types present in v1 but not v2 were removed; types in v2 but not v1 were added.
Diff output format:
## API Diff: Config
**7.1.0** → **7.2.0**
**Summary:** +0 added, -2 removed
### Removed
- `IServiceResolver ServiceResolver { get; set; }`
### Added
+ `string NewProperty { get; set; }`
Get package metadata, check vulnerabilities, list versions.
dotnet-inspect System.Text.Json # Latest version
dotnet-inspect [email protected] -v:d # Specific version, detailed
dotnet-inspect System.Text.Json --versions -n 5 # List versionsExplore types and members in packages or platform assemblies.
dotnet-inspect api --package System.Text.Json # List all types
dotnet-inspect api --package System.Text.Json --filter "*Json*" # Filter by glob
dotnet-inspect api JsonSerializer --package System.Text.Json # Single type
dotnet-inspect api JsonSerializer --package [email protected] # Specific version
dotnet-inspect api JsonSerializer --package System.Text.Json -m Serialize # Single member
dotnet-inspect api JsonSerializer --package System.Text.Json --signatures-only # Plain output
dotnet-inspect api 'Option<T>' --package System.CommandLine # Generic types
dotnet-inspect api Command --package System.CommandLine --ctor # Constructors
dotnet-inspect api JsonSerializer --package Newtonsoft.Json --docs # With documentation
dotnet-inspect api --platform System.Text.Json # Platform assembly
dotnet-inspect api JsonSerializer --platform System.Text.Json --interfaces # With interfacesShow type shape with hierarchy and members in tree format.
dotnet-inspect type JsonSerializer --package System.Text.Json
dotnet-inspect type "List<T>" --platform System.Collections
dotnet-inspect type JsonSerializer --package System.Text.Json --jsonSearch for types across packages, assemblies, and frameworks.
dotnet-inspect find HttpClient # Search runtime (default)
dotnet-inspect find "*Stream*" -n 10 # Glob pattern, limit results
dotnet-inspect find "*Json*" --package System.Text.Json # Search in package
dotnet-inspect find "*Serializer*" --package System.Text.Json --package Newtonsoft.Json
dotnet-inspect find "*Command*" --project ./MyApp.csproj # Project dependencies
dotnet-inspect find "*Service*" --bin ./bin/Debug/net8.0 # Built output directory
dotnet-inspect find ILogger --framework aspnetcore # ASP.NET Core framework| Scope | Description |
|---|---|
| (none) | Defaults to --framework runtime |
--package |
NuGet package (name or name@version) |
--assembly |
Local assembly file |
--platform |
Specific platform assembly |
--framework |
All assemblies in framework (runtime, aspnetcore) |
--project |
Project dependencies via project.assets.json |
--bin |
All DLLs in output directory |
Compare a specific type's API surface between versions. Requires a valid type name that exists in both versions.
# Package version comparison
dotnet-inspect diff JsonSerializer --package [email protected]
dotnet-inspect diff Config --package [email protected]
# Platform version comparison
dotnet-inspect diff JsonSerializer --platform [email protected]
dotnet-inspect diff HttpClient --platform [email protected] --framework runtimeImportant:
- The type name must exist in both versions, or the command fails
- Use
findfirst to discover valid type names:dotnet-inspect find "*" --package pkg@version - This command compares one type at a time, not entire packages
- Some types may cause internal errors (e.g., "Argument_AddingDuplicateWithKey") — skip these and try other types
List installed frameworks and inspect platform assemblies.
dotnet-inspect platform # List installed frameworks
dotnet-inspect platform --list-versions # Installed SDK versions
dotnet-inspect platform --framework runtime # List runtime assemblies
dotnet-inspect platform --framework aspnetcore # List ASP.NET Core assembliesSome assemblies exist in both NuGet packages and the installed SDK:
| Source | When to Use |
|---|---|
--package |
Third-party libraries, specific versions, packages not in SDK |
--platform |
.NET runtime/SDK assemblies, comparing SDK versions, no network needed |
# From NuGet package (downloads if needed)
dotnet-inspect api JsonSerializer --package [email protected]
# From installed SDK (no download)
dotnet-inspect api JsonSerializer --platform System.Text.Json| Verbosity | Output |
|---|---|
-v:q |
Title + compact line |
-v:m |
+ description (default) |
-v:n |
+ Metadata table |
-v:d |
+ Full member signatures, Statistics, Dependencies |
| Format | Description |
|---|---|
--json |
Full JSON output |
--json --compact |
Minified JSON, nulls omitted |
--signatures-only |
Plain method signatures (api command) |
Section filtering (for verbose output):
dotnet-inspect package --discover # List sections with numbers
dotnet-inspect System.Text.Json -v:d -x:3,4 # Exclude sections 3 and 4
dotnet-inspect System.Text.Json -v:d -s:1,2 # Include only sections 1 and 2| Option | Description |
|---|---|
--tfm net8.0 |
Select target framework |
-m Name |
Filter to member |
--filter "Pattern*" |
Glob filter for types |
--ctor |
Constructor details |
--docs |
Fetch XML documentation |
--all |
Include hidden/obsolete |
--unsafe |
Filter to pointer methods |
--audit |
SourceLink/determinism check |
--deps |
Show runtime dependencies |
--interfaces |
Show implemented interfaces |
Use C# generic syntax - the tool automatically converts to metadata format:
"List<T>"→List\1`"Dictionary<TKey, TValue>"→Dictionary\2`
Quote the type name to prevent shell interpretation.
| Type | Platform Assembly |
|---|---|
| List, Dictionary, Queue | System.Collections |
| String, Int32, Object, Span | System.Runtime |
| JsonSerializer, JsonDocument | System.Text.Json |
| HttpClient | System.Net.Http |
| Regex, Match | System.Text.RegularExpressions |
| Task, Async | System.Threading.Tasks |
| File, Stream, Path | System.IO |
- Glob patterns must be quoted:
"*Stream*"(prevents shell expansion) - Member filter (
-m) is case-insensitive - Uses NuGet cache;
--verboseshows cache activity - For full overload details, use
-v:dwith-mfilter - Run independent commands in parallel for efficiency (e.g.,
api -v:qfor both versions, multiplediffcommands) - When comparing packages, look at Types/Methods/Properties counts first to gauge scope of changes
Made an update after a few runs