TypeNameFormatter.Sources
1.1.2
Requires NuGet 2.8 or higher.
dotnet add package TypeNameFormatter.Sources --version 1.1.2
NuGet\Install-Package TypeNameFormatter.Sources -Version 1.1.2
<PackageReference Include="TypeNameFormatter.Sources" Version="1.1.2"> <PrivateAssets>all</PrivateAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets> </PackageReference>
<PackageVersion Include="TypeNameFormatter.Sources" Version="1.1.2" />
<PackageReference Include="TypeNameFormatter.Sources"> <PrivateAssets>all</PrivateAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets> </PackageReference>
paket add TypeNameFormatter.Sources --version 1.1.2
#r "nuget: TypeNameFormatter.Sources, 1.1.2"
#addin nuget:?package=TypeNameFormatter.Sources&version=1.1.2
#tool nuget:?package=TypeNameFormatter.Sources&version=1.1.2
TypeNameFormatter is a small .NET library for formatting type names à la C#.
What is this good for?
Have you ever stumbled over the cryptic formatting of Type
objects?
var someType = typeof(IEnumerable<int[]>);
Console.WriteLine(someType);
// => System.Collections.Generic.IEnumerable`1[System.Int32[]]
If you'd rather see something that looks more like a C# type name, then this library might be for you:
using TypeNameFormatter;
var someType = typeof(IEnumerable<int[]>);
Console.WriteLine(someType.GetFormattedName());
// => IEnumerable<int[]>
Formatting any Type
involves more special cases than you might expect (such as generic types, nested types, multi-dimensional and jagged arrays, by-reference and pointer types). This library deals with all of those, so that you don't have to.
How do I use it?
By importing the TypeNameFormatter
namespace, the following extension methods become available:
stringBuilder.AppendFormattedName(Type type, [TypeNameFormatOptions options])
:
Appends a C#-formatted type name to the givenStringBuilder
.type.GetFormattedName([TypeNameFormatOptions options])
:
Returns a C#-formatted type name as a string. (This is a convenience method that does exactly the same as the above, using a throw-awayStringBuilder
.)
Both methods allow you to specify any combination of the following TypeNameFormatOptions
flags:
Namespaces
:
Namespaces should be included. (For example,System.Action
instead ofAction
.)NoAnonymousTypes
: Anonymous types should not have their "display class" name transformed to a more legible syntax. (For example,<>f__AnonymousType5<string, int>
instead of{string Name, int Count}
.)NoGenericParameterNames
:
Parameter names of an open generic type should be omitted. (For example,IEnumerable<>
instead ofIEnumerable<T>
. Note that this setting does not affect closed generic types; their arguments are always included.)NoKeywords
:
Primitive types should not be mapped to their corresponding C# language keywords. (For example,Int32
instead ofint
.)NoNullableQuestionMark
: Nullable types should not be formatted using C# question mark syntax. (For example,Nullable<int>
instead ofint?
.)NoTuple
: Value tuple types should not be formatted using C# tuple syntax. (For example,ValueTuple<bool, int>
instead of(bool, int)
.)
But it doesn't format <some type> correctly!
If you think you've found a bug, please raise an issue so it can be looked into. (Make sure to mention the type that doesn't get formatted as expected.)
Alternatives
If you're targeting the .NET Framework, you can use good old
System.CodeDom
(which isn't particularly fast, however):using Microsoft.CSharp; using System.CodeDom; static string GetFormattedName(this Type type) { using (var provider = new CSharpCodeProvider()) { var typeReference = new CodeTypeReference(type); return provider.GetTypeOutput(typeReference); } }
You could perhaps use Microsoft's .NET Compiler Platform (Roslyn), but that is a large library that can do much more than is needed.
Advanced usage
Configuration knobs for the source code distribution
The TypeNameFormatter.Sources NuGet package comes with a few MSBuild properties that you can set inside your project file (inside a <PropertyGroup>
):
<TypeNameFormatterInternal>
:
This property determines the visibility of the types provided by TypeNameFormatter:- If set to
True
(the default), they are declaredinternal
. - If set to
False
, they are declaredpublic
.
- If set to
<TypeNameFormatterProjectNodeName>
:
This property determines the name under which TypeNameFormatter's single.cs
file will appear in e.g. Visual Studio's Solution Explorer:- If set to
TypeNameFormatter.cs
(the default), a hidden linked file by that name will be added to your project's root. - If set to any other relative file path, a visible linked file will be added to your project.
- If set to
For example:
<Project …>
…
<PropertyGroup>
<TypeNameFormatterInternal>False<TypeNameFormatterInternal>
<TypeNameFormatterProjectNodeName>Utilities\TypeNameFormatter.cs</TypeNameFormatterProjectNodeName>
</PropertyGroup>
…
</Project>
Learn more about Target Frameworks and .NET Standard.
This package has no dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (4)
Showing the top 4 popular GitHub repositories that depend on TypeNameFormatter.Sources:
Repository | Stars |
---|---|
devlooped/moq
The most popular and friendly mocking framework for .NET
|
|
moq/labs
The most popular and friendly mocking framework for .NET
|
|
lindexi/lindexi_gd
博客用到的代码
|
|
devlooped/avatar
A modern compile-time generated interception/proxy library
|
Version | Downloads | Last updated |
---|---|---|
1.1.2 | 259 | 4/1/2025 |
1.1.1 | 409,792 | 1/16/2021 |
1.1.0 | 2,023 | 11/12/2020 |
1.0.1 | 6,387 | 12/30/2018 |
1.0.0 | 10,695 | 7/11/2018 |
1.0.0-beta3 | 2,337 | 6/7/2018 |
1.0.0-beta | 2,243 | 5/24/2018 |
1.0.0-alpha | 2,657 | 5/24/2018 |
A changelog is available at https://github.com/stakx/TypeNameFormatter/blob/main/CHANGELOG.md.