GDShrapt.Linter
5.0.0
dotnet add package GDShrapt.Linter --version 5.0.0
NuGet\Install-Package GDShrapt.Linter -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.Linter" Version="5.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="GDShrapt.Linter" Version="5.0.0" />
<PackageReference Include="GDShrapt.Linter" />
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.Linter --version 5.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: GDShrapt.Linter, 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.Linter@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.Linter&version=5.0.0
#tool nuget:?package=GDShrapt.Linter&version=5.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
GDShrapt.Linter
Configurable style checking for GDScript 2.0 (Godot 4.x) with gdtoolkit-compatible suppression.
Features
- Naming conventions - PascalCase, snake_case, SCREAMING_SNAKE_CASE
- Best practices - Unused variables, empty functions, type hints
- Comment suppression - gdtoolkit compatible
gdlint:ignore,gdlint:disable/enable - Strict typing - Per-element configurable severity for type hints
- Presets - Default, Strict, Minimal configurations
Quick Start
using GDShrapt.Reader;
var code = @"
var MyVariable = 10 # Should be snake_case
const lowercase = 5 # Should be SCREAMING_SNAKE_CASE
func BadName(): # Should be snake_case
pass
";
var linter = new GDLinter();
var result = linter.LintCode(code);
foreach (var issue in result.Issues)
{
// Output: "warning GDL101: Variable 'MyVariable' should use snake_case (2:4)"
Console.WriteLine(issue.ToString());
}
Linter Options
var options = new GDLinterOptions
{
// Naming conventions
ClassNameCase = NamingCase.PascalCase,
FunctionNameCase = NamingCase.SnakeCase,
VariableNameCase = NamingCase.SnakeCase,
ConstantNameCase = NamingCase.ScreamingSnakeCase,
RequireUnderscoreForPrivate = true,
// Style
MaxLineLength = 100,
// Best practices
WarnUnusedVariables = true,
WarnEmptyFunctions = true
};
var linter = new GDLinter(options);
Strict Typing (GDL215)
Require type hints with configurable severity per element:
var options = new GDLinterOptions();
options.StrictTypingClassVariables = GDLintSeverity.Warning;
options.StrictTypingParameters = GDLintSeverity.Error;
options.StrictTypingReturnTypes = GDLintSeverity.Error;
var linter = new GDLinter(options);
Comment Suppression
Suppress warnings using gdtoolkit-compatible comments:
# gdlint:ignore = variable-name
var my_Var = 10 # No warning
# gdlint: disable=function-name
func BadName():
pass
# gdlint: enable=function-name
Presets
var linter = new GDLinter(GDLinterOptions.Default); // Standard rules
var linter = new GDLinter(GDLinterOptions.Strict); // All rules enabled
var linter = new GDLinter(GDLinterOptions.Minimal); // Critical rules only
Related Packages
| Package | Description |
|---|---|
| GDShrapt.Reader | Core parser and AST (required) |
| GDShrapt.Builder | Fluent API for code generation |
| GDShrapt.Validator | Compiler-style AST validation |
| GDShrapt.Formatter | Code formatting with type inference |
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)
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 | 68 | 1/2/2026 |