CP.Extensions.Hosting.Wpf 1.1.28

There is a newer version of this package available.
See the version list below for details.
dotnet add package CP.Extensions.Hosting.Wpf --version 1.1.28                
NuGet\Install-Package CP.Extensions.Hosting.Wpf -Version 1.1.28                
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="CP.Extensions.Hosting.Wpf" Version="1.1.28" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add CP.Extensions.Hosting.Wpf --version 1.1.28                
#r "nuget: CP.Extensions.Hosting.Wpf, 1.1.28"                
#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.
// Install CP.Extensions.Hosting.Wpf as a Cake Addin
#addin nuget:?package=CP.Extensions.Hosting.Wpf&version=1.1.28

// Install CP.Extensions.Hosting.Wpf as a Cake Tool
#tool nuget:?package=CP.Extensions.Hosting.Wpf&version=1.1.28                

CP.Extensions.Hosting

An Extension of the Microsoft.Extensions.Hosting library with the aim of allowing windows applications to use the hosting base.

CP.Extensions.Hosting.Identity.EntityFrameworkCore.Sqlite

Nuget Nuget

.UseWebHostServices((whb, services) =>
{
    services.UseEntityFrameworkCoreSqlite<DBContext, IdentityUser, IdentityRole>(whb, "DefaultConnection")
    .Configure<IdentityOptions>(options =>
    {
        // Configure options
    });
})
CP.Extensions.Hosting.Identity.EntityFrameworkCore.SqlServer

Nuget Nuget

.UseWebHostServices((whb, services) =>
{
    services.UseEntityFrameworkCoreSqlServer<DBContext, IdentityUser, IdentityRole>(whb, "DefaultConnection")
    .Configure<IdentityOptions>(options =>
    {
        // Configure options
    });
})
CP.Extensions.Hosting.MainUIThread

Nuget Nuget

Used to run the main UI thread in a Wpf / WinUI / WinForms application.

CP.Extensions.Hosting.Plugins

Nuget Nuget

.ConfigurePlugins(pluginBuilder =>
{
    Console.ForegroundColor = ConsoleColor.Yellow;
    Console.WriteLine("Running using dotNet {0}", Environment.Version);

    //// Specify the location from where the Dll's are "globbed"
    var process = Process.GetCurrentProcess();
    var fullPath = process.MainModule?.FileName?.Replace(process.MainModule.ModuleName!, string.Empty);
    Console.WriteLine("Add Scan Directories: {0}", fullPath);
    pluginBuilder?.AddScanDirectories(fullPath!);

    //// Add the framework libraries which can be found with the specified globs
    pluginBuilder?.IncludeFrameworks(@"\netstandard2.0\*.FrameworkLib.dll");

    //// Add the plugins which can be found with the specified globs
    var runtime = targetRuntime ?? Path.GetFileName(executableLocation);
    Console.WriteLine(@"Include Plugins from: \Plugins\{0}\{1}*.dll", runtime, nameSpace);
    pluginBuilder?.IncludePlugins(@$"\Plugins\{runtime}\{##YourPluginNameSpace##}*.dll");
    Console.ResetColor();
})
/// <summary>
/// This plug-in configures the HostBuilderContext to have the hosted services from the online example
/// </summary>
public class Plugin : PluginBase<FirstService, SecondService, ThirdService>
{
}
CP.Extensions.Hosting.PluginService

Nuget Nuget

await ServiceHost.Create(
            typeof(Program),
            args,
            hb => hb, // Configure the HostBuilder
            host => {}, // Configure the Host
            nameSpace: "AICS.Plugin").ConfigureAwait(false);
CP.Extensions.Hosting.ReactiveUI.WinForms

Nuget Nuget

    .ConfigureSplatForMicrosoftDependencyResolver()
CP.Extensions.Hosting.ReactiveUI.WinUI

Nuget Nuget

    .ConfigureSplatForMicrosoftDependencyResolver()
CP.Extensions.Hosting.ReactiveUI.Wpf

Nuget Nuget

    .ConfigureSplatForMicrosoftDependencyResolver()
CP.Extensions.Hosting.SingleInstance

Nuget Nuget

.ConfigureSingleInstance(builder =>
{
	builder.MutexId = "{ea031523-3a63-45e5-85f2-6fa75fbf37ed}";
	builder.WhenNotFirstInstance = (hostingEnvironment, logger) =>
	{
		// Application already started, this is another instance
		logger.LogWarning("Application {0} already running.", hostingEnvironment.ApplicationName);
	};
})
CP.Extensions.Hosting.WinForms

Nuget Nuget

.ConfigureWinForms<MainForm>()
.UseWinFormsLifetime()
CP.Extensions.Hosting.WinUI

Nuget Nuget

.ConfigureWinUI<MainWindow>()
.UseWpfLifetime()
CP.Extensions.Hosting.Wpf

Nuget Nuget

.ConfigureWpf<MainWindow>()
.UseWpfLifetime()
Product Compatible and additional computed target framework versions.
.NET net6.0-windows7.0 is compatible.  net7.0-windows was computed.  net7.0-windows7.0 is compatible.  net8.0-windows was computed.  net8.0-windows7.0 is compatible. 
.NET Framework net462 is compatible.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on CP.Extensions.Hosting.Wpf:

Package Downloads
CP.Extensions.Hosting.ReactiveUI.Wpf

This extension adds ReactiveUI support to generic host based dotnet core 8.0 / 9.0 WPF applications. With this you can enhance your application with a UI, and use all the services provided by the generic host like DI, logging etc, together with this reactive MVVM framework.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.1.4 29 11/21/2024
2.0.5 280 5/18/2024
1.5.2 85 5/17/2024
1.4.2 114 5/5/2024
1.3.13 111 5/1/2024
1.3.2 193 4/11/2024
1.2.2 176 3/26/2024
1.1.90 150 3/19/2024
1.1.28 209 2/5/2024
1.1.18 235 1/4/2024
1.1.11 121 12/23/2023
1.1.10 122 12/23/2023
1.1.7 135 12/14/2023
1.1.5 199 11/23/2023
1.1.3 131 11/12/2023
1.0.61 150 11/6/2023
1.0.60 129 11/6/2023
1.0.58 148 10/27/2023
1.0.56 153 10/27/2023
1.0.55 144 10/27/2023
1.0.54 138 10/27/2023
1.0.52 144 10/17/2023
1.0.50 128 10/17/2023
1.0.48 150 10/16/2023
1.0.47 125 10/16/2023
1.0.46 125 10/16/2023
1.0.44 136 10/3/2023
1.0.43 159 10/2/2023
1.0.39 139 10/2/2023
1.0.37 140 9/30/2023
1.0.33 151 9/19/2023
1.0.31 122 9/19/2023
1.0.29 169 9/14/2023
1.0.17 156 8/31/2023
1.0.15 144 8/30/2023
1.0.13 178 8/30/2023
1.0.8 193 8/1/2023
1.0.7 169 8/1/2023
1.0.6 194 7/25/2023
1.0.4 157 7/25/2023

Compatability with Net 6 / 7 / 8 and net462