GDShrapt.Formatter
5.0.0
dotnet add package GDShrapt.Formatter --version 5.0.0
NuGet\Install-Package GDShrapt.Formatter -Version 5.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="GDShrapt.Formatter" Version="5.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="GDShrapt.Formatter" Version="5.0.0" />
<PackageReference Include="GDShrapt.Formatter" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add GDShrapt.Formatter --version 5.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: GDShrapt.Formatter, 5.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.
#:package GDShrapt.Formatter@5.0.0
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=GDShrapt.Formatter&version=5.0.0
#tool nuget:?package=GDShrapt.Formatter&version=5.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
GDShrapt.Formatter
Configurable code formatting for GDScript 2.0 (Godot 4.x) with auto type inference.
Features
- Rule-based formatting - 8 configurable formatting rules (GDF001-GDF008)
- Auto type hints - Automatically add inferred type hints to untyped variables
- Style extraction - Learn formatting style from sample code
- LSP compatible - Options map directly to LSP
textDocument/formatting - Presets - Default, GDScriptStyleGuide, Minimal
Quick Start
using GDShrapt.Reader;
var code = @"func test():
var x=10+5
print(x)
";
var formatter = new GDFormatter();
var formatted = formatter.FormatCode(code);
// Result: properly spaced "var x = 10 + 5"
Format Rules
| Rule | Description |
|---|---|
| GDF001 | Indentation (tabs/spaces) |
| GDF002 | Blank lines between members |
| GDF003 | Spacing around operators |
| GDF004 | Trailing whitespace removal |
| GDF005 | Line ending normalization |
| GDF006 | Line wrapping for long lines |
| GDF007 | Auto type hints (opt-in) |
| GDF008 | Code member reordering (opt-in) |
Formatter Options
var options = new GDFormatterOptions
{
IndentStyle = IndentStyle.Tabs,
IndentSize = 4,
SpaceAroundOperators = true,
SpaceAfterComma = true,
MaxLineLength = 100,
WrapLongLines = true,
RemoveTrailingWhitespace = true,
EnsureTrailingNewline = true
};
var formatter = new GDFormatter(options);
Auto Type Inference (GDF007)
Automatically add type hints using type inference:
var options = new GDFormatterOptions
{
AutoAddTypeHints = true,
AutoAddTypeHintsToClassVariables = true,
AutoAddTypeHintsToLocals = true,
UnknownTypeFallback = "Variant"
};
var formatter = new GDFormatter(options);
var code = "var x = 10\nvar name = \"hello\"";
var result = formatter.FormatCode(code);
// Result: var x: int = 10
// var name: String = "hello"
Format by Example
Extract style from sample code and apply to other code:
var formatter = new GDFormatter();
// Sample with 2-space indentation
var sampleCode = @"func sample():
var x = 10
";
var codeToFormat = @"func test():
var y = 20
";
// Will format using 2-space indentation
var result = formatter.FormatCodeWithStyle(codeToFormat, sampleCode);
Presets
var formatter = new GDFormatter(GDFormatterOptions.Default);
var formatter = new GDFormatter(GDFormatterOptions.GDScriptStyleGuide);
var formatter = new GDFormatter(GDFormatterOptions.Minimal);
Related Packages
| Package | Description |
|---|---|
| GDShrapt.Reader | Core parser and AST (required) |
| GDShrapt.Validator | Type inference (required for GDF007) |
| GDShrapt.Builder | Fluent API for code generation |
| GDShrapt.Linter | Style checking and naming conventions |
Documentation
Full documentation and examples: GitHub Repository
License
MIT License - see LICENSE for details.
| Product | Versions 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. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.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.
-
.NETStandard 2.0
- GDShrapt.Reader (>= 5.0.0)
- GDShrapt.Validator (>= 5.0.0)
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 |
|---|---|---|
| 5.0.0 | 81 | 1/2/2026 |