Those sets haven't been merged.
[neverball] / ball / st_conf.c
index 0fac901..8524675 100644 (file)
 
 /*---------------------------------------------------------------------------*/
 
-#define CONF_FULL   1
-#define CONF_WIN    2
-#define CONF_TEXHI  8
-#define CONF_TEXLO  9
-#define CONF_GEOHI  10
-#define CONF_GEOLO  11
-#define CONF_REFON  12
-#define CONF_REFOF  13
-#define CONF_BACON  14
-#define CONF_BACOF  15
-#define CONF_SHDON  16
-#define CONF_SHDOF  17
-#define CONF_AUDHI  18
-#define CONF_AUDLO  19
-#define CONF_BACK   20
-#define CONF_RES    21
-#define CONF_PLAYER 22
-
-static int audlo_id;
-static int audhi_id;
+enum {
+    CONF_FULL = 1,
+    CONF_WIN,
+    CONF_TEXHI,
+    CONF_TEXLO,
+    CONF_GEOHI,
+    CONF_GEOLO,
+    CONF_REFON,
+    CONF_REFOF,
+    CONF_BACON,
+    CONF_BACOF,
+    CONF_SHDON,
+    CONF_SHDOF,
+    CONF_BACK,
+    CONF_RES,
+    CONF_PLAYER
+};
+
 static int music_id[11];
 static int sound_id[11];
 
@@ -136,24 +134,6 @@ static int conf_action(int i)
         goto_state(&st_conf);
         break;
 
-    case CONF_AUDHI:
-        audio_free();
-        config_set_d(CONFIG_AUDIO_RATE, 44100);
-        config_set_d(CONFIG_AUDIO_BUFF, AUDIO_BUFF_HI);
-        gui_toggle(audlo_id);
-        gui_toggle(audhi_id);
-        audio_init();
-        break;
-
-    case CONF_AUDLO:
-        audio_free();
-        config_set_d(CONFIG_AUDIO_RATE, 22050);
-        config_set_d(CONFIG_AUDIO_BUFF, AUDIO_BUFF_LO);
-        gui_toggle(audlo_id);
-        gui_toggle(audhi_id);
-        audio_init();
-        break;
-
     case CONF_BACK:
         goto_state(&st_title);
         break;
@@ -163,7 +143,7 @@ static int conf_action(int i)
         break;
 
     case CONF_PLAYER:
-        goto_name(&st_conf, &st_conf);
+        goto_name(&st_conf, &st_conf, 1);
         break;
 
     default:
@@ -198,131 +178,155 @@ static int conf_enter(void)
 {
     int id, jd, kd;
 
+    game_free();
     back_init("back/gui.png", config_get_d(CONFIG_GEOMETRY));
 
     /* Initialize the configuration GUI. */
 
-    if ((id = gui_harray(0)))
+    if ((id = gui_vstack(0)))
     {
         int f = config_get_d(CONFIG_FULLSCREEN);
+        int t = config_get_d(CONFIG_TEXTURES);
+        int g = config_get_d(CONFIG_GEOMETRY);
+        int r = config_get_d(CONFIG_REFLECTION);
+        int b = config_get_d(CONFIG_BACKGROUND);
+        int h = config_get_d(CONFIG_SHADOW);
+        int s = config_get_d(CONFIG_SOUND_VOLUME);
+        int m = config_get_d(CONFIG_MUSIC_VOLUME);
+
+        char resolution[20], player[MAXNAM];
+
+        sprintf(resolution, "%d x %d",
+                config_get_d(CONFIG_WIDTH),
+                config_get_d(CONFIG_HEIGHT));
+
+        config_get_s(CONFIG_PLAYER, player, MAXNAM);
+
+        if ((jd = gui_harray(id)))
+        {
+            gui_label(jd, _("Options"), GUI_SML, GUI_ALL, 0, 0);
+            gui_space(jd);
+            gui_start(jd, _("Back"),    GUI_SML, CONF_BACK, 0);
+        }
+
+        gui_space(id);
+
+        if ((jd = gui_harray(id)) &&
+            (kd = gui_harray(jd)))
+        {
+            gui_state(kd, _("No"),  GUI_SML, CONF_WIN,  (f == 0));
+            gui_state(kd, _("Yes"), GUI_SML, CONF_FULL, (f == 1));
+
+            gui_label(jd, _("Fullscreen"), GUI_SML, GUI_ALL, 0, 0);
+        }
+
+        if ((jd = gui_harray(id)) &&
+            (kd = gui_harray(jd)))
+        {
+            gui_state(kd, resolution, GUI_SML, CONF_RES, 0);
+
+            gui_label(jd, _("Resolution"), GUI_SML, GUI_ALL, 0, 0);
+        }
+
+        gui_space(id);
+
+        if ((jd = gui_harray(id)) &&
+            (kd = gui_harray(jd)))
+        {
+            gui_state(kd, _("Low"),  GUI_SML, CONF_TEXLO, (t == 2));
+            gui_state(kd, _("High"), GUI_SML, CONF_TEXHI, (t == 1));
 
-        if ((jd = gui_varray(id)))
+            gui_label(jd, _("Textures"), GUI_SML, GUI_ALL, 0, 0);
+        }
+
+        if ((jd = gui_harray(id)) &&
+            (kd = gui_harray(jd)))
+        {
+            gui_state(kd, _("Low"),  GUI_SML, CONF_GEOLO, (g == 0));
+            gui_state(kd, _("High"), GUI_SML, CONF_GEOHI, (g == 1));
+
+            gui_label(jd, _("Geometry"), GUI_SML, GUI_ALL, 0, 0);
+        }
+
+        if ((jd = gui_harray(id)) &&
+            (kd = gui_harray(jd)))
         {
-            int t = config_get_d(CONFIG_TEXTURES);
-            int g = config_get_d(CONFIG_GEOMETRY);
-            int r = config_get_d(CONFIG_REFLECTION);
-            int b = config_get_d(CONFIG_BACKGROUND);
-            int h = config_get_d(CONFIG_SHADOW);
-            int a = config_get_d(CONFIG_AUDIO_RATE);
-            int s = config_get_d(CONFIG_SOUND_VOLUME);
-            int m = config_get_d(CONFIG_MUSIC_VOLUME);
-
-            char res[20];
-
-            sprintf(res, "%d x %d", config_get_d(CONFIG_WIDTH),
-                    config_get_d(CONFIG_HEIGHT));
-
-            if ((kd = gui_harray(jd)))
-            {
-                gui_label(kd, _("Options"), GUI_SML, GUI_ALL, 0, 0);
-                gui_filler(kd);
-            }
-
-            gui_state(jd, _("Window"),   GUI_SML, CONF_WIN, (f == 0));
-            gui_state(jd, res,           GUI_SML, CONF_RES, 0);
-
-            if ((kd = gui_harray(jd)))
-            {
-                gui_state(kd, _("Low"),  GUI_SML, CONF_TEXLO, (t == 2));
-                gui_state(kd, _("High"), GUI_SML, CONF_TEXHI, (t == 1));
-            }
-            if ((kd = gui_harray(jd)))
-            {
-                gui_state(kd, _("Low"),  GUI_SML, CONF_GEOLO, (g == 0));
-                gui_state(kd, _("High"), GUI_SML, CONF_GEOHI, (g == 1));
-            }
-            if ((kd = gui_harray(jd)))
-            {
-                gui_state(kd, _("Off"),  GUI_SML, CONF_REFOF, (r == 0));
-                gui_state(kd, _("On"),   GUI_SML, CONF_REFON, (r == 1));
-            }
-            if ((kd = gui_harray(jd)))
-            {
-                gui_state(kd, _("Off"),  GUI_SML, CONF_BACOF, (b == 0));
-                gui_state(kd, _("On"),   GUI_SML, CONF_BACON, (b == 1));
-            }
-            if ((kd = gui_harray(jd)))
-            {
-                gui_state(kd, _("Off"),  GUI_SML, CONF_SHDOF, (h == 0));
-                gui_state(kd, _("On"),   GUI_SML, CONF_SHDON, (h == 1));
-            }
-            if ((kd = gui_harray(jd)))
-            {
-                int lo = (a == 22050);
-                int hi = (a == 44100);
-
-                audlo_id = gui_state(kd, _("Low"),  GUI_SML, CONF_AUDLO, lo);
-                audhi_id = gui_state(kd, _("High"), GUI_SML, CONF_AUDHI, hi);
-            }
-            if ((kd = gui_harray(jd)))
-            {
-                /* A series of empty buttons forms the sound volume control. */
-
-                sound_id[10] = gui_state(kd, NULL, GUI_SML, 110, (s == 10));
-                sound_id[ 9] = gui_state(kd, NULL, GUI_SML, 109, (s ==  9));
-                sound_id[ 8] = gui_state(kd, NULL, GUI_SML, 108, (s ==  8));
-                sound_id[ 7] = gui_state(kd, NULL, GUI_SML, 107, (s ==  7));
-                sound_id[ 6] = gui_state(kd, NULL, GUI_SML, 106, (s ==  6));
-                sound_id[ 5] = gui_state(kd, NULL, GUI_SML, 105, (s ==  5));
-                sound_id[ 4] = gui_state(kd, NULL, GUI_SML, 104, (s ==  4));
-                sound_id[ 3] = gui_state(kd, NULL, GUI_SML, 103, (s ==  3));
-                sound_id[ 2] = gui_state(kd, NULL, GUI_SML, 102, (s ==  2));
-                sound_id[ 1] = gui_state(kd, NULL, GUI_SML, 101, (s ==  1));
-                sound_id[ 0] = gui_state(kd, NULL, GUI_SML, 100, (s ==  0));
-            }
-            if ((kd = gui_harray(jd)))
-            {
-                /* A series of empty buttons forms the music volume control. */
-
-                music_id[10] = gui_state(kd, NULL, GUI_SML, 210, (m == 10));
-                music_id[ 9] = gui_state(kd, NULL, GUI_SML, 209, (m ==  9));
-                music_id[ 8] = gui_state(kd, NULL, GUI_SML, 208, (m ==  8));
-                music_id[ 7] = gui_state(kd, NULL, GUI_SML, 207, (m ==  7));
-                music_id[ 6] = gui_state(kd, NULL, GUI_SML, 206, (m ==  6));
-                music_id[ 5] = gui_state(kd, NULL, GUI_SML, 205, (m ==  5));
-                music_id[ 4] = gui_state(kd, NULL, GUI_SML, 204, (m ==  4));
-                music_id[ 3] = gui_state(kd, NULL, GUI_SML, 203, (m ==  3));
-                music_id[ 2] = gui_state(kd, NULL, GUI_SML, 202, (m ==  2));
-                music_id[ 1] = gui_state(kd, NULL, GUI_SML, 201, (m ==  1));
-                music_id[ 0] = gui_state(kd, NULL, GUI_SML, 200, (m ==  0));
-            }
-            gui_state(jd, config_simple_get_s(CONFIG_PLAYER), GUI_SML,
-                      CONF_PLAYER, 0);
+            gui_state(kd, _("Off"), GUI_SML, CONF_REFOF, (r == 0));
+            gui_state(kd, _("On"),  GUI_SML, CONF_REFON, (r == 1));
+
+            gui_label(jd, _("Reflection"), GUI_SML, GUI_ALL, 0, 0);
+        }
+
+        if ((jd = gui_harray(id)) &&
+            (kd = gui_harray(jd)))
+        {
+            gui_state(kd, _("Off"), GUI_SML, CONF_BACOF, (b == 0));
+            gui_state(kd, _("On"),  GUI_SML, CONF_BACON, (b == 1));
+
+            gui_label(jd, _("Background"), GUI_SML, GUI_ALL, 0, 0);
         }
 
-        if ((jd = gui_vstack(id)))
+        if ((jd = gui_harray(id)) &&
+            (kd = gui_harray(jd)))
         {
+            gui_state(kd, _("Off"), GUI_SML, CONF_SHDOF, (h == 0));
+            gui_state(kd, _("On"),  GUI_SML, CONF_SHDON, (h == 1));
 
-            if ((kd = gui_harray(jd)))
-            {
-                gui_filler(kd);
-                gui_start(kd, _("Back"), GUI_SML, CONF_BACK, 0);
-            }
+            gui_label(jd, _("Shadow"), GUI_SML, GUI_ALL, 0, 0);
+        }
 
-            gui_state(jd, _("Fullscreen"),   GUI_SML, CONF_FULL, (f == 1));
+        gui_space(id);
 
-            gui_filler(jd);
+        if ((jd = gui_harray(id)) &&
+            (kd = gui_harray(jd)))
+        {
+            /* A series of empty buttons forms the sound volume control. */
+
+            sound_id[10] = gui_state(kd, NULL, GUI_SML, 110, (s == 10));
+            sound_id[ 9] = gui_state(kd, NULL, GUI_SML, 109, (s ==  9));
+            sound_id[ 8] = gui_state(kd, NULL, GUI_SML, 108, (s ==  8));
+            sound_id[ 7] = gui_state(kd, NULL, GUI_SML, 107, (s ==  7));
+            sound_id[ 6] = gui_state(kd, NULL, GUI_SML, 106, (s ==  6));
+            sound_id[ 5] = gui_state(kd, NULL, GUI_SML, 105, (s ==  5));
+            sound_id[ 4] = gui_state(kd, NULL, GUI_SML, 104, (s ==  4));
+            sound_id[ 3] = gui_state(kd, NULL, GUI_SML, 103, (s ==  3));
+            sound_id[ 2] = gui_state(kd, NULL, GUI_SML, 102, (s ==  2));
+            sound_id[ 1] = gui_state(kd, NULL, GUI_SML, 101, (s ==  1));
+            sound_id[ 0] = gui_state(kd, NULL, GUI_SML, 100, (s ==  0));
 
-            gui_label(jd, _("Textures"),     GUI_SML, GUI_ALL, 0, 0);
-            gui_label(jd, _("Geometry"),     GUI_SML, GUI_ALL, 0, 0);
-            gui_label(jd, _("Reflection"),   GUI_SML, GUI_ALL, 0, 0);
-            gui_label(jd, _("Background"),   GUI_SML, GUI_ALL, 0, 0);
-            gui_label(jd, _("Shadow"),       GUI_SML, GUI_ALL, 0, 0);
-            gui_label(jd, _("Audio"),        GUI_SML, GUI_ALL, 0, 0);
             gui_label(jd, _("Sound Volume"), GUI_SML, GUI_ALL, 0, 0);
+        }
+
+        if ((jd = gui_harray(id)) &&
+            (kd = gui_harray(jd)))
+        {
+            /* A series of empty buttons forms the music volume control. */
+
+            music_id[10] = gui_state(kd, NULL, GUI_SML, 210, (m == 10));
+            music_id[ 9] = gui_state(kd, NULL, GUI_SML, 209, (m ==  9));
+            music_id[ 8] = gui_state(kd, NULL, GUI_SML, 208, (m ==  8));
+            music_id[ 7] = gui_state(kd, NULL, GUI_SML, 207, (m ==  7));
+            music_id[ 6] = gui_state(kd, NULL, GUI_SML, 206, (m ==  6));
+            music_id[ 5] = gui_state(kd, NULL, GUI_SML, 205, (m ==  5));
+            music_id[ 4] = gui_state(kd, NULL, GUI_SML, 204, (m ==  4));
+            music_id[ 3] = gui_state(kd, NULL, GUI_SML, 203, (m ==  3));
+            music_id[ 2] = gui_state(kd, NULL, GUI_SML, 202, (m ==  2));
+            music_id[ 1] = gui_state(kd, NULL, GUI_SML, 201, (m ==  1));
+            music_id[ 0] = gui_state(kd, NULL, GUI_SML, 200, (m ==  0));
+
             gui_label(jd, _("Music Volume"), GUI_SML, GUI_ALL, 0, 0);
-            gui_label(jd, _("Player Name"),  GUI_SML, GUI_ALL, 0, 0);
         }
+
+        gui_space(id);
+
+        if ((jd = gui_harray(id)) &&
+            (kd = gui_harray(jd)))
+        {
+            gui_state(kd, player, GUI_SML, CONF_PLAYER, 0);
+
+            gui_label(jd, _("Player Name"), GUI_SML, GUI_ALL, 0, 0);
+        }
+
         gui_layout(id, 0, 0);
     }
 
@@ -400,6 +404,7 @@ struct state st_conf = {
     shared_timer,
     shared_point,
     shared_stick,
+    shared_angle,
     shared_click,
     NULL,
     conf_buttn,
@@ -416,5 +421,6 @@ struct state st_null = {
     NULL,
     NULL,
     NULL,
+    NULL,
     1, 0
 };