Swallow.Refactor
5.0.0
dotnet tool install --global Swallow.Refactor --version 5.0.0
dotnet new tool-manifest
dotnet tool install --local Swallow.Refactor --version 5.0.0
#tool dotnet:?package=Swallow.Refactor&version=5.0.0
nuke :add-package Swallow.Refactor --version 5.0.0
Swallow.Refactor
Refactor goes BRRR!
A tool that was originally designed as a way to enable reliably refactor a big code-base automatically, it has since turned into a generic interface to the Roslyn API to interact with any C# code, be it just reading and analyzing or even modifying.
What's BRRR short for, you ask? Boundless Roslyn Refactoring Runner.
BRRRusage
brrr refactor -s|--solution <solution> code [--filter-name <name>] [--filter-content <content>] <rewriters>
When calling refactor, instead of passing all rewriters via CLI you can instead pass the path to a JSON file.
This file must match the following scheme:
{
"filter": {
"name": "<some regex>", // A regex that filenames should match, optional
"content": "<some text>" // A text that files should contain, optional
},
"rewriters": [
{ "name": "<some rewriter>" }, // A rewriter without any parameters
{ "name": "<some rewriter>", "parameters": [ "parameter", "parameter" ] } // A rewriter with parameters
]
}
To find out what rewriters are available, you can use brrr rewriter list and brrr rewriter describe <rewriter>.
But it doesn't stop there - there's a lot of things you can do. Using brrr asyncify, for example, allows you to
turn a chain of calls into async calls automatically, fixing any GetAwaiter().GetResult()-calls along the way.
To see all commands that you can use, run
brrr --help
BRRRinstallation
Building and installing yourself
To install the tool (and thus make it available globally), you can use the following command:
dotnet pack -c Release -o packages/
dotnet tool install --global --no-cache --add-source packages/ Swallow.Refactor
This will make brrr be a globally executable tool. To uninstall it again, you can execute:
dotnet tool uninstall --global Swallow.Refactor
Installing via NuGet
The tool is published on NuGet as well. To install it from there, you can use the following command:
dotnet tool install --global Swallow.Refactor
BRRRlugins
If you want to use your own rewriters, commands, symbol filters, you name it - you can pass your own assemblies to the execution. They will get picked up and the relevant classes are available in all the use-cases as if they were embedded in the program!
Invoking the tool using the -p or --plugin option passing a list of semicolon-separated filepaths will load each assembly.
brrr -p|--plugin SomeAssembly.dll;SomeOtherAssembly.dll list
Using this, you can extend the basic behaviour in many ways, like defining additional commands to be executed or registering
additional IDocumentRewriters or ITargetedRewriters.
BRRRackages
BRRRRoadmap
Next step is going to be a rather big overhaul. The previous versions were more focused on the CLI tool, providing more and more ways to use it. I'll put more focus on the library aspect for the next version - just so that you're not forced to use the tool to get any benefit.
My plan is for BRRR to be a neat wrapper for the Roslyn API, which might be unwieldy at times. The CLI tool is then supposed to be a way to make this wrapper scriptable for generalized usage.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. 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. |
This package has no dependencies.