X-Git-Url: http://vcs.maemo.org/git/?a=blobdiff_plain;f=ball%2Fst_save.c;h=ea4abe37c927731c9a8eae5f0dfa6fbb780e91cb;hb=9a5b5f027b27b45b4926604f48cf00904b37ec64;hp=d4dd4c97d278367eaca5d7720a029274e6bf8756;hpb=0f17528baaf530edc2b7b5d0f5f616d0c39f8dc7;p=neverball diff --git a/ball/st_save.c b/ball/st_save.c index d4dd4c9..ea4abe3 100644 --- a/ball/st_save.c +++ b/ball/st_save.c @@ -1,4 +1,4 @@ -/* +/* * Copyright (C) 2003 Robert Kooima * * NEVERBALL is free software; you can redistribute it and/or modify @@ -13,153 +13,137 @@ */ #include +#include #include "gui.h" #include "game.h" #include "util.h" -#include "demo.h" -#include "level.h" #include "audio.h" #include "config.h" +#include "demo.h" +#include "levels.h" +#include "text.h" +#include "st_shared.h" #include "st_save.h" -#include "st_over.h" -#include "st_done.h" -#include "st_level.h" -#include "st_title.h" + +extern struct state st_save; +extern struct state st_clobber; + +static char filename[MAXNAM]; /*---------------------------------------------------------------------------*/ -#define SAVE_SAVE 2 -#define SAVE_CANCEL 3 +static struct state *ok_state; +static struct state *cancel_state; -static int file_id; -static char filename[MAXNAM]; +int goto_save(struct state *ok, struct state *cancel) +{ + demo_unique(filename); + + ok_state = ok; + cancel_state = cancel; + + return goto_state(&st_save); +} + +/*---------------------------------------------------------------------------*/ + +static int file_id; + +#define SAVE_SAVE 1 +#define SAVE_CANCEL 2 static int save_action(int i) { - size_t l = strlen(filename); + char *n; audio_play(AUD_MENU, 1.0f); switch (i) { case SAVE_SAVE: - if (demo_exists(filename)) + n = text_to_locale(filename); + + if (strlen(n) == 0) + return 1; + + if (demo_exists(n)) return goto_state(&st_clobber); else { - if (level_exit(filename, 1)) - return goto_state(&st_level); - else - return goto_state(&st_done); + demo_rename(n); + return goto_state(ok_state); } case SAVE_CANCEL: - if (level_exit(NULL, 1)) - return goto_state(&st_level); - else - return goto_state(&st_done); + return goto_state(cancel_state); case GUI_CL: gui_keyboard_lock(); break; case GUI_BS: - if (l > 0) - { - filename[l - 1] = 0; + if (text_del_char(filename)) gui_set_label(file_id, filename); - } break; default: - if (l < MAXNAM - 1) - { - filename[l + 0] = gui_keyboard_char((char) i); - filename[l + 1] = 0; + if (text_add_char(i, filename, MAXNAM, 17)) gui_set_label(file_id, filename); - } } return 1; } +static int enter_id; + static int save_enter(void) { int id, jd; - demo_unique(filename); - if ((id = gui_vstack(0))) { - gui_space(id); - if ((jd = gui_hstack(id))) - { - gui_filler(jd); - gui_count(jd, curr_level(), GUI_LRG, GUI_NE | GUI_SE); - gui_label(jd, _("Level "), GUI_LRG, GUI_NW | GUI_SW, 0, 0); - gui_filler(jd); - } - gui_space(id); + gui_label(id, _("Replay Name"), GUI_MED, GUI_ALL, 0, 0); gui_space(id); + file_id = gui_label(id, filename, GUI_MED, GUI_ALL, gui_yel, gui_yel); + gui_space(id); + gui_keyboard(id); + if ((jd = gui_harray(id))) { - gui_start(jd, _("Cancel"), GUI_SML, SAVE_CANCEL, 0); - gui_start(jd, _("Save"), GUI_SML, SAVE_SAVE, 0); + enter_id = gui_start(jd, _("Save"), GUI_SML, SAVE_SAVE, 0); + gui_state(jd, _("Cancel"), GUI_SML, SAVE_CANCEL, 0); } - gui_keyboard(id); - + gui_layout(id, 0, 0); } + SDL_EnableUNICODE(1); + return id; } static void save_leave(int id) { + SDL_EnableUNICODE(0); gui_delete(id); } -static void save_paint(int id, float st) -{ - game_draw(0, st); - gui_paint(id); -} - -static void save_timer(int id, float dt) -{ - gui_timer(id, dt); - audio_timer(dt); -} - -static void save_point(int id, int x, int y, int dx, int dy) -{ - gui_pulse(gui_point(id, x, y), 1.2f); -} - -static void save_stick(int id, int a, int v) -{ - if (config_tst_d(CONFIG_JOYSTICK_AXIS_X, a)) - gui_pulse(gui_stick(id, v, 0), 1.2f); - if (config_tst_d(CONFIG_JOYSTICK_AXIS_Y, a)) - gui_pulse(gui_stick(id, 0, v), 1.2f); -} - -static int save_click(int b, int d) -{ - if (b <= 0 && d == 1) - return save_action(gui_token(gui_click())); - return 1; -} - static int save_keybd(int c, int d) { - if (d && c == SDLK_ESCAPE) - goto_state(&st_over); + if (d) + { + gui_focus(enter_id); + + if (c == '\b' || c == 0x7F) + return save_action(GUI_BS); + if (c > ' ') + return save_action(c); + } return 1; } @@ -168,9 +152,15 @@ static int save_buttn(int b, int d) if (d) { if (config_tst_d(CONFIG_JOYSTICK_BUTTON_A, b)) - return save_click(0, 1); + { + int c = gui_token(gui_click()); + + /* Ugh. This is such a hack. */ + + return save_action(isupper(c) ? gui_keyboard_char(c) : c); + } if (config_tst_d(CONFIG_JOYSTICK_BUTTON_EXIT, b)) - return goto_state(&st_over); + return save_action(SAVE_CANCEL); } return 1; } @@ -183,10 +173,8 @@ static int clobber_action(int i) if (i == SAVE_SAVE) { - if (level_exit(filename, 1)) - return goto_state(&st_level); - else - return goto_state(&st_title); + demo_rename(text_to_locale(filename)); + return goto_state(ok_state); } return goto_state(&st_save); } @@ -203,8 +191,8 @@ static int clobber_enter(void) if ((jd = gui_harray(id))) { - gui_state(jd, _("Yes"), GUI_SML, SAVE_SAVE, 0); gui_start(jd, _("No"), GUI_SML, SAVE_CANCEL, 1); + gui_state(jd, _("Yes"), GUI_SML, SAVE_SAVE, 0); } gui_pulse(kd, 1.2f); @@ -214,48 +202,6 @@ static int clobber_enter(void) return id; } -static void clobber_leave(int id) -{ - gui_delete(id); -} - -static void clobber_paint(int id, float st) -{ - game_draw(0, st); - gui_paint(id); -} - -static void clobber_timer(int id, float dt) -{ - gui_timer(id, dt); - audio_timer(dt); -} - -static int clobber_keybd(int c, int d) -{ - return (d && c == SDLK_ESCAPE) ? clobber_action(SAVE_CANCEL) : 1; -} - -static void clobber_point(int id, int x, int y, int dx, int dy) -{ - gui_pulse(gui_point(id, x, y), 1.2f); -} - -static void clobber_stick(int id, int a, int v) -{ - if (config_tst_d(CONFIG_JOYSTICK_AXIS_X, a)) - gui_pulse(gui_stick(id, v, 0), 1.2f); - if (config_tst_d(CONFIG_JOYSTICK_AXIS_Y, a)) - gui_pulse(gui_stick(id, 0, v), 1.2f); -} - -static int clobber_click(int b, int d) -{ - if (d && b < 0) - return clobber_action(gui_token(gui_click())); - return 1; -} - static int clobber_buttn(int b, int d) { if (d) @@ -273,11 +219,12 @@ static int clobber_buttn(int b, int d) struct state st_save = { save_enter, save_leave, - save_paint, - save_timer, - save_point, - save_stick, - save_click, + shared_paint, + shared_timer, + shared_point, + shared_stick, + shared_angle, + shared_click, save_keybd, save_buttn, 1, 0 @@ -285,13 +232,14 @@ struct state st_save = { struct state st_clobber = { clobber_enter, - clobber_leave, - clobber_paint, - clobber_timer, - clobber_point, - clobber_stick, - clobber_click, - clobber_keybd, + shared_leave, + shared_paint, + shared_timer, + shared_point, + shared_stick, + shared_angle, + shared_click, + NULL, clobber_buttn, 1, 0 };