/////////////////////////////////////////////////////////////////////////////// // // Copyright (c) 2015 Microsoft Corporation. All rights reserved. // // This code is licensed under the MIT License (MIT). // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. // /////////////////////////////////////////////////////////////////////////////// #ifdef _MSC_VER // blanket turn off warnings from CppCoreCheck from catch // so people aren't annoyed by them when running the tool. #pragma warning(disable : 26440 26426) #endif // _MSC_VER #if __clang__ || __GNUC__ //disable warnings from gtest #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wundef" #endif // __clang__ || __GNUC__ #if __clang__ #pragma GCC diagnostic ignored "-Wglobal-constructors" #pragma GCC diagnostic ignored "-Wused-but-marked-unused" #pragma GCC diagnostic ignored "-Wcovered-switch-default" #pragma GCC diagnostic ignored "-Winconsistent-missing-destructor-override" #endif // __clang__ #include #include // for to_byte, to_integer, byte, operator&, ope... using namespace std; using namespace gsl; namespace { int modify_both(gsl::byte& b, int& i) { i = 10; b = to_byte<5>(); return i; } TEST(byte_tests, construction) { { const byte b = static_cast(4); EXPECT_TRUE(static_cast(b) == 4); } GSL_SUPPRESS(es.49) { const byte b = byte(12); EXPECT_TRUE(static_cast(b) == 12); } { const byte b = to_byte<12>(); EXPECT_TRUE(static_cast(b) == 12); } { const unsigned char uc = 12; const byte b = to_byte(uc); EXPECT_TRUE(static_cast(b) == 12); } #if defined(__cplusplus) && (__cplusplus >= 201703L) { const byte b { 14 }; EXPECT_TRUE(static_cast(b) == 14); } #endif } TEST(byte_tests, bitwise_operations) { const byte b = to_byte<0xFF>(); byte a = to_byte<0x00>(); EXPECT_TRUE((b | a) == to_byte<0xFF>()); EXPECT_TRUE(a == to_byte<0x00>()); a |= b; EXPECT_TRUE(a == to_byte<0xFF>()); a = to_byte<0x01>(); EXPECT_TRUE((b & a) == to_byte<0x01>()); a &= b; EXPECT_TRUE(a == to_byte<0x01>()); EXPECT_TRUE((b ^ a) == to_byte<0xFE>()); EXPECT_TRUE(a == to_byte<0x01>()); a ^= b; EXPECT_TRUE(a == to_byte<0xFE>()); a = to_byte<0x01>(); EXPECT_TRUE(~a == to_byte<0xFE>()); a = to_byte<0xFF>(); EXPECT_TRUE((a << 4) == to_byte<0xF0>()); EXPECT_TRUE((a >> 4) == to_byte<0x0F>()); a <<= 4; EXPECT_TRUE(a == to_byte<0xF0>()); a >>= 4; EXPECT_TRUE(a == to_byte<0x0F>()); } TEST(byte_tests, to_integer) { const byte b = to_byte<0x12>(); EXPECT_TRUE(0x12 == gsl::to_integer(b)); EXPECT_TRUE(0x12 == gsl::to_integer(b)); EXPECT_TRUE(0x12 == gsl::to_integer(b)); EXPECT_TRUE(0x12 == gsl::to_integer(b)); EXPECT_TRUE(0x12 == gsl::to_integer(b)); EXPECT_TRUE(0x12 == gsl::to_integer(b)); EXPECT_TRUE(0x12 == gsl::to_integer(b)); EXPECT_TRUE(0x12 == gsl::to_integer(b)); // EXPECT_TRUE(0x12 == gsl::to_integer(b)); // expect compile-time error // EXPECT_TRUE(0x12 == gsl::to_integer(b)); // expect compile-time error } TEST(byte_tests, aliasing) { int i{0}; const int res = modify_both(reinterpret_cast(i), i); EXPECT_TRUE(res == i); } } #ifdef CONFIRM_COMPILATION_ERRORS copy(src_span_static, dst_span_static); #endif #if __clang__ || __GNUC__ #pragma GCC diagnostic pop #endif // __clang__ || __GNUC__