2019-03-18 07:25:20 +01:00
|
|
|
/**
|
|
|
|
* @file lv_utils.c
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* INCLUDES
|
|
|
|
*********************/
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
|
|
|
#include "lv_utils.h"
|
|
|
|
#include "lv_math.h"
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* DEFINES
|
|
|
|
*********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* TYPEDEFS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* STATIC PROTOTYPES
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* STATIC VARIABLES
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* MACROS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* GLOBAL FUNCTIONS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert a number to string
|
|
|
|
* @param num a number
|
|
|
|
* @param buf pointer to a `char` buffer. The result will be stored here (max 10 elements)
|
|
|
|
* @return same as `buf` (just for convenience)
|
|
|
|
*/
|
|
|
|
char * lv_utils_num_to_str(int32_t num, char * buf)
|
|
|
|
{
|
2019-04-04 07:15:40 +02:00
|
|
|
if(num == 0) {
|
2019-03-18 07:25:20 +01:00
|
|
|
buf[0] = '0';
|
|
|
|
buf[1] = '\0';
|
|
|
|
return buf;
|
|
|
|
}
|
2019-03-18 16:09:52 +01:00
|
|
|
int8_t digitCount = 0;
|
2019-04-04 07:15:40 +02:00
|
|
|
int8_t i = 0;
|
|
|
|
if(num < 0) {
|
2019-03-18 16:09:52 +01:00
|
|
|
buf[digitCount++] = '-';
|
2019-04-04 07:15:40 +02:00
|
|
|
num = LV_MATH_ABS(num);
|
2019-03-18 16:09:52 +01:00
|
|
|
++i;
|
2019-03-18 07:25:20 +01:00
|
|
|
}
|
2019-04-04 07:15:40 +02:00
|
|
|
while(num) {
|
|
|
|
char digit = num % 10;
|
2019-03-18 16:09:52 +01:00
|
|
|
buf[digitCount++] = digit + 48;
|
|
|
|
num /= 10;
|
2019-03-18 07:25:20 +01:00
|
|
|
}
|
2019-03-18 16:09:52 +01:00
|
|
|
buf[digitCount] = '\0';
|
|
|
|
digitCount--;
|
2019-04-04 07:15:40 +02:00
|
|
|
while(digitCount > i) {
|
|
|
|
char temp = buf[i];
|
|
|
|
buf[i] = buf[digitCount];
|
2019-03-18 16:09:52 +01:00
|
|
|
buf[digitCount] = temp;
|
|
|
|
digitCount--;
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
return buf;
|
2019-03-18 07:25:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Searches base[0] to base[n - 1] for an item that matches *key.
|
|
|
|
*
|
|
|
|
* @note The function cmp must return negative if its first
|
|
|
|
* argument (the search key) is less that its second (a table entry),
|
|
|
|
* zero if equal, and positive if greater.
|
|
|
|
*
|
|
|
|
* @note Items in the array must be in ascending order.
|
|
|
|
*
|
|
|
|
* @param key Pointer to item being searched for
|
|
|
|
* @param base Pointer to first element to search
|
|
|
|
* @param n Number of elements
|
|
|
|
* @param size Size of each element
|
2019-04-04 07:15:40 +02:00
|
|
|
* @param cmp Pointer to comparison function (see #lv_font_codeCompare as a comparison function
|
|
|
|
* example)
|
2019-03-18 07:25:20 +01:00
|
|
|
*
|
|
|
|
* @return a pointer to a matching item, or NULL if none exists.
|
|
|
|
*/
|
2019-04-04 07:15:40 +02:00
|
|
|
void * lv_utils_bsearch(const void * key, const void * base, uint32_t n, uint32_t size,
|
|
|
|
int32_t (*cmp)(const void * pRef, const void * pElement))
|
2019-03-18 07:25:20 +01:00
|
|
|
{
|
|
|
|
const char * middle;
|
|
|
|
int32_t c;
|
|
|
|
|
2019-04-04 07:15:40 +02:00
|
|
|
for(middle = base; n != 0;) {
|
|
|
|
middle += (n / 2) * size;
|
|
|
|
if((c = (*cmp)(key, middle)) > 0) {
|
|
|
|
n = (n / 2) - ((n & 1) == 0);
|
2019-03-18 07:25:20 +01:00
|
|
|
base = (middle += size);
|
2019-04-04 07:15:40 +02:00
|
|
|
} else if(c < 0) {
|
2019-03-18 07:25:20 +01:00
|
|
|
n /= 2;
|
|
|
|
middle = base;
|
|
|
|
} else {
|
2019-04-04 07:15:40 +02:00
|
|
|
return (char *)middle;
|
2019-03-18 07:25:20 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* STATIC FUNCTIONS
|
|
|
|
**********************/
|