From 1d29fb08536758918e5d7c38ee1d5f3ecd7a40c7 Mon Sep 17 00:00:00 2001 From: Andreia Gaita Date: Mon, 12 Feb 2024 16:39:58 +0100 Subject: VS: Fix user workflows with custom user VS configurations Users can add additional VS project configurations with their own custom settings, but to support this workflow, we can't rely directly on $(Platform) and $(Configuration), because VS needs those to be both unique Configuration|Platform combos, and we need to allow for different combos of Configuration|Platform to point to the same scons build configuration. GodotPlatform and GodotConfiguration properties lets us decouple from the magic VS properties that we don't control, so users can add however many Platform|Configuration combos they want and still point to a specific GodotPlatform|GodotConfiguration build config. --- methods.py | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) (limited to 'methods.py') diff --git a/methods.py b/methods.py index c22b1f11e4..69d8df1d72 100644 --- a/methods.py +++ b/methods.py @@ -1367,7 +1367,7 @@ def generate_vs_project(env, original_args, project_name="godot"): vsconf = f'{target}|{a["platform"]}' break - condition = "'$(Configuration)|$(Platform)'=='" + vsconf + "'" + condition = "'$(GodotConfiguration)|$(GodotPlatform)'=='" + vsconf + "'" properties.append(";" + ";".join(activeItems) + ";") output = f'bin\\godot{env["PROGSUFFIX"]}' @@ -1482,6 +1482,13 @@ def generate_vs_project(env, original_args, project_name="godot"): "", ] + properties += [ + f"", + f" {godot_target}", + f" {proj_plat}", + "", + ] + if godot_platform != "windows": configurations += [ f'', @@ -1490,6 +1497,13 @@ def generate_vs_project(env, original_args, project_name="godot"): "", ] + properties += [ + f"", + f" editor", + f" {proj_plat}", + "", + ] + p = f"{project_name}.{godot_platform}.{godot_target}.{godot_arch}.generated.props" imports += [ f'' @@ -1502,6 +1516,10 @@ def generate_vs_project(env, original_args, project_name="godot"): f"{{{proj_uuid}}}.{godot_target}|{sln_plat}.Build.0 = {godot_target}|{proj_plat}", ] + # Add an extra import for a local user props file at the end, so users can add more overrides. + imports += [ + f'' + ] section1 = sorted(section1) section2 = sorted(section2) -- cgit v1.2.3