Phase 1 MVP end-to-end. Program.cs initializes Serilog, builds an AppPluginHost that hands plugins a SerilogAdapter (IPluginLogger), discovers plugins from the App's output plugins/ dir, loads each via PluginLoader, calls Enable on all of them before opening the GameWindow, and calls Disable in a finally block on shutdown. AcDream.Plugins.Smoke is a new first-party plugin that logs through the host during Initialize / Enable / Disable. Its csproj references the abstractions with Private=false + ExcludeAssets=runtime to avoid shipping a second copy of AcDream.Plugin.Abstractions.dll (which would break ALC type identity). An MSBuild Target on the App project copies the plugin DLL into plugins/AcDream.Plugins.Smoke/ and writes the plugin.json manifest next to it. Smoke verified against real dats. Console output observed: [INF] scanning plugins in ...\plugins [INF] smoke plugin initialized [INF] loaded plugin acdream.smoke (Smoke Plugin) [INF] smoke plugin enabled loaded landblock 0xA9B4FFFF <window renders terrain> [INF] smoke plugin disabled (on shutdown) Phase 1 done. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
13 lines
631 B
Text
13 lines
631 B
Text
<Solution>
|
|
<Folder Name="/src/">
|
|
<Project Path="src/AcDream.App/AcDream.App.csproj" />
|
|
<Project Path="src/AcDream.Cli/AcDream.Cli.csproj" />
|
|
<Project Path="src/AcDream.Core/AcDream.Core.csproj" />
|
|
<Project Path="src/AcDream.Plugin.Abstractions/AcDream.Plugin.Abstractions.csproj" />
|
|
<Project Path="src/AcDream.Plugins.Smoke/AcDream.Plugins.Smoke.csproj" />
|
|
</Folder>
|
|
<Folder Name="/tests/">
|
|
<Project Path="tests/AcDream.Core.Tests.Fixtures.HelloPlugin/AcDream.Core.Tests.Fixtures.HelloPlugin.csproj" />
|
|
<Project Path="tests/AcDream.Core.Tests/AcDream.Core.Tests.csproj" />
|
|
</Folder>
|
|
</Solution>
|