start refactor context states with kubo_state_wall_select

This commit is contained in:
Luka Jankovic 2025-08-31 02:22:29 +02:00
parent c2c99e73d2
commit 7e065745d2
13 changed files with 349 additions and 103 deletions

View file

@ -24,11 +24,8 @@ static const struct kubo_context_state_data kubo_context_states[] = {
{.id = KUBO_CONTEXT_WALL_NEW, .label = "Wall New", .color = GREEN},
{.id = KUBO_CONTEXT_WALL_SELECT, .label = "Wall Select", .color = BLUE}};
static inline void wall_select_refresh(struct kubo_context *context);
static void select_next_wall(struct kubo_context *context);
static void select_prev_wall(struct kubo_context *context);
void kubo_context_init(struct kubo_context *context) {
if (!context) {
return;
}
@ -55,13 +52,16 @@ void kubo_context_set_state(struct kubo_context *context,
case KUBO_CONTEXT_WALL_NEW:
break;
case KUBO_CONTEXT_WALL_SELECT:
wall_select_refresh(context);
break;
default:
break;
}
for (unsigned i = 0; i < kubo_state_data_length; i++) {
if (context->state.id == kubo_state_data[i].id &&
kubo_state_data[i].data.state_entered != NULL) {
kubo_state_data[i].data.state_entered(context);
}
}
}
struct kubo_wall *kubo_context_get_pending_wall(struct kubo_context *context) {
@ -90,85 +90,11 @@ struct kubo_wall *kubo_context_get_pending_wall(struct kubo_context *context) {
return wall;
}
void kubo_context_delete_wall(struct kubo_context *context) {
if (context->state.id != KUBO_CONTEXT_WALL_SELECT ||
!context->walls.count) {
return;
}
kubo_wall_arr_del(&context->walls, context->wall_select_index);
select_next_wall(context);
}
void kubo_context_input_up(struct kubo_context *context) {
switch (context->state.id) {
case KUBO_CONTEXT_WALL_SELECT:
select_next_wall(context);
break;
default:
break;
}
}
void kubo_context_input_down(struct kubo_context *context) {
switch (context->state.id) {
case KUBO_CONTEXT_WALL_SELECT:
select_prev_wall(context);
break;
default:
break;
}
}
void kubo_context_input_left(struct kubo_context *context) {
switch (context->state.id) {
case KUBO_CONTEXT_WALL_SELECT:
select_prev_wall(context);
break;
default:
break;
}
}
void kubo_context_input_right(struct kubo_context *context) {
switch (context->state.id) {
case KUBO_CONTEXT_WALL_SELECT:
select_next_wall(context);
break;
default:
break;
}
}
static void select_next_wall(struct kubo_context *context) {
if (!context->walls.count) {
return;
}
context->wall_select_index =
(context->wall_select_index + 1) % context->walls.count;
wall_select_refresh(context);
}
static void select_prev_wall(struct kubo_context *context) {
if (context->state.id != KUBO_CONTEXT_WALL_SELECT ||
!context->walls.count) {
return;
}
size_t count = context->walls.count;
context->wall_select_index =
(context->wall_select_index + count - 1) % count;
wall_select_refresh(context);
}
static inline void wall_select_refresh(struct kubo_context *context) {
for (size_t i = 0; i < context->walls.count; i++) {
struct kubo_wall *wall = kubo_wall_arr_get(&context->walls, i);
wall->state = i == context->wall_select_index ? KUBO_WALL_SELECTED
: KUBO_WALL_DONE;
void kubo_context_key(struct kubo_context *context, int key_code) {
for (unsigned i = 0; i < kubo_state_data_length; i++) {
if (context->state.id == kubo_state_data[i].id &&
kubo_state_data[i].data.state_key != NULL) {
kubo_state_data[i].data.state_key(context, key_code);
}
}
}