views:

118

answers:

4

I would like to have different Project Dependencies depending on which Project Configuration I'm currently building.

For example, I don't want to build and link SomeTestLib.vcproj in Release configuration, but I'd like to build and link to it in Debug.

One solution, that sorta works, is to use conditional compilation macros:

#ifdef DEBUG  
#pragma comment( lib, "SomeTestLib" )  
#endif

But in this case, the debugger and IntelliSense don't work for SomeTestLib.
Is there a .sln or .vcproj hack that I could use?
Thanks.

A: 

In visual studio, each build configuration keeps its own list of properties for your project. Just add your lib to whichever build configuration you want. Just don't add to "All Configurations"

Andrew Keith
I'm actually asking about a project that is a part of the solution, not an external lib. I'm aware of the option you're suggesting. What I'd like to achieve is to mark a project dependency inactive in certain solution configurations.
k0dek0mmand0
A: 

Right click your solution and select properties. Solution property page will show up..

In right page select Configuration Properties >>> Configuration

Here you can select the build configuration for Debug, Release and All build type by checking the check box labeled as Build.

S M Kamran
If I understand correctly, unchecking a project here will prevent it from being built. But if this unchecked project is marked as a Project Dependency, the linker will complain (SomeTestLib.lib can not be found.)
k0dek0mmand0
Not if it's already built and the assembly is present in the same directory. Since when you built a project all its dependencies other then those installed in GAC is copied into the private folder of that assembly. However since it's dependent on other assembly and a change is made in the source of that assembly it'll built all the dependencies first.
S M Kamran
OK, but I don't even want to build SomeTestLib in the Release configuration, that's the whole point. :)
k0dek0mmand0
+1  A: 

It's possible to turn off the Linker/General/Link library dependencies property in the dependent project and put the library in linker inputs in relevant configurations.

It makes the project references less useful, but is workable.

Jan Hudec
+1  A: 

After searching Google for days, I finally gave up on finding a solution to this problem and blew a VS developer, who gave me the workaround for this problem (actually, I tried a bajillion different things on my own to find this).

Apparently, the IDE isn't smart enough to figure out that you've disabled building for a particular library under a given configuration and to not add that project's output to the linker command line for projects that depend on it. I'm sure that you are aware of this.

However, since it is just pasting the output line from the library project into the command line of the dependent project, setting the output line to " " will result in NOTHING being added to the linker command line on dependent projects!

Hopefully, this problem will be remedied in Visual Studio in the future. I remain optimistic, because it is my favorite IDE, and I am always impressed by the features it supports. However, some of the VS help threads that I've seen say that this bug is "by design", so maybe they won't fix it. It seems easy enough to do, though.

Anyways, to summarize:

  • Right-Click on your library project in the Solution Explorer and Click "Properties".
  • Switch to the "Configuration/Platform" pair that your library project does not build for.
  • Select "Configuration Properties -> Librarian -> General".
  • For "Output File", type " " (that is open parens, space, close parens).
  • Click OK.

Please note that this workaround will give you errors if you Build or Clean the disabled library project. If you just build your solution, it will be skipped on disabled configurations, so you won't get errors.

Hope this helps!

Daniel

Daniel
Thanks, this is great!Another thing: If the dependency you're linking happens to be a .dll, you can also set the name of the Import Library to " " and it'll be ignored. This option is under Linker->Advanced->Import Library.
k0dek0mmand0