bytebuffer: esphome: on_boot: - lambda: |- using namespace bytebuffer; auto buf = ByteBuffer(16); assert(buf.get_endianness() == LITTLE); assert(buf.get_remaining() == 16); buf.set_limit(10); assert(buf.get_capacity() == 16); buf.put_uint8(1); assert(buf.get_remaining() == 9); buf.put_uint16(0xABCD); auto da = buf.get_data(); assert(buf.get_uint8(0) == 1); auto x = buf.get_uint16(1); assert(buf.get_uint16(1) == 0xABCD); assert(buf.get_remaining() == 7); buf.put_uint32(0x12345678UL); assert(buf.get_uint32(3) == 0x12345678UL); assert(buf.get_remaining() == 3); assert(buf.get_data()[1] == 0xCD); assert(buf.get_data()[2] == 0xAB); assert(buf.get_data()[3] == 0x78); assert(buf.get_data()[4] == 0x56); assert(buf.get_data()[5] == 0x34); assert(buf.get_data()[6] == 0x12); buf.flip(); assert(buf.get_capacity() == 16); assert(buf.get_uint32(3) == 0x12345678UL); assert(buf.get_uint8(0) == 1); assert(buf.get_uint16(1) == 0xABCD); buf.put_uint16(0x1234, 1); assert(buf.get_uint16(1) == 0x1234); assert(buf.get_remaining() == 7); assert(buf.get_uint8() == 1); assert(buf.get_uint16() == 0x1234); assert(buf.get_uint32() == 0x12345678ul); assert(buf.get_remaining() == 0); assert(buf.get_remaining() == 0); buf.rewind(); buf.big_endian(); assert(buf.get_remaining() == 7); assert(buf.get_uint8() == 1); assert(buf.get_uint16() == 0x3412); buf.mark(); assert(buf.get_uint32() == 0x78563412ul); assert(buf.get_remaining() == 0); buf.reset(); assert(buf.get_remaining() == 4); assert(buf.get_uint32() == 0x78563412ul); auto buf1 = ByteBuffer::wrap(buf.get_data().data(), buf.get_limit()); buf.clear(); assert(buf.get_position() == 0); assert(buf.get_capacity() == 16); assert(buf.get_limit() == 16); assert(buf1.get_remaining() == 7); assert(buf1.get_capacity() == 7); buf1.set_position(3); assert(buf1.get_uint32() == 0x12345678ul); buf1.clear(); assert(buf1.get_limit() == 7); assert(buf1.get_capacity() == 7); assert(buf1.get_position() == 0); float f = 1.2345; buf1.put_float(f); buf1.flip(); assert(buf1.get_remaining() == 4); assert(buf1.get_float() == f); buf1.clear(); buf1.put_uint16(-32760); buf1.put_uint24(-302760); buf1.flip(); assert(buf1.get_int16() == -32760); assert(buf1.get_int24() == -302760); uint8_t arr[4] = {0x10, 0x20, 0x30, 0x40}; buf1 = ByteBuffer::wrap(arr, 4); assert(buf1.get_capacity() == 4); assert(buf1.get_limit() == 4); assert(buf1.get_position() == 0); assert(buf1.get_uint32() == 0x40302010UL); assert(buf1.get_position() == 4); assert(buf1.get_remaining() == 0); std::vector vec{}; vec.push_back(0x10); vec.push_back(0x20); vec.push_back(0x30); vec.push_back(0x40); buf1 = ByteBuffer::wrap(vec); assert(buf1.get_capacity() == 4); assert(buf1.get_limit() == 4); assert(buf1.get_position() == 0); buf1.mark(); buf1.reset(); assert(buf1.get_uint32() == 0x40302010UL); buf = ByteBuffer::wrap(true); assert(buf.get_bool() == true); buf = ByteBuffer::wrap((uint8_t)0xFE); assert(buf.get_uint8() == 0xFE); buf = ByteBuffer::wrap((uint16_t)0xA5A6, BIG); assert(buf.get_remaining() == 2); assert(buf.get_position() == 0); assert(buf.get_capacity() == 2); assert(buf.get_endianness() == BIG); assert(buf.get_data()[0] == 0xA5); assert(buf.get_uint16() == 0xA5A6); buf.flip(); buf.little_endian(); assert(buf.get_uint16() == 0xA6A5); buf = ByteBuffer::wrap(f, BIG); assert(buf.get_float() == f); double d = 1.2345678E7; buf = ByteBuffer::wrap(d, BIG); assert(buf.get_double() == d); buf = ByteBuffer::wrap({1, 2, 3, 4}, BIG); assert(buf.get_endianness() == BIG); assert(buf.get_remaining() == 4); assert(buf.get_data()[2] == 3); buf.little_endian(); assert(buf.get_data()[2] == 3); assert(buf.get_uint16() == 0x0201); buf.big_endian(); assert(buf.get_uint16() == 0x0304); buf.rewind(); vec = buf.get_vector(3); assert(buf.get_remaining() == 1); assert(vec[0] == 1); assert(vec.size() == 3); buf = ByteBuffer(10); buf.put_vector(vec); assert(buf.get_remaining() == 7); buf.flip(); assert(buf.get_remaining() == 3); assert(buf.get_uint24() == 0x030201); buf = ByteBuffer(64); buf.put_uint8(1, 1); buf.put_uint16(16, 2); buf.put_uint32(1232, 4); buf.put_uint64(123432ul, 8); buf.put_float(1.2f, 16); buf.put_int24(0x678, 20); assert(buf.get_uint8(1) == 1); assert(buf.get(1) == 1); assert(buf.get_uint16(2) == 16); assert(buf.get(2) == 16); assert(buf.get_uint32(4) == 1232); assert(buf.get(4) == 1232); assert(buf.get_uint64(8) == 123432ul); assert(buf.get(8) == 123432ul); assert(buf.get_float(16) == 1.2f); assert(buf.get(16) == 1.2f); assert(buf.get_int24(20) == 0x678); buf.clear(); buf.put(1.234, 10); double dx = buf.get(10); assert(dx == 1.234); buf.put((uint16_t)1, 10); assert(buf.get_uint16(10) == 1); ESP_LOGD("bytebuffer", "******************** All tests succeeded");