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:
@@ -3,6 +3,7 @@
|
||||
|
||||
#include <cmsis_os.h>
|
||||
#include <flipper.h>
|
||||
#include <flipper_v2.h>
|
||||
|
||||
#include "gui.h"
|
||||
#include "gui_i.h"
|
||||
@@ -25,13 +26,13 @@ Widget* widget_alloc(WidgetDrawCallback callback, void* callback_context) {
|
||||
}
|
||||
|
||||
void widget_free(Widget* widget) {
|
||||
assert(widget);
|
||||
assert(widget->gui == NULL);
|
||||
furi_assert(widget);
|
||||
furi_check(widget->gui == NULL);
|
||||
free(widget);
|
||||
}
|
||||
|
||||
void widget_enabled_set(Widget* widget, bool enabled) {
|
||||
assert(widget);
|
||||
furi_assert(widget);
|
||||
if(widget->is_enabled != enabled) {
|
||||
widget->is_enabled = enabled;
|
||||
widget_update(widget);
|
||||
@@ -39,47 +40,47 @@ void widget_enabled_set(Widget* widget, bool enabled) {
|
||||
}
|
||||
|
||||
bool widget_is_enabled(Widget* widget) {
|
||||
assert(widget);
|
||||
furi_assert(widget);
|
||||
return widget->is_enabled;
|
||||
}
|
||||
|
||||
void widget_draw_callback_set(Widget* widget, WidgetDrawCallback callback, void* context) {
|
||||
assert(widget);
|
||||
furi_assert(widget);
|
||||
widget->draw_callback = callback;
|
||||
widget->draw_callback_context = context;
|
||||
}
|
||||
|
||||
void widget_input_callback_set(Widget* widget, WidgetInputCallback callback, void* context) {
|
||||
assert(widget);
|
||||
furi_assert(widget);
|
||||
widget->input_callback = callback;
|
||||
widget->input_callback_context = context;
|
||||
}
|
||||
|
||||
void widget_update(Widget* widget) {
|
||||
assert(widget);
|
||||
furi_assert(widget);
|
||||
if(widget->gui) gui_update(widget->gui);
|
||||
}
|
||||
|
||||
void widget_gui_set(Widget* widget, Gui* gui) {
|
||||
assert(widget);
|
||||
assert(gui);
|
||||
furi_assert(widget);
|
||||
furi_assert(gui);
|
||||
widget->gui = gui;
|
||||
}
|
||||
|
||||
void widget_draw(Widget* widget, CanvasApi* canvas_api) {
|
||||
assert(widget);
|
||||
assert(canvas_api);
|
||||
assert(widget->gui);
|
||||
furi_assert(widget);
|
||||
furi_assert(canvas_api);
|
||||
|
||||
furi_check(widget->gui);
|
||||
if(widget->draw_callback) {
|
||||
widget->draw_callback(canvas_api, widget->draw_callback_context);
|
||||
}
|
||||
}
|
||||
|
||||
void widget_input(Widget* widget, InputEvent* event) {
|
||||
assert(widget);
|
||||
assert(event);
|
||||
assert(widget->gui);
|
||||
furi_assert(widget);
|
||||
furi_assert(event);
|
||||
|
||||
furi_check(widget->gui);
|
||||
if(widget->input_callback) widget->input_callback(event, widget->input_callback_context);
|
||||
}
|
||||
|
Reference in New Issue
Block a user