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:
@@ -41,7 +41,7 @@ ValueMutex* menu_init() {
|
||||
|
||||
// Open GUI and register fullscreen widget
|
||||
GuiApi* gui = furi_open("gui");
|
||||
assert(gui);
|
||||
furi_check(gui);
|
||||
gui->add_widget(gui, menu->widget, GuiLayerFullscreen);
|
||||
|
||||
widget_enabled_set(menu->widget, false);
|
||||
@@ -52,7 +52,7 @@ ValueMutex* menu_init() {
|
||||
}
|
||||
|
||||
void menu_build_main(Menu* menu) {
|
||||
assert(menu);
|
||||
furi_assert(menu);
|
||||
// Root point
|
||||
menu->root = menu_item_alloc_menu(NULL, NULL);
|
||||
|
||||
@@ -76,13 +76,13 @@ void menu_draw_secondary(Menu* menu, CanvasApi* canvas) {
|
||||
}
|
||||
|
||||
void menu_widget_callback(CanvasApi* canvas, void* context) {
|
||||
assert(canvas);
|
||||
assert(context);
|
||||
furi_assert(canvas);
|
||||
furi_assert(context);
|
||||
|
||||
Menu* menu = acquire_mutex((ValueMutex*)context, 100); // wait 10 ms to get mutex
|
||||
if(menu == NULL) return; // redraw fail
|
||||
|
||||
assert(menu->current);
|
||||
furi_assert(menu->current);
|
||||
|
||||
canvas->clear(canvas);
|
||||
canvas->set_color(canvas, ColorBlack);
|
||||
@@ -123,14 +123,14 @@ void menu_widget_callback(CanvasApi* canvas, void* context) {
|
||||
}
|
||||
|
||||
void menu_update(Menu* menu) {
|
||||
assert(menu);
|
||||
furi_assert(menu);
|
||||
|
||||
menu_event_activity_notify(menu->event);
|
||||
widget_update(menu->widget);
|
||||
}
|
||||
|
||||
void menu_up(Menu* menu) {
|
||||
assert(menu);
|
||||
furi_assert(menu);
|
||||
|
||||
size_t position = menu_item_get_position(menu->current);
|
||||
MenuItemArray_t* items = menu_item_get_subitems(menu->current);
|
||||
@@ -141,7 +141,7 @@ void menu_up(Menu* menu) {
|
||||
}
|
||||
|
||||
void menu_down(Menu* menu) {
|
||||
assert(menu);
|
||||
furi_assert(menu);
|
||||
size_t position = menu_item_get_position(menu->current);
|
||||
MenuItemArray_t* items = menu_item_get_subitems(menu->current);
|
||||
position++;
|
||||
@@ -151,7 +151,7 @@ void menu_down(Menu* menu) {
|
||||
}
|
||||
|
||||
void menu_ok(Menu* menu) {
|
||||
assert(menu);
|
||||
furi_assert(menu);
|
||||
|
||||
if(!menu->current) {
|
||||
widget_enabled_set(menu->widget, true);
|
||||
@@ -180,7 +180,7 @@ void menu_ok(Menu* menu) {
|
||||
}
|
||||
|
||||
void menu_back(Menu* menu) {
|
||||
assert(menu);
|
||||
furi_assert(menu);
|
||||
MenuItem* parent = menu_item_get_parent(menu->current);
|
||||
if(parent) {
|
||||
menu->current = parent;
|
||||
@@ -191,7 +191,7 @@ void menu_back(Menu* menu) {
|
||||
}
|
||||
|
||||
void menu_exit(Menu* menu) {
|
||||
assert(menu);
|
||||
furi_assert(menu);
|
||||
widget_enabled_set(menu->widget, false);
|
||||
menu->current = NULL;
|
||||
menu_update(menu);
|
||||
@@ -203,7 +203,7 @@ void menu_task(void* p) {
|
||||
MenuEvent* menu_event = NULL;
|
||||
{
|
||||
Menu* menu = acquire_mutex_block(menu_mutex);
|
||||
assert(menu);
|
||||
furi_check(menu);
|
||||
|
||||
menu_build_main(menu);
|
||||
|
||||
|
@@ -1,11 +1,11 @@
|
||||
#include "menu_event.h"
|
||||
|
||||
#include <cmsis_os.h>
|
||||
#include <assert.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include <flipper.h>
|
||||
#include <flipper_v2.h>
|
||||
|
||||
#define MENU_MESSAGE_MQUEUE_SIZE 8
|
||||
|
||||
@@ -25,30 +25,28 @@ MenuEvent* menu_event_alloc() {
|
||||
MenuEvent* menu_event = furi_alloc(sizeof(MenuEvent));
|
||||
|
||||
menu_event->mqueue = osMessageQueueNew(MENU_MESSAGE_MQUEUE_SIZE, sizeof(MenuMessage), NULL);
|
||||
assert(menu_event->mqueue);
|
||||
furi_check(menu_event->mqueue);
|
||||
|
||||
menu_event->timeout_timer =
|
||||
osTimerNew(MenuEventimeout_callback, osTimerOnce, menu_event, NULL);
|
||||
assert(menu_event->timeout_timer);
|
||||
furi_check(menu_event->timeout_timer);
|
||||
|
||||
return menu_event;
|
||||
}
|
||||
|
||||
void menu_event_free(MenuEvent* menu_event) {
|
||||
osStatus_t status;
|
||||
assert(menu_event);
|
||||
status = osMessageQueueDelete(menu_event->mqueue);
|
||||
assert(status == osOK);
|
||||
furi_assert(menu_event);
|
||||
furi_check(osMessageQueueDelete(menu_event->mqueue) == osOK);
|
||||
free(menu_event);
|
||||
}
|
||||
|
||||
void menu_event_activity_notify(MenuEvent* menu_event) {
|
||||
assert(menu_event);
|
||||
furi_assert(menu_event);
|
||||
osTimerStart(menu_event->timeout_timer, 60000U); // 1m timeout, return to main
|
||||
}
|
||||
|
||||
MenuMessage menu_event_next(MenuEvent* menu_event) {
|
||||
assert(menu_event);
|
||||
furi_assert(menu_event);
|
||||
MenuMessage message;
|
||||
while(osMessageQueueGet(menu_event->mqueue, &message, NULL, osWaitForever) != osOK) {
|
||||
};
|
||||
|
@@ -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