2019-10-06 15:34:29 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 Inria
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup sys_progress_bar
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief A simple CLI progress bar
|
|
|
|
*
|
|
|
|
* @author Alexandre Abadie <alexandre.abadie@inria.fr>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PROGRESS_BAR_H
|
|
|
|
#define PROGRESS_BAR_H
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <inttypes.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Progress bar maximum characters length
|
|
|
|
*/
|
2021-03-22 11:48:11 +01:00
|
|
|
#ifndef CONFIG_PROGRESS_BAR_LENGTH
|
|
|
|
#define CONFIG_PROGRESS_BAR_LENGTH (25U)
|
2019-10-06 15:34:29 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Progress bar character
|
|
|
|
*/
|
2021-03-22 11:48:11 +01:00
|
|
|
#ifndef CONFIG_PROGRESS_BAR_FULL_CHARACTER
|
|
|
|
#define CONFIG_PROGRESS_BAR_FULL_CHARACTER "█"
|
2019-10-06 15:34:29 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Progress bar empty character
|
|
|
|
*/
|
2021-03-22 11:48:11 +01:00
|
|
|
#ifndef CONFIG_PROGRESS_BAR_EMPTY_CHARACTER
|
|
|
|
#define CONFIG_PROGRESS_BAR_EMPTY_CHARACTER " "
|
2019-10-06 15:34:29 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Character displayed on the left of the progress bar
|
|
|
|
*/
|
2021-03-22 11:48:11 +01:00
|
|
|
#ifndef CONFIG_PROGRESS_BAR_PREFIX_CHARACTER
|
|
|
|
#define CONFIG_PROGRESS_BAR_PREFIX_CHARACTER "|"
|
2019-10-06 15:34:29 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Character displayed on the left of the progress bar
|
|
|
|
*/
|
2021-03-22 11:48:11 +01:00
|
|
|
#ifndef CONFIG_PROGRESS_BAR_SUFFIX_CHARACTER
|
|
|
|
#define CONFIG_PROGRESS_BAR_SUFFIX_CHARACTER "|"
|
2019-10-06 15:34:29 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Progress bar prefix max length
|
|
|
|
*/
|
2021-03-22 11:48:11 +01:00
|
|
|
#ifndef CONFIG_PROGRESS_BAR_PREFIX_MAX_LENGTH
|
|
|
|
#define CONFIG_PROGRESS_BAR_PREFIX_MAX_LENGTH (32U)
|
2019-10-06 15:34:29 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Progress bar suffix max length
|
|
|
|
*/
|
2021-03-22 11:48:11 +01:00
|
|
|
#ifndef CONFIG_PROGRESS_BAR_SUFFIX_MAX_LENGTH
|
|
|
|
#define CONFIG_PROGRESS_BAR_SUFFIX_MAX_LENGTH (32U)
|
2019-10-06 15:34:29 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Progress bar descriptor
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
/** Current value of the progress bar. Must be between 0 and 100 (included) */
|
|
|
|
uint8_t value;
|
|
|
|
/** Prefix displayed on the left of the progress bar */
|
2021-03-22 11:48:11 +01:00
|
|
|
char prefix[CONFIG_PROGRESS_BAR_PREFIX_MAX_LENGTH];
|
2019-10-06 15:34:29 +02:00
|
|
|
/** Suffix displayed on the right of the progress bar */
|
2021-03-22 11:48:11 +01:00
|
|
|
char suffix[CONFIG_PROGRESS_BAR_SUFFIX_MAX_LENGTH];
|
2019-10-06 15:34:29 +02:00
|
|
|
} progress_bar_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Print a progress bar in the terminal
|
|
|
|
*
|
|
|
|
* @param[in] prefix String displayed on the left of the progress bar
|
|
|
|
* @param[in] suffix String displayed on the right of the progress bar
|
|
|
|
* @param[in] value Value of the progress bar
|
|
|
|
*/
|
|
|
|
void progress_bar_print(char *prefix, char *suffix, uint8_t value);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Update the progress bar display in the terminal
|
|
|
|
*
|
|
|
|
* @param[in] progress_bar Pointer to the progress bar descriptor
|
|
|
|
*/
|
|
|
|
void progress_bar_update(progress_bar_t *progress_bar);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Prepare the output for displaying multiple progress bars.
|
|
|
|
*
|
|
|
|
* This function is just adding enough empty lines to give enough space to
|
|
|
|
* print the list of progress bars.
|
|
|
|
*
|
|
|
|
* This function must be called only once and before starting the progress bar
|
|
|
|
* list updates with.
|
|
|
|
*
|
|
|
|
* @param[in] len The length of the progress bar array
|
|
|
|
*/
|
|
|
|
void progress_bar_prepare_multi(uint8_t len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Update all progress bar displays of the given progress bars list
|
|
|
|
*
|
|
|
|
* @param[in] progress_bar_list An array of progress bars
|
|
|
|
* @param[in] len The length of the progress bar array
|
|
|
|
*/
|
|
|
|
void progress_bar_update_multi(progress_bar_t *progress_bar_list, uint8_t len);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @} */
|
|
|
|
#endif /* PROGRESS_BAR_H */
|