ProgrammerAL.Tools.CodeUpdater
0.1.0-preview.18
See the version list below for details.
dotnet tool install --global ProgrammerAL.Tools.CodeUpdater --version 0.1.0-preview.18
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local ProgrammerAL.Tools.CodeUpdater --version 0.1.0-preview.18
#tool dotnet:?package=ProgrammerAL.Tools.CodeUpdater&version=0.1.0-preview.18&prerelease
nuke :add-package ProgrammerAL.Tools.CodeUpdater --version 0.1.0-preview.18
Code Updater
The purpose of this project is to update all code versioning and dependencies below a directory. This is useful when you have a large number of projects that you want to update all at once. This application is assumed to run on a local machine, and then the changes are manually committed to source control. This allows for a more controlled update process, because a developer is meant to manually check the changes before committing them.
It would be great to get this to work for all kinds of languages/frameworks someday, but for now it's just .NET and NPM.
What Updates Are Done
- Updates .NET *.csproj files to use a specified C# Language Version
- Updates .NET *.csproj files to use a specified .NET SDK Version (AKA TargetFramework element)
- Updates all NuGet packages in all *.csproj files to the latest version
- Updates all NPM packages in all package.json files to the latest version
How to Use It
Remember, the purpose of this is to update code. It is assumed, and recommended, a developer runs this locally and verifies the changes before comitting to source control. Below are the steps assumed steps a user would follow.
There are 2 ways to run this. As a .NET Tool installed on your machine, or downloading the repository and running the code yourself.
- Install the application. Choose one:
- Install the tool globally by running
dotnet tool install --global ProgrammerAL.Tools.CodeUpdater --version 1.0.0
- Or clone this repository locally
- Run the application
- If you installed the tool, run it with the command:
code-updater --config-file "C:/my-repos/my-app-1"
- If you downloaded the code, open a terminal to the
~/src/CodeUpdater/CodeUpdater
directory and run the application using dotnet run while passing in the required arguments. Example:dotnet run -- --config-file "C:/my-repos/my-app-1"
- Wait for the application to finish. It will output the number of projects updated, and the number of projects that failed to update.
- Manually check a diff of all the file changes to ensure everything is as you expect
- Commit the code changes to source control. Wait for a CI/CD pipeline to run and ensure everything is still working as expected.
CLI Options
-d|--config-file
- Required
- Path to the file to use for config values when updating code
-h|--help
- Outputs CLI help
Config File
The config file holds all values to determine what changes to make. The reason this is separate from CLI input arguments is to let a developer store this config in different repos but have this .NET Tool installed globally on their machine. That makes it easy to let other developers run this tool with specific settings for each repository, while only needing to provide a single CLI input argument.
Below are the list of properties in the config file.
- RootDirectory
- Required
- Root directory to run from. Code Updater will search all child directories within this for projects to update.
- Required
- IgnorePatterns
- Required
- String to ignore within file paths when looking for projects to update. This is OS sensitive, so use \ as the path separator for Windows, and / as the path separator everywhere else. Eg:
\my-skip-path\
will ignore all projects that have the text\my-skip-path\
within the full path. Note this example will only happen on Windows because that uses backslashes for path separators.- NpmBuildCommand
- String to ignore within file paths when looking for projects to update. This is OS sensitive, so use \ as the path separator for Windows, and / as the path separator everywhere else. Eg:
- Required
- NpmBuildCommand
- Required
- After upgrading all of the code, this application will attempt to build all applications it updated. This option sets the npm command to run to do the build.
- Npm command to run to "compile" the npm directory. Default value is
publish
. Format run is: npm run <npmBuildCommand>.
- Required
- DotNetTargetFramework
- Required
- Target Framework to set in all *.CsProj files
- Required
- DotNetLangVersion
- Required
- C# language version to set in all *.CsProj files
- Required
- EnableNetAnalyzers
- Required
- Boolean value to set the
EnableNetAnalyzers
csproj element to. If theEnableNetAnalyzers
element does not exist in the project file, it will be added.
- Boolean value to set the
- Required
- EnforceCodeStyleInBuild
- Required
- Boolean value to set the
EnforceCodeStyleInBuild
csproj element to. If theEnableNetAnalyzers
element does not exist in the project file, it will be added.
- Boolean value to set the
- Required
- OutputFile
- Optional
- If this is set, it will be the file to write logs to, in addition to the console
- LogLevel
- Optional
- Verbosity level to log. Valid values are: Verbose, Info, Warn, Error. Default value: verbose.
Example Config File
{
"RootDirectory": "C:/my-repos/my-app-1",
"IgnorePatterns": [],
"NpmBuildCommand": "publish",
"DotNetTargetFramework": "net8.0",
"DotNetLangVersion": "latest",
"EnableNetAnalyzers": true,
"EnforceCodeStyleInBuild": true
}
Ignore Patterns
The Code Updater application has a default set of paths to ignore. The list is below. Note that all paths are in the list using both forwardslashes and backslashes. These are in addition to any skip paths passed in with the IgnorePatterns
config file property. As of right now, there is no way to remove these.
Ignore all obj and bin folders:
- /obj/Debug/
- /obj/Release/
- /bin/Debug/
- /bin/Release/
- \obj\Debug\
- \obj\Release\
- \bin\Debug\
- \bin\Release\
Ignore packages inside node_modules folder:
- /node_modules/
- \node_modules\
Installing Locally vs Downloading the Code
The tool is very opinionated. It updates all packages to the latest version, and sets some project level properties. If the tool does some things you can't use for your projects, you can download the code, make changes, and keep thay for yourself. Maybe in the future we can hide certain settings behind a flag. Feel free to file an issue and and we can discuss it.
Required 3rd Party Software
In order to run the tool you need the following software installed on your local machine.
- .NET CLI
- So you can install .NET Tool from nuget.org
- PowerShell
- Quick Reminder: PowerShell is cross platform, you can run it on Linux and MacOS, not just Windows
PowerShell is required as a workaround. The NPM executable on Windows doesn't run like other applications. It doesn't exit like a normal process. I don't know why, I never spent the time figuring it out. The workaround makes PowerShell the host application so it exits like you would expect, when the process is done. For this reason, whenever an external process must be run, it's run through PowerShell. Kind of a hack, but it works well enough.
.NET Standard Projects
When updating *.csproj files to a specific TargetFramework
version, the project is skipped if using .NET Standard. Those are usually set for a specific level of API compatibility so we don't want to mess with those.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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. 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. |
This package has no dependencies.
Version | Downloads | Last updated |
---|---|---|
1.0.1.61 | 108 | 11/22/2024 |
1.0.1-preview.60 | 57 | 11/20/2024 |
1.0.1-preview.58 | 48 | 11/20/2024 |
1.0.1-preview.55 | 47 | 11/20/2024 |
1.0.0.47 | 103 | 11/3/2024 |
1.0.0-preview.53 | 57 | 11/20/2024 |
0.1.0-preview.42 | 56 | 11/2/2024 |
0.1.0-preview.37 | 54 | 11/2/2024 |
0.1.0-preview.28 | 62 | 10/11/2024 |
0.1.0-preview.26 | 56 | 10/11/2024 |
0.1.0-preview.23 | 75 | 10/9/2024 |
0.1.0-preview.21 | 68 | 10/7/2024 |
0.1.0-preview.18 | 64 | 10/6/2024 |
0.1.0-preview.16 | 60 | 10/6/2024 |
0.1.0-preview.10 | 57 | 10/4/2024 |
0.1.0-preview.8 | 78 | 10/4/2024 |
0.1.0-preview.5 | 58 | 10/1/2024 |