home *** CD-ROM | disk | FTP | other *** search
/ Amiga ISO Collection / AmigaUtilCD1.iso / Emulatoren / FS_FRO23.LZX / Frodo / src / Prefs.c < prev    next >
Encoding:
C/C++ Source or Header  |  1996-02-29  |  25.3 KB  |  884 lines

  1. /*
  2.  *  Prefs.c - Handhabung des Einstellungsfensters
  3.  *
  4.  *  Copyright (C) 1994-1996 by Christian Bauer
  5.  */
  6.  
  7. #include <exec/types.h>
  8. #include <intuition/gadgetclass.h>
  9. #include <graphics/displayinfo.h>
  10. #include <workbench/workbench.h>
  11. #include <libraries/asl.h>
  12. #include <libraries/gadtools.h>
  13. #include <clib/exec_protos.h>
  14. #include <clib/dos_protos.h>
  15. #include <clib/intuition_protos.h>
  16. #include <clib/graphics_protos.h>
  17. #include <clib/gadtools_protos.h>
  18. #include <clib/asl_protos.h>
  19. #include <clib/icon_protos.h>
  20. #include <string.h>
  21.  
  22. #include "Prefs.h"
  23. #include "FrodoGUI.h"
  24. #include "Frodo_rev.h"
  25. #define CATCOMP_NUMBERS 1
  26. #include "LocStrings.h"
  27.  
  28.  
  29. // Aus Main.asm
  30. extern char *GetStr(int strnum);
  31. extern short PrefsFromEmul;
  32. extern char PrefsName[256];
  33. extern USHORT IsDraco;
  34.  
  35. // Aus 6510(SC).asm
  36. extern USHORT IsFrodoSC;
  37.  
  38.  
  39. // Prototypes
  40. void set_gadgets(Preferences *p);
  41. void set_display_id_gadget(Preferences *p);
  42. void get_gadgets(Preferences *p);
  43. void ghost_gadgets(Preferences *p);
  44. int handle_IDCMP(Preferences *p, struct Window *win, int done);
  45. int handle_gadget(Preferences *p, struct Window *win, struct Gadget *gad, UWORD code, int done);
  46. int handle_menu(Preferences *p, struct Window *win, int menu, int item, int done);
  47. int handle_key(Preferences *p, struct Window *win, UWORD code, int done);
  48. int request_display_id(struct Window *win, ULONG *display_id, UWORD *overscan);
  49. int request_drive(struct Window *win, UWORD type, char *str);
  50. int request_file(struct Window *win, char *name, int hail, int save);
  51. void open_prefs_as(Preferences *p);
  52. void save_prefs(Preferences *p);
  53. void save_prefs_as(Preferences *p);
  54.  
  55.  
  56. // Requester
  57. struct EasyStruct about_req = {
  58.   sizeof(struct EasyStruct), 0, NULL, NULL, NULL
  59. };
  60.  
  61.  
  62. // Icon der Prefs-Datei
  63. const UWORD PrefsI1Data[] =
  64. {
  65. /* Plane 0 */
  66.     0x0000,0x0000,0x0000,0x0400,0x0000,0x0000,0x0000,0x0C00,
  67.     0x0003,0xFFC0,0x0000,0x0C00,0x000C,0x0030,0x0000,0x0C00,
  68.     0x0010,0x7E08,0x0000,0x0C00,0x0020,0x8104,0x0000,0x0C00,
  69.     0x0020,0x4104,0x0000,0x0C00,0x0020,0x4104,0x0000,0x0C00,
  70.     0x0010,0x8204,0x0000,0x0C00,0x000F,0x0C08,0x0000,0x0C00,
  71.     0x0000,0x3010,0x0000,0x0C00,0x0000,0x4060,0x0000,0x0C00,
  72.     0x0000,0x8180,0x0000,0x0C00,0x0001,0x0E00,0x0000,0x0C00,
  73.     0x0000,0x8400,0x0000,0x0C00,0x0000,0x7800,0x0000,0x0C00,
  74.     0x0000,0x8400,0x0000,0x0C00,0x0000,0x8400,0x0000,0x0C00,
  75.     0x0000,0x7800,0x0000,0x0C00,0x0000,0x0000,0x0000,0x0C00,
  76.     0x0000,0x0000,0x0000,0x0C00,0x7FFF,0xFFFF,0xFFFF,0xFC00,
  77. /* Plane 1 */
  78.     0xFFFF,0xFFFF,0xFFFF,0xF800,0xD555,0x5557,0xD555,0x5000,
  79.     0xD554,0x001F,0xF555,0x5000,0xD553,0xFFCF,0xF555,0x5000,
  80.     0xD54F,0x81F7,0xF555,0x5000,0xD55F,0x54FB,0xF555,0x5000,
  81.     0xD55F,0x94FB,0xFFD5,0x5000,0xD55F,0x94F9,0x7FF5,0x5000,
  82.     0xD54F,0x55F9,0x7FD5,0x5000,0xD550,0x53F5,0x7FD5,0x5000,
  83.     0xD555,0x4FE5,0x5F55,0x5000,0xD555,0x3F95,0x60D5,0x5000,
  84.     0xD555,0x7E7D,0x6055,0x5000,0xD554,0xF1FD,0x6035,0x5000,
  85.     0xD555,0x79FF,0xFFD5,0x5000,0xD555,0x05FF,0xF555,0x5000,
  86.     0xD555,0x797F,0xF555,0x5000,0xD555,0x797F,0xF555,0x5000,
  87.     0xD555,0x055F,0xF555,0x5000,0xD555,0x5557,0xD555,0x5000,
  88.     0xD555,0x5555,0x5555,0x5000,0x8000,0x0000,0x0000,0x0000,
  89. /* Plane 2 */
  90.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  91.     0x0000,0x0007,0xC000,0x0000,0x0000,0x000F,0xE000,0x0000,
  92.     0x0000,0x0007,0xE000,0x0000,0x0000,0x0003,0xE000,0x0000,
  93.     0x0000,0x0000,0x6000,0x0000,0x0000,0x0000,0x1FC0,0x0000,
  94.     0x0000,0x0000,0x1F80,0x0000,0x0000,0x0000,0x1F00,0x0000,
  95.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x1F00,0x0000,
  96.     0x0000,0x0070,0x1F80,0x0000,0x0000,0x00F0,0x1FC0,0x0000,
  97.     0x0000,0x00FC,0x6000,0x0000,0x0000,0x007F,0xE000,0x0000,
  98.     0x0000,0x003F,0xE000,0x0000,0x0000,0x001F,0xE000,0x0000,
  99.     0x0000,0x0007,0xC000,0x0000,0x0000,0x0000,0x0000,0x0000,
  100.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  101. /* Plane 3 */
  102.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  103.     0x0000,0x0007,0xC000,0x0000,0x0000,0x000F,0xE000,0x0000,
  104.     0x0000,0x0007,0xE000,0x0000,0x0000,0x0003,0xE000,0x0000,
  105.     0x0000,0x0000,0x6000,0x0000,0x0000,0x0000,0x1FC0,0x0000,
  106.     0x0000,0x0000,0x1F80,0x0000,0x0000,0x0000,0x1F00,0x0000,
  107.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x1F00,0x0000,
  108.     0x0000,0x0070,0x1F80,0x0000,0x0000,0x00F0,0x1FC0,0x0000,
  109.     0x0000,0x00FC,0x6000,0x0000,0x0000,0x007F,0xE000,0x0000,
  110.     0x0000,0x003F,0xE000,0x0000,0x0000,0x001F,0xE000,0x0000,
  111.     0x0000,0x0007,0xC000,0x0000,0x0000,0x0000,0x0000,0x0000,
  112.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  113. /* Plane 4 */
  114.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  115.     0x0000,0x0007,0xC000,0x0000,0x0000,0x000F,0xE000,0x0000,
  116.     0x0000,0x0007,0xE000,0x0000,0x0000,0x0003,0xE000,0x0000,
  117.     0x0000,0x0000,0x6000,0x0000,0x0000,0x0000,0x1FC0,0x0000,
  118.     0x0000,0x0000,0x1F80,0x0000,0x0000,0x0000,0x1F00,0x0000,
  119.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x1F00,0x0000,
  120.     0x0000,0x0070,0x1F80,0x0000,0x0000,0x00F0,0x1FC0,0x0000,
  121.     0x0000,0x00FC,0x6000,0x0000,0x0000,0x007F,0xE000,0x0000,
  122.     0x0000,0x003F,0xE000,0x0000,0x0000,0x001F,0xE000,0x0000,
  123.     0x0000,0x0007,0xC000,0x0000,0x0000,0x0000,0x0000,0x0000,
  124.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  125. /* Plane 5 */
  126.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  127.     0x0000,0x0007,0xC000,0x0000,0x0000,0x000F,0xE000,0x0000,
  128.     0x0000,0x0007,0xE000,0x0000,0x0000,0x0003,0xE000,0x0000,
  129.     0x0000,0x0000,0x6000,0x0000,0x0000,0x0000,0x1FC0,0x0000,
  130.     0x0000,0x0000,0x1F80,0x0000,0x0000,0x0000,0x1F00,0x0000,
  131.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x1F00,0x0000,
  132.     0x0000,0x0070,0x1F80,0x0000,0x0000,0x00F0,0x1FC0,0x0000,
  133.     0x0000,0x00FC,0x6000,0x0000,0x0000,0x007F,0xE000,0x0000,
  134.     0x0000,0x003F,0xE000,0x0000,0x0000,0x001F,0xE000,0x0000,
  135.     0x0000,0x0007,0xC000,0x0000,0x0000,0x0000,0x0000,0x0000,
  136.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  137. /* Plane 6 */
  138.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  139.     0x0000,0x0007,0xC000,0x0000,0x0000,0x000F,0xE000,0x0000,
  140.     0x0000,0x0007,0xE000,0x0000,0x0000,0x0003,0xE000,0x0000,
  141.     0x0000,0x0000,0x6000,0x0000,0x0000,0x0000,0x1FC0,0x0000,
  142.     0x0000,0x0000,0x1F80,0x0000,0x0000,0x0000,0x1F00,0x0000,
  143.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x1F00,0x0000,
  144.     0x0000,0x0070,0x1F80,0x0000,0x0000,0x00F0,0x1FC0,0x0000,
  145.     0x0000,0x00FC,0x6000,0x0000,0x0000,0x007F,0xE000,0x0000,
  146.     0x0000,0x003F,0xE000,0x0000,0x0000,0x001F,0xE000,0x0000,
  147.     0x0000,0x0007,0xC000,0x0000,0x0000,0x0000,0x0000,0x0000,
  148.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  149. /* Plane 7 */
  150.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  151.     0x0000,0x0007,0xC000,0x0000,0x0000,0x000F,0xE000,0x0000,
  152.     0x0000,0x0007,0xE000,0x0000,0x0000,0x0003,0xE000,0x0000,
  153.     0x0000,0x0000,0x6000,0x0000,0x0000,0x0000,0x1FC0,0x0000,
  154.     0x0000,0x0000,0x1F80,0x0000,0x0000,0x0000,0x1F00,0x0000,
  155.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x1F00,0x0000,
  156.     0x0000,0x0070,0x1F80,0x0000,0x0000,0x00F0,0x1FC0,0x0000,
  157.     0x0000,0x00FC,0x6000,0x0000,0x0000,0x007F,0xE000,0x0000,
  158.     0x0000,0x003F,0xE000,0x0000,0x0000,0x001F,0xE000,0x0000,
  159.     0x0000,0x0007,0xC000,0x0000,0x0000,0x0000,0x0000,0x0000,
  160.     0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,
  161. };
  162.  
  163. const struct Image PrefsI1 =
  164. {
  165.     0, 0,            /* Upper left corner */
  166.     54, 22, 8,        /* Width, Height, Depth */
  167.     PrefsI1Data,    /* Image data */
  168.     0x00FF, 0x0000,    /* PlanePick, PlaneOnOff */
  169.     NULL            /* Next image */
  170. };
  171.  
  172. const struct DiskObject PrefsIcon =
  173. {
  174.     WB_DISKMAGIC,        /* Magic Number */
  175.     WB_DISKVERSION,        /* Version */
  176.     {                    /* Embedded Gadget Structure */
  177.     NULL,                /* Next Gadget Pointer */
  178.     0, 0, 54, 23,        /* Left,Top,Width,Height */
  179.     GFLG_GADGIMAGE | GFLG_GADGHCOMP,    /* Flags */
  180.     GACT_RELVERIFY,        /* Activation Flags */
  181.     BOOLGADGET,            /* Gadget Type */
  182.     (APTR)&PrefsI1,        /* Render Image */
  183.     NULL,                /* Select Image */
  184.     NULL,                /* Gadget Text */
  185.     NULL,                /* Mutual Exclude */
  186.     NULL,                /* Special Info */
  187.     0,                    /* Gadget ID */
  188.     (APTR) 0x0001,        /* User Data (Revision) */
  189.     },
  190.     WBPROJECT,            /* Icon Type */
  191.     (char *)"Frodo",    /* Default Tool */
  192.     NULL,                /* Tool Type Array */
  193.     NO_ICON_POSITION,    /* Current X */
  194.     NO_ICON_POSITION,    /* Current Y */
  195.     NULL,                /* Drawer Structure */
  196.     NULL,                /* Tool Window */
  197.     0                    /* Stack Size */
  198. };
  199.  
  200.  
  201. /*
  202.  *  Einstellungsfenster öffnen, handhaben und schließen
  203.  *  Die Preferences werden auf jeden Fall verändert, auch bei Cancel
  204.  *  0: Cancel, 1: OK
  205.  */
  206.  
  207. int DoThePrefs(Preferences *p)
  208. {
  209.   int done = FALSE;
  210.  
  211.   if (!SetupScreen()) {
  212.     if (!OpenPrefsWindow()) {
  213.       SetWindowTitles(PrefsWnd,
  214.         GetStr(IsFrodoSC ? MSG_PREFSTITLESC : MSG_PREFSTITLE),
  215.         GetStr(IsFrodoSC ? MSG_SCREENTITLESC : MSG_SCREENTITLE));
  216.  
  217.       set_gadgets(p);
  218.  
  219.       // ScreenReqWindow, DirReqWindow, FileReqWindow setzen
  220.       while (!done) {
  221.         WaitPort(PrefsWnd->UserPort);
  222.         done = handle_IDCMP(p, PrefsWnd, done);
  223.       }
  224.       if (done == -1) done = 0;
  225.  
  226.       get_gadgets(p);
  227.  
  228.       ClosePrefsWindow();
  229.     }
  230.     CloseDownScreen();
  231.   }
  232.  
  233.   return done;
  234. }
  235.  
  236.  
  237. /*
  238.  *  Gadgets auf die Einstellungen setzen
  239.  */
  240.  
  241. void set_gadgets(Preferences *p)
  242. {
  243.   GT_SetGadgetAttrs(PrefsGadgets[GDX_NormalCycles], PrefsWnd, NULL,
  244.     GTIN_Number, p->normal_cycles, TAG_DONE);
  245.   GT_SetGadgetAttrs(PrefsGadgets[GDX_BadLineCycles], PrefsWnd, NULL,
  246.     GTIN_Number, p->bad_line_cycles, TAG_DONE);
  247.   GT_SetGadgetAttrs(PrefsGadgets[GDX_CIACycles], PrefsWnd, NULL,
  248.     GTIN_Number, p->CIA_cycles, TAG_DONE);
  249.   GT_SetGadgetAttrs(PrefsGadgets[GDX_SkipLatch], PrefsWnd, NULL,
  250.     GTIN_Number, p->skip_latch, TAG_DONE);
  251.  
  252.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Joystick1On], PrefsWnd, NULL,
  253.     GTCB_Checked, p->joystick_1_on, TAG_DONE);
  254.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Joystick2On], PrefsWnd, NULL,
  255.     GTCB_Checked, p->joystick_2_on, TAG_DONE);
  256.   GT_SetGadgetAttrs(PrefsGadgets[GDX_JoystickSwap], PrefsWnd, NULL,
  257.     GTCB_Checked, p->joystick_swap, TAG_DONE);
  258.   GT_SetGadgetAttrs(PrefsGadgets[GDX_KeyboardYZ], PrefsWnd, NULL,
  259.     GTCB_Checked, p->keyboard_yz, TAG_DONE);
  260.   GT_SetGadgetAttrs(PrefsGadgets[GDX_SpritesOn], PrefsWnd, NULL,
  261.     GTCB_Checked, p->sprites_on, TAG_DONE);
  262.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Collisions], PrefsWnd, NULL,
  263.     GTCB_Checked, p->collisions, TAG_DONE);
  264.   GT_SetGadgetAttrs(PrefsGadgets[GDX_FastReset], PrefsWnd, NULL,
  265.     GTCB_Checked, p->fast_reset, TAG_DONE);
  266.   GT_SetGadgetAttrs(PrefsGadgets[GDX_LimitSpeed], PrefsWnd, NULL,
  267.     GTCB_Checked, p->limit_speed, TAG_DONE);
  268.   GT_SetGadgetAttrs(PrefsGadgets[GDX_DirectVideo], PrefsWnd, NULL,
  269.     GTCB_Checked, p->direct_video, TAG_DONE);
  270.   GT_SetGadgetAttrs(PrefsGadgets[GDX_OtherIEC], PrefsWnd, NULL,
  271.     GTCB_Checked, p->other_IEC, TAG_DONE);
  272.   GT_SetGadgetAttrs(PrefsGadgets[GDX_MapSlash], PrefsWnd, NULL,
  273.     GTCB_Checked, p->map_slash, TAG_DONE);
  274.  
  275.   GT_SetGadgetAttrs(PrefsGadgets[GDX_SIDType], PrefsWnd, NULL,
  276.     GTCY_Active, p->SID_type, TAG_DONE);
  277.   GT_SetGadgetAttrs(PrefsGadgets[GDX_ScreenType], PrefsWnd, NULL,
  278.     GTCY_Active, p->screen_type, TAG_DONE);
  279.  
  280.   set_display_id_gadget(p);
  281.  
  282.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Drv8Type], PrefsWnd, NULL,
  283.     GTCY_Active, p->drv_8_type, TAG_DONE);
  284.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Drv9Type], PrefsWnd, NULL,
  285.     GTCY_Active, p->drv_9_type, TAG_DONE);
  286.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Drv10Type], PrefsWnd, NULL,
  287.     GTCY_Active, p->drv_10_type, TAG_DONE);
  288.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Drv11Type], PrefsWnd, NULL,
  289.     GTCY_Active, p->drv_11_type, TAG_DONE);
  290.  
  291.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir8], PrefsWnd, NULL,
  292.     GTST_String, p->dir_8, TAG_DONE);
  293.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir9], PrefsWnd, NULL,
  294.     GTST_String, p->dir_9, TAG_DONE);
  295.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir10], PrefsWnd, NULL,
  296.     GTST_String, p->dir_10, TAG_DONE);
  297.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir11], PrefsWnd, NULL,
  298.     GTST_String, p->dir_11, TAG_DONE);
  299.  
  300.   ghost_gadgets(p);
  301. }
  302.  
  303.  
  304. /*
  305.  *  Display-ID-Gadget setzen
  306.  */
  307.  
  308. char mode_name[DISPLAYNAMELEN];
  309.  
  310. void set_display_id_gadget(Preferences *p)
  311. {
  312.   struct NameInfo query;
  313.  
  314.   GetDisplayInfoData(NULL, (UBYTE *)&query, sizeof(query), DTAG_NAME, p->display_id);
  315.   strncpy(mode_name, query.Name, DISPLAYNAMELEN);
  316.  
  317.   GT_SetGadgetAttrs(PrefsGadgets[GDX_DisplayID], PrefsWnd, NULL,
  318.     GTTX_Text, mode_name, TAG_DONE);
  319. }
  320.  
  321.  
  322. /*
  323.  *  Einstellungen aus den Gadgets lesen
  324.  */
  325.  
  326. void get_gadgets(Preferences *p)
  327. {
  328.   p->normal_cycles = GetNumber(PrefsGadgets[GDX_NormalCycles]);
  329.   p->bad_line_cycles = GetNumber(PrefsGadgets[GDX_BadLineCycles]);
  330.   p->CIA_cycles = GetNumber(PrefsGadgets[GDX_CIACycles]);
  331.   p->skip_latch = GetNumber(PrefsGadgets[GDX_SkipLatch]);
  332.  
  333.   strncpy(p->dir_8, GetString(PrefsGadgets[GDX_Dir8]), 256);
  334.   strncpy(p->dir_9, GetString(PrefsGadgets[GDX_Dir9]), 256);
  335.   strncpy(p->dir_10, GetString(PrefsGadgets[GDX_Dir10]), 256);
  336.   strncpy(p->dir_11, GetString(PrefsGadgets[GDX_Dir11]), 256);
  337. }
  338.  
  339.  
  340. /*
  341.  *  Gadgets korrekt ghosten
  342.  */
  343.  
  344. void ghost_gadgets(Preferences *p)
  345. {
  346.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir8], PrefsWnd, NULL,
  347.     GA_Disabled, p->drv_8_type == DRVTYPE_IEC, TAG_DONE);
  348.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir9], PrefsWnd, NULL,
  349.     GA_Disabled, p->drv_9_type == DRVTYPE_IEC, TAG_DONE);
  350.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir10], PrefsWnd, NULL,
  351.     GA_Disabled, p->drv_10_type == DRVTYPE_IEC, TAG_DONE);
  352.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir11], PrefsWnd, NULL,
  353.     GA_Disabled, p->drv_11_type == DRVTYPE_IEC, TAG_DONE);
  354.  
  355.   GT_SetGadgetAttrs(PrefsGadgets[GDX_Collisions], PrefsWnd, NULL,
  356.     GA_Disabled, p->screen_type == SCRTYPE_1BIT, TAG_DONE);
  357.   GT_SetGadgetAttrs(PrefsGadgets[GDX_DirectVideo], PrefsWnd, NULL,
  358.     GA_Disabled, (p->screen_type != SCRTYPE_8BIT) || PrefsFromEmul, TAG_DONE);
  359.  
  360.   GT_SetGadgetAttrs(PrefsGadgets[GDX_GetDisplayID], PrefsWnd, NULL,
  361.     GA_Disabled, PrefsFromEmul, TAG_DONE);
  362.   GT_SetGadgetAttrs(PrefsGadgets[GDX_ScreenType], PrefsWnd, NULL,
  363.     GA_Disabled, PrefsFromEmul, TAG_DONE);
  364.  
  365.   if (IsFrodoSC) {
  366.     GT_SetGadgetAttrs(PrefsGadgets[GDX_ScreenType], PrefsWnd, NULL,
  367.       GA_Disabled, TRUE, TAG_DONE);
  368.     GT_SetGadgetAttrs(PrefsGadgets[GDX_Collisions], PrefsWnd, NULL,
  369.       GA_Disabled, TRUE, TAG_DONE);
  370.     GT_SetGadgetAttrs(PrefsGadgets[GDX_NormalCycles], PrefsWnd, NULL,
  371.       GA_Disabled, TRUE, TAG_DONE);
  372.     GT_SetGadgetAttrs(PrefsGadgets[GDX_BadLineCycles], PrefsWnd, NULL,
  373.       GA_Disabled, TRUE, TAG_DONE);
  374.     GT_SetGadgetAttrs(PrefsGadgets[GDX_CIACycles], PrefsWnd, NULL,
  375.       GA_Disabled, TRUE, TAG_DONE);
  376.     GT_SetGadgetAttrs(PrefsGadgets[GDX_DirectVideo], PrefsWnd, NULL,
  377.       GA_Disabled, TRUE, TAG_DONE);
  378.   }
  379.  
  380.   if (IsDraco) {
  381.     GT_SetGadgetAttrs(PrefsGadgets[GDX_Joystick1On], PrefsWnd, NULL,
  382.       GA_Disabled, TRUE, TAG_DONE);
  383.     GT_SetGadgetAttrs(PrefsGadgets[GDX_Joystick2On], PrefsWnd, NULL,
  384.       GA_Disabled, TRUE, TAG_DONE);
  385.     GT_SetGadgetAttrs(PrefsGadgets[GDX_OtherIEC], PrefsWnd, NULL,
  386.       GA_Disabled, TRUE, TAG_DONE);
  387.   }
  388. }
  389.  
  390.  
  391. /*
  392.  *  IDCMP-Messages eines Fensters handhaben
  393.  *  -1: Cancel, 1: OK, 0: weitermachen
  394.  */
  395.  
  396. int handle_IDCMP(Preferences *p, struct Window *win, int done)
  397. {
  398.   struct IntuiMessage *msg;
  399.   ULONG class;
  400.   UWORD code;
  401.   UWORD menu_number;
  402.   struct Gadget *gad;
  403.   struct MenuItem *item;
  404.  
  405.   while (!done && (msg = GT_GetIMsg(win->UserPort))) {
  406.     class = msg->Class;
  407.     code = msg->Code;
  408.     gad = (struct Gadget *)msg->IAddress;
  409.  
  410.     GT_ReplyIMsg(msg);
  411.  
  412.     switch (class) {
  413.       case IDCMP_GADGETUP:
  414.         done = handle_gadget(p, win, gad, code, done);
  415.         break;
  416.  
  417.       case IDCMP_MENUPICK:
  418.         menu_number = code;
  419.         while (!done && (menu_number != MENUNULL)) {
  420.           item = ItemAddress(win->MenuStrip, menu_number);
  421.           done = handle_menu(p, win, MENUNUM(menu_number), ITEMNUM(menu_number), done);
  422.           menu_number = item->NextSelect;
  423.         }
  424.         break;
  425.  
  426.       case IDCMP_VANILLAKEY:
  427.         done = handle_key(p, win, code, done);
  428.         break;
  429.  
  430.       case IDCMP_REFRESHWINDOW:
  431.         GT_BeginRefresh(win);
  432.         GT_EndRefresh(win, TRUE);
  433.         break;
  434.     }
  435.   }
  436.  
  437.   return done;
  438. }
  439.  
  440.  
  441. /*
  442.  *  Gadget wurde betätigt
  443.  *  -1: Cancel, 1: OK, 0: weitermachen
  444.  */
  445.  
  446. int handle_gadget(Preferences *p, struct Window *win, struct Gadget *gad, UWORD code, int done)
  447. {
  448.   switch (gad->GadgetID) {
  449.     case GD_OK:
  450.       done = 1;
  451.       break;
  452.  
  453.     case GD_Cancel:
  454.       done = -1;
  455.       break;
  456.  
  457.     case GD_Save:
  458.       save_prefs(p);
  459.       break;
  460.  
  461.     case GD_Joystick1On:
  462.       p->joystick_1_on = p->joystick_1_on ? 0 : -1;
  463.       break;
  464.  
  465.     case GD_Joystick2On:
  466.       p->joystick_2_on = p->joystick_2_on ? 0 : -1;
  467.       break;
  468.  
  469.     case GD_JoystickSwap:
  470.       p->joystick_swap = p->joystick_swap ? 0 : -1;
  471.       break;
  472.  
  473.     case GD_SIDType:
  474.       p->SID_type = code;
  475.       break;
  476.  
  477.     case GD_OtherIEC:
  478.       p->other_IEC = p->other_IEC ? 0 : -1;
  479.       break;
  480.  
  481.     case GD_KeyboardYZ:
  482.       p->keyboard_yz = p->keyboard_yz ? 0 : -1;
  483.       break;
  484.  
  485.     case GD_SpritesOn:
  486.       p->sprites_on = p->sprites_on ? 0 : -1;
  487.       break;
  488.  
  489.     case GD_Collisions:
  490.       p->collisions = p->collisions ? 0 : -1;
  491.       break;
  492.  
  493.     case GD_MapSlash:
  494.       p->map_slash = p->map_slash ? 0 : -1;
  495.       break;
  496.  
  497.     case GD_FastReset:
  498.       p->fast_reset = p->fast_reset ? 0 : -1;
  499.       break;
  500.  
  501.     case GD_LimitSpeed:
  502.       p->limit_speed = p->limit_speed ? 0 : -1;
  503.       break;
  504.  
  505.     case GD_DirectVideo:
  506.       if (!PrefsFromEmul)
  507.         p->direct_video = p->direct_video ? 0 : -1;
  508.       break;
  509.  
  510.     case GD_ScreenType:
  511.       if (!PrefsFromEmul)
  512.         p->screen_type = code;
  513.       ghost_gadgets(p);
  514.       break;
  515.  
  516.     case GD_GetDisplayID:
  517.       if (!PrefsFromEmul)
  518.         if (request_display_id(win, &p->display_id, &p->overscan))
  519.           set_display_id_gadget(p);
  520.       break;
  521.  
  522.     case GD_Drv8Type:
  523.       p->drv_8_type = code;
  524.       ghost_gadgets(p);
  525.       break;
  526.  
  527.     case GD_Drv9Type:
  528.       p->drv_9_type = code;
  529.       ghost_gadgets(p);
  530.       break;
  531.  
  532.     case GD_Drv10Type:
  533.       p->drv_10_type = code;
  534.       ghost_gadgets(p);
  535.       break;
  536.  
  537.     case GD_Drv11Type:
  538.       p->drv_11_type = code;
  539.       ghost_gadgets(p);
  540.       break;
  541.  
  542.     case GD_GetDir8:
  543.       strncpy(p->dir_8, GetString(PrefsGadgets[GDX_Dir8]), 256);
  544.       if (request_drive(win, p->drv_8_type, p->dir_8))
  545.         GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir8], PrefsWnd, NULL,
  546.           GTST_String, p->dir_8, TAG_DONE);
  547.       break;
  548.  
  549.     case GD_GetDir9:
  550.       strncpy(p->dir_9, GetString(PrefsGadgets[GDX_Dir9]), 256);
  551.       if (request_drive(win, p->drv_9_type, p->dir_9))
  552.         GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir9], PrefsWnd, NULL,
  553.           GTST_String, p->dir_9, TAG_DONE);
  554.       break;
  555.  
  556.     case GD_GetDir10:
  557.       strncpy(p->dir_10, GetString(PrefsGadgets[GDX_Dir10]), 256);
  558.       if (request_drive(win, p->drv_10_type, p->dir_10))
  559.         GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir10], PrefsWnd, NULL,
  560.           GTST_String, p->dir_10, TAG_DONE);
  561.       break;
  562.  
  563.     case GD_GetDir11:
  564.       strncpy(p->dir_11, GetString(PrefsGadgets[GDX_Dir11]), 256);
  565.       if (request_drive(win, p->drv_11_type, p->dir_11))
  566.         GT_SetGadgetAttrs(PrefsGadgets[GDX_Dir11], PrefsWnd, NULL,
  567.           GTST_String, p->dir_11, TAG_DONE);
  568.       break;
  569.   }
  570.  
  571.   return done;
  572. }
  573.  
  574.  
  575. /*
  576.  *  Menü wurde ausgewählt
  577.  *  -1: Cancel, 1: OK, 0: weitermachen
  578.  */
  579.  
  580. int handle_menu(Preferences *p, struct Window *win, int menu, int item, int done)
  581. {
  582.   if (menu == 0) {
  583.     switch (item) {
  584.       case 0:        // Open
  585.         open_prefs_as(p);
  586.         break;
  587.  
  588.       case 2:        // Save
  589.         save_prefs(p);
  590.         break;
  591.  
  592.       case 3:        // Save As
  593.         save_prefs_as(p);
  594.         break;
  595.  
  596.       case 5:        // About
  597.         EasyRequest(win, &about_req, NULL, VERSION, REVISION);
  598.         break;
  599.  
  600.       case 7:        // OK
  601.         done = 1;
  602.         break;
  603.  
  604.       case 8:        // Cancel
  605.         done = -1;
  606.         break;
  607.     }
  608.   }
  609.  
  610.   return done;
  611. }
  612.  
  613.  
  614. /*
  615.  *  Taste wurde gedrückt
  616.  *  -1: Cancel, 1: OK, 0: weitermachen
  617.  */
  618.  
  619. int handle_key(Preferences *p, struct Window *win, UWORD code, int done)
  620. {
  621.   switch (code) {
  622.     case 'o':        // OK
  623.     case 'O':
  624.       done = 1;
  625.       break;
  626.  
  627.     case 'c':        // Cancel
  628.     case 'C':
  629.       done = -1;
  630.       break;
  631.  
  632.     case 's':
  633.     case 'S':
  634.       save_prefs(p);
  635.       break;
  636.   }
  637.  
  638.   return done;
  639. }
  640.  
  641.  
  642. /*
  643.  *  Screenmode-Requester
  644.  *  FALSE: Cancel, TRUE: OK
  645.  */
  646.  
  647. int request_display_id(struct Window *win, ULONG *display_id, UWORD *overscan)
  648. {
  649.   struct ScreenModeRequester *sm;
  650.   int result = FALSE;
  651.  
  652.   if (sm = AllocAslRequestTags(ASL_ScreenModeRequest,
  653.     ASLSM_TitleText, GetStr(MSG_SCREENHAIL),
  654.     ASLSM_Window, win,
  655.     ASLSM_SleepWindow, TRUE,
  656.     ASLSM_DoOverscanType, TRUE,
  657.     ASLSM_PropertyMask, DIPF_IS_HAM | DIPF_IS_EXTRAHALFBRITE | DIPF_IS_DUALPF,
  658.     ASLSM_PropertyFlags, 0,
  659.     ASLSM_InitialDisplayID, *display_id,
  660.     ASLSM_InitialOverscanType, *overscan,
  661.     TAG_DONE)) {
  662.  
  663.     if (result = AslRequest(sm, NULL)) {
  664.       *display_id = sm->sm_DisplayID;
  665.       *overscan = sm->sm_OverscanType;
  666.     }
  667.  
  668.     FreeAslRequest(sm);
  669.   }
  670.  
  671.   return result;
  672. }
  673.  
  674.  
  675. /*
  676.  *  Requester für Verzeichnis/.d64-Datei
  677.  *  FALSE: Cancel, TRUE: OK
  678.  */
  679.  
  680. int request_drive(struct Window *win, UWORD type, char *str)
  681. {
  682.   struct FileRequester *fr;
  683.   int result = FALSE;
  684.  
  685.   if (type == DRVTYPE_D64) {
  686.     return request_file(win, str, MSG_D64HAIL, FALSE);
  687.  
  688.   } else {
  689.     if (fr = AllocAslRequestTags(ASL_FileRequest,
  690.       ASLFR_TitleText, GetStr(MSG_DIRHAIL),
  691.       ASLFR_InitialDrawer, str,
  692.       ASLFR_Window, win,
  693.       ASLFR_SleepWindow, TRUE,
  694.       ASLFR_Flags2, FRF_REJECTICONS | FRF_DRAWERSONLY,
  695.       TAG_DONE)) {
  696.  
  697.       if (result = AslRequest(fr, NULL))
  698.         strncpy(str, fr->fr_Drawer, 256);
  699.  
  700.       FreeAslRequest(fr);
  701.     }
  702.   }
  703.  
  704.   return result;
  705. }
  706.  
  707.  
  708. /*
  709.  *  Einfacher Dateirequester
  710.  *  FALSE: Cancel, TRUE: OK
  711.  */
  712.  
  713. int request_file(struct Window *win, char *name, int hail, int save)
  714. {
  715.   struct FileRequester *fr;
  716.   int result = FALSE;
  717.   char dir[256];
  718.   char file[256];
  719.   char *s;
  720.  
  721.   // Pfad und Dateinamen aufteilen (dir, file)
  722.   strcpy(dir, name);
  723.   s = FilePart(dir);
  724.   strcpy(file, s);
  725.   *s = 0;
  726.  
  727.   if (fr = AllocAslRequestTags(ASL_FileRequest,
  728.     ASLFR_TitleText, GetStr(hail),
  729.     ASLFR_Window, win,
  730.     ASLFR_SleepWindow, TRUE,
  731.     ASLFR_InitialDrawer, dir,
  732.     ASLFR_InitialFile, file,
  733.     ASLFR_Flags1, save ? FRF_DOSAVEMODE : 0,
  734.     ASLFR_Flags2, FRF_REJECTICONS,
  735.     TAG_DONE)) {
  736.  
  737.     if (result = AslRequest(fr, NULL)) {
  738.       strncpy(name, fr->fr_Drawer, 256);
  739.       AddPart(name, fr->fr_File, 256);
  740.     }
  741.  
  742.     FreeAslRequest(fr);
  743.   }
  744.  
  745.   return result;
  746. }
  747.  
  748.  
  749. /*
  750.  *  Einstellungen laden
  751.  */
  752.  
  753. void OpenPrefs(Preferences *p)
  754. {
  755.   BPTR fh;
  756.  
  757.   if (fh = Open(PrefsName, MODE_OLDFILE)) {
  758.     Read(fh, p, sizeof(Preferences));
  759.     Close(fh);
  760.  
  761.     // Altes drv_?_is_IEC konvertieren
  762.     if (p->drv_8_type == 0xffff)
  763.       p->drv_8_type = DRVTYPE_IEC;
  764.     if (p->drv_9_type == 0xffff)
  765.       p->drv_9_type = DRVTYPE_IEC;
  766.     if (p->drv_10_type == 0xffff)
  767.       p->drv_10_type = DRVTYPE_IEC;
  768.     if (p->drv_11_type == 0xffff)
  769.       p->drv_11_type = DRVTYPE_IEC;
  770.  
  771.     // Altes use_SID_card konvertieren
  772.     if (p->SID_type == 0xffff)
  773.       p->SID_type = SIDTYPE_CARD;
  774.   }  
  775. }
  776.  
  777.  
  778. /*
  779.  *  Einstellungen laden (Dateirequester, ändert PrefsName)
  780.  */
  781.  
  782. void open_prefs_as(Preferences *p)
  783. {
  784.   if (request_file(PrefsWnd, PrefsName, MSG_PREFSHAIL, FALSE)) {
  785.     OpenPrefs(p);
  786.     set_gadgets(p);
  787.   }
  788. }
  789.  
  790.  
  791. /*
  792.  *  Einstellungen unter aktuellem Namen speichern
  793.  */
  794.  
  795. void save_prefs(Preferences *p)
  796. {
  797.   BPTR fh;
  798.   struct DiskObject *dobj;
  799.  
  800.   get_gadgets(p);
  801.  
  802.   if (fh = Open(PrefsName, MODE_NEWFILE)) {
  803.     Write(fh, p, sizeof(Preferences));
  804.     Close(fh);
  805.  
  806.     if (dobj = GetDiskObject(PrefsName))
  807.       FreeDiskObject(dobj);
  808.     else
  809.       PutDiskObject(PrefsName, &PrefsIcon);
  810.   }
  811. }
  812.  
  813.  
  814. /*
  815.  *  Einstellungen speichern (Dateirequester, ändert PrefsName)
  816.  */
  817.  
  818. void save_prefs_as(Preferences *p)
  819. {
  820.   if (request_file(PrefsWnd, PrefsName, MSG_PREFSHAIL, TRUE))
  821.     save_prefs(p);
  822. }
  823.  
  824.  
  825. /*
  826.  *  Lokalisierungen vornehmen
  827.  */
  828.  
  829. const int gadget_table[] = {
  830.   GDX_OK, MSG_OK_GAD,
  831.   GDX_Save, MSG_SAVE_GAD,
  832.   GDX_Cancel, MSG_CANCEL_GAD,
  833.   GDX_Joystick1On, MSG_JOYSTICK1ON_GAD,
  834.   GDX_Joystick2On, MSG_JOYSTICK2ON_GAD,
  835.   GDX_JoystickSwap, MSG_JOYSTICKSWAP_GAD,
  836.   GDX_GetDisplayID, MSG_GETDISPLAYID_GAD,
  837.   GDX_DisplayID, MSG_DISPLAYID_GAD,
  838.   GDX_ScreenType, MSG_SCREENTYPE_GAD,
  839.   GDX_NormalCycles, MSG_NORMALCYCLES_GAD,
  840.   GDX_BadLineCycles, MSG_BADLINECYCLES_GAD,
  841.   GDX_CIACycles, MSG_CIACYCLES_GAD,
  842.   GDX_Drv8Type, MSG_DIR8_GAD,
  843.   GDX_Drv9Type, MSG_DIR9_GAD,
  844.   GDX_Drv10Type, MSG_DIR10_GAD,
  845.   GDX_Drv11Type, MSG_DIR11_GAD,
  846.   GDX_SIDType, MSG_SIDTYPE_GAD,
  847.   GDX_OtherIEC, MSG_OTHERIEC_GAD,
  848.   GDX_KeyboardYZ, MSG_KEYBOARDYZ_GAD,
  849.   GDX_SpritesOn, MSG_SPRITESON_GAD,
  850.   GDX_Collisions, MSG_COLLISIONS_GAD,
  851.   GDX_MapSlash, MSG_MAPSLASH_GAD,
  852.   GDX_FastReset, MSG_FASTRESET_GAD,
  853.   GDX_SkipLatch, MSG_SKIPLATCH_GAD,
  854.   GDX_LimitSpeed, MSG_LIMITSPEED_GAD,
  855.   GDX_DirectVideo, MSG_DIRECTVIDEO_GAD,
  856.   -1
  857. };
  858.  
  859. void LocalizePrefs(void)
  860. {
  861.   int i;
  862.  
  863.   about_req.es_Title = GetStr(IsFrodoSC ? MSG_ABOUTTITLESC : MSG_ABOUTTITLE);
  864.   about_req.es_TextFormat = GetStr(IsFrodoSC ? MSG_ABOUTSC_REQ : MSG_ABOUT_REQ);
  865.   about_req.es_GadgetFormat = GetStr(MSG_REQGADS5);
  866.  
  867.   PrefsWdt = GetStr(MSG_PREFSTITLE);
  868.  
  869.   PrefsNewMenu[0].nm_Label = GetStr(MSG_PROJECT_MENU);
  870.   PrefsNewMenu[1].nm_Label = GetStr(MSG_OPEN_MENU);
  871.   PrefsNewMenu[3].nm_Label = GetStr(MSG_SAVE_MENU);
  872.   PrefsNewMenu[4].nm_Label = GetStr(MSG_SAVEAS_MENU);
  873.   PrefsNewMenu[6].nm_Label = GetStr(IsFrodoSC ? MSG_ABOUTSC_MENU : MSG_ABOUT_MENU);
  874.   PrefsNewMenu[8].nm_Label = GetStr(MSG_OK_MENU);
  875.   PrefsNewMenu[9].nm_Label = GetStr(MSG_CANCEL_MENU);
  876.  
  877.   for (i=0; gadget_table[i]>=0; i+=2)
  878.     PrefsNGad[gadget_table[i]].ng_GadgetText = GetStr(gadget_table[i+1]);
  879.  
  880.   SIDType0Labels[0] = GetStr(MSG_SIDTYPEOFF_LAB);
  881.   SIDType0Labels[1] = GetStr(MSG_SIDTYPECARD_LAB);
  882.   SIDType0Labels[2] = GetStr(MSG_SIDTYPEA64_LAB);
  883.   SIDType0Labels[3] = GetStr(MSG_SIDTYPEPSID_LAB);
  884. }