store_convenience_test.cpp 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. // Copyright 2019 Peter Dimov
  2. //
  3. // Distributed under the Boost Software License, Version 1.0.
  4. // http://www.boost.org/LICENSE_1_0.txt
  5. #include <boost/endian/conversion.hpp>
  6. #include <boost/core/lightweight_test.hpp>
  7. #include <boost/config.hpp>
  8. #include <boost/cstdint.hpp>
  9. #include <cstddef>
  10. #include <ostream>
  11. #include <iomanip>
  12. class byte_span
  13. {
  14. private:
  15. unsigned char const * p_;
  16. std::size_t n_;
  17. public:
  18. byte_span( unsigned char const * p, std::size_t n ): p_( p ), n_( n )
  19. {
  20. }
  21. template<std::size_t N> explicit byte_span( unsigned char const (&a)[ N ] ): p_( a ), n_( N )
  22. {
  23. }
  24. bool operator==( byte_span const& r ) const
  25. {
  26. if( n_ != r.n_ ) return false;
  27. for( std::size_t i = 0; i < n_; ++i )
  28. {
  29. if( p_[ i ] != r.p_[ i ] ) return false;
  30. }
  31. return true;
  32. }
  33. friend std::ostream& operator<<( std::ostream& os, byte_span s )
  34. {
  35. if( s.n_ == 0 ) return os;
  36. os << std::hex << std::setfill( '0' ) << std::uppercase;
  37. os << std::setw( 2 ) << +s.p_[ 0 ];
  38. for( std::size_t i = 1; i < s.n_; ++i )
  39. {
  40. os << ':' << std::setw( 2 ) << +s.p_[ i ];
  41. }
  42. os << std::dec << std::setfill( ' ' ) << std::nouppercase;;
  43. return os;
  44. }
  45. };
  46. int main()
  47. {
  48. using namespace boost::endian;
  49. // 16
  50. {
  51. unsigned char v[] = { 0xAA, 0xAA, 0xAA };
  52. store_little_s16( v, -3343 );
  53. unsigned char w1[] = { 0xF1, 0xF2, 0xAA };
  54. BOOST_TEST_EQ( byte_span( v ), byte_span( w1 ) );
  55. store_little_u16( v, 0x0201 );
  56. unsigned char w2[] = { 0x01, 0x02, 0xAA };
  57. BOOST_TEST_EQ( byte_span( v ), byte_span( w2 ) );
  58. store_big_s16( v, -3343 );
  59. unsigned char w3[] = { 0xF2, 0xF1, 0xAA };
  60. BOOST_TEST_EQ( byte_span( v ), byte_span( w3 ) );
  61. store_big_u16( v, 0x0201 );
  62. unsigned char w4[] = { 0x02, 0x01, 0xAA };
  63. BOOST_TEST_EQ( byte_span( v ), byte_span( w4 ) );
  64. }
  65. // 24
  66. {
  67. unsigned char v[] = { 0xAA, 0xAA, 0xAA, 0xAA };
  68. store_little_s24( v, -789775 );
  69. unsigned char w1[] = { 0xF1, 0xF2, 0xF3, 0xAA };
  70. BOOST_TEST_EQ( byte_span( v ), byte_span( w1 ) );
  71. store_little_u24( v, 0x030201 );
  72. unsigned char w2[] = { 0x01, 0x02, 0x03, 0xAA };
  73. BOOST_TEST_EQ( byte_span( v ), byte_span( w2 ) );
  74. store_big_s24( v, -789775 );
  75. unsigned char w3[] = { 0xF3, 0xF2, 0xF1, 0xAA };
  76. BOOST_TEST_EQ( byte_span( v ), byte_span( w3 ) );
  77. store_big_u24( v, 0x030201 );
  78. unsigned char w4[] = { 0x03, 0x02, 0x01, 0xAA };
  79. BOOST_TEST_EQ( byte_span( v ), byte_span( w4 ) );
  80. }
  81. // 32
  82. {
  83. unsigned char v[] = { 0xAA, 0xAA, 0xAA, 0xAA, 0xAA };
  84. store_little_s32( v, 0xF4F3F2F1 );
  85. unsigned char w1[] = { 0xF1, 0xF2, 0xF3, 0xF4, 0xAA };
  86. BOOST_TEST_EQ( byte_span( v ), byte_span( w1 ) );
  87. store_little_u32( v, 0x04030201 );
  88. unsigned char w2[] = { 0x01, 0x02, 0x03, 0x04, 0xAA };
  89. BOOST_TEST_EQ( byte_span( v ), byte_span( w2 ) );
  90. store_big_s32( v, 0xF4F3F2F1 );
  91. unsigned char w3[] = { 0xF4, 0xF3, 0xF2, 0xF1, 0xAA };
  92. BOOST_TEST_EQ( byte_span( v ), byte_span( w3 ) );
  93. store_big_u32( v, 0x04030201 );
  94. unsigned char w4[] = { 0x04, 0x03, 0x02, 0x01, 0xAA };
  95. BOOST_TEST_EQ( byte_span( v ), byte_span( w4 ) );
  96. }
  97. // 40
  98. {
  99. unsigned char v[] = { 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA };
  100. store_little_s40( v, -43135012111 );
  101. unsigned char w1[] = { 0xF1, 0xF2, 0xF3, 0xF4, 0xF5, 0xAA };
  102. BOOST_TEST_EQ( byte_span( v ), byte_span( w1 ) );
  103. store_little_u40( v, 0x0504030201 );
  104. unsigned char w2[] = { 0x01, 0x02, 0x03, 0x04, 0x05, 0xAA };
  105. BOOST_TEST_EQ( byte_span( v ), byte_span( w2 ) );
  106. store_big_s40( v, -43135012111 );
  107. unsigned char w3[] = { 0xF5, 0xF4, 0xF3, 0xF2, 0xF1, 0xAA };
  108. BOOST_TEST_EQ( byte_span( v ), byte_span( w3 ) );
  109. store_big_u40( v, 0x0504030201 );
  110. unsigned char w4[] = { 0x05, 0x04, 0x03, 0x02, 0x01, 0xAA };
  111. BOOST_TEST_EQ( byte_span( v ), byte_span( w4 ) );
  112. }
  113. // 48
  114. {
  115. unsigned char v[] = { 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA };
  116. store_little_s48( v, -9938739662095 );
  117. unsigned char w1[] = { 0xF1, 0xF2, 0xF3, 0xF4, 0xF5, 0xF6, 0xAA };
  118. BOOST_TEST_EQ( byte_span( v ), byte_span( w1 ) );
  119. store_little_u48( v, 0x060504030201 );
  120. unsigned char w2[] = { 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0xAA };
  121. BOOST_TEST_EQ( byte_span( v ), byte_span( w2 ) );
  122. store_big_s48( v, -9938739662095 );
  123. unsigned char w3[] = { 0xF6, 0xF5, 0xF4, 0xF3, 0xF2, 0xF1, 0xAA };
  124. BOOST_TEST_EQ( byte_span( v ), byte_span( w3 ) );
  125. store_big_u48( v, 0x060504030201 );
  126. unsigned char w4[] = { 0x06, 0x05, 0x04, 0x03, 0x02, 0x01, 0xAA };
  127. BOOST_TEST_EQ( byte_span( v ), byte_span( w4 ) );
  128. }
  129. // 56
  130. {
  131. unsigned char v[] = { 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA };
  132. store_little_s56( v, -2261738553347343 );
  133. unsigned char w1[] = { 0xF1, 0xF2, 0xF3, 0xF4, 0xF5, 0xF6, 0xF7, 0xAA };
  134. BOOST_TEST_EQ( byte_span( v ), byte_span( w1 ) );
  135. store_little_u56( v, 0x07060504030201 );
  136. unsigned char w2[] = { 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0xAA };
  137. BOOST_TEST_EQ( byte_span( v ), byte_span( w2 ) );
  138. store_big_s56( v, -2261738553347343 );
  139. unsigned char w3[] = { 0xF7, 0xF6, 0xF5, 0xF4, 0xF3, 0xF2, 0xF1, 0xAA };
  140. BOOST_TEST_EQ( byte_span( v ), byte_span( w3 ) );
  141. store_big_u56( v, 0x07060504030201 );
  142. unsigned char w4[] = { 0x07, 0x06, 0x05, 0x04, 0x03, 0x02, 0x01, 0xAA };
  143. BOOST_TEST_EQ( byte_span( v ), byte_span( w4 ) );
  144. }
  145. // 64
  146. {
  147. unsigned char v[] = { 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA };
  148. store_little_s64( v, 0xF8F7F6F5F4F3F2F1 );
  149. unsigned char w1[] = { 0xF1, 0xF2, 0xF3, 0xF4, 0xF5, 0xF6, 0xF7, 0xF8, 0xAA };
  150. BOOST_TEST_EQ( byte_span( v ), byte_span( w1 ) );
  151. store_little_u64( v, 0x0807060504030201 );
  152. unsigned char w2[] = { 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0xAA };
  153. BOOST_TEST_EQ( byte_span( v ), byte_span( w2 ) );
  154. store_big_s64( v, 0xF8F7F6F5F4F3F2F1 );
  155. unsigned char w3[] = { 0xF8, 0xF7, 0xF6, 0xF5, 0xF4, 0xF3, 0xF2, 0xF1, 0xAA };
  156. BOOST_TEST_EQ( byte_span( v ), byte_span( w3 ) );
  157. store_big_u64( v, 0x0807060504030201 );
  158. unsigned char w4[] = { 0x08, 0x07, 0x06, 0x05, 0x04, 0x03, 0x02, 0x01, 0xAA };
  159. BOOST_TEST_EQ( byte_span( v ), byte_span( w4 ) );
  160. }
  161. return boost::report_errors();
  162. }