furi_check - a new way to asserting (#204)
* hal-related task_is_isr_context function * furi_check implementation * change application to use furi_check * add second level of assertion * add TODO about ISR context * Applications: refactor furi_check and furi_assert. * Apploader: propwer widget usage. Menu: check on furi resource request. * refactor furi_check Co-authored-by: Aleksandr Kutuzov <aku@plooks.com> Co-authored-by: coreglitch <mail@s3f.ru>
This commit is contained in:
@@ -1,8 +1,8 @@
|
||||
#include "menu_item.h"
|
||||
#include <stdlib.h>
|
||||
#include <assert.h>
|
||||
#include <string.h>
|
||||
#include <flipper.h>
|
||||
#include <flipper_v2.h>
|
||||
|
||||
struct MenuItem {
|
||||
MenuItemType type;
|
||||
@@ -52,7 +52,7 @@ menu_item_alloc_function(const char* label, Icon* icon, MenuItemCallback callbac
|
||||
}
|
||||
|
||||
void menu_item_release(MenuItem* menu_item) {
|
||||
assert(menu_item);
|
||||
furi_assert(menu_item);
|
||||
if(menu_item->type == MenuItemTypeMenu) {
|
||||
//TODO: iterate and release
|
||||
free(menu_item->data);
|
||||
@@ -61,62 +61,61 @@ void menu_item_release(MenuItem* menu_item) {
|
||||
}
|
||||
|
||||
MenuItem* menu_item_get_parent(MenuItem* menu_item) {
|
||||
assert(menu_item);
|
||||
furi_assert(menu_item);
|
||||
return menu_item->parent;
|
||||
}
|
||||
|
||||
void menu_item_subitem_add(MenuItem* menu_item, MenuItem* sub_item) {
|
||||
assert(menu_item);
|
||||
assert(menu_item->type == MenuItemTypeMenu);
|
||||
furi_assert(menu_item);
|
||||
furi_check(menu_item->type == MenuItemTypeMenu);
|
||||
MenuItemArray_t* items = menu_item->data;
|
||||
sub_item->parent = menu_item;
|
||||
MenuItemArray_push_back(*items, sub_item);
|
||||
}
|
||||
|
||||
uint8_t menu_item_get_type(MenuItem* menu_item) {
|
||||
assert(menu_item);
|
||||
furi_assert(menu_item);
|
||||
return menu_item->type;
|
||||
}
|
||||
|
||||
void menu_item_set_position(MenuItem* menu_item, size_t position) {
|
||||
assert(menu_item);
|
||||
furi_assert(menu_item);
|
||||
menu_item->position = position;
|
||||
}
|
||||
|
||||
size_t menu_item_get_position(MenuItem* menu_item) {
|
||||
assert(menu_item);
|
||||
furi_assert(menu_item);
|
||||
return menu_item->position;
|
||||
}
|
||||
|
||||
void menu_item_set_label(MenuItem* menu_item, const char* label) {
|
||||
assert(menu_item);
|
||||
furi_assert(menu_item);
|
||||
menu_item->label = label;
|
||||
}
|
||||
|
||||
const char* menu_item_get_label(MenuItem* menu_item) {
|
||||
assert(menu_item);
|
||||
furi_assert(menu_item);
|
||||
return menu_item->label;
|
||||
}
|
||||
|
||||
void menu_item_set_icon(MenuItem* menu_item, Icon* icon) {
|
||||
assert(menu_item);
|
||||
furi_assert(menu_item);
|
||||
menu_item->icon = icon;
|
||||
}
|
||||
|
||||
Icon* menu_item_get_icon(MenuItem* menu_item) {
|
||||
assert(menu_item);
|
||||
furi_assert(menu_item);
|
||||
return menu_item->icon;
|
||||
}
|
||||
|
||||
MenuItemArray_t* menu_item_get_subitems(MenuItem* menu_item) {
|
||||
assert(menu_item);
|
||||
assert(menu_item->type == MenuItemTypeMenu);
|
||||
furi_assert(menu_item);
|
||||
furi_check(menu_item->type == MenuItemTypeMenu);
|
||||
return menu_item->data;
|
||||
}
|
||||
|
||||
void menu_item_function_call(MenuItem* menu_item) {
|
||||
assert(menu_item);
|
||||
assert(menu_item->type == MenuItemTypeFunction);
|
||||
|
||||
furi_assert(menu_item);
|
||||
furi_check(menu_item->type == MenuItemTypeFunction);
|
||||
if(menu_item->callback) menu_item->callback(menu_item->callback_context);
|
||||
}
|
||||
|
Reference in New Issue
Block a user