This post was most recently updated on September 12th, 2021.3 min read.
This article describes how to fix and tweak your pre-build directives in Visual Studio – just in case they refuse to work properly. Because yeah, apparently that sometimes just randomly happens. But fear not – there’s a stupid and ugly, but definitely thoughtful workaround available!
Also, sorry for the confusing title. I’m taking suggestions for a more descriptive one – but this one was kind of difficult to word clearly.
Anyway – on to the topic of the day!
So you’re either trying to get a new build configuration to be visible in the dropdown in Visual Studio or perhaps one of the existing ones has disappeared. You might also not have the associated variable available for your sweet, sweet preprocessor/pre-build statements/directives – whatever they’re actually called :)
The problem is, the visibility of these configurations in the dropdown – the place from which they’re arguably accessed most often – is finicky at best. Sometimes a new configuration simply won’t be visible, no matter what you do, and which hacks you apply.
And that’s not all – additionally, the build constants might not work as expected. In the example below, “STAGING” is selected as the configuration, but instead “DEBUG” is enabled in the code.
And it’s not just IntelliSense, it’ll also happen during the build – and obviously then runtime.
For example, a close-up from the screenshot above. I had an integration test project configured with a couple of URLs for different environments configured like this:
But enabling any other configuration than “Release” would always result in DEBUG being true, and I never ended up with the URLs from STAGING or DEV.
This obviously needs to be fixed, somehow… But what do?
This article explains my most favorite thoughtful workarounds to the issue!
This one is going to be a combination of a couple of steps to verify things haven’t gone wrong, and if that all looks peachy, an unorthodox and stupid workaround as a final, ugly cherry on top.
I mean… I guess that applies to a lot of my articles.
Time needed: 10 minutes.
How to expose a project configuration as a build directive?
- (Prerequisite) Make sure you have added an additional configuration
This guide presumes you’ve already created the configuration from the Configurations -dropdown:
- Open the project file in edit mode
This can be done by clicking the project file with the right mouse button, and then selecting “Edit Project File”.
- Make sure your configurations exist in the project file
Should be one of the first things in the file:
If not, feel free to add them – because they really do need to be there :)
- Make sure your build constants exist in the project file
- Add a redundant condition to your PropertyGroup
Okay, so I know this sounds nonsensical from the get-go, but hear me out!
For whatever reason, Visual Studio sometimes messes up parsing the PropertyGroup your build constants live inside unless it has a Condition set up.
But what should that condition be?
Well, how about… Condition=”false” ? 😁
- Last-ditch effort: Add another constant as the last one
Do you see the “TRACE” constant in the DefineConstants node above? That’s not a build configuration!
This may sound ridiculous, but if even know you still either don’t have the build configuration available on the dropdown OR it doesn’t activate the right parts of your code, try adding another constant in the DefineConstants node.
TRACE is built-in – you can even add it from Project Options > Build – but you could even just add one called NONSENSE and see if it helps.
I mean… It did for me.
Ridiculous, right? Hey, that’s how my workarounds often end up. Give it a try and let me know how it goes!
- Microsoft’s documentation that doesn’t really help you here although it probably should:
- How to fix disconnected Sonoff Zigbee sensors in Home Assistant? - January 24, 2023
- How to fix all UWP/WinUI apps being laggy in Windows 10/11? - January 17, 2023
- How to export the SSL/TLS certificate from a website using PowerShell? - January 10, 2023