-
Notifications
You must be signed in to change notification settings - Fork 31
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
Support C++20 #346
Milestone
Comments
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 688985785
copybara-service bot
pushed a commit
that referenced
this issue
Oct 23, 2024
This is an issue specifically on CRTP classes templated equality operators that is resolved by making equality operators free standing functions. e.g. ``` implementation/local_object_test.cc:194:22: error: use of overloaded operator '==' is ambiguous (with operand types 'LocalObject<kClass>' and 'LocalObject<kClass2>') EXPECT_FALSE(val_1 == val_2); ~~~~~ ^ ~~~~~ ``` See #346. Sample failure https://github.com/google/jni-bind/actions/runs/11474529819/job/31930608615?pr=345. PiperOrigin-RevId: 689141602
C++20 now compiles without failure and has been added in the test suite for both Mac and Linux. I was desperately hoping I could enable full compiler support with C++20 and maintain the existing syntax, but I think it is impossible despite trying incredibly hard. I'm going to call this task completed and leave #42 to be resolved in due course. |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Currently there are compilation failures when building for C++20.
C++20 will enable broader compiler support so this is a prerequisite. This work was originally slated for milestone 2.0 but I think it makes sense to start significantly pushing this work forward.
This work may move around. I may or may not fully rev the major release version.
The text was updated successfully, but these errors were encountered: