I’m developing a custom MSBuild task that builds an ORM layer, and using it in a project. I’m being hampered by Visual Studio’s behaviour of holding onto MSBuild task DLLs and not letting go.
I’d like to organize my solution like this;
My Solution
|
+- (1) ORM Layer Custom Task Project
| |
| +- BuildOrmLayerTask.cs // here's my task
|
+- (2) Business Logic Project // and here's the project that uses it.
|
+- <UsingTask TaskName="BuildOrmLayerTask" AssemblyFile="$(TaskAssembly)" />
However, when project (2) builds, it locks onto the assembly from project (1). So now I can’t build project (1) again without closing the solution and re-opening it.
Is there any way I can organize things so that the custom build task is not kept locked by Visual Studio?
(Edit: Sayed Ibrahim Hashimi, who literally wrote the book on msbuild, suggests the AppDomainIsolatedTask class for a better approach)
I’ve managed to solve this one myself…
Found this forum post from Dan Moseley, one of the MSBuild developers from Microsoft:
So, it seems that to stop the locks, you must spawn out a new MSBuild.exe process. It can’t be the one that runs inside Visual Studio, because when MSBuild runs, it loads the tasks into Visual Studio’s primary app domain, and that can never be unloaded.
create a new MSBuild project (a .csproj or similar) which overrides the ‘Build’ Target and performs your custom actions, eg;
Add it to visual studio if you want, but use Configuration Manager to make sure it is notbuilt in any configuration. Just let VS take care of source control and suchlike, not building.
Edit the .csproj file of the project that depends on
Prebuild.csproj. Add aBeforeBuildtarget which invokes MSBuild using theExectask. This will start a new process, and when that process ends, the file locks are released. Example;Now, when you build the dependent project, it executes MSBuild in a new process before running the compile.