All notable changes to this project will be documented in this file. The format is based on Keep a Changelog This project adheres to Semantic Versioning.
- Switched to C++14 as minimum requirement. Modernised the code accordingly.
- Only the tests need the Protobuf library when building.
- Improve compatibility with various STL flavors.
- Change license formatting to get recognized by license scanning tools.
- Add lots of
const
in places where we can. Also fix some other issues reported by clang-tidy. - Various other code cleanups.
- Modernize documentation config, CMake config and CI workflows.
basic_pbf_builder
constructor can not be noexcept.
1.7.1 - 2022-01-10
- Don't build tests if the standard CMake
BUILD_TESTING
variable is set to off. - Now needs CMake 3.5.0 or greater.
- Update included catch2 framework to current version v2.13.8.
- Only enable clang-tidy make target if protobuf was found.
- Allow setting C++ version to compile with in CMake config.
- Fixes undefined behaviour in
float
anddouble
byteswap. - Add missing includes of "config.hpp".
- Avoid narrowing conversion by doing an explicit
static_cast
.
1.7.0 - 2020-06-08
- Support for buffer types other that
std::string
.pbf_writer
is now just a typedef forbasic_pbf_writer<std::string>
. Other buffer types can be used withbasic_pbf_writer
. Seedoc/advanced.md
for details.
- Switched to catch2 for testing.
- Some minor tweaks.
- Removed some undefined behaviour.
1.6.8 - 2019-08-15
- Various code cleanups due to clang-tidy warnings.
- Made
data_view::compare
noexcept.
1.6.7 - 2018-02-21
- Signed-unsigned comparison on 32 bit systems.
1.6.6 - 2018-02-20
- Fixed several place with possible undefined behaviour.
1.6.5 - 2018-02-05
- Avoid UB: Do not calculate pointer outside array bounds.
- Specify proto2 syntax in .proto files to appease protoc.
1.6.4 - 2018-11-08
- Add function
data()
to get the not yet read data from apbf_reader
. - New
add_packed_fixed()
template function forpbf_writer
. - New
length_of_varint()
helper function calculates how long a varint would be for a specified value.
- More consistent implementation of operators as free friend functions.
- Fixed some zigzag encoding tests on MSVC.
- Add extra cast so we do an xor with unsigned ints.
- No more bitwise operations on signed integers in varint decoder.
- No more bitwise operations on signed integers in zigzag encoder/decoder.
1.6.3 - 2018-07-17
- Moved
byteswap_inplace
functions from detail into protozero namespace. They can be useful outsize protozero. - More asserts and unit tests and small cleanups.
1.6.2 - 2018-03-09
- Update included catch.hpp to v1.12.0.
- Move basic unit tests into their own directory (
test/unit
). - Improved clang-tidy config and fixed some code producing warnings.
- Buffer overflow in pbf-decoder tool.
1.6.1 - 2017-11-16
- Document internal handling of varints.
- Add aliases for fixed iterators, too.
- The
const_fixed_iterator
is now a random access iterator making code using it potentially more performant (for instance when usingstd::distance
) - Overloads
std::distance
for the varint and svarint iterators. This is better than the workaround with therage_size
function used before.
- Rename
.proto
files in some tests to be unique. This solves a problem when building with newer versions of the Google Protobuf library. - Floating point comparisons in tests are now always correctly done using
Approx()
.
1.6.0 - 2017-10-24
- Comparison functions (<, <=, >, >=) for
data_view
. Allows use instd::map
for instance. - Tool
pbf-decoder
for decoding raw messages. This has limited use for normal users, but it can be used for fuzzing.
- Protozero now uses CMake to build the tests etc. This does not affect
simple users of the library, but if you are using CMake yourself you might
want to use the
cmake/FindProtozero.cmake
module provided. The README contains more information about build options. - Moved
data_view
class fromtypes.hpp
into its own header filedata_view.hpp
. - Implementation of the
const_fixed_iterator
to use only a single pointer instead of two. - Made
operator==
andoperator!=
ondata_view
constexpr. - The
pbf_reader
constructor taking astd::pair
is deprecated. Use one of the other constructors instead.
- Varints where the last byte was larger than what would fit in 64bit were triggering undefined behaviour. This can only happen when the message being decoded was corrupt in some way.
- Do not assert when reading too long varints for bools any more. A valid encoder should never generate varints with more than one byte for bools, but if they are longer that's not really a problem, so just handle it.
- Throw exception if the length of a packed repeated field of a fixed-length type is invalid. The length must always be a multiple of the size of the underlying type. This can only happen if the data is corrupted in some way, a valid encoder would never generate data like this.
- Throw an exception when reading invalid tags. This can only happen if the data is corrupted in some way, a valid encoder would never generate invalid tags.
1.5.3 - 2017-09-22
- More documentation.
- New
size()
method on iterator range used for packed repeated fields to find out how many elements there are in the range. This is much faster compared to thestd::difference()
call you had to do before, because the varints don't have to be fully decoded. See Advanced Topics for details.
- Updated clang-tidy settings in Makefiles and fixed a lot of minor issues reported by clang-tidy.
- Update included catch.hpp to version 1.10.0.
- Miscellaneous code cleanups.
- Support for invalid state in
pbf_writer
andpacked_repeated_fields
. This fixes move construction and move assignement inpbf_writer
and disables the copy construction and copy assignement which don't have clear semantics. It introduces an invalid or empty state in thepbf_writer
,pbf_builder
, andpacked_repeated_fields
classes used for default-constructed, moved from, or committed objects. There is a newcommit()
function forpbf_writer
and thepacked_repeated_fields
which basically does the same as the destructor but can be called explicitly.
- The
empty()
method of the iterator range now returns abool
instead of asize_t
.
1.5.2 - 2017-06-30
- Add missing two-parameter version of
pbf_message::next()
function. - Add
data_view::empty()
function. - Add missing versions of
add_bytes()
,add_string()
, andadd_message()
topbf_builder
.
- Clarify include file usage in tutorial.
- Updated included Catch unit test framework to version 1.9.6 and updated tests to work with the current version.
- Make some constructors explicit (best practice to avoid silent conversions).
- Important bugfix in
data_view
equality operator. The equality operator is actually never used in the protozero code itself, but users of protozero might use it. This is a serious bug that could lead to buffer overrun type problems.
1.5.1 - 2017-01-14
- Better documentation for
tag_and_type()
in doc/advanced.md.
- Fixed broken "make doc" build.
1.5.0 - 2017-01-12
- Add
add_bytes_vectored()
methods topbf_writer
andpbf_builder
. This allows single-copy scatter-gather type adding of data that has been prepared in pieces to a protobuf message. - New functions to check the tag and wire type at the same time: Two parameter
version of
pbf_reader::next()
andpbf_reader::tag_and_type()
can be used together with the free functiontag_and_type()
to easily and quickly check that not only the tag but also the wire type is correct for a field.
packed_field_*
classes now work withpbf_builder
.- Reorganized documentation. Advanced docs are now under doc/advanced.md.
packed_field
class is now non-copyable because data can get corrupted if you copy it around.- Comparison operators of
data_view
now have const& parameters. - Make zigzag encoding/decoding functions constexpr.
1.4.5 - 2016-11-18
- Undefined behaviour in packed fixed iterator. As a result, the macro
PROTOZERO_DO_NOT_USE_BARE_POINTER
is not used any more.
1.4.4 - 2016-11-15
- Byteswap implementation.
1.4.3 - 2016-11-15
- Undefined behaviour in byte swapping code.
- Rename some parameters to avoid "shadow" warning from some compilers.
1.4.2 - 2016-08-27
- Compile fix: Variable shadowing.
1.4.1 - 2016-08-21
- GCC 4.8 compile fixed
- New ability to dynamically require the module as a node module to ease building against from other node C++ modules.
1.4.0 - 2016-07-22
- Use more efficient new
skip_varint()
function when iterating over packed varints. - Split
decode_varint()
function into two functions speeding up the common case where a varint is only one byte long. - Introduce new class
iterator_range
used instead ofstd::pair
of iterators. This way the objects can be used in range-based for loops. Read UPGRADING.md for details. - Introduce new class
data_view
and functions using and returning it. Read UPGRADING.md for details.
1.3.0 - 2016-02-18
- Added
config.hpp
header which now includes all the macro magic to configure the library for different architectures etc. - New way to create repeated packed fields without using an iterator.
- Add
rollback()
function topbf_writer
for "manual" rollback.
- Various test and documentation cleanups.
- Rename
pbf_types.hpp
totypes.hpp
.
1.2.3 - 2015-11-30
- Added
config.hpp
header which now includes all the macro magic to configure the library for different architectures etc.
- Unaligned access to floats/doubles on some ARM architectures.
1.2.2 - 2015-10-13
- Fix the recently broken writing of bools on big-endian architectures.
1.2.1 - 2015-10-12
- Removed unneeded code (1-byte "swap") which lead to test failures.
1.2.0 - 2015-10-08
pbf_message
andpbf_builder
template classes wrappingpbf_reader
andpbf_writer
, respectively. The new classes are the preferred interface now.
- Improved byte swapping operation.
- Detect some types of data corruption earlier and throw.
1.1.0 - 2015-08-22
- Make pbf reader and writer code endianess-aware.