Version 0.8.
This commit is contained in:
parent
1005c62e90
commit
c96ff018fe
|
@ -6,11 +6,11 @@ project(simdjson
|
||||||
)
|
)
|
||||||
|
|
||||||
set(PROJECT_VERSION_MAJOR 0)
|
set(PROJECT_VERSION_MAJOR 0)
|
||||||
set(PROJECT_VERSION_MINOR 7)
|
set(PROJECT_VERSION_MINOR 8)
|
||||||
set(PROJECT_VERSION_PATCH 1)
|
set(PROJECT_VERSION_PATCH 0)
|
||||||
set(SIMDJSON_SEMANTIC_VERSION "0.7.1" CACHE STRING "simdjson semantic version")
|
set(SIMDJSON_SEMANTIC_VERSION "0.8.0" CACHE STRING "simdjson semantic version")
|
||||||
set(SIMDJSON_LIB_VERSION "6.0.0" CACHE STRING "simdjson library version")
|
set(SIMDJSON_LIB_VERSION "7.0.0" CACHE STRING "simdjson library version")
|
||||||
set(SIMDJSON_LIB_SOVERSION "6" CACHE STRING "simdjson library soversion")
|
set(SIMDJSON_LIB_SOVERSION "7" CACHE STRING "simdjson library soversion")
|
||||||
set(SIMDJSON_GITHUB_REPOSITORY https://github.com/simdjson/simdjson)
|
set(SIMDJSON_GITHUB_REPOSITORY https://github.com/simdjson/simdjson)
|
||||||
|
|
||||||
include(GNUInstallDirs)
|
include(GNUInstallDirs)
|
||||||
|
|
2
Doxyfile
2
Doxyfile
|
@ -38,7 +38,7 @@ PROJECT_NAME = simdjson
|
||||||
# could be handy for archiving the generated documentation or if some version
|
# could be handy for archiving the generated documentation or if some version
|
||||||
# control system is used.
|
# control system is used.
|
||||||
|
|
||||||
PROJECT_NUMBER = "0.7.0"
|
PROJECT_NUMBER = "0.8.0"
|
||||||
|
|
||||||
# Using the PROJECT_BRIEF tag one can provide an optional one line description
|
# Using the PROJECT_BRIEF tag one can provide an optional one line description
|
||||||
# for a project that appears at the top of each page and should give viewer a
|
# for a project that appears at the top of each page and should give viewer a
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
[![Ubuntu 20.04 CI](https://github.com/simdjson/simdjson/workflows/Ubuntu%2020.04%20CI%20(GCC%209)/badge.svg)](https://simdjson.org/plots.html)
|
[![Ubuntu 20.04 CI](https://github.com/simdjson/simdjson/workflows/Ubuntu%2020.04%20CI%20(GCC%209)/badge.svg)](https://simdjson.org/plots.html)
|
||||||
![VS16-CI](https://github.com/simdjson/simdjson/workflows/VS16-CI/badge.svg)
|
![VS16-CI](https://github.com/simdjson/simdjson/workflows/VS16-CI/badge.svg)
|
||||||
![MinGW64-CI](https://github.com/simdjson/simdjson/workflows/MinGW64-CI/badge.svg)
|
![MinGW64-CI](https://github.com/simdjson/simdjson/workflows/MinGW64-CI/badge.svg)
|
||||||
[![][license img]][license] [![Doxygen Documentation](https://img.shields.io/badge/docs-doxygen-green.svg)](https://simdjson.org/api/0.7.0/index.html)
|
[![][license img]][license] [![Doxygen Documentation](https://img.shields.io/badge/docs-doxygen-green.svg)](https://simdjson.org/api/0.8.0/index.html)
|
||||||
|
|
||||||
simdjson : Parsing gigabytes of JSON per second
|
simdjson : Parsing gigabytes of JSON per second
|
||||||
===============================================
|
===============================================
|
||||||
|
@ -105,7 +105,7 @@ Usage documentation is available:
|
||||||
* [Performance](doc/performance.md) shows some more advanced scenarios and how to tune for them.
|
* [Performance](doc/performance.md) shows some more advanced scenarios and how to tune for them.
|
||||||
* [Implementation Selection](doc/implementation-selection.md) describes runtime CPU detection and
|
* [Implementation Selection](doc/implementation-selection.md) describes runtime CPU detection and
|
||||||
how you can work with it.
|
how you can work with it.
|
||||||
* [API](https://simdjson.org/api/0.7.0/annotated.html) contains the automatically generated API documentation.
|
* [API](https://simdjson.org/api/0.8.0/annotated.html) contains the automatically generated API documentation.
|
||||||
|
|
||||||
Performance results
|
Performance results
|
||||||
-------------------
|
-------------------
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
#define SIMDJSON_SIMDJSON_VERSION_H
|
#define SIMDJSON_SIMDJSON_VERSION_H
|
||||||
|
|
||||||
/** The version of simdjson being used (major.minor.revision) */
|
/** The version of simdjson being used (major.minor.revision) */
|
||||||
#define SIMDJSON_VERSION 0.7.0
|
#define SIMDJSON_VERSION 0.8.0
|
||||||
|
|
||||||
namespace simdjson {
|
namespace simdjson {
|
||||||
enum {
|
enum {
|
||||||
|
@ -15,7 +15,7 @@ enum {
|
||||||
/**
|
/**
|
||||||
* The minor version (major.MINOR.revision) of simdjson being used.
|
* The minor version (major.MINOR.revision) of simdjson being used.
|
||||||
*/
|
*/
|
||||||
SIMDJSON_VERSION_MINOR = 7,
|
SIMDJSON_VERSION_MINOR = 8,
|
||||||
/**
|
/**
|
||||||
* The revision (major.minor.REVISION) of simdjson being used.
|
* The revision (major.minor.REVISION) of simdjson being used.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* auto-generated on 2021-01-14 17:33:49 -0500. Do not edit! */
|
/* auto-generated on 2021-01-20 13:20:49 -0500. Do not edit! */
|
||||||
/* begin file src/simdjson.cpp */
|
/* begin file src/simdjson.cpp */
|
||||||
#include "simdjson.h"
|
#include "simdjson.h"
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* auto-generated on 2021-01-14 17:33:49 -0500. Do not edit! */
|
/* auto-generated on 2021-01-20 13:20:49 -0500. Do not edit! */
|
||||||
/* begin file include/simdjson.h */
|
/* begin file include/simdjson.h */
|
||||||
#ifndef SIMDJSON_H
|
#ifndef SIMDJSON_H
|
||||||
#define SIMDJSON_H
|
#define SIMDJSON_H
|
||||||
|
@ -2017,7 +2017,7 @@ SIMDJSON_DISABLE_UNDESIRED_WARNINGS
|
||||||
#define SIMDJSON_SIMDJSON_VERSION_H
|
#define SIMDJSON_SIMDJSON_VERSION_H
|
||||||
|
|
||||||
/** The version of simdjson being used (major.minor.revision) */
|
/** The version of simdjson being used (major.minor.revision) */
|
||||||
#define SIMDJSON_VERSION 0.7.0
|
#define SIMDJSON_VERSION 0.8.0
|
||||||
|
|
||||||
namespace simdjson {
|
namespace simdjson {
|
||||||
enum {
|
enum {
|
||||||
|
@ -2028,7 +2028,7 @@ enum {
|
||||||
/**
|
/**
|
||||||
* The minor version (major.MINOR.revision) of simdjson being used.
|
* The minor version (major.MINOR.revision) of simdjson being used.
|
||||||
*/
|
*/
|
||||||
SIMDJSON_VERSION_MINOR = 7,
|
SIMDJSON_VERSION_MINOR = 8,
|
||||||
/**
|
/**
|
||||||
* The revision (major.minor.REVISION) of simdjson being used.
|
* The revision (major.minor.REVISION) of simdjson being used.
|
||||||
*/
|
*/
|
||||||
|
@ -2137,7 +2137,7 @@ namespace internal {
|
||||||
* Then any method returning simdjson_result<T> will be chainable with your methods.
|
* Then any method returning simdjson_result<T> will be chainable with your methods.
|
||||||
*/
|
*/
|
||||||
template<typename T>
|
template<typename T>
|
||||||
struct simdjson_result_base : public std::pair<T, error_code> {
|
struct simdjson_result_base : protected std::pair<T, error_code> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new empty result with error = UNINITIALIZED.
|
* Create a new empty result with error = UNINITIALIZED.
|
||||||
|
@ -2208,8 +2208,20 @@ struct simdjson_result_base : public std::pair<T, error_code> {
|
||||||
* @throw simdjson_error if there was an error.
|
* @throw simdjson_error if there was an error.
|
||||||
*/
|
*/
|
||||||
simdjson_really_inline operator T&&() && noexcept(false);
|
simdjson_really_inline operator T&&() && noexcept(false);
|
||||||
|
|
||||||
#endif // SIMDJSON_EXCEPTIONS
|
#endif // SIMDJSON_EXCEPTIONS
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the result value. This function is safe if and only
|
||||||
|
* the error() method returns a value that evoluates to false.
|
||||||
|
*/
|
||||||
|
simdjson_really_inline const T& value_unsafe() const& noexcept;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Take the result value (move it). This function is safe if and only
|
||||||
|
* the error() method returns a value that evoluates to false.
|
||||||
|
*/
|
||||||
|
simdjson_really_inline T&& value_unsafe() && noexcept;
|
||||||
|
|
||||||
}; // struct simdjson_result_base
|
}; // struct simdjson_result_base
|
||||||
|
|
||||||
} // namespace internal
|
} // namespace internal
|
||||||
|
@ -2287,8 +2299,20 @@ struct simdjson_result : public internal::simdjson_result_base<T> {
|
||||||
* @throw simdjson_error if there was an error.
|
* @throw simdjson_error if there was an error.
|
||||||
*/
|
*/
|
||||||
simdjson_really_inline operator T&&() && noexcept(false);
|
simdjson_really_inline operator T&&() && noexcept(false);
|
||||||
|
|
||||||
#endif // SIMDJSON_EXCEPTIONS
|
#endif // SIMDJSON_EXCEPTIONS
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the result value. This function is safe if and only
|
||||||
|
* the error() method returns a value that evoluates to false.
|
||||||
|
*/
|
||||||
|
simdjson_really_inline const T& value_unsafe() const& noexcept;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Take the result value (move it). This function is safe if and only
|
||||||
|
* the error() method returns a value that evoluates to false.
|
||||||
|
*/
|
||||||
|
simdjson_really_inline T&& value_unsafe() && noexcept;
|
||||||
|
|
||||||
}; // struct simdjson_result
|
}; // struct simdjson_result
|
||||||
|
|
||||||
#ifndef SIMDJSON_DISABLE_DEPRECATED_API
|
#ifndef SIMDJSON_DISABLE_DEPRECATED_API
|
||||||
|
@ -6972,6 +6996,16 @@ simdjson_really_inline simdjson_result_base<T>::operator T&&() && noexcept(false
|
||||||
|
|
||||||
#endif // SIMDJSON_EXCEPTIONS
|
#endif // SIMDJSON_EXCEPTIONS
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
simdjson_really_inline const T& simdjson_result_base<T>::value_unsafe() const& noexcept {
|
||||||
|
return this->first;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
simdjson_really_inline T&& simdjson_result_base<T>::value_unsafe() && noexcept {
|
||||||
|
return std::forward<T>(this->first);;
|
||||||
|
}
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
simdjson_really_inline simdjson_result_base<T>::simdjson_result_base(T &&value, error_code error) noexcept
|
simdjson_really_inline simdjson_result_base<T>::simdjson_result_base(T &&value, error_code error) noexcept
|
||||||
: std::pair<T, error_code>(std::forward<T>(value), error) {}
|
: std::pair<T, error_code>(std::forward<T>(value), error) {}
|
||||||
|
@ -7030,6 +7064,16 @@ simdjson_really_inline simdjson_result<T>::operator T&&() && noexcept(false) {
|
||||||
|
|
||||||
#endif // SIMDJSON_EXCEPTIONS
|
#endif // SIMDJSON_EXCEPTIONS
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
simdjson_really_inline const T& simdjson_result<T>::value_unsafe() const& noexcept {
|
||||||
|
return internal::simdjson_result_base<T>::value_unsafe();
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
simdjson_really_inline T&& simdjson_result<T>::value_unsafe() && noexcept {
|
||||||
|
return std::forward<internal::simdjson_result_base<T>>(*this).value_unsafe();
|
||||||
|
}
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
simdjson_really_inline simdjson_result<T>::simdjson_result(T &&value, error_code error) noexcept
|
simdjson_really_inline simdjson_result<T>::simdjson_result(T &&value, error_code error) noexcept
|
||||||
: internal::simdjson_result_base<T>(std::forward<T>(value), error) {}
|
: internal::simdjson_result_base<T>(std::forward<T>(value), error) {}
|
||||||
|
@ -15322,7 +15366,7 @@ simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::it
|
||||||
simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::iterate(const simdjson_result<padded_string> &result) & noexcept {
|
simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::iterate(const simdjson_result<padded_string> &result) & noexcept {
|
||||||
// We don't presently have a way to temporarily get a const T& from a simdjson_result<T> without throwing an exception
|
// We don't presently have a way to temporarily get a const T& from a simdjson_result<T> without throwing an exception
|
||||||
SIMDJSON_TRY( result.error() );
|
SIMDJSON_TRY( result.error() );
|
||||||
const padded_string &buf = result.first;
|
const padded_string &buf = result.value_unsafe();
|
||||||
return iterate(buf);
|
return iterate(buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21816,7 +21860,7 @@ simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::it
|
||||||
simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::iterate(const simdjson_result<padded_string> &result) & noexcept {
|
simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::iterate(const simdjson_result<padded_string> &result) & noexcept {
|
||||||
// We don't presently have a way to temporarily get a const T& from a simdjson_result<T> without throwing an exception
|
// We don't presently have a way to temporarily get a const T& from a simdjson_result<T> without throwing an exception
|
||||||
SIMDJSON_TRY( result.error() );
|
SIMDJSON_TRY( result.error() );
|
||||||
const padded_string &buf = result.first;
|
const padded_string &buf = result.value_unsafe();
|
||||||
return iterate(buf);
|
return iterate(buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28261,7 +28305,7 @@ simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::it
|
||||||
simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::iterate(const simdjson_result<padded_string> &result) & noexcept {
|
simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::iterate(const simdjson_result<padded_string> &result) & noexcept {
|
||||||
// We don't presently have a way to temporarily get a const T& from a simdjson_result<T> without throwing an exception
|
// We don't presently have a way to temporarily get a const T& from a simdjson_result<T> without throwing an exception
|
||||||
SIMDJSON_TRY( result.error() );
|
SIMDJSON_TRY( result.error() );
|
||||||
const padded_string &buf = result.first;
|
const padded_string &buf = result.value_unsafe();
|
||||||
return iterate(buf);
|
return iterate(buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34855,7 +34899,7 @@ simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::it
|
||||||
simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::iterate(const simdjson_result<padded_string> &result) & noexcept {
|
simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::iterate(const simdjson_result<padded_string> &result) & noexcept {
|
||||||
// We don't presently have a way to temporarily get a const T& from a simdjson_result<T> without throwing an exception
|
// We don't presently have a way to temporarily get a const T& from a simdjson_result<T> without throwing an exception
|
||||||
SIMDJSON_TRY( result.error() );
|
SIMDJSON_TRY( result.error() );
|
||||||
const padded_string &buf = result.first;
|
const padded_string &buf = result.value_unsafe();
|
||||||
return iterate(buf);
|
return iterate(buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40859,7 +40903,7 @@ simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::it
|
||||||
simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::iterate(const simdjson_result<padded_string> &result) & noexcept {
|
simdjson_warn_unused simdjson_really_inline simdjson_result<document> parser::iterate(const simdjson_result<padded_string> &result) & noexcept {
|
||||||
// We don't presently have a way to temporarily get a const T& from a simdjson_result<T> without throwing an exception
|
// We don't presently have a way to temporarily get a const T& from a simdjson_result<T> without throwing an exception
|
||||||
SIMDJSON_TRY( result.error() );
|
SIMDJSON_TRY( result.error() );
|
||||||
const padded_string &buf = result.first;
|
const padded_string &buf = result.value_unsafe();
|
||||||
return iterate(buf);
|
return iterate(buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue