File: test_std_cmp.cpp

package info (click to toggle)
emscripten 3.1.69%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 121,860 kB
  • sloc: ansic: 636,110; cpp: 425,974; javascript: 78,401; python: 58,404; sh: 49,154; pascal: 5,237; makefile: 3,366; asm: 2,415; lisp: 1,869
file content (28 lines) | stat: -rw-r--r-- 1,030 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include <utility>
#include <cstdio>

// Uncommenting the next line will disable "signed/unsigned comparison" warnings:
// #pragma GCC diagnostic ignored "-Wsign-compare"

int main() {
  static_assert(sizeof(int) == 4); // precondition

  // Quite surprisingly
  static_assert(-1 > 1U ); //< warning: sign-unsign comparison
  // because after implicit conversion of -1 to the RHS type (`unsigned int`)
  // the expression is equivalent to:
  static_assert(0xFFFFFFFFU > 1U);
  static_assert(0xFFFFFFFFU == static_cast<unsigned>(-1));

  // In contrast, the cmp_* family compares integers as most expected -
  // negative signed integers always compare less than unsigned integers:
  static_assert(std::cmp_less( -1, 1U ));
  static_assert(std::cmp_less_equal( -1, 1U ));
  static_assert(!std::cmp_greater( -1, 1U ));
  static_assert(!std::cmp_greater_equal( -1, 1U));

  static_assert(-1 == 0xFFFFFFFFU); //< warning: sign-unsign comparison
  static_assert(std::cmp_not_equal(-1, 0xFFFFFFFFU ));
  printf("done\n");
  return 0;
}