Faithlife.FindReplaceCode.Tool 1.2.0

The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org. Prefix Reserved
dotnet tool install --global Faithlife.FindReplaceCode.Tool --version 1.2.0
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest # if you are setting up this repo
dotnet tool install --local Faithlife.FindReplaceCode.Tool --version 1.2.0
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=Faithlife.FindReplaceCode.Tool&version=1.2.0
nuke :add-package Faithlife.FindReplaceCode.Tool --version 1.2.0

ProjectName

Used to generate a new code project from a template.

Build NuGet

Documentation | Release Notes | Contributing

WARNING: This tool is recursively destructive. Please be extremely careful with it.

This tool is installed as a dotnet tool: dotnet tool install Faithlife.FindReplaceCode.Tool --global.

Usage

Usage: findreplacecode <folder-path> <find> <replace> [<find> <replace> ...]

For example:

> findreplacecode C:\Code\MyItemApi MyItem CoolThing

Folder Path

The first argument is the folder path. This tool may edit and/or rename every file and every folder in that folder and all of its subfolders, so be very careful where you point it.

Normally you would point the tool at a folder where you have made a copy of a project or solution that you want to modify.

Find and Replace

Each pair of arguments after the folder path indicate text to find and text to replace it with.

The find-and-replace is executed not only on the content of code files, but it is also used to rename files and folders.

This tool also creates new a Visual Studio project GUID for each renamed .csproj and automatically substitutes that project GUID in any .sln file that references the old one.

The find-and-replace is case-sensitive, but certain case variants are automatically replaced. For example, if you replace "MyItem" with "CoolThing", these replacements will also be executed: "myItem" for "coolThing", "myitem" for "coolthing", and "MYITEM" for "COOLTHING".

If the find text is not sufficiently unique in the existing files, this tool may not work well. For example, replacing Project would break Visual Studio project and solution files. This tool isn't that smart.

At least one find-and-replace pair is required. Any additional pairs are executed in the order they are provided.

Any .git subfolders are automatically excluded from modification.

Issues

Only certain file extensions are currently considered for content replacement. Please let us know if there are others that should be added.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  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 is compatible.  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 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

Version Downloads Last updated
1.2.0 86 2/16/2024
1.1.0 790 4/29/2019
1.0.0 676 3/13/2019
1.0.0-beta1 697 9/10/2018