Latest Arduino Library Version:
Latest Espressif Component Version:
esp-lib-utils
is a library designed to offer utility functions for other libraries, including the following features:
- Supports a variety of utility functions, such as
logging
,checking
, andmemory
functions. - Supports flexible static configuration, such as setting log levels, enabling/disabling checks, using custom memory allocation functions, and more.
- Compatible with the
Arduino
,ESP-IDF
andMicroPython
for compilation.
Dependency | Version |
---|---|
esp-idf | >= 5.1 |
esp-lib-utils
has been uploaded to the Espressif Component Registry, and users can add it to their project using the idf.py add-dependency
command, for example:
idf.py add-dependency "espressif/esp-lib-utils"
Alternatively, users can create or modify the idf_component.yml file in the project directory. For more details, please refer to the Espressif Documentation - IDF Component Manager.
When developing with esp-idf, users can configure esp-lib-utils
through the menuconfig:
- Run the command
idf.py menuconfig
. - Navigate to
Component config
>ESP Library Utils Configurations
.
Note
To support try-catch
when using esp_utils::make_shared()
in C++, users need to enable the COMPILER_CXX_EXCEPTIONS
configuration in the menuconfig.
Dependency | Version |
---|---|
arduino-esp32 | >= v3.0.0 |
For installation of the esp-lib-utils
library, refer to How to Install esp-lib-utils in Arduino IDE.
Below are detailed instructions on how to configure esp-lib-utils
. They are optional operations and are configured through the esp_utils_conf.h file with the following characteristics:
-
The path sequence to search for the esp_utils_conf.h file is:
Current Project Directory
>Arduino Library Directory
>esp-lib-utils Directory
. -
If a project needs to use a separate configuration, users can copy it from the root directory of
esp-lib-utils
to the project. -
If multiple projects need to use the same configuration, users can place it in the Arduino Library Directory, so that all projects can share the same configuration. The layout of the Arduino library folder should look like this:
Arduino |-libraries |-esp-lib-utils |-esp_utils_conf.h |-other_libs
Warning
- When the library version is updated, the configurations within the esp_utils_conf.h file might change, such as adding, deleting, or renaming.
- To ensure the compatibility of the program, the library manages the version of the file independently and checks whether the configuration file currently used by the user are compatible with the library during compilation.
- Detailed version information and checking rules can be found at the end of the file.
Since esp-lib-utils
configures its functionality through the esp_utils_conf.h file, users can customize behavior and default parameters by adjusting the macro definitions within this file. For example, to enable debug log output, here is a snippet of the modified esp_utils_conf.h
file:
...
/**
* Global log level, logs with a level lower than this will not be compiled. Choose one of the following:
* - ESP_UTILS_LOG_LEVEL_DEBUG: Extra information which is not necessary for normal use (values, pointers, sizes, etc)
* (lowest level)
* - ESP_UTILS_LOG_LEVEL_INFO: Information messages which describe the normal flow of events
* - ESP_UTILS_LOG_LEVEL_WARNING: Error conditions from which recovery measures have been taken
* - ESP_UTILS_LOG_LEVEL_ERROR: Critical errors, software module cannot recover on its own
* - ESP_UTILS_LOG_LEVEL_NONE: No log output (highest level) (Minimum code size)
*
*/
#define ESP_UTILS_CONF_LOG_LEVEL (ESP_UTILS_LOG_LEVEL_DEBUG)
...
Note
arduino-esp32
supports try-catch
in C++ by default.
// Define the log tag for the current library, should be declared before `esp_lib_utils.h`
#define ESP_UTILS_LOG_TAG "MyLibrary"
#include "esp_lib_utils.h"
void test_log(void)
{
ESP_UTILS_LOG_TRACE_ENTER();
ESP_UTILS_LOGD("This is a debug message");
ESP_UTILS_LOGI("This is an info message");
ESP_UTILS_LOGW("This is a warning message");
ESP_UTILS_LOGE("This is an error message");
ESP_UTILS_LOG_TRACE_EXIT();
}
// Define the log tag for the current library, should be declared before `esp_lib_utils.h`
#define ESP_UTILS_LOG_TAG "MyLibrary"
#include "esp_lib_utils.h"
bool test_check_false_return(void)
{
ESP_UTILS_CHECK_FALSE_RETURN(true, false, "Check false return failed");
ESP_UTILS_CHECK_FALSE_RETURN(false, true, "Check false return success");
return false;
}
bool test_check_false_goto(void)
{
ESP_UTILS_CHECK_FALSE_GOTO(true, err, "Check false goto failed");
ESP_UTILS_CHECK_FALSE_GOTO(false, end, "Check false goto success");
err:
return false;
end:
return true;
}
void test_check_false_exit(void)
{
ESP_UTILS_CHECK_FALSE_EXIT(true, "Check false exit failed");
ESP_UTILS_CHECK_FALSE_EXIT(false, "Check false exit success");
}
bool test_check_error_return(void)
{
ESP_UTILS_CHECK_ERROR_RETURN(ESP_OK, false, "Check error return failed");
ESP_UTILS_CHECK_ERROR_RETURN(ESP_FAIL, true, "Check error return success");
return false;
}
bool test_check_error_goto(void)
{
ESP_UTILS_CHECK_ERROR_GOTO(ESP_OK, err, "Check error goto failed");
ESP_UTILS_CHECK_ERROR_GOTO(ESP_FAIL, end, "Check error goto success");
err:
return false;
end:
return true;
}
void test_check_error_exit(void)
{
ESP_UTILS_CHECK_ERROR_EXIT(ESP_OK, "Check error exit failed");
ESP_UTILS_CHECK_ERROR_EXIT(ESP_FAIL, "Check error exit success");
}
bool test_check_null_return(void)
{
ESP_UTILS_CHECK_NULL_RETURN((void *)1, false, "Check null return failed");
ESP_UTILS_CHECK_NULL_RETURN(NULL, true, "Check null return success");
return false;
}
static bool test_check_null_goto(void)
{
ESP_UTILS_CHECK_NULL_GOTO((void *)1, err, "Check null goto failed");
ESP_UTILS_CHECK_NULL_GOTO(NULL, end, "Check null goto success");
err:
return false;
end:
return true;
}
void test_check_null_exit(void)
{
ESP_UTILS_CHECK_NULL_EXIT((void *)1, "Check null exit failed");
ESP_UTILS_CHECK_NULL_EXIT(NULL, "Check null exit success");
}
// Define the log tag for the current library, should be declared before `esp_lib_utils.h`
#define ESP_UTILS_LOG_TAG "MyLibrary"
#include "esp_lib_utils.h"
void test_memory(void)
{
// Allocate memory in C style (`malloc/calloc` and `free` are re-defined in the library)
int *c_ptr = (int *)malloc(sizeof(int));
ESP_UTILS_CHECK_NULL_EXIT(c_ptr, "Failed to allocate memory");
free(c_ptr);
// Allocate memory in C++ style
std::shared_ptr<int> cxx_ptr = nullptr;
ESP_UTILS_CHECK_EXCEPTION_EXIT(
(cxx_ptr = esp_utils::make_shared<int>()), "Failed to allocate memory"
);
cxx_ptr = nullptr;
}
Users can find and modify the directory path for Arduino libraries by selecting File
> Preferences
> Settings
> Sketchbook location
from the menu bar in the Arduino IDE.
- If users want to install online, navigate to
Sketch
>Include Library
>Manage Libraries...
in the Arduino IDE, then search foresp-lib-utils
and click theInstall
button to install it. - If users want to install manually, download the required version of the
.zip
file from esp-lib-utils, then navigate toSketch
>Include Library
>Add .ZIP Library...
in the Arduino IDE, select the downloaded.zip
file, and clickOpen
to install it. - Users can also refer to the guides on library installation in the Arduino IDE v1.x.x or Arduino IDE v2.x.x documentation.
The default installation path for arduino-esp32 depends on the PC operating system:
- Windows:
C:\Users\<user name>\AppData\Local\Arduino15\packages\esp32
- Linux:
~/.arduino15/packages/esp32
The SDK for arduino-esp32 v3.x.x version is located in the <arduino-esp32 root>/tools/esp32-arduino-libs/idf-release_x
directory within the default installation path.