[FL-976] Removing lambdas (#1849)
* Removing lambdas... * Wake the fk up, Gordon! We have a citadel to burn! * Here comes the Nihilanth * Lambda documentation Co-authored-by: あく <alleteam@gmail.com>
This commit is contained in:
@@ -70,15 +70,17 @@ ButtonPanel* button_panel_alloc() {
|
||||
view_set_input_callback(button_panel->view, button_panel_view_input_callback);
|
||||
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
model->reserve_x = 0;
|
||||
model->reserve_y = 0;
|
||||
model->selected_item_x = 0;
|
||||
model->selected_item_y = 0;
|
||||
ButtonMatrix_init(model->button_matrix);
|
||||
LabelList_init(model->labels);
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
|
||||
return button_panel;
|
||||
}
|
||||
@@ -88,7 +90,9 @@ void button_panel_reserve(ButtonPanel* button_panel, size_t reserve_x, size_t re
|
||||
furi_check(reserve_y > 0);
|
||||
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
model->reserve_x = reserve_x;
|
||||
model->reserve_y = reserve_y;
|
||||
ButtonMatrix_reserve(model->button_matrix, model->reserve_y);
|
||||
@@ -99,8 +103,8 @@ void button_panel_reserve(ButtonPanel* button_panel, size_t reserve_x, size_t re
|
||||
// TODO: do we need to clear allocated memory of ptr-s to ButtonItem ??
|
||||
}
|
||||
LabelList_init(model->labels);
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
}
|
||||
|
||||
void button_panel_free(ButtonPanel* button_panel) {
|
||||
@@ -109,11 +113,13 @@ void button_panel_free(ButtonPanel* button_panel) {
|
||||
button_panel_reset(button_panel);
|
||||
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
LabelList_clear(model->labels);
|
||||
ButtonMatrix_clear(model->button_matrix);
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
|
||||
view_free(button_panel->view);
|
||||
free(button_panel);
|
||||
@@ -123,7 +129,9 @@ void button_panel_reset(ButtonPanel* button_panel) {
|
||||
furi_assert(button_panel);
|
||||
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
for(size_t x = 0; x < model->reserve_x; ++x) {
|
||||
for(size_t y = 0; y < model->reserve_y; ++y) {
|
||||
ButtonItem** button_item = button_panel_get_item(model, x, y);
|
||||
@@ -137,8 +145,8 @@ void button_panel_reset(ButtonPanel* button_panel) {
|
||||
model->selected_item_y = 0;
|
||||
LabelList_reset(model->labels);
|
||||
ButtonMatrix_reset(model->button_matrix);
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
}
|
||||
|
||||
static ButtonItem** button_panel_get_item(ButtonPanelModel* model, size_t x, size_t y) {
|
||||
@@ -165,7 +173,9 @@ void button_panel_add_item(
|
||||
furi_assert(button_panel);
|
||||
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
ButtonItem** button_item_ptr =
|
||||
button_panel_get_item(model, matrix_place_x, matrix_place_y);
|
||||
furi_check(*button_item_ptr == NULL);
|
||||
@@ -178,8 +188,8 @@ void button_panel_add_item(
|
||||
button_item->icon.name = icon_name;
|
||||
button_item->icon.name_selected = icon_name_selected;
|
||||
button_item->index = index;
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
}
|
||||
|
||||
View* button_panel_get_view(ButtonPanel* button_panel) {
|
||||
@@ -216,114 +226,123 @@ static void button_panel_view_draw_callback(Canvas* canvas, void* _model) {
|
||||
|
||||
static void button_panel_process_down(ButtonPanel* button_panel) {
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
uint16_t new_selected_item_x = model->selected_item_x;
|
||||
uint16_t new_selected_item_y = model->selected_item_y;
|
||||
size_t i;
|
||||
|
||||
if(new_selected_item_y >= (model->reserve_y - 1)) return false;
|
||||
if(new_selected_item_y < (model->reserve_y - 1)) {
|
||||
++new_selected_item_y;
|
||||
|
||||
++new_selected_item_y;
|
||||
|
||||
for(i = 0; i < model->reserve_x; ++i) {
|
||||
new_selected_item_x = (model->selected_item_x + i) % model->reserve_x;
|
||||
if(*button_panel_get_item(model, new_selected_item_x, new_selected_item_y)) {
|
||||
break;
|
||||
for(i = 0; i < model->reserve_x; ++i) {
|
||||
new_selected_item_x = (model->selected_item_x + i) % model->reserve_x;
|
||||
if(*button_panel_get_item(model, new_selected_item_x, new_selected_item_y)) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if(i != model->reserve_x) {
|
||||
model->selected_item_x = new_selected_item_x;
|
||||
model->selected_item_y = new_selected_item_y;
|
||||
}
|
||||
}
|
||||
if(i == model->reserve_x) return false;
|
||||
|
||||
model->selected_item_x = new_selected_item_x;
|
||||
model->selected_item_y = new_selected_item_y;
|
||||
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
}
|
||||
|
||||
static void button_panel_process_up(ButtonPanel* button_panel) {
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
size_t new_selected_item_x = model->selected_item_x;
|
||||
size_t new_selected_item_y = model->selected_item_y;
|
||||
size_t i;
|
||||
|
||||
if(new_selected_item_y <= 0) return false;
|
||||
if(new_selected_item_y > 0) {
|
||||
--new_selected_item_y;
|
||||
|
||||
--new_selected_item_y;
|
||||
|
||||
for(i = 0; i < model->reserve_x; ++i) {
|
||||
new_selected_item_x = (model->selected_item_x + i) % model->reserve_x;
|
||||
if(*button_panel_get_item(model, new_selected_item_x, new_selected_item_y)) {
|
||||
break;
|
||||
for(i = 0; i < model->reserve_x; ++i) {
|
||||
new_selected_item_x = (model->selected_item_x + i) % model->reserve_x;
|
||||
if(*button_panel_get_item(model, new_selected_item_x, new_selected_item_y)) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if(i != model->reserve_x) {
|
||||
model->selected_item_x = new_selected_item_x;
|
||||
model->selected_item_y = new_selected_item_y;
|
||||
}
|
||||
}
|
||||
if(i == model->reserve_x) return false;
|
||||
|
||||
model->selected_item_x = new_selected_item_x;
|
||||
model->selected_item_y = new_selected_item_y;
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
}
|
||||
|
||||
static void button_panel_process_left(ButtonPanel* button_panel) {
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
size_t new_selected_item_x = model->selected_item_x;
|
||||
size_t new_selected_item_y = model->selected_item_y;
|
||||
size_t i;
|
||||
|
||||
if(new_selected_item_x <= 0) return false;
|
||||
if(new_selected_item_x > 0) {
|
||||
--new_selected_item_x;
|
||||
|
||||
--new_selected_item_x;
|
||||
|
||||
for(i = 0; i < model->reserve_y; ++i) {
|
||||
new_selected_item_y = (model->selected_item_y + i) % model->reserve_y;
|
||||
if(*button_panel_get_item(model, new_selected_item_x, new_selected_item_y)) {
|
||||
break;
|
||||
for(i = 0; i < model->reserve_y; ++i) {
|
||||
new_selected_item_y = (model->selected_item_y + i) % model->reserve_y;
|
||||
if(*button_panel_get_item(model, new_selected_item_x, new_selected_item_y)) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if(i != model->reserve_y) {
|
||||
model->selected_item_x = new_selected_item_x;
|
||||
model->selected_item_y = new_selected_item_y;
|
||||
}
|
||||
}
|
||||
if(i == model->reserve_y) return false;
|
||||
|
||||
model->selected_item_x = new_selected_item_x;
|
||||
model->selected_item_y = new_selected_item_y;
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
}
|
||||
|
||||
static void button_panel_process_right(ButtonPanel* button_panel) {
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
uint16_t new_selected_item_x = model->selected_item_x;
|
||||
uint16_t new_selected_item_y = model->selected_item_y;
|
||||
size_t i;
|
||||
|
||||
if(new_selected_item_x >= (model->reserve_x - 1)) return false;
|
||||
if(new_selected_item_x < (model->reserve_x - 1)) {
|
||||
++new_selected_item_x;
|
||||
|
||||
++new_selected_item_x;
|
||||
|
||||
for(i = 0; i < model->reserve_y; ++i) {
|
||||
new_selected_item_y = (model->selected_item_y + i) % model->reserve_y;
|
||||
if(*button_panel_get_item(model, new_selected_item_x, new_selected_item_y)) {
|
||||
break;
|
||||
for(i = 0; i < model->reserve_y; ++i) {
|
||||
new_selected_item_y = (model->selected_item_y + i) % model->reserve_y;
|
||||
if(*button_panel_get_item(model, new_selected_item_x, new_selected_item_y)) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if(i != model->reserve_y) {
|
||||
model->selected_item_x = new_selected_item_x;
|
||||
model->selected_item_y = new_selected_item_y;
|
||||
}
|
||||
}
|
||||
if(i == model->reserve_y) return false;
|
||||
|
||||
model->selected_item_x = new_selected_item_x;
|
||||
model->selected_item_y = new_selected_item_y;
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
}
|
||||
|
||||
void button_panel_process_ok(ButtonPanel* button_panel) {
|
||||
ButtonItem* button_item = NULL;
|
||||
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
button_item =
|
||||
*button_panel_get_item(model, model->selected_item_x, model->selected_item_y);
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
|
||||
if(button_item && button_item->callback) {
|
||||
button_item->callback(button_item->callback_context, button_item->index);
|
||||
@@ -374,12 +393,14 @@ void button_panel_add_label(
|
||||
furi_assert(button_panel);
|
||||
|
||||
with_view_model(
|
||||
button_panel->view, (ButtonPanelModel * model) {
|
||||
button_panel->view,
|
||||
ButtonPanelModel * model,
|
||||
{
|
||||
LabelElement* label = LabelList_push_raw(model->labels);
|
||||
label->x = x;
|
||||
label->y = y;
|
||||
label->font = font;
|
||||
label->str = label_str;
|
||||
return true;
|
||||
});
|
||||
},
|
||||
true);
|
||||
}
|
||||
|
Reference in New Issue
Block a user