UserConfigMigrator 1.3.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package UserConfigMigrator --version 1.3.0
NuGet\Install-Package UserConfigMigrator -Version 1.3.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="UserConfigMigrator" Version="1.3.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="UserConfigMigrator" Version="1.3.0" />
<PackageReference Include="UserConfigMigrator" />
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 UserConfigMigrator --version 1.3.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: UserConfigMigrator, 1.3.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 UserConfigMigrator@1.3.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=UserConfigMigrator&version=1.3.0
#tool nuget:?package=UserConfigMigrator&version=1.3.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
User configuration migrator
A helper utility for migrating user-scoped application settings between different versions of a .NET application.
Useful when:
- Application version upgrades should reuse settings from older versions.
- Application root namespace or assembly name has changed.
- Supports downgrades by allowing import of settings from future versions.
⚠️ Scope: This is a minimal utility tailored for internal use in .NET Framework (e.g., 4.8) desktop applications that store settings using
SettingsBase
anduser.config
.
It does not support roaming profiles, custom configuration files, or non-standard config structures.
Features
- Finds the most recent valid
user.config
file from previous application versions. - Exports settings from a
user.config
file. - Applies exported settings from a
user.config
file into the current application settings, skipping unknown fields.
📦 NuGet
Install via NuGet Package Manager:
Install-Package UserConfigMigrator
Or via .NET CLI:
dotnet add package UserConfigMigrator
Usage examples
Direct upgrading of user settings
UserConfigMigrator.UpgradeSettings(Properties.Settings.Default);
Direct upgrading of user settings with support for previous app versions
string assemblyName = Assembly.GetExecutingAssembly().GetName().Name;
string oldCompanyName = "oldCompanyName";
IReadOnlyCollection<UserConfigMigrator.AppInfo> previousAppInfos =
new ReadOnlyCollection<UserConfigMigrator.AppInfo>(
new List<UserConfigMigrator.AppInfo>()
{
new UserConfigMigrator.AppInfo(
company: new UserConfigMigrator.Filename(oldCompanyName),
assembly_name: new UserConfigMigrator.Filename(assemblyName))
});
UserConfigMigrator.UpgradeSettings(Properties.Settings.Default, previous_app_infos: previousAppInfos);
Step-by-step upgrading of user settings
ConfigurationUserLevel userLevelConf = ConfigurationUserLevel.PerUserRoaming;
Version appVersion;
UserConfigMigrator.AppInfo appInfo =
UserConfigMigrator.GetAppInfoFromCurrentUserConfig(out appVersion, userLevelConf);
string userConfigPath;
if (UserConfigMigrator.TryFindLatestUserConfig(appVersion, appInfo, out userConfigPath))
{
IDictionary<string, object> exportedSettings =
UserConfigMigrator.ExportSettings(userConfigPath, Properties.Settings.Default);
UserConfigMigrator.ApplySettings(exportedSettings, Properties.Settings.Default);
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET Framework | net48 is compatible. net481 was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETFramework 4.8
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.