A Change Wave is a set of risky features developed under the same opt-out flag. The purpose of this is to warn developers of "risky" changes that will become standard functionality down the line. If there's something we think is worth the risk, we found that Change Waves were a good middle ground between making necessary changes and warning customers of what will soon be permanent.
Opt-out is a better approach for us because we'd likely get limited feedback when a feature impacts customer builds. When a feature does impact a customer negatively, it's a quick switch to disable and allows time to adapt. The key aspect to Change Waves is that it smooths the transition for customers adapting to risky changes that the MSBuild team feels strongly enough to take.
The opt-out comes in the form of setting the environment variable MSBuildDisableFeaturesFromVersion
to the Change Wave (or version) that contains the feature you want disabled. This version happens to be the version of MSBuild that the features were developed for. See the mapping of change waves to features below.
MSBuildDisableFeaturesFromVersion Value |
Result | Receive Warning? |
---|---|---|
Unset | All Change Waves will be enabled, meaning all features behind each Change Wave will be enabled. | No |
Any valid & current Change Wave (Ex: 16.8 ) |
All features behind Change Wave 16.8 and higher will be disabled. |
No |
Invalid Value (Ex: 16.9 when valid waves are 16.8 and 16.10 ) |
Default to the closest valid value (ascending). Ex: Setting 16.9 will default you to 16.10 . |
No |
Out of Rotation (Ex: 17.1 when the highest wave is 17.0 ) |
Clamp to the closest valid value. Ex: 17.1 clamps to 17.0 , and 16.5 clamps to 16.8 |
Yes |
Invalid Format (Ex: 16x8 , 17_0 , garbage ) |
All Change Waves will be enabled, meaning all features behind each Change Wave will be enabled. | Yes |