Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(185)

Side by Side Diff: util/numeric/int128_test.cc

Issue 583283003: Add uint128_struct and its test (Closed) Base URL: https://chromium.googlesource.com/crashpad/crashpad@master
Patch Set: Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « util/numeric/int128.h ('k') | util/util.gyp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2014 The Crashpad Authors. All rights reserved.
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14
15 #include "util/numeric/int128.h"
16
17 #include "base/basictypes.h"
18 #include "gtest/gtest.h"
19
20 namespace {
21
22 using namespace crashpad;
23
24 TEST(Int128, UInt128) {
25 #if defined(ARCH_CPU_LITTLE_ENDIAN)
26 const uint8_t kBytes[] =
27 {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
28 #else
29 const uint8_t kBytes[] =
30 {15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0};
31 #endif
32
33 uint128_struct uint128;
34 COMPILE_ASSERT(sizeof(uint128) == sizeof(kBytes), sizes_must_be_equal);
Robert Sesek 2014/09/22 19:02:14 Maybe also something simpler: COMPILE_ASSERT(8 * s
Mark Mentovai 2014/09/22 19:41:20 rsesek wrote:
Robert Sesek 2014/09/22 19:46:12 I meant "in addition to".
35
36 uint128 = bit_cast<uint128_struct>(kBytes);
37
38 EXPECT_EQ(0x0706050403020100u, uint128.lo);
39 EXPECT_EQ(0x0f0e0d0c0b0a0908u, uint128.hi);
40 }
41
42 } // namespace
OLDNEW
« no previous file with comments | « util/numeric/int128.h ('k') | util/util.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698