ard-boost (community library)
Summary
Name | Value |
---|---|
Name | ard-boost |
Version | 0.0.3 |
Installs | |
License | Boost Software License, Version 1.0. |
Author | Vladimir Talybin |
URL | https://github.com/talybin/ard-boost |
Repository | https://github.com/talybin/ard-boost.git |
Download | .tar.gz |
All Versions | 0.0.3, 0.0.2, 0.0.1 |
Boost library port. Boost is a set of C++ libraries usable across a broad spectrum of applications.
Library Read Me
This content is provided by the library maintainer and has not been validated or approved.
ARD-BOOST
This is a mini port of Boost library, version 1.72.0 (latest on time of writing). Boost is a set of C++ libraries that provide support for tasks and structures such as linear algebra, pseudorandom number generation, multithreading, image processing, regular expressions, unit testing and many more. It contains 160 individual libraries.
Not all libraries are included in this port. Some libraries, such as threading and filesystem, makes no sence on Arduino hardware. Others are already in the standard, like chrono and array, and can be used from standard namespace. But there are many libraries that are not yet in standard or require C++17 or just great parts of Boost. These parts ported to this library.
So far it includes only libraries I was able to compile for Arduino. My intention is to add more libraries as needed. Requests are welcome.
Currently supporting
The following is a list of supported libraries with all their dependencies:
- any
- concept check
- container
- container hash
- core
- functional
- iterator
- mp11
- mpl
- optional
- preprocessor
- range
- static assert
- string_view / string_ref
- type index
- type traits
- utility
- variant
- variant2
Get started
Before include of any Boost library make sure to include ard-boost.h
. This will setup exception handling and fix some compile problems. Otherwise the usage is the same as usual. Include any of supported library and you are good to go.
#include "ard-boost.h"
#include "boost/range.hpp"
void setup()
{
int sum = 0;
for (int i : boost::irange(5, 10))
sum += i;
}
void loop() { }
Exception handling
As you may know, exceptions are disabled on Arduino. Instead of throwing exception, Boost will call special handler function with exception as argument. It is defined in ard-boost.h
and by default, in case of an exception, will reboot the device.
To provide your own exception handler, make sure to define CUSTOM_EXCEPTION_HANDLER
before include of ard-boost.h
and override exception function. For example:
#define CUSTOM_EXCEPTION_HANDLER
#include "ard-boost.h"
void boost::throw_exception(const std::exception& ex) {
// Log exception and reboot
Particle.publish("Error", ex.what(), PRIVATE);
System.reset();
}
void setup() { }
void loop() { }
Note! The exception handler must not return (protected by noreturn attribute).
Browse Library Files