From e76cf3e2ed01e1b7199a336463c21b5b8904c745 Mon Sep 17 00:00:00 2001 From: Milan Burda Date: Tue, 10 May 2022 23:26:07 +0200 Subject: [PATCH] fix: building node modules with Visual Studio 2017 (#34109) --- patches/v8/.patches | 2 +- ...recated_attribute_for_older_msvc_versions.patch} | 13 +++++-------- 2 files changed, 6 insertions(+), 9 deletions(-) rename patches/v8/{fix_build_deprecated_attirbute_for_older_msvc_versions.patch => fix_build_deprecated_attribute_for_older_msvc_versions.patch} (72%) diff --git a/patches/v8/.patches b/patches/v8/.patches index 1e5615f3ce25..67b42548459b 100644 --- a/patches/v8/.patches +++ b/patches/v8/.patches @@ -4,6 +4,6 @@ dcheck.patch export_symbols_needed_for_windows_build.patch workaround_an_undefined_symbol_error.patch do_not_export_private_v8_symbols_on_windows.patch -fix_build_deprecated_attirbute_for_older_msvc_versions.patch +fix_build_deprecated_attribute_for_older_msvc_versions.patch fix_disable_implies_dcheck_for_node_stream_array_buffers.patch revert_fix_cppgc_removed_deleted_cstors_in_cppheapcreateparams.patch diff --git a/patches/v8/fix_build_deprecated_attirbute_for_older_msvc_versions.patch b/patches/v8/fix_build_deprecated_attribute_for_older_msvc_versions.patch similarity index 72% rename from patches/v8/fix_build_deprecated_attirbute_for_older_msvc_versions.patch rename to patches/v8/fix_build_deprecated_attribute_for_older_msvc_versions.patch index def8b4cf37dd..547b2778ac3c 100644 --- a/patches/v8/fix_build_deprecated_attirbute_for_older_msvc_versions.patch +++ b/patches/v8/fix_build_deprecated_attribute_for_older_msvc_versions.patch @@ -1,15 +1,12 @@ From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Deepak Mohan Date: Tue, 28 Jan 2020 15:48:03 -0800 -Subject: fix: usage of c++ [[deprecated]] attirbute for older msvc versions +Subject: fix: usage of c++ [[deprecated]] attribute for older msvc versions -VS 2015 update 3 has a bug where [[deprecated]] attribute cannot -be applied to constructor declarations, this is fixed in 2017 and -higher versions, but native module compiling with this version -will have an issue. +This attribute can only be used in all contexts in Visual Studio 2019 diff --git a/include/v8config.h b/include/v8config.h -index 77fd65c6c5b7d8c0a7fe7a37c40e17ce66f49ce6..010b3633546601ba70a55aeb8e8fc503ef79e2f5 100644 +index 77fd65c6c5b7d8c0a7fe7a37c40e17ce66f49ce6..d203053d41c702733f5f3b950aa31cef74c2ab57 100644 --- a/include/v8config.h +++ b/include/v8config.h @@ -454,10 +454,13 @@ path. Add it with -I to the command line @@ -20,7 +17,7 @@ index 77fd65c6c5b7d8c0a7fe7a37c40e17ce66f49ce6..010b3633546601ba70a55aeb8e8fc503 // A macro (V8_DEPRECATED) to mark classes or functions as deprecated. #if defined(V8_DEPRECATION_WARNINGS) -# define V8_DEPRECATED(message) [[deprecated(message)]] -+# if defined(_MSC_VER) && _MSC_VER <= 1900 ++# if !defined(__clang__) && defined(_MSC_VER) && _MSC_VER < 1920 +# define V8_DEPRECATED(message) __declspec(deprecated(message)) +# else +# define V8_DEPRECATED(message) [[deprecated(message)]] @@ -33,7 +30,7 @@ index 77fd65c6c5b7d8c0a7fe7a37c40e17ce66f49ce6..010b3633546601ba70a55aeb8e8fc503 // A macro (V8_DEPRECATE_SOON) to make it easier to see what will be deprecated. #if defined(V8_IMMINENT_DEPRECATION_WARNINGS) -# define V8_DEPRECATE_SOON(message) [[deprecated(message)]] -+# if defined(_MSC_VER) && _MSC_VER <= 1900 ++# if !defined(__clang__) && defined(_MSC_VER) && _MSC_VER < 1920 +# define V8_DEPRECATE_SOON(message) __declspec(deprecated(message)) +# else +# define V8_DEPRECATE_SOON(message) [[deprecated(message)]]