Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Require MSVC 19.26 and Clang 10 in the STL #708

Merged
merged 5 commits into from
Apr 13, 2020

Conversation

CaseyCarter
Copy link
Contributor

@CaseyCarter CaseyCarter commented Apr 11, 2020

  • <yvals_core.h> changes:

    • Clang 10 _HAS_CONDITIONAL_EXPLICIT in C++14 mode (Only CUDA now requires the _HAS_CONDITIONAL_EXPLICIT == 0 code paths)
    • reject Clang < 10
    • reject MSVC < 1926
  • Unskip libc++ tests that need Concepts and/or <=>

  • std/tests/P0595R2_is_constant_evaluated: We no longer need suppress the warning Clang 9 emits when it sees the suppression for the warning Clang 10 emits in this test ;)

  • std/tests/VSO_0157762_feature_test_macros: Remove Clang 9 support

  • std/tests/concepts_matrix.lst: This is now simply a copy of usual_latest_matrix.lst with the /BE lines (EDG configs) commented out. (i.e., we now run the Concepts tests with Clang as well as MSVC.)

  • Remove workarounds for LLVM-38491 "clang-cl should accept __declspec(allocator)": Replace uses of _DECLSPEC_ALLOCATOR with __declspec(allocator), and suppress Clang's warning when the return type isn't a pointer or reference.

  • Remove workarounds for LLVM-43531 "clang-format damages 'alternative representations' for operators": Re-enable clang-format in the test which triggered the bug.

  • Remove workarounds for LLVM-38478 "clang -fno-ms-compatibility rejects Windows.h": Add -fno-ms-compatibility to the XXX_winsdk_XXX.lst files. (Yes, we still need these because the Windows SDK breaks /Za.)

[This is a dual of internal MSVC-PR-241460.]

* `<yvals_core.h>` changes:
  * Clang 10 `_HAS_CONDITIONAL_EXPLICIT` in C++14 mode (Only CUDA now requires the `_HAS_CONDITIONAL_EXPLICIT == 0` code paths)
  * reject Clang < 10
  * reject MSVC < 1926

* Unskip libc++ tests that need Concepts and/or `<=>`

* `std/tests/P0595R2_is_constant_evaluated`: We no longer need  suppress the warning Clang 9 emits when it sees the suppression for the warning Clang 10 emits in this test ;)

* `std/tests/VSO_0157762_feature_test_macros`: Remove Clang 9 support

* `std/tests/concepts_matrix.lst`: This is now simply a copy of `usual_latest_matrix.lst` with the `/BE` lines (EDG configs) commented out. (i.e., we now run the Concepts tests with Clang as well as MSVC.)

* Remove workarounds for LLVM-38491 "clang-cl should accept __declspec(allocator)": Replace uses of `_DECLSPEC_ALLOCATOR` with `__declspec(allocator)`, and suppress Clang's warning when the return type isn't a pointer or reference.

* Remove workarounds for LLVM-43531 "clang-format damages 'alternative representations' for operators": Re-enable clang-format in the test which triggered the bug.

* Remove workarounds for LLVM-38478 "clang -fno-ms-compatibility rejects Windows.h": Add -fno-ms-compatibility to the XXX_winsdk_XXX.lst files. (Yes, we still need these because the Windows SDK breaks `/Za`.)
@CaseyCarter CaseyCarter added the enhancement Something can be improved label Apr 11, 2020
@CaseyCarter CaseyCarter requested a review from a team as a code owner April 11, 2020 18:01
@CaseyCarter CaseyCarter self-assigned this Apr 11, 2020
@CaseyCarter CaseyCarter mentioned this pull request Apr 11, 2020
4 tasks
@miscco
Copy link
Contributor

miscco commented Apr 12, 2020

Awesome! Great work @CaseyCarter

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement Something can be improved
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants