home *** CD-ROM | disk | FTP | other *** search
/ Computerworld 1996 March / Computerworld_1996-03_cd.bin / idg_cd3 / grafika / fraktaly / wins1821 / winfract.c < prev    next >
C/C++ Source or Header  |  1996-02-13  |  86KB  |  2,388 lines

  1. /****************************************************************************
  2.  
  3.  
  4.     PROGRAM: winfract.c
  5.  
  6.     PURPOSE: Windows-specific main-driver code for Fractint for Windows
  7.              (look in MAINFRAC.C for the non-windows-specific code)
  8.  
  9.     Copyright (C) 1990-1993 The Stone Soup Group.  Fractint for Windows 
  10.     may be freely copied and distributed, but may not be sold.
  11.     
  12.     We are, of course, copyrighting the code we wrote to implement
  13.     Fractint-for-Windows, and not the routines we lifted directly
  14.     or indirectly from Microsoft's Windows 3.0 Software Development Kit.
  15.  
  16. ****************************************************************************/
  17.  
  18. #include "windows.h"
  19. #include "winfract.h"
  20. #include "mathtool.h"
  21. #include "fractype.h"
  22. #include "fractint.h"
  23. #include "select.h"
  24. #include <math.h>
  25. #include <stdio.h>
  26. #include <stdlib.h>
  27. #include <search.h>
  28. #include <string.h>
  29. #include <time.h>
  30. #include "profile.h"
  31.  
  32. unsigned int windows_version;        /* 0x0300 = Win 3.0, 0x030A = 3.1 */
  33.  
  34. extern LPSTR win_lpCmdLine;
  35.  
  36. HANDLE hInst;
  37.  
  38. HANDLE hAccTable;                        /* handle to accelerator table */
  39. extern BOOL ZoomBarOpen;
  40. int ZoomMode;
  41.  
  42. HWND hMainWnd, hwnd;                     /* handle to main window */
  43. HWND hWndCopy;                 /* Copy of hWnd */
  44.  
  45. char far winfract_title_text[41];    /* Winfract title-bar text */
  46.  
  47. #define PALETTESIZE 256               /* dull-normal VGA                    */
  48. HANDLE hpal;                          /* palette handle                     */
  49. PAINTSTRUCT ps;                       /* paint structure                    */
  50. HDC hDC;                              /* handle to device context           */
  51. HDC hMemoryDC;                        /* handle to memory device context    */
  52. BITMAP Bitmap;                        /* bitmap structure                   */
  53. extern time_t last_time;
  54. unsigned IconWidth, IconHeight, IconSize;
  55. HANDLE hIconBitmap;
  56.  
  57. HANDLE  hPal;          /* Handle to the application's logical palette  */
  58. HANDLE  hLogPal;       /* Temporary Handle */
  59. LPLOGPALETTE pLogPal;  /* pointer to tha application's logical palette */
  60. int     iNumColors;    /* Number of colors supported by device           */
  61. int     iRasterCaps;   /* Raster capabilities                           */
  62. int     iPalSize;      /* Size of Physical palette                       */
  63.  
  64. BOOL    win_systempaletteused = FALSE;    /* flag system palette set */
  65. extern int win_syscolorindex[21];
  66. extern DWORD win_syscolorold[21];
  67. extern DWORD win_syscolornew[21];
  68.  
  69. /* MCP 6-16-91 */
  70. extern int pixelshift_per_byte;
  71. extern long pixels_per_bytem1;        /* pixels / byte - 1 (for ANDing) */
  72. extern unsigned char win_andmask[8];
  73. extern unsigned char win_notmask[8];
  74. extern unsigned char win_bitshift[8];
  75.  
  76. extern int CoordBoxOpen;
  77. extern HWND hCoordBox;
  78. extern int TrackingZoom, Zooming, ReSizing;
  79.  
  80. #define EXE_NAME_MAX_SIZE  128
  81.  
  82. BOOL       bHelp = FALSE;      /* Help mode flag; TRUE = "ON"*/
  83. HCURSOR    hHelpCursor;        /* Cursor displayed when in help mode*/
  84. char       szHelpFileName[EXE_NAME_MAX_SIZE+1];    /* Help file name*/
  85.  
  86. extern int stopmsg(int ,CHAR far *);
  87.  
  88. void MakeHelpPathName(char*);  /* Function deriving help file path */
  89.  
  90. unsigned char far win_dacbox[256][3];
  91. extern unsigned char dacbox[256][3], olddacbox[256][3];
  92. extern int colorpreloaded;
  93. extern int  colorstate;
  94.  
  95. int win_fastupdate;                   /* 0 for "normal" fast screen updates */
  96. extern int show_orbit;
  97.  
  98. int max_colors;
  99.  
  100. BOOL bTrack = FALSE;                  /* TRUE if user is selecting a region */
  101. BOOL bMove  = FALSE;
  102. BOOL bMoving = FALSE;
  103. BOOL zoomflag = FALSE;                /* TRUE if a zoom-box selected */
  104. extern POINT DragPoint;
  105. RECT Rect;
  106.  
  107. int Shape = SL_ZOOM;            /* shape to use for the selection rectangle */
  108.  
  109. /* pointers to various dialog-box routines */
  110. FARPROC lpProcAbout;
  111. FARPROC lpSelectFractal;
  112. FARPROC lpSelectFracParams;
  113. FARPROC lpSelectImage;
  114. FARPROC lpSelectDoodads;
  115. FARPROC lpSelectExtended;
  116. FARPROC lpSelectSavePar;
  117. FARPROC lpSelectCycle;
  118. FARPROC lpProcStatus;
  119. FARPROC lpSelect3D;
  120. FARPROC lpSelect3DPlanar;
  121. FARPROC lpSelect3DSpherical;
  122. FARPROC lpSelectIFS3D;
  123. FARPROC lpSelectFunnyGlasses;
  124. FARPROC lpSelectLightSource;
  125. FARPROC lpSelectStarfield;
  126.  
  127. extern int FileFormat;
  128. extern unsigned char readname[];
  129. extern unsigned char FormFileName[];
  130. extern unsigned char DefPath[];
  131. extern unsigned char LFileName[];
  132. extern unsigned char LName[];
  133. extern char far StatusTitle[];
  134. unsigned char far DialogTitle[128];
  135. unsigned char FileName[128];
  136. unsigned char FullPathName[128];
  137. unsigned char DefSpec[13];
  138. unsigned char DefExt[10];
  139.  
  140. HBITMAP hBitmap, oldBitmap, oldoldbitmap;              /* working bitmaps */
  141.  
  142. HANDLE hDibInfo;        /* handle to the Device-independent bitmap */
  143. LPBITMAPINFO pDibInfo;        /* pointer to the DIB info */
  144. HANDLE hpixels;            /* handle to the DIB pixels */
  145. unsigned char huge *pixels;    /* the device-independent bitmap  pixels */
  146. extern int bytes_per_pixelline;    /* pixels/line / pixels/byte */
  147. extern long win_bitmapsize;     /* size of the DIB in bytes */
  148. extern    int    resave_flag;    /* resaving after a timed save */
  149. extern    char overwrite;     /* overwrite on/off */
  150.  
  151. HANDLE hClipboard1, hClipboard2, hClipboard3; /* handles to clipboard info */
  152. LPSTR lpClipboard1, lpClipboard2;            /* pointers to clipboard info */
  153.  
  154. int last_written_y = -2;        /* last line written */
  155. int screen_to_be_cleared = 1;    /* flag that the screen is to be cleared */
  156. int time_to_act = 0;        /* time to take some sort of action? */
  157. int time_to_restart = 0;        /* time to restart?  */
  158. int time_to_reinit = 0;         /* time to reinitialize?  */
  159. int time_to_resume = 0;        /* time to resume? */
  160. int time_to_quit = 0;           /* time to quit? */
  161. int time_to_save = 0;        /* time to save the file? */
  162. int time_to_print = 0;        /* time to print the file? */
  163. int time_to_load = 0;        /* time to load a new file? */
  164. int time_to_cycle = 0;          /* time to begin color-cycling? */
  165. int time_to_starfield = 0;      /* time to make a starfield? */
  166. int time_to_orbit = 0;          /* time to activate orbits? */
  167.  
  168. int win_3dspherical = 0;          /* spherical 3D? */
  169. int win_display3d, win_overlay3d; /* 3D flags */
  170. extern    int    init3d[20];    /* '3d=nn/nn/nn/...' values */
  171. extern    int RAY;
  172.  
  173. extern int win_cycledir, win_cyclerand, win_cycledelay;
  174.  
  175. extern int calc_status;
  176. extern int julibrot;
  177.  
  178. int xdots, ydots, colors, maxiter;
  179. int ytop, ybottom, xleft, xright;
  180. int xposition, yposition, win_xoffset, win_yoffset, xpagesize, ypagesize;
  181. int win_xdots, win_ydots;
  182. extern int fractype;
  183. extern double param[4];
  184. extern double xxmin, xxmax, yymin, yymax, xx3rd, yy3rd;
  185. double jxxmin, jxxmax, jyymin, jyymax, jxx3rd, jyy3rd;
  186. extern int frommandel, bitshift, biomorph;
  187. extern int maxit;
  188.  
  189. int cpu, fpu;            /* cpu, fpu flags */
  190.  
  191. extern int win_release;
  192.  
  193. char *win_choices[100];
  194. int win_numchoices, win_choicemade;
  195.  
  196. extern int onthelist[];
  197. extern int CountFractalList;
  198. extern int CurrentFractal;
  199. int MaxFormNameChoices = 80;
  200. char FormNameChoices[80][25];
  201. extern char FormName[30];
  202. extern char    IFSFileName[];    /* IFS code file */
  203. extern char    IFSName[];        /* IFS code item */
  204. double far *temp_array;
  205. HANDLE htemp_array;
  206.  
  207. HANDLE hSaveCursor;             /* the original cursor value */
  208. HANDLE hHourGlass;              /* the hourglass cursor value */
  209.  
  210. BOOL winfract_menustyle = FALSE;/* Menu style:
  211.                    FALSE = Winfract-style,
  212.                    TRUE  = Fractint-style */
  213.  
  214. /* far strings (near space is precious) */
  215. char far winfract_msg01[] = "Fractint For Windows";
  216. char far winfract_msg02[] = "WinFracMenu";
  217. char far winfract_msg03[] = "FractintForWindowsV0010";
  218. char far winfract_msg04[] = "WinfractAcc";
  219. char far winfract_msg96[] = "I'm sorry, but color-cycling \nrequires a palette-based\nvideo driver";
  220. char far winfract_msg97[] = "There isn't enough available\nmemory to run Winfract";
  221. char far winfract_msg98[] =  "This program requires Standard\nor 386-Enhanced Mode";
  222. char far winfract_msg99[] = "Not Enough Free Memory to Copy to the Clipboard";
  223.  
  224.  
  225. int PASCAL WinMain(hInstance, hPrevInstance, lpCmdLine, nCmdShow)
  226. HANDLE hInstance;
  227. HANDLE hPrevInstance;
  228. LPSTR lpCmdLine;
  229. int nCmdShow;
  230. {
  231.     win_lpCmdLine = lpCmdLine;
  232.  
  233.     if (!hPrevInstance)
  234.         if (!InitApplication(hInstance))
  235.             return (FALSE);
  236.  
  237.     if (!InitInstance(hInstance, nCmdShow))
  238.         return (FALSE);
  239.  
  240.     fractint_main();            /* fire up the main Fractint code */
  241.     if(htemp_array) {
  242.         GlobalUnlock(htemp_array);
  243.         GlobalFree(htemp_array);
  244.     }
  245.     
  246.     wintext_destroy();        /* destroy the text window */
  247.  
  248.     DestroyWindow(hWndCopy);    /* stop everything when it returns */
  249.  
  250.     return(0);                  /* we done when 'fractint_main' returns */
  251. }
  252.  
  253.  
  254. BOOL InitApplication(hInstance)
  255. HANDLE hInstance;
  256. {
  257.     WNDCLASS  wc;
  258.  
  259.     wc.style = CS_VREDRAW | CS_HREDRAW | CS_DBLCLKS;
  260.     wc.lpfnWndProc = MainWndProc;
  261.     wc.cbClsExtra = 0;
  262.     wc.cbWndExtra = 0;
  263.     wc.hInstance = hInstance;
  264.     wc.hIcon = NULL;
  265.     wc.hCursor = LoadCursor(NULL, IDC_ARROW);
  266.     wc.hbrBackground = GetStockObject(BLACK_BRUSH);
  267.     wc.lpszMenuName =  winfract_msg02;
  268.     wc.lpszClassName = winfract_msg03;
  269.  
  270.     return(RegisterClass(&wc) && RegisterMathWindows(hInstance));
  271. }
  272.  
  273.  
  274. BOOL InitInstance(hInstance, nCmdShow)
  275.     HANDLE          hInstance;
  276.     int             nCmdShow;
  277. {
  278.     DWORD WinFlags;
  279.     unsigned int version, i;
  280.     int iLoop, jLoop;
  281.     DWORD ThisColor;
  282.  
  283.     float temp;
  284.  
  285.     /* so, what kind of a computer are we on, anyway? */
  286.     WinFlags = GetWinFlags();
  287.     cpu = 88;                             /* determine the CPU type */
  288.     if (WinFlags & WF_CPU186) cpu = 186;
  289.     if (WinFlags & WF_CPU286) cpu = 286;
  290.     if (WinFlags & WF_CPU386) cpu = 386;
  291.     if (WinFlags & WF_CPU486) cpu = 386;
  292.     fpu = 0;                              /* determine the FPU type */
  293.     if (WinFlags & WF_80x87)  fpu = 87;
  294.     if (fpu && (cpu == 386))  fpu = 387;
  295.  
  296.     version = LOWORD(GetVersion());    /* which version of Windows is it? */
  297.     windows_version = ((LOBYTE(version) << 8) | HIBYTE(version));
  298.  
  299.     hInst = hInstance;
  300.  
  301.     hAccTable = LoadAccelerators(hInst, winfract_msg04);
  302.  
  303.     win_set_title_text();
  304.  
  305.     hMainWnd = hwnd = CreateWindow(
  306.         winfract_msg03,
  307.         winfract_title_text,
  308.         WS_OVERLAPPEDWINDOW | WS_HSCROLL | WS_VSCROLL,
  309.         140, 100,  /* initial locn instead of CW_USEDEFAULT, CW_USEDEFAULT, */
  310.         360, 280,  /* initial size instead of CW_USEDEFAULT, CW_USEDEFAULT, */
  311.         NULL,
  312.         NULL,
  313.         hInstance,
  314.         NULL
  315.     );
  316.  
  317.     if (!hwnd) {  /* ?? can't create the initial window! */
  318.         return (FALSE);
  319.         }
  320.  
  321.     wintext_initialize(
  322.         (HANDLE) hInstance,
  323.         (HWND) hwnd,
  324.         (LPSTR) winfract_title_text);
  325.  
  326.     /* This program doesn't run in "real" mode, so shut down right
  327.        now to keep from mucking up Windows */
  328.     if (!((WinFlags & WF_STANDARD) || (WinFlags & WF_ENHANCED))) {
  329.         MessageBox (
  330.             GetFocus(),
  331.             winfract_msg98,
  332.             winfract_msg01,
  333.             MB_ICONSTOP | MB_OK);
  334.         return(FALSE);
  335.         }
  336.     
  337.     win_xdots = xdots;
  338.     win_ydots = ydots;
  339.     maxiter = 150;                   /* and a few iterations */
  340.     xposition = yposition = 0;       /* dummy up a few pointers */
  341.     xpagesize = ypagesize = 2000;
  342.     set_win_offset();
  343.  
  344.     SizeWindow(hwnd);
  345.     ShowWindow(hwnd, nCmdShow);
  346.     UpdateWindow(hwnd);
  347.  
  348.     /* let's ensure that we have at lease 40K of free memory */
  349.     {
  350.     HANDLE temphandle;
  351.     if (!(temphandle = GlobalAlloc(GMEM_FIXED,40000L)) ||
  352.         !(htemp_array = GlobalAlloc(GMEM_FIXED, 5L * sizeof(double) * MAXPIXELS))) {
  353.         MessageBox (
  354.             GetFocus(),
  355.             winfract_msg97,
  356.             winfract_msg01,
  357.             MB_ICONSTOP | MB_OK);
  358.         return(FALSE);
  359.         }
  360.         GlobalLock(temphandle);
  361.         GlobalUnlock(temphandle);
  362.         GlobalFree(temphandle);
  363.         temp_array = (double far *)GlobalLock(htemp_array);
  364.     }
  365.  
  366.    MakeHelpPathName(szHelpFileName);
  367.  
  368.     /* so, what kind of a display are we using, anyway? */
  369.     hDC = GetDC(NULL);
  370.     iPalSize    = GetDeviceCaps (hDC, SIZEPALETTE);
  371.     iRasterCaps = GetDeviceCaps (hDC, RASTERCAPS);
  372.     iRasterCaps = (iRasterCaps & RC_PALETTE) ? TRUE : FALSE;
  373.     if (iRasterCaps)
  374.        iNumColors = GetDeviceCaps(hDC, SIZEPALETTE);
  375.     else
  376.        iNumColors = GetDeviceCaps(hDC, NUMCOLORS);
  377.     ReleaseDC(NULL,hDC);
  378.  
  379.     /* fudges for oddball stuff (is there any?) */
  380.     /* also, note that "true color" devices return -1 for NUMCOLORS */
  381.     colors = iNumColors;
  382.     if (colors < 2 || colors > 16) colors = 256;
  383.     if (colors > 2 && colors < 16) colors = 16;
  384.     /* adjust for Windows' 20 reserved palettes in 256-color mode */
  385.     max_colors = 256;
  386.     if (colors == 256  && iNumColors >= 0) max_colors = 236;
  387.  
  388.      /* Allocate enough memory for a logical palette with
  389.       * PALETTESIZE entries and set the size and version fields
  390.       * of the logical palette structure.
  391.       */
  392.      if (!(hLogPal = GlobalAlloc (GMEM_FIXED,
  393.         (sizeof (LOGPALETTE) +
  394.         (sizeof (PALETTEENTRY) * (PALETTESIZE)))))) {
  395.         MessageBox (
  396.             GetFocus(),
  397.             winfract_msg97,
  398.             winfract_msg01,
  399.             MB_ICONSTOP | MB_OK);
  400.         return(FALSE);
  401.           }
  402.     pLogPal = (LPLOGPALETTE)GlobalLock(hLogPal); 
  403.     pLogPal->palVersion    = 0x300;
  404.     pLogPal->palNumEntries = PALETTESIZE;
  405.     /* fill in intensities for all palette entry colors */
  406.     for (iLoop = 0; iLoop < PALETTESIZE; iLoop++) {
  407.         pLogPal->palPalEntry[iLoop].peRed   = iLoop;
  408.         pLogPal->palPalEntry[iLoop].peGreen = 0;
  409.         pLogPal->palPalEntry[iLoop].peBlue  = 0;
  410.         pLogPal->palPalEntry[iLoop].peFlags = PC_EXPLICIT;
  411.         }
  412.     /* flip the ugly red color #1 with the pretty blue color #4 */
  413. /*
  414.     if (iNumColors < 0 || iNumColors > 4) {
  415.         pLogPal->palPalEntry[1].peRed = 4;
  416.         pLogPal->palPalEntry[4].peRed = 1;
  417.         }
  418. */
  419.     /*  create a logical color palette according the information
  420.         in the LOGPALETTE structure. */
  421.     hDC = GetDC(GetFocus());
  422.     SetMapMode(hDC,MM_TEXT);
  423.     hPal = CreatePalette ((LPLOGPALETTE) pLogPal) ;
  424.     ReleaseDC(GetFocus(),hDC);
  425.  
  426.     /* allocate a device-independent bitmap header */
  427.     if (!(hDibInfo = GlobalAlloc(GMEM_FIXED,
  428.         sizeof(BITMAPINFOHEADER)+256*sizeof(PALETTEENTRY)))) {
  429.         MessageBox (
  430.             GetFocus(),
  431.             winfract_msg97,
  432.             winfract_msg01,
  433.             MB_ICONSTOP | MB_OK);
  434.         return(FALSE);
  435.         }
  436.     pDibInfo = (LPBITMAPINFO)GlobalLock(hDibInfo);
  437.     /* fill in the header */
  438.     pDibInfo->bmiHeader.biSize  = (long)sizeof(BITMAPINFOHEADER);
  439.     pDibInfo->bmiHeader.biWidth  = win_xdots;
  440.     pDibInfo->bmiHeader.biHeight = win_ydots;
  441.     pDibInfo->bmiHeader.biSizeImage = (DWORD)win_xdots * win_ydots;
  442.     pDibInfo->bmiHeader.biPlanes = 1;
  443.     pDibInfo->bmiHeader.biBitCount = 8;
  444.     pDibInfo->bmiHeader.biCompression = BI_RGB;
  445.     pDibInfo->bmiHeader.biXPelsPerMeter = 0L;
  446.     pDibInfo->bmiHeader.biYPelsPerMeter = 0L;
  447.     pDibInfo->bmiHeader.biClrUsed = 0L;
  448.     pDibInfo->bmiHeader.biClrImportant = 0L;
  449.     default_dib_palette();
  450.  
  451.     IconWidth = GetSystemMetrics(SM_CXICON);
  452.     IconHeight = GetSystemMetrics(SM_CYICON);
  453.     IconSize = (IconWidth * IconHeight) >> pixelshift_per_byte;
  454.     hIconBitmap = GlobalAlloc(GMEM_MOVEABLE, IconSize);
  455.  
  456.     /* initialize our delay counter */
  457.     CalibrateDelay();
  458.     win_cycledelay = 15;
  459.  
  460.     /* obtain an hourglass cursor */
  461.     hHourGlass  = LoadCursor(NULL, IDC_WAIT);
  462.     hSaveCursor = LoadCursor(NULL, IDC_ARROW);
  463.  
  464.     /* allocate and lock a pixel array for the initial bitmap */
  465.     hpixels = (HANDLE) 0;
  466.     pixels = (char huge *) NULL;
  467.     if (hIconBitmap && clear_screen(0))
  468.         return(TRUE);
  469.  
  470.     MessageBox (
  471.         GetFocus(),
  472.         winfract_msg97,
  473.         winfract_msg01,
  474.          MB_ICONSTOP | MB_OK);
  475.  
  476.     return (FALSE);
  477.  
  478. }
  479.  
  480. void lmemcpy(char huge *to, char huge *from, long len)
  481. {
  482. long i;
  483.  
  484. for (i = 0; i < len; i++)
  485.   to[i] = from[i];
  486. }
  487.  
  488. HWND SecondaryhWnd;
  489. unsigned Secondarymessage;
  490. WORD SecondarywParam;
  491. LONG SecondarylParam;
  492.  
  493.  
  494. long FAR PASCAL MainWndProc(hWnd, message, wParam, lParam)
  495. HWND hWnd;                /* handle to main window */
  496. unsigned message;
  497. WORD wParam;
  498. LONG lParam;
  499. {
  500.  
  501.     RECT tempRect;
  502.     HMENU hMenu;
  503.  
  504.     int Return;
  505.     int i, fchoice;
  506.     extern char FractintMenusStr[];
  507.     extern char FractintPixelsStr[];
  508.  
  509.     switch (message) {
  510.  
  511.         case WM_INITMENU:
  512.            if (!iRasterCaps || iNumColors < 16) {
  513.                EnableMenuItem(GetMenu(hWnd), IDM_CYCLE, MF_DISABLED | MF_GRAYED);
  514.                }
  515.            hMenu = GetMenu(hWnd);
  516.            if (winfract_menustyle) {
  517.                CheckMenuItem(hMenu, IDF_FRACTINTSTYLE, MF_CHECKED);
  518.                CheckMenuItem(hMenu, IDF_WINFRACTSTYLE, MF_UNCHECKED);
  519.                }
  520.            else {
  521.                CheckMenuItem(hMenu, IDF_FRACTINTSTYLE, MF_UNCHECKED);
  522.                CheckMenuItem(hMenu, IDF_WINFRACTSTYLE, MF_CHECKED);
  523.                }
  524.            if (win_fastupdate)
  525.                CheckMenuItem(hMenu, IDM_PIXELS, MF_CHECKED);
  526.            else
  527.                CheckMenuItem(hMenu, IDM_PIXELS, MF_UNCHECKED);
  528.            hWndCopy = hWnd;
  529.            return (TRUE);
  530.  
  531.         case WM_LBUTTONDBLCLK:
  532.             if(Zooming) {
  533.                win_savedac();
  534.                ExecuteZoom();
  535.                }
  536.             if (bMove) {
  537.                DragPoint = MAKEPOINT(lParam);
  538.         ExecZoom:
  539.                /* End the selection */
  540.                EndSelection(DragPoint, &Rect);
  541.                ClearSelection(hWnd, &Rect, Shape);
  542.            win_title_text(-1);
  543.  
  544.                if(PtInRect(&Rect, DragPoint)) {
  545.                   if (abs(Rect.bottom - Rect.top ) > 5 &&
  546.                       abs(Rect.right  - Rect.left) > 5) {
  547.                         double xd, yd, z;
  548.                         extern POINT Center, ZoomDim;
  549.                         extern double delxx, delyy;
  550.         
  551.             z = (double)(ZoomDim.x << 1) / xdots;
  552.             if(ZoomMode == IDM_ZOOMOUT) {
  553.                 z = 1.0 / z;
  554.                 xd = (xxmin + xxmax) / 2 - (delxx * z * (Center.x + win_xoffset - (xdots/2)));
  555.                 yd = (yymin + yymax) / 2 + (delxx * z * (Center.y + win_yoffset - (ydots/2)));
  556.                 }
  557.             else {
  558.                 xd = xxmin + (delxx * (Center.x + win_xoffset));  /* BDT 11/6/91 */
  559.                 yd = yymax - (delyy * (Center.y + win_yoffset));  /* BDT 11/6/91 */
  560.                 }
  561.             xxmin = xd - (delxx * z * (xdots / 2));
  562.             xxmax = xd + (delxx * z * (xdots / 2));
  563.             yymin = yd - (delyy * z * (ydots / 2));
  564.             yymax = yd + (delyy * z * (ydots / 2));
  565.             }
  566.  
  567.                       zoomflag = TRUE;
  568.                       win_savedac();
  569.                       time_to_restart = 1;
  570.                       time_to_cycle = 0;
  571.                       calc_status = 0;
  572.                   }
  573.  
  574.                   bMove = FALSE;
  575.                   bMoving = FALSE;
  576.                   bTrack = FALSE;
  577.                }
  578.  
  579.             break;
  580.  
  581.         case WM_LBUTTONDOWN:           /* message: left mouse button pressed */
  582.  
  583.             /* Start selection of region */
  584.  
  585.             if(bMove)
  586.             {
  587.                DragPoint = MAKEPOINT(lParam);
  588.                bMoving   = PtInRect(&Rect, DragPoint);
  589.                if(bMoving)
  590.                   SetCapture(hWnd);
  591.             }
  592.             else if(Zooming)
  593.                StartZoomTracking(lParam);
  594.             else if(ZoomMode == IDM_ZOOMIN || ZoomMode == IDM_ZOOMOUT)
  595.             {
  596.            win_title_text(3);
  597.                bTrack = TRUE;
  598.                bMoving = FALSE;
  599.                bMove = FALSE;
  600.                SetRectEmpty(&Rect);
  601.                StartSelection(hWnd, MAKEPOINT(lParam), &Rect,
  602.                    (wParam & MK_SHIFT) ? (SL_EXTEND | Shape) : Shape);
  603.             }
  604.             break;
  605.  
  606.         case WM_MOUSEMOVE:                        /* message: mouse movement */
  607.  
  608.             /* Update the selection region */
  609.  
  610.             if (bTrack || bMoving)
  611.                 UpdateSelection(hWnd, MAKEPOINT(lParam), &Rect, Shape);
  612.             if(CoordBoxOpen)
  613.                 UpdateCoordBox(lParam);
  614.             if(TrackingZoom)
  615.                TrackZoom(lParam);
  616.             break;
  617.  
  618.         case WM_LBUTTONUP:            /* message: left mouse button released */
  619.  
  620.             if(bTrack)
  621.             {
  622.                bTrack = FALSE;
  623.                bMove = TRUE;
  624.                ReleaseCapture();
  625.                if (abs(Rect.bottom - Rect.top ) <= 5 ||
  626.                    abs(Rect.right  - Rect.left) <= 5) {
  627.                    /* Zoom Box is too small - kill it off */
  628.                    ClearSelection(hWnd, &Rect, Shape);
  629.                win_title_text(-1);
  630.                    bMove = bMoving = bTrack = FALSE;
  631.                    }
  632.             }
  633.             else if(bMoving)
  634.             {
  635.                bMoving = FALSE;
  636.                ReleaseCapture();
  637.             }
  638.             else if(TrackingZoom)
  639.                EndZoom(lParam);
  640.             break;
  641.  
  642.         case WM_RBUTTONUP:
  643.             {
  644.             int xx, yy;
  645.             win_kill_all_zooming();
  646.             xx = LOWORD(lParam);
  647.             yy = HIWORD(lParam);
  648.             xx += win_xoffset;
  649.             yy += win_yoffset;
  650.             if (xx >= xdots || yy >= ydots) 
  651.                 break;
  652.             if (fractalspecific[fractype].tojulia != NOFRACTAL
  653.                 && param[0] == 0.0 && param[1] == 0.0) {
  654.                 /* switch to corresponding Julia set */
  655.                 fractype = fractalspecific[fractype].tojulia;
  656.                 curfractalspecific = &fractalspecific[fractype];
  657.                 param[0] = xxmin + (xxmax - xxmin) * xx / xdots;
  658.                 param[1] = yymax - (yymax - yymin) * yy / ydots;
  659.                 jxxmin = xxmin; jxxmax = xxmax;
  660.                 jyymax = yymax; jyymin = yymin;
  661.                 jxx3rd = xx3rd; jyy3rd = yy3rd;
  662.                 frommandel = 1;
  663.                 xxmin = fractalspecific[fractype].xmin;
  664.                 xxmax = fractalspecific[fractype].xmax;
  665.                 yymin = fractalspecific[fractype].ymin;
  666.                 yymax = fractalspecific[fractype].ymax;
  667.                 xx3rd = xxmin;
  668.                 yy3rd = yymin;
  669.                 if(biomorph != -1 && bitshift != 29) {
  670.                    xxmin *= 3.0;
  671.                    xxmax *= 3.0;
  672.                    yymin *= 3.0;
  673.                    yymax *= 3.0;
  674.                    xx3rd *= 3.0;
  675.                    yy3rd *= 3.0;
  676.                    }
  677.                 calc_status = 0;
  678.                 }
  679.             else if (fractalspecific[fractype].tomandel != NOFRACTAL) {
  680.                 /* switch to corresponding Mandel set */
  681.                 fractype = fractalspecific[fractype].tomandel;
  682.                 curfractalspecific = &fractalspecific[fractype];
  683.                 if (frommandel) {
  684.                     xxmin = jxxmin;  xxmax = jxxmax;
  685.                     yymin = jyymin;  yymax = jyymax;
  686.                     xx3rd = jxx3rd;  yy3rd = jyy3rd;
  687.                     }
  688.                 else {
  689.                     double ccreal,ccimag;
  690.                     ccreal = (fractalspecific[fractype].xmax - fractalspecific[fractype].xmin) / 2;
  691.                     ccimag = (fractalspecific[fractype].ymax - fractalspecific[fractype].ymin) / 2;
  692.                     xxmin = xx3rd = param[0] - ccreal;
  693.                     xxmax = param[0] + ccreal;
  694.                     yymin = yy3rd = param[1] - ccimag;
  695.                     yymax = param[1] + ccimag;
  696.                     }
  697.                 frommandel = 0;
  698.                 param[0] = 0;
  699.                 param[1] = 0;
  700.                 calc_status = 0;
  701.                 }
  702.             else {
  703.                 buzzer(2); /* can't switch */
  704.                 break;
  705.                 }
  706.  
  707.             ytop    = 0;
  708.             ybottom = ydots-1;
  709.             xleft   = 0;
  710.             xright  = xdots-1;
  711.  
  712.             time_to_restart  = 1;
  713.             time_to_cycle = 0;
  714.             calc_status = 0;
  715.             }
  716.             break;
  717.  
  718.         case WM_CREATE:
  719.  
  720.             /* the scroll bars are hard-coded to 100 possible values */
  721.             xposition = yposition = 0;      /* initial scroll-bar positions */
  722.             SetScrollRange(hWnd,SB_HORZ,0,100,FALSE);
  723.             SetScrollRange(hWnd,SB_VERT,0,100,FALSE);
  724.             SetScrollPos(hWnd,SB_HORZ,xposition,TRUE);
  725.             SetScrollPos(hWnd,SB_VERT,yposition,TRUE);
  726.             InitializeParameters(hWnd);
  727.             break;
  728.  
  729.         case WM_SIZE:
  730.             win_kill_all_zooming();
  731.             xpagesize = LOWORD(lParam);        /* remember the window size */
  732.             ypagesize = HIWORD(lParam);
  733.         set_win_offset();
  734.             if(!ReSizing && !IsIconic(hWnd))
  735.            ReSizeWindow(hWnd);
  736.             break;
  737.  
  738.         case WM_MOVE:
  739.             SaveWindowPosition(hWnd, WinfractPosStr);
  740.             break;
  741.  
  742.         case WM_HSCROLL:
  743.             win_kill_all_zooming();
  744.             switch (wParam) {
  745.                case SB_LINEDOWN:       xposition += 1; break;
  746.                case SB_LINEUP:         xposition -= 1; break;
  747.                case SB_PAGEDOWN:       xposition += 10; break;
  748.                case SB_PAGEUP:         xposition -= 10; break;
  749.                case SB_THUMBPOSITION:  xposition = LOWORD(lParam);
  750.                default:                break;
  751.                }
  752.             if (xposition > 100) xposition = 100;
  753.             if (xposition <     0) xposition = 0;
  754.             if (xposition != GetScrollPos(hWnd,SB_HORZ)) {
  755.                SetScrollPos(hWnd,SB_HORZ,xposition,TRUE);
  756.                InvalidateRect(hWnd,NULL,TRUE);
  757.                }
  758.             set_win_offset();
  759.            break;
  760.         case WM_VSCROLL:
  761.             win_kill_all_zooming();
  762.             switch (wParam) {
  763.                case SB_LINEDOWN:       yposition += 1; break;
  764.                case SB_LINEUP:         yposition -= 1; break;
  765.                case SB_PAGEDOWN:       yposition += 10; break;
  766.                case SB_PAGEUP:         yposition -= 10; break;
  767.                case SB_THUMBPOSITION:  yposition = LOWORD(lParam);
  768.                default:                break;
  769.                }
  770.             if (yposition > 100) yposition = 100;
  771.             if (yposition <     0) yposition = 0;
  772.             if (yposition != GetScrollPos(hWnd,SB_VERT)) {
  773.                SetScrollPos(hWnd,SB_VERT,yposition,TRUE);
  774.                InvalidateRect(hWnd,NULL,TRUE);
  775.                }
  776.             set_win_offset();
  777.             break;
  778.  
  779.         case WM_CLOSE:
  780.             message = WM_COMMAND;
  781.             wParam  = IDM_EXIT;
  782.             goto GlobalExit;
  783.  
  784.         case WM_PAINT:
  785.             if (screen_to_be_cleared && last_written_y < 0) {
  786.                  /* an empty window */
  787.                  screen_to_be_cleared = 0;
  788.                  GetUpdateRect(hWnd, &tempRect, TRUE);
  789.                  hDC = BeginPaint(hWnd,&ps);
  790.                  if (last_written_y == -2)
  791.                      last_written_y = -1;
  792.                  else
  793.                      BitBlt(hDC, 0, 0, xdots, ydots,
  794.                          NULL, 0, 0, BLACKNESS);
  795.                  ValidateRect(hWnd, &tempRect);
  796.                  EndPaint(hWnd,&ps);
  797.                  break;
  798.                  }
  799.             if(IsIconic(hWnd)) {
  800.                int x, y;
  801.                LPSTR icon;
  802.                long lx, ly, dlx, dly;
  803.                DWORD tSize, tWidth, tHeight;
  804.  
  805.                if((icon = GlobalLock(hIconBitmap)) == NULL)
  806.                   break;
  807.  
  808.                dlx = ((long)xdots << 8) / IconWidth;
  809.                dly = ((long)ydots << 8) / IconHeight;
  810.                for(ly = y = 0; y < IconHeight; y++, ly += dly)
  811.                {
  812.                   for(lx = x = 0; x < IconWidth; x++, lx += dlx)
  813.                   {
  814.                      unsigned ix, iy;
  815.                      unsigned char color;
  816.  
  817.                      ix = lx >> 8;
  818.                      iy = ly >> 8;
  819.                      color = getcolor(ix, iy);
  820.  
  821.                      ix = IconWidth - y - 1;
  822.                      ix = (ix * IconWidth) + x;
  823.                      iy = ix & pixels_per_bytem1;
  824.                      ix = ix >> pixelshift_per_byte;
  825.                      icon[ix] = (icon[ix] & win_notmask[iy]) +
  826.                                (color << win_bitshift[iy]);
  827.                   }
  828.                }
  829.  
  830.                hDC = BeginPaint(hWnd, &ps);
  831.  
  832.                SelectPalette (hDC, hPal, 0);
  833.                RealizePalette(hDC);
  834.  
  835.                tSize   = pDibInfo->bmiHeader.biSizeImage;
  836.                tHeight = pDibInfo->bmiHeader.biHeight;
  837.                tWidth  = pDibInfo->bmiHeader.biWidth;
  838.  
  839.                pDibInfo->bmiHeader.biSizeImage = IconSize;
  840.                pDibInfo->bmiHeader.biHeight    = IconHeight;
  841.                pDibInfo->bmiHeader.biWidth     = IconWidth;
  842.  
  843.                SetDIBitsToDevice(hDC,
  844.                        2, 2,
  845.                        IconWidth, IconHeight,
  846.                        0, 0,
  847.                        0, IconHeight,
  848.                        icon, (LPBITMAPINFO)pDibInfo,
  849.                        DIB_PAL_COLORS);
  850.  
  851.                pDibInfo->bmiHeader.biSizeImage = tSize;
  852.                pDibInfo->bmiHeader.biHeight    = tHeight;
  853.                pDibInfo->bmiHeader.biWidth     = tWidth;
  854.  
  855.                GlobalUnlock(hIconBitmap);
  856.  
  857.                EndPaint(hWnd, &ps);
  858.                break;
  859.             }
  860.             screen_to_be_cleared = 0;
  861.             GetUpdateRect(hWnd, &tempRect, FALSE);
  862.             if (Zooming)
  863.                 PaintMathTools();
  864.             if (bTrack || bMove || bMoving)
  865.                 UpdateSelection(hWnd, DragPoint, &Rect, Shape);
  866.             hDC = BeginPaint(hWnd,&ps);
  867.             if (last_written_y >= 0) {
  868.               int top, bottom, left, right, xcount, ycount;
  869.               /* bit-blit the invalidated bitmap area */
  870.               int fromleft, fromtop, fromright, frombottom;
  871.               long firstpixel;
  872.               top    = tempRect.top;
  873.               bottom = tempRect.bottom;
  874.               left   = tempRect.left;
  875.               right  = tempRect.right;
  876.               if (bottom >  ydots) bottom = ydots;
  877.               if (right  >= xdots) right  = xdots-1;
  878.               if (top    >  ydots) top    = ydots;
  879.               if (left   >= xdots) left   = xdots;
  880.               xcount = right  - left + 1;
  881.               ycount = bottom - top;
  882.               fromleft  = left  + win_xoffset;
  883.               fromtop   = win_ydots - bottom - win_yoffset;
  884.               if (left < xdots && top < ydots) {
  885.                   SelectPalette (hDC, hPal, 0);
  886.                   RealizePalette(hDC);
  887.                   SetMapMode(hDC,MM_TEXT);
  888.                   SetDIBitsToDevice(hDC,
  889.                        left, top,
  890.                        xcount, ycount,
  891.                        fromleft, fromtop,
  892.                        0, ydots,
  893.                        (LPSTR)pixels, (LPBITMAPINFO)pDibInfo,
  894.                        DIB_PAL_COLORS);
  895.                   }
  896.               }
  897.             ValidateRect(hWnd, &tempRect);
  898.             EndPaint(hWnd,&ps);
  899.             if (bTrack || bMove || bMoving)
  900.                 UpdateSelection(hWnd, DragPoint, &Rect, Shape);
  901.             if (Zooming)
  902.                 PaintMathTools();
  903.             last_time = time(NULL);  /* reset the "end-paint" time */
  904.             break;
  905.  
  906.         case WM_DESTROY:
  907.             win_kill_all_zooming();
  908.             if (win_systempaletteused)
  909.                 win_stop_cycling();
  910.             SaveParameters(hWnd);
  911.             /* delete the handle to the logical palette if it has any
  912.                color entries and quit. */
  913.             if (pLogPal->palNumEntries)
  914.                 DeleteObject (hPal);
  915.             time_to_quit = 1;
  916.             time_to_cycle = 0;
  917.             WinHelp(hWnd,szHelpFileName,HELP_QUIT,0L);
  918.             GlobalFree(hIconBitmap);
  919.             PostQuitMessage(0);
  920.             hWndCopy = hWnd;
  921.             break;
  922.  
  923.         case WM_ACTIVATE:
  924.             if (!wParam) {  /* app. is being de-activated */
  925.                 if (win_systempaletteused)
  926.                     win_stop_cycling();
  927.                 break;
  928.                 }
  929.  
  930.         case WM_QUERYNEWPALETTE:
  931.             /* If palette realization causes a palette change,
  932.              * we need to do a full redraw.
  933.              */
  934.              if (last_written_y >= 0) {
  935.                  hDC = GetDC (hWnd);
  936.                  SelectPalette (hDC, hPal, 0);
  937.                  i = RealizePalette(hDC);
  938.                  ReleaseDC (hWnd, hDC);
  939.                  if (i) {
  940.                      InvalidateRect (hWnd, (LPRECT) (NULL), 1);
  941.                      return 1;
  942.                      }
  943.                  else
  944.                      return FALSE;
  945.                  }
  946.              else
  947.                  return FALSE;
  948.  
  949.         case WM_PALETTECHANGED:
  950.             if (wParam != hWnd){
  951.                 if (last_written_y >= 0) {
  952.                     hDC = GetDC (hWnd);
  953.                     SelectPalette (hDC, hPal, 0);
  954.                     i = RealizePalette (hDC);
  955.                     if (i)
  956.                         UpdateColors (hDC);
  957.                     else
  958.                         InvalidateRect (hWnd, (LPRECT) (NULL), 1);
  959.                     ReleaseDC (hWnd, hDC);
  960.                     }
  961.                 }
  962.             break;
  963.  
  964.         case WM_COMMAND:
  965.  
  966. GlobalExit:            
  967.             switch (wParam) {
  968.  
  969.               /* Help menu items */
  970.  
  971.                case IDM_HELP_INDEX:
  972.                case IDF_HELP_INDEX:
  973.                    WinHelp(hWnd,szHelpFileName,HELP_INDEX,0L);
  974.                    break;
  975.  
  976.                case IDM_HELP_FRACTINT:
  977.                case IDF_HELP_FRACTINT:
  978.                    fractint_help();
  979.                    break;
  980.  
  981.                case IDM_HELP_KEYBOARD:
  982.            WinHelp(hWnd,szHelpFileName,HELP_KEY,(DWORD)(LPSTR)"keys");
  983.                    break;
  984.  
  985.                case IDM_HELP_HELP:
  986.            WinHelp(hWnd,"WINHELP.HLP",HELP_INDEX,0L);
  987.                    break;
  988.  
  989.                 case IDM_ABOUT:
  990.                     lpProcAbout = MakeProcInstance(About, hInst);
  991.                     DialogBox(hInst, "AboutBox", hWnd, lpProcAbout);
  992.                     FreeProcInstance(lpProcAbout);
  993.                     break;
  994.  
  995.                 /* View menu items */
  996.  
  997.                 case IDF_STATUS:
  998.                     if (winfract_menustyle) {    /* Fractint prompts */
  999.                         tab_display();
  1000.                         break;
  1001.                         }
  1002.                 case IDS_STATUS:
  1003.                     lpProcStatus = MakeProcInstance(Status, hInst);
  1004.                     DialogBox(hInst, "ShowStatus", hWnd, lpProcStatus);
  1005.                     FreeProcInstance(lpProcStatus);
  1006.                     break;
  1007.             
  1008.                 case IDF_FRACTINTSTYLE:
  1009.                     winfract_menustyle = TRUE;
  1010.             hMenu = GetMenu(hWnd);
  1011.             CheckMenuItem(hMenu, IDF_FRACTINTSTYLE, MF_CHECKED);
  1012.             CheckMenuItem(hMenu, IDF_WINFRACTSTYLE, MF_UNCHECKED);
  1013.                     SaveParamSwitch(FractintMenusStr, winfract_menustyle);
  1014.                     break;
  1015.             
  1016.                 case IDF_WINFRACTSTYLE:
  1017.                     winfract_menustyle = FALSE;
  1018.             hMenu = GetMenu(hWnd);
  1019.             CheckMenuItem(hMenu, IDF_FRACTINTSTYLE, MF_UNCHECKED);
  1020.             CheckMenuItem(hMenu, IDF_WINFRACTSTYLE, MF_CHECKED);
  1021.                     SaveParamSwitch(FractintMenusStr, winfract_menustyle);
  1022.                     break;
  1023.             
  1024.                /* Color-Cycling (and Zooming) hotkeys */
  1025.                
  1026.                case IDF_HOTCYCLERAND:
  1027.                    if(Zooming) {
  1028.                       win_savedac();
  1029.                       ExecuteZoom();
  1030.                       }
  1031.                    else if(bMove)
  1032.                    {
  1033.                        extern POINT Center;
  1034.  
  1035.                        DragPoint = Center;
  1036.                        goto ExecZoom;
  1037.                    }
  1038.                    else if (win_oktocycle()) {
  1039.                        win_kill_all_zooming();
  1040.                        time_to_cycle = 1;
  1041.                        win_cyclerand = 2;
  1042.                        colorstate = 1;
  1043.                        }
  1044.                    break;
  1045.  
  1046.                case IDF_HOTNOZOOM:
  1047.                   win_kill_all_zooming();
  1048.                   if(Zooming)
  1049.                      CancelZoom();
  1050.                   else if(bMove)
  1051.                   {
  1052.                      extern POINT Center;
  1053.  
  1054.                      EndSelection(Center, &Rect);
  1055.  
  1056.                      ClearSelection(hWnd, &Rect, Shape);
  1057.                      bMove = bMoving = bTrack = FALSE;
  1058.              win_title_text(-1);
  1059.                   }
  1060.                   break;
  1061.  
  1062.                case IDF_HOTCYCLEON:
  1063.                /* Space/etc.. toggles Color-cycling parameters */
  1064.                    win_kill_all_zooming();
  1065.                    if (time_to_cycle == 1) {
  1066.                        time_to_resume = 1;
  1067.                        time_to_cycle = 0;
  1068.                        }
  1069.                    else
  1070.                        if (win_oktocycle()) {
  1071.                             time_to_cycle = 1;
  1072.                             colorstate = 1;
  1073.                             }
  1074.                    break;
  1075.                    
  1076.                case IDF_HOTCYCLERIGHT: 
  1077.                    win_kill_all_zooming();
  1078.                    if (win_oktocycle()) {
  1079.                        time_to_cycle = 1;
  1080.                        win_cycledir = -1;
  1081.                        colorstate = 1;
  1082.                        }
  1083.                    break;
  1084.  
  1085.                case IDF_HOTCYCLELEFT: 
  1086.                    win_kill_all_zooming();
  1087.                    if (win_oktocycle()) {
  1088.                        time_to_cycle = 1;
  1089.                        win_cycledir = 1;
  1090.                        colorstate = 1;
  1091.                        }
  1092.                    break;
  1093.                    
  1094.                case IDF_HOTCYCLERSTEP: 
  1095.                    if (win_oktocycle()) {
  1096.                        time_to_cycle = 0;
  1097.                        win_cycledir = -1;
  1098.                        colorstate = 1;
  1099.                        spindac(win_cycledir,1);
  1100.                        }
  1101.                    break;
  1102.                    
  1103.                case IDF_HOTCYCLELSTEP: 
  1104.                    win_kill_all_zooming();
  1105.                    if (win_oktocycle()) {
  1106.                        time_to_cycle = 0;
  1107.                        win_cycledir = 1;
  1108.                        colorstate = 1;
  1109.                        spindac(win_cycledir,1);
  1110.                        }
  1111.                    break;
  1112.  
  1113.                case IDF_HOTCYCLEFAST: 
  1114.                    win_kill_all_zooming();
  1115.                    if (time_to_cycle != 0 && win_cycledelay > 4)
  1116.                        win_cycledelay -= 5;
  1117.                    break;
  1118.  
  1119.                case IDF_HOTCYCLESLOW: 
  1120.                    win_kill_all_zooming();
  1121.                    if (time_to_cycle != 0 && win_cycledelay < 100)
  1122.                        win_cycledelay += 5;
  1123.                    break;
  1124.  
  1125.         case IDM_ORBITS:
  1126.             /* toggle orbits only if in pixel-by-pixel mode */
  1127.             if (win_fastupdate)
  1128.                         time_to_orbit = 1;
  1129.                 break;
  1130.                    
  1131.                 /* the following commands all cause a flag to be set
  1132.                    which causes the main fractal engine to return to
  1133.                    its main level, call SecondaryWndProc(), and then
  1134.                    either resume, restart, or exit */
  1135.                 case IDM_EXIT:
  1136.                 case IDM_OPEN:
  1137.                 case IDF_OPEN:
  1138.                 case IDM_NEW:
  1139.                 case IDM_SAVE:
  1140.                 case IDF_SAVE:
  1141.                 case IDM_SAVEAS:
  1142.                 case IDM_PRINT:
  1143.                 case IDF_PRINT:
  1144.                 case IDM_3D:
  1145.                 case IDF_3D:
  1146.                 case IDM_3DOVER:
  1147.                 case IDF_3DOVER:
  1148.                 case IDM_PARFILE:
  1149.                 case IDF_PARFILE:
  1150.                 case IDM_SAVEPAR:
  1151.                 case IDF_SAVEPAR:
  1152.                 case IDM_COPY:
  1153.                 case IDC_EDIT:
  1154.                 case IDM_FORMULA:
  1155.                 case IDF_FORMULA:
  1156.                 case IDM_DOODADX:
  1157.                 case IDF_DOODADX:
  1158.                 case IDM_DOODADY:
  1159.                 case IDF_DOODADY:
  1160.             case IDM_DOODADZ:
  1161.                 case IDF_DOODADZ:
  1162.         case IDM_IFS3D:
  1163.                 case IDF_IFS3D:
  1164.                 case IDM_RESTART:
  1165.                 case IDF_RESTART:
  1166.                 case IDM_STARFIELD:
  1167.                 case IDF_STARFIELD:
  1168.                 case IDM_IMAGE:
  1169.                 case IDF_IMAGE:
  1170.                 case IDM_COORD:
  1171.         case IDM_SIZING:
  1172.                 case IDM_PIXELS:
  1173.                 case IDF_MAPIN:
  1174.                 case IDF_MAPOUT:
  1175.                 case IDM_MAPIN:
  1176.                 case IDM_MAPOUT:
  1177.                 case IDF_CYCLE:
  1178.                 case IDM_CYCLE:
  1179.                 case IDM_MATH_TOOLS:
  1180.                 case IDM_ZOOMIN:
  1181.                 case IDM_ZOOMOUT:
  1182.                 case IDM_ZOOM:
  1183.                     win_kill_all_zooming();
  1184.                     time_to_cycle = 0;
  1185.                     SecondaryhWnd = hWnd;
  1186.                     Secondarymessage = message;
  1187.                     SecondarywParam = wParam;
  1188.                     SecondarylParam = lParam;
  1189.                     time_to_act = 1;
  1190.                     break;
  1191.  
  1192.             } 
  1193.             break;
  1194.  
  1195.         default:
  1196.             return (DefWindowProc(hWnd, message, wParam, lParam));
  1197.     }
  1198.     return (NULL);
  1199. }
  1200.  
  1201.  
  1202. void SecondaryWndProc()
  1203. {
  1204.     HWND hWnd;                /* handle to main window */
  1205.     unsigned message;
  1206.     WORD wParam;
  1207.     LONG lParam;
  1208.  
  1209.     RECT tempRect;
  1210.     HMENU hMenu;
  1211.  
  1212.     int Return;
  1213.     int i, fchoice;
  1214.     extern char FractintMenusStr[];
  1215.     extern char FractintPixelsStr[];
  1216.  
  1217.     hWnd    = SecondaryhWnd;
  1218.     message = Secondarymessage;
  1219.     wParam  = SecondarywParam;
  1220.     lParam  = SecondarylParam;
  1221.  
  1222.     switch (message) {
  1223.  
  1224.         case WM_COMMAND:
  1225.             
  1226.             switch (wParam) {
  1227.  
  1228.                 /* File menu items */
  1229.                 
  1230.                 case IDF_OPEN:
  1231.                 case IDF_3D:
  1232.                 case IDF_3DOVER:
  1233.                     if (winfract_menustyle) {    /* Fractint prompts */
  1234.                         extern int display3d, overlay3d;
  1235.                         extern int tabmode, helpmode, initbatch;
  1236.                         extern char gifmask[];
  1237.                         int showfile;
  1238.                         char *hdg;
  1239.                         
  1240.                         win_kill_all_zooming();
  1241.                         time_to_resume = 1;
  1242.                         initbatch = 0;
  1243.                         display3d = 0;
  1244.                         overlay3d = 0;
  1245.                         if (wParam == IDM_3D || wParam == IDM_3DOVER
  1246.                             || wParam == IDF_3D || wParam == IDF_3DOVER)
  1247.                             display3d = 1;
  1248.                         if (wParam == IDM_3DOVER || wParam == IDF_3DOVER)
  1249.                             overlay3d = 1;
  1250.                         win_display3d = 0;
  1251.                         win_overlay3d = 0;
  1252.                         stackscreen();
  1253.                         tabmode = 0;
  1254.                         showfile = -1;
  1255.                         while (showfile <= 0) {        /* image is to be loaded */
  1256.                             if (overlay3d)
  1257.                                 hdg = "Select File for 3D Overlay";
  1258.                             else if (display3d)
  1259.                                 hdg = "Select File for 3D Transform";
  1260.                             else
  1261.                                 hdg = "Select File to Restore";
  1262.                             if (showfile < 0 &&
  1263.                                 getafilename(hdg,gifmask,readname) < 0) {
  1264.                             showfile = 1;             /* cancelled */
  1265.                             break;
  1266.                             }
  1267.                             showfile = 0;
  1268.                             tabmode = 1;
  1269.                             if (read_overlay() == 0)         /* read hdr, get video mode */
  1270.                             break;              /* got it, exit */
  1271.                             showfile = -1;             /* retry */
  1272.                             }
  1273.                         if (!showfile) {
  1274.                             lstrcpy(FileName, readname);
  1275.                             time_to_load = 1;
  1276.                             time_to_cycle = 0;
  1277.                             if (wParam == IDM_3D || wParam == IDM_3DOVER
  1278.                                 || wParam == IDF_3D || wParam == IDF_3DOVER)
  1279.                                 win_display3d = 1;
  1280.                             if (wParam == IDM_3DOVER || wParam == IDF_3DOVER)
  1281.                                 win_overlay3d = 1;
  1282.                             }
  1283.                         tabmode = 1;
  1284.                         unstackscreen();
  1285.                         break;
  1286.                         }
  1287.                 case IDM_NEW:
  1288.                 case IDM_OPEN:
  1289.                 case IDM_3D:
  1290.                 case IDM_3DOVER:
  1291.                     win_display3d = 0;
  1292.                     win_overlay3d = 0;
  1293.                     lstrcpy(DialogTitle,"File to Open");
  1294.                     if (wParam == IDM_3D || wParam == IDF_3D)
  1295.                         lstrcpy(DialogTitle,"File for 3D Transform");
  1296.                     if (wParam == IDM_3DOVER || wParam == IDF_3DOVER)
  1297.                         lstrcpy(DialogTitle,"File for 3D Overlay Transform");
  1298.                     lstrcpy(FileName, readname);
  1299.                     lstrcpy(DefSpec,"*.gif");
  1300.                     lstrcpy(DefExt,".gif");
  1301.                     Return = Win_OpenFile(FileName);
  1302.                     if (Return && (wParam == IDM_3D || wParam == IDM_3DOVER)) {
  1303.                 extern int glassestype;
  1304.                         lpSelect3D = MakeProcInstance(
  1305.                             (FARPROC) Select3D, hInst);
  1306.                         Return = DialogBox(hInst, "Select3D",
  1307.                              hWnd, lpSelect3D);
  1308.                         FreeProcInstance(lpSelect3D);
  1309.                          if (glassestype) {
  1310.                              int Return2;
  1311.                              lpSelectFunnyGlasses = MakeProcInstance(
  1312.                                  (FARPROC) SelectFunnyGlasses, hInst);
  1313.                              Return2 = DialogBox(hInst, "SelectFunnyGlasses",
  1314.                                  hWnd, lpSelectFunnyGlasses);
  1315.                              FreeProcInstance(lpSelectFunnyGlasses);
  1316.                              check_funnyglasses_name();
  1317.                              }
  1318.                         if (Return && !win_3dspherical) {
  1319.                             lpSelect3DPlanar = MakeProcInstance(
  1320.                                 (FARPROC) Select3DPlanar, hInst);
  1321.                             Return = DialogBox(hInst, "Select3DPlanar",
  1322.                                  hWnd, lpSelect3DPlanar);
  1323.                             FreeProcInstance(lpSelect3DPlanar);
  1324.                             }
  1325.                         if (Return && win_3dspherical) {
  1326.                             lpSelect3DSpherical = MakeProcInstance(
  1327.                                 (FARPROC) Select3DSpherical, hInst);
  1328.                             Return = DialogBox(hInst, "Select3DSpherical",
  1329.                                  hWnd, lpSelect3DSpherical);
  1330.                             FreeProcInstance(lpSelect3DSpherical);
  1331.                             }
  1332.                         if (Return && (ILLUMINE || RAY)) {
  1333.                             lpSelectLightSource = MakeProcInstance(
  1334.                                 (FARPROC) SelectLightSource, hInst);
  1335.                             Return = DialogBox(hInst, "SelectLightSource",
  1336.                                  hWnd, lpSelectLightSource);
  1337.                             FreeProcInstance(lpSelectLightSource);
  1338.                             }
  1339.                         }
  1340.                     if (Return) {
  1341.                         lstrcpy(readname,FileName);
  1342.                         time_to_load = 1;
  1343.                         win_kill_all_zooming();
  1344.                         time_to_cycle = 0;
  1345.                         if (wParam == IDM_3D || wParam == IDM_3DOVER
  1346.                          || wParam == IDF_3D || wParam == IDF_3DOVER)
  1347.                             win_display3d = 1;
  1348.                         if (wParam == IDM_3DOVER || wParam == IDF_3DOVER)
  1349.                             win_overlay3d = 1;
  1350.                         }
  1351.                     break;
  1352.  
  1353.                 case IDF_SAVE:
  1354.                     if (winfract_menustyle) {    /* Fractint prompts */
  1355.                         /* (no change) */
  1356.                         }
  1357.                 case IDM_SAVE:
  1358.                 case IDM_SAVEAS:
  1359.                     lstrcpy(DialogTitle,"File to SaveAs");
  1360.                     lstrcpy(FileName, readname);
  1361.                     lstrcpy(DefSpec,"*.gif");
  1362.                     lstrcpy(DefExt,".gif");
  1363.                     Return = Win_SaveFile(FileName);
  1364.                     if (Return)
  1365.                         time_to_save = 1;
  1366.                     if (time_to_save)
  1367.                     {
  1368.                        time_to_cycle = 0;
  1369.                        wsprintf(StatusTitle, "Saving:  %s", (LPSTR)FullPathName);
  1370.                        OpenStatusBox(hWnd, hInst);
  1371.                        resave_flag = overwrite = 1;
  1372.                     }
  1373.                     break;
  1374.  
  1375.                 case IDF_PRINT:
  1376.                     if (winfract_menustyle) {    /* Fractint prompts */
  1377.                         /* (no change) */
  1378.                         }
  1379.                 case IDM_PRINT:
  1380.                     time_to_print = 1;
  1381.                     time_to_cycle = 0;
  1382.                     break;
  1383.  
  1384.                 case IDM_PARFILE:
  1385. winfract_loadpar:
  1386.                     {
  1387.                     FILE *parmfile;
  1388.                     extern char CommandFile[];
  1389.                     extern char CommandName[];
  1390.                     long point;
  1391.  
  1392.                     win_kill_all_zooming();
  1393.                     lstrcpy(DialogTitle,"Parameter File to Load");
  1394.                     lstrcpy(FileName, CommandFile);
  1395.                     lstrcpy(DefSpec,"*.par");
  1396.                     lstrcpy(DefExt,".par");
  1397.                     Return = Win_OpenFile(FileName);
  1398.                     if (Return) {
  1399.                         lstrcpy(LFileName, FileName);
  1400.                         lstrcpy(CommandFile, FileName);
  1401.                         get_lsys_name();
  1402.                         lstrcpy(DialogTitle,"Parameter Entry to Load");
  1403.                         win_choicemade = 0;
  1404.                         lpSelectFractal = MakeProcInstance(SelectFractal, hInst);
  1405.                         Return = DialogBox(hInst, "SelectFractal",
  1406.                             hWnd, lpSelectFractal);
  1407.                         FreeProcInstance(lpSelectFractal);
  1408.                         if (Return) { 
  1409.                             parmfile = fopen(CommandFile,"rb");
  1410.                             memcpy((char *)&point,
  1411.                                 (char *)&win_choices[win_choicemade][21],
  1412.                                 4);
  1413.                             fseek(parmfile,point,SEEK_SET);
  1414.                             Return = load_commands(parmfile);
  1415.                             }
  1416.                         if (Return) {
  1417.                             if (xx3rd != xxmin || yy3rd != yymin)
  1418.                                 stopmsg(4," This image uses a skewed zoom-box,\n a feature not available in Winfract.\n All Skewness has been dropped"); 
  1419.                             if (colorpreloaded)
  1420.                                 win_savedac();
  1421.                         maxiter = maxit;
  1422.                     time_to_restart = 1;
  1423.                     time_to_cycle = 0;
  1424.                     calc_status = 0;
  1425.                             }
  1426.                         }
  1427.                     break;
  1428.                     }
  1429.  
  1430.                 case IDM_SAVEPAR:
  1431.                     {
  1432.                     extern char CommandFile[];
  1433.                     win_kill_all_zooming();
  1434.                     lstrcpy(DialogTitle,"Parameter File to SaveAs");
  1435.                     lstrcpy(FileName, CommandFile);
  1436.                     lstrcpy(DefSpec,"*.par");
  1437.                     lstrcpy(DefExt,".par");
  1438.                     Return = Win_SaveFile(FileName);
  1439.                     if (Return) {
  1440.                         lstrcpy(LFileName, FileName);
  1441.                         lstrcpy(CommandFile, FileName);
  1442.                 lpSelectSavePar = MakeProcInstance(SelectSavePar, hInst);
  1443.                 Return = DialogBox(hInst, "SelectSavePar",
  1444.                  hWnd, lpSelectSavePar);
  1445.                 FreeProcInstance(lpSelectSavePar);
  1446.                 }
  1447.             if (Return) {
  1448.                 time_to_resume = 1;
  1449.                 win_make_batch_file();
  1450.              }
  1451.                     break;
  1452.                     }
  1453.  
  1454.                 case IDF_SAVEPAR:
  1455.                     win_kill_all_zooming();
  1456.                     time_to_resume = 1;
  1457.                     make_batch_file();
  1458.                     break;
  1459.                    
  1460.                 case IDM_COPY:
  1461.                    win_copy_to_clipboard();
  1462.  
  1463.                     break;
  1464.  
  1465.                 case IDM_EXIT:
  1466.                     win_kill_all_zooming();
  1467.                     time_to_quit = 1;
  1468.                     time_to_cycle = 0;
  1469.                     ValidateRect(hWnd, NULL);
  1470.                     hWndCopy = hWnd;
  1471.                     /* the main routine will actually call 'DestroyWindow()' */
  1472.                     break;
  1473.  
  1474.                 /* Fractals menu items */
  1475.  
  1476.                 case IDF_FORMULA:
  1477.                     if (winfract_menustyle) {    /* Fractint prompts */
  1478.                         win_kill_all_zooming();
  1479.                         time_to_resume = 1;
  1480.                         julibrot = 0;        /* disable Julibrot logic */
  1481. julibrot_fudge:                /* dive in here for Julibrots */
  1482.                     stackscreen();
  1483.             i = get_fracttype();
  1484.                     unstackscreen();
  1485.                     SetFocus(hWnd);
  1486.                     if (i == 0) {        /* time to redraw? */
  1487.                     time_to_restart = 1;
  1488.                     time_to_cycle = 0;
  1489.                     calc_status = 0;
  1490.                     }
  1491.                     break;
  1492.                         }
  1493.                 case IDM_FORMULA:
  1494.                     lstrcpy(DialogTitle,"Select a Fractal Formula");
  1495.                     win_kill_all_zooming();
  1496.                     win_numchoices = CountFractalList;
  1497.                     win_choicemade = 0;
  1498.                     CurrentFractal = fractype;
  1499.                     for (i = 0; i < win_numchoices; i++) {
  1500.                         win_choices[i] = fractalspecific[onthelist[i]].name;
  1501.                         if (onthelist[i] == fractype ||
  1502.                             fractalspecific[onthelist[i]].tofloat == fractype)
  1503.                             win_choicemade = i;
  1504.                         }
  1505.                     lpSelectFractal = MakeProcInstance(SelectFractal, hInst);
  1506.                     Return = DialogBox(hInst, "SelectFractal",
  1507.                         hWnd, lpSelectFractal);
  1508.                     FreeProcInstance(lpSelectFractal);
  1509.                     fchoice = win_choicemade;
  1510.                     if (Return && (onthelist[fchoice] == IFS ||
  1511.                         onthelist[fchoice] == IFS3D)) {
  1512.                         lstrcpy(DialogTitle,"IFS Filename to Load");
  1513.                         lstrcpy(FileName, IFSFileName);
  1514.                         lstrcpy(DefSpec,"*.ifs");
  1515.                         lstrcpy(DefExt,".ifs");
  1516.                         Return = Win_OpenFile(FileName);
  1517.                         if (Return) {
  1518.                             lstrcpy(IFSFileName, FileName);
  1519.                             lstrcpy(FormFileName, FileName);
  1520.                             get_formula_names();
  1521.                             lstrcpy(DialogTitle,"Select an IFS type");
  1522.                             win_choicemade = 0;
  1523.                             lpSelectFractal = MakeProcInstance(SelectFractal, hInst);
  1524.                             Return = DialogBox(hInst, "SelectFractal",
  1525.                                 hWnd, lpSelectFractal);
  1526.                             FreeProcInstance(lpSelectFractal);
  1527.                             if (Return) {
  1528.                                 lstrcpy(IFSName, win_choices[win_choicemade]);
  1529.                                 Return = ! ifsload();
  1530.                                 }
  1531.                             }
  1532.                         }
  1533.                     if (Return && (onthelist[fchoice] == FORMULA || 
  1534.                         onthelist[fchoice] == FFORMULA)) {
  1535.                         /* obtain the formula filename */
  1536.                         lstrcpy(DialogTitle,"Formula File to Load");
  1537.                         lstrcpy(FileName, FormFileName);
  1538.                         lstrcpy(DefSpec,"*.frm");
  1539.                         lstrcpy(DefExt,".frm");
  1540.                         Return = Win_OpenFile(FileName);
  1541.                         if (Return) {
  1542.                             lstrcpy(FormFileName, FileName);
  1543.                             get_formula_names();
  1544.                             lstrcpy(DialogTitle,"Select a Formula");
  1545.                             win_choicemade = 0;
  1546.                             lpSelectFractal = MakeProcInstance(SelectFractal, hInst);
  1547.                             Return = DialogBox(hInst, "SelectFractal",
  1548.                                 hWnd, lpSelectFractal);
  1549.                             FreeProcInstance(lpSelectFractal);
  1550.                             if (Return) 
  1551.                                 Return = parse_formula_names();
  1552.                             }
  1553.                         }
  1554.                     if (Return && (onthelist[fchoice] == LSYSTEM)) {
  1555.                         lstrcpy(DialogTitle,"Lsystem File to Load");
  1556.                         lstrcpy(FileName, LFileName);
  1557.                         lstrcpy(DefSpec,"*.l");
  1558.                         lstrcpy(DefExt,".l");
  1559.                         Return = Win_OpenFile(FileName);
  1560.                         if (Return) {
  1561.                             lstrcpy(LFileName, FileName);
  1562.                             get_lsys_name();
  1563.                             lstrcpy(DialogTitle,"Select a Formula");
  1564.                             win_choicemade = 0;
  1565.                             lpSelectFractal = MakeProcInstance(SelectFractal, hInst);
  1566.                             Return = DialogBox(hInst, "SelectFractal",
  1567.                                 hWnd, lpSelectFractal);
  1568.                             FreeProcInstance(lpSelectFractal);
  1569.                             if (Return) {
  1570.                                 lstrcpy(LName, win_choices[win_choicemade]);
  1571.                                 Return = !LLoad();
  1572.                                 }
  1573.                             }
  1574.                         }
  1575.                     julibrot = 0;
  1576.                     if (Return) {
  1577.                         double oldxxmin, oldxxmax, oldyymin, oldyymax;
  1578.                         double oldparam[4];
  1579.                         int i;
  1580.                         oldxxmin = xxmin;
  1581.                         oldxxmax = xxmax;
  1582.                         oldyymin = yymin;
  1583.                         oldyymax = yymax;
  1584.                         for (i = 0; i < 4; i++)
  1585.                             oldparam[i] = param[i];
  1586.                         CurrentFractal = onthelist[fchoice];
  1587.                         curfractalspecific = &fractalspecific[CurrentFractal];
  1588.                         if (CurrentFractal == BIFURCATION
  1589.                             || CurrentFractal == LBIFURCATION
  1590.                             || CurrentFractal == BIFSTEWART
  1591.                             || CurrentFractal == LBIFSTEWART
  1592.                             || CurrentFractal == BIFLAMBDA
  1593.                             || CurrentFractal == LBIFLAMBDA
  1594.                             ) set_trig_array(0,"ident");
  1595.                         if (CurrentFractal == BIFEQSINPI
  1596.                             || CurrentFractal == LBIFEQSINPI
  1597.                             || CurrentFractal == BIFADSINPI
  1598.                             || CurrentFractal == LBIFADSINPI
  1599.                             ) set_trig_array(0,"sin");
  1600.                         set_default_parms();
  1601.                         if (CurrentFractal == JULIBROT || CurrentFractal == JULIBROTFP) {
  1602.                             fractype = CurrentFractal;
  1603.                             julibrot = 1;
  1604.                             stackscreen();
  1605.                             if (get_fract_params(0) < 0)
  1606.                                 Return = 0;
  1607.                         unstackscreen();
  1608.                             }
  1609.                         else {
  1610.                             lpSelectFracParams = MakeProcInstance(SelectFracParams,
  1611.                                 hInst);
  1612.                             Return = DialogBox(hInst, "SelectFracParams",
  1613.                                 hWnd, lpSelectFracParams);
  1614.                             FreeProcInstance(lpSelectFracParams);
  1615.                             }
  1616.                         if (! Return) {
  1617.                             xxmin = oldxxmin;
  1618.                             xxmax = oldxxmax;
  1619.                             yymin = oldyymin;
  1620.                             yymax = oldyymax;
  1621.                             for (i = 0; i < 4; i++)
  1622.                                 param[i] = oldparam[i];
  1623.                             }
  1624.                         }
  1625.                     if (Return) {
  1626.                         time_to_reinit = 1;
  1627.                         time_to_cycle = 0;
  1628.                         calc_status = 0;
  1629.                         }
  1630.                     break;
  1631.  
  1632.                 case IDF_PARFILE:
  1633.                     if (!winfract_menustyle) {    /* winfract prompts */
  1634.                         goto winfract_loadpar; /* for now */
  1635.                         }
  1636.                 case IDF_DOODADX:
  1637.                     if (!winfract_menustyle)   /* Windows menus */
  1638.                         goto winfract_xmenu;   /* for now */
  1639.                 case IDF_DOODADY:
  1640.                     if (!winfract_menustyle)   /* Windows menus */
  1641.                         goto winfract_ymenu;   /* for now */
  1642.                 case IDF_DOODADZ:
  1643.                     if (!winfract_menustyle)   /* Windows menus */
  1644.                         goto winfract_zmenu;   /* for now */
  1645.  
  1646.                     if (winfract_menustyle) {    /* fractint prompts */
  1647.                         win_kill_all_zooming();
  1648.                         time_to_resume = 1;
  1649.                     stackscreen();
  1650.                     maxiter = maxit;
  1651.                         if (wParam == IDF_DOODADX || wParam == IDM_DOODADX)
  1652.                             i = get_toggles();
  1653.                         else if (wParam == IDF_DOODADY || wParam == IDM_DOODADY)
  1654.                             i = get_toggles2();
  1655.                         else if (wParam == IDF_DOODADZ || wParam == IDM_DOODADZ)
  1656.                             i = get_fract_params(1);
  1657.                         else {
  1658.                 i = get_commands();
  1659.                             if (xx3rd != xxmin || yy3rd != yymin)
  1660.                                 stopmsg(4," This image uses a skewed zoom-box,\n a feature not available in Winfract.\n All Skewness has been dropped"); 
  1661.                 if (colorpreloaded)
  1662.                     win_savedac();
  1663.                 }
  1664.                     unstackscreen();
  1665.                     SetFocus(hWnd);
  1666.                         time_to_cycle = 0;
  1667.                     if (i > 0) {        /* time to redraw? */
  1668.                         maxiter = maxit;
  1669.                     time_to_restart = 1;
  1670.                     calc_status = 0;
  1671.                     }
  1672.                     break;
  1673.                    }
  1674.  
  1675.                 case IDM_DOODADX:
  1676. winfract_xmenu:
  1677.             lpSelectDoodads = MakeProcInstance(SelectDoodads, hInst);
  1678.             Return = DialogBox(hInst, "SelectDoodads",
  1679.                 hWnd, lpSelectDoodads);
  1680.             FreeProcInstance(lpSelectDoodads);
  1681.             if (Return) {
  1682.                                 win_kill_all_zooming();
  1683.                 win_savedac();
  1684.                 time_to_restart = 1;
  1685.                                 time_to_cycle = 0;
  1686.                                 calc_status = 0;
  1687.                 }
  1688.                         break;
  1689.  
  1690.                 case IDM_DOODADY:
  1691. winfract_ymenu:
  1692.             lpSelectExtended = MakeProcInstance(SelectExtended, hInst);
  1693.             Return = DialogBox(hInst, "SelectExtended",
  1694.                 hWnd, lpSelectExtended);
  1695.             FreeProcInstance(lpSelectExtended);
  1696.             if (Return) {
  1697.                                 win_kill_all_zooming();
  1698.                 win_savedac();
  1699.                 time_to_restart = 1;
  1700.                                 time_to_cycle = 0;
  1701.                                 calc_status = 0;
  1702.                 }
  1703.                         break;
  1704.  
  1705.            case IDM_DOODADZ:
  1706. winfract_zmenu:
  1707.             CurrentFractal = fractype;
  1708.                     lpSelectFracParams = MakeProcInstance(SelectFracParams,
  1709.                         hInst);
  1710.                     Return = DialogBox(hInst, "SelectFracParams",
  1711.                         hWnd, lpSelectFracParams);
  1712.                     FreeProcInstance(lpSelectFracParams);
  1713.                     if (Return) {
  1714.                         win_kill_all_zooming();
  1715.             win_savedac();
  1716.                         time_to_reinit = 1;
  1717.                         time_to_cycle = 0;
  1718.                         calc_status = 0;
  1719.                         }
  1720.               break;
  1721.  
  1722.         case IDF_IFS3D:
  1723.                     if (winfract_menustyle) {    /* Fractint prompts */
  1724.                         extern int display3d, overlay3d;
  1725.                         extern int tabmode, helpmode, initbatch;
  1726.                         extern char gifmask[];
  1727.                         int showfile;
  1728.                         tabmode = 0;
  1729.                         if (get_fract3d_params() >= 0) {
  1730.                             win_kill_all_zooming();
  1731.                             time_to_restart = 1;
  1732.                             }
  1733.                         tabmode = 1;
  1734.                         break;
  1735.                         }
  1736.         case IDM_IFS3D:
  1737.             {
  1738.             extern int glassestype;
  1739.                     lpSelectIFS3D = MakeProcInstance(
  1740.                         (FARPROC) SelectIFS3D, hInst);
  1741.                     Return = DialogBox(hInst, "SelectIFS3D",
  1742.                          hWnd, lpSelectIFS3D);
  1743.                     FreeProcInstance(lpSelectIFS3D);
  1744.                     if (Return) {
  1745.                          win_kill_all_zooming();
  1746.                          time_to_restart = 1;
  1747.                          if (glassestype) {
  1748.                              lpSelectFunnyGlasses = MakeProcInstance(
  1749.                                  (FARPROC) SelectFunnyGlasses, hInst);
  1750.                              Return = DialogBox(hInst, "SelectFunnyGlasses",
  1751.                                  hWnd, lpSelectFunnyGlasses);
  1752.                              FreeProcInstance(lpSelectFunnyGlasses);
  1753.                              check_funnyglasses_name();
  1754.                              }
  1755.                          }
  1756.                     break;
  1757.                     }
  1758.  
  1759.                case IDM_RESTART:
  1760.                case IDF_RESTART:
  1761.                    time_to_reinit  = 2;
  1762.                    time_to_cycle = 0;
  1763.                    calc_status = 0;
  1764.                    break;
  1765.  
  1766.                case IDF_STARFIELD:
  1767.                    if (winfract_menustyle) {    /* fractint prompts */
  1768.                        if (get_starfield_params() >= 0) {
  1769.                            win_kill_all_zooming();
  1770.                            time_to_starfield = 1;
  1771.                            time_to_cycle = 0;
  1772.                            calc_status = 0;
  1773.                            }
  1774.                        break;
  1775.                        }
  1776.                case IDM_STARFIELD:
  1777.                    lpSelectStarfield = MakeProcInstance(
  1778.                        (FARPROC) SelectStarfield, hInst);
  1779.                    Return = DialogBox(hInst, "Starfield",
  1780.                         hWnd, lpSelectStarfield);
  1781.                    FreeProcInstance(lpSelectStarfield);
  1782.                    if (Return) {
  1783.                        win_kill_all_zooming();
  1784.                        time_to_starfield = 1;
  1785.                        time_to_cycle = 0;
  1786.                        calc_status = 0;
  1787.                        }
  1788.                    break;
  1789.  
  1790.                 /* View menu items */
  1791.  
  1792.                 case IDF_IMAGE:
  1793.                     if (winfract_menustyle) {    /* Fractint prompts */
  1794.                         /* (no change) */
  1795.                         }
  1796.                 case IDM_IMAGE:
  1797.                         win_kill_all_zooming();
  1798.             lpSelectImage = MakeProcInstance(SelectImage, hInst);
  1799.             Return = DialogBox(hInst, "SelectImage",
  1800.                 hWnd, lpSelectImage);
  1801.             FreeProcInstance(lpSelectImage);
  1802.             if (Return) {
  1803.                 time_to_restart = 1;
  1804.                                 time_to_cycle = 0;
  1805.                                 calc_status = 0;
  1806.                 }
  1807.             ReSizeWindow(hWnd);
  1808.                         break;
  1809.  
  1810.                 case IDM_MATH_TOOLS:
  1811.                     MathToolBox(hWnd);
  1812.                     break;
  1813.  
  1814.                 case IDM_ZOOMOUT:
  1815.                 case IDM_ZOOMIN:
  1816.                     if(ZoomBarOpen)
  1817.                        ZoomBar(hWnd);
  1818.                     else
  1819.                        CheckMenuItem(GetMenu(hWnd), ZoomMode, MF_UNCHECKED);
  1820.                     CheckMenuItem(GetMenu(hWnd), wParam, MF_CHECKED);
  1821.                     ZoomMode = wParam;
  1822.                     break;
  1823.  
  1824.                 case IDM_ZOOM:
  1825.                     if(!ZoomBarOpen)
  1826.                        CheckMenuItem(GetMenu(hWnd), ZoomMode, MF_UNCHECKED);
  1827.                     win_kill_all_zooming();
  1828.                     ZoomBar(hWnd);
  1829.                     break;
  1830.  
  1831.                 case IDM_COORD:
  1832.                     CoordinateBox(hWnd);
  1833.                     break;
  1834.  
  1835.         case IDM_SIZING:
  1836.                     win_kill_all_zooming();
  1837.             WindowSizing(hWnd);
  1838.             break;
  1839.  
  1840.                 case IDM_PIXELS:
  1841.                     {
  1842.                     BOOL profile_fastupdate;
  1843.             hMenu = GetMenu(hWnd);
  1844.                     if (win_fastupdate) {
  1845.                         win_fastupdate = 0;
  1846.                         /* if disabling p-by-p, disable orbits, too */
  1847.                         if (show_orbit)
  1848.                             time_to_orbit = 1;
  1849.                         profile_fastupdate = FALSE;
  1850.                         CheckMenuItem(hMenu, IDM_PIXELS, MF_UNCHECKED);
  1851.                         }
  1852.                     else {
  1853.                         win_fastupdate = 2;
  1854.                         profile_fastupdate = TRUE;
  1855.                         CheckMenuItem(hMenu, IDM_PIXELS, MF_CHECKED);
  1856.                         }
  1857.                     SaveParamSwitch(FractintPixelsStr, profile_fastupdate);
  1858.                     }
  1859.                     break;
  1860.  
  1861.                 case IDF_STATUS:
  1862.                     if (winfract_menustyle) {    /* Fractint prompts */
  1863.                         tab_display();
  1864.                         break;
  1865.                         }
  1866.                 case IDS_STATUS:
  1867.                     lpProcStatus = MakeProcInstance(Status, hInst);
  1868.                     DialogBox(hInst, "ShowStatus", hWnd, lpProcStatus);
  1869.                     FreeProcInstance(lpProcStatus);
  1870.                     break;
  1871.  
  1872.                 /* Colors menu items */
  1873.  
  1874.                 case IDF_MAPIN:
  1875.                     if (winfract_menustyle) {  /* fractint-style prompts */
  1876.                         win_kill_all_zooming();
  1877.                         time_to_resume = 1;
  1878.                         time_to_cycle = 0;
  1879.                         if (wParam == IDF_MAPIN)
  1880.                             load_palette();
  1881.                         else
  1882.                             save_palette();
  1883.                         spindac(0,1);
  1884.                         break;
  1885.                         }
  1886.                 case IDF_MAPOUT:
  1887.                 case IDM_MAPIN:
  1888.                 case IDM_MAPOUT:
  1889.                     lstrcpy(DialogTitle,"Palette File to Load");
  1890.                     lstrcpy(FileName, "default");
  1891.                     if (wParam == IDM_MAPOUT || wParam == IDF_MAPOUT)
  1892.                         lstrcpy(FileName, "mymap");
  1893.                     lstrcpy(DefSpec,"*.map");
  1894.                     lstrcpy(DefExt,".map");
  1895.                     if (wParam == IDM_MAPOUT || wParam == IDF_MAPOUT) {
  1896.                         Return = Win_SaveFile(FileName);
  1897.                         }
  1898.                     else {
  1899.                         Return = Win_OpenFile(FileName);
  1900.                         }
  1901.                     if (Return && (wParam == IDM_MAPIN || wParam == IDF_MAPIN)) {
  1902.                         win_kill_all_zooming();
  1903.                         ValidateLuts(FileName);
  1904.                         spindac(0,1);
  1905.                         }
  1906.                     if (Return && (wParam == IDM_MAPOUT || wParam == IDF_MAPOUT)) {
  1907.                         FILE *dacfile;
  1908.             dacfile = fopen(FileName,"w");
  1909.             if (dacfile == NULL) {
  1910.                 break;
  1911.                 }
  1912.             fprintf(dacfile,"  0   0   0\n");
  1913.             for (i = 1; i < 256; i++)
  1914.                 fprintf(dacfile, "%3d %3d %3d\n",
  1915.                 dacbox[i][0] << 2,
  1916.                 dacbox[i][1] << 2,
  1917.                 dacbox[i][2] << 2);
  1918.             fclose(dacfile);
  1919.                         }
  1920.                     break;
  1921.  
  1922.                 case IDF_CYCLE:
  1923.                     if (winfract_menustyle) {    /* Fractint prompts */
  1924.                         /* (no change) */
  1925.                         }
  1926.                 case IDM_CYCLE:
  1927.                     if (!win_oktocycle())
  1928.                         break;
  1929.                     win_kill_all_zooming();
  1930.                     lpSelectCycle = MakeProcInstance(SelectCycle, hInst);
  1931.                     Return = DialogBox(hInst, "SelectCycle",
  1932.                     hWnd, lpSelectCycle);
  1933.                     FreeProcInstance(lpSelectCycle);
  1934.                     break;
  1935.  
  1936.                 case IDC_EDIT:
  1937.                     if (HIWORD (lParam) == EN_ERRSPACE) {
  1938.                         MessageBox (
  1939.                               GetFocus ()
  1940.                             , "Out of memory."
  1941.                             , "Fractint For Windows"
  1942.                             , MB_ICONSTOP | MB_OK
  1943.                         );
  1944.                     }
  1945.                     break;
  1946.  
  1947.             } 
  1948.             break;
  1949.  
  1950.     }
  1951.     return;
  1952. }
  1953.  
  1954. win_set_title_text()
  1955. {
  1956.     float temp;
  1957.     char ctemp[80];
  1958.     
  1959.     temp = win_release / 100.0;
  1960.     sprintf(ctemp,"Fractint for Windows - Vers %5.2f", temp);
  1961.     lstrcpy(winfract_title_text, ctemp);
  1962. }
  1963.  
  1964. char far win_oldtitle[30];
  1965. char far win_title1[] = " (calculating)";
  1966. char far win_title2[] = " (color-cycling)";
  1967. char far win_title3[] = " (zooming)";
  1968. char far win_title4[] = " (starfield generation)";
  1969.  
  1970. win_title_text(int title)
  1971. {
  1972. char newtitle[80];
  1973.  
  1974. lstrcpy(newtitle, winfract_title_text);
  1975.  
  1976. if (title < 0) {
  1977.     lstrcat(newtitle, win_oldtitle);
  1978.     }
  1979. if (title == 0) {
  1980.     win_oldtitle[0] = 0;
  1981.     lstrcat(newtitle, win_oldtitle);
  1982.     }
  1983. if (title == 1) {
  1984.     lstrcpy(win_oldtitle, win_title1);
  1985.     lstrcat(newtitle, win_oldtitle);
  1986.     }
  1987. if (title == 2) {
  1988.     lstrcat(newtitle, win_title2);
  1989.     }
  1990. if (title == 3) {
  1991.     lstrcat(newtitle, win_title3);
  1992.     }
  1993. if (title == 4) {
  1994.     lstrcat(newtitle, win_title4);
  1995.     }
  1996.  
  1997. SetWindowText(hMainWnd, newtitle);
  1998.  
  1999. }
  2000.  
  2001. win_oktocycle()
  2002. {
  2003. if (!(iRasterCaps) || iNumColors < 16) {
  2004.     stopmsg(0,
  2005.         winfract_msg96
  2006.          );
  2007.     return(0);
  2008.     }
  2009. return(1);
  2010. }
  2011.  
  2012. extern int win_animate_flag;
  2013.  
  2014. win_stop_cycling()
  2015. {
  2016. HDC hDC;                      /* handle to device context           */
  2017.  
  2018. hDC = GetDC(GetFocus());
  2019. SetSystemPaletteUse(hDC,SYSPAL_STATIC);
  2020. ReleaseDC(GetFocus(),hDC);
  2021.  
  2022. time_to_cycle = 0;
  2023. win_animate_flag = 0;
  2024. restoredac();
  2025. win_systempaletteused = FALSE;
  2026. SetSysColors(COLOR_ENDCOLORS,(LPINT)win_syscolorindex,(LONG FAR *)win_syscolorold);
  2027. return(0);
  2028. }
  2029.  
  2030. win_kill_all_zooming()
  2031. {
  2032.     if(Zooming)
  2033.         CancelZoom();
  2034.     else if(bMove)
  2035.         {
  2036.          extern POINT Center;
  2037.  
  2038.          EndSelection(Center, &Rect);
  2039.          ClearSelection(hWndCopy, &Rect, Shape);
  2040.          bMove = bMoving = bTrack = FALSE;
  2041.          win_title_text(-1);
  2042.          }
  2043. }
  2044.  
  2045. void mono_dib_palette()
  2046. {
  2047. int i;        /* fill in the palette index values */
  2048.     for (i = 0; i < 128; i = i+2) {
  2049.         pDibInfo->bmiColors[i  ].rgbBlue      =   0;
  2050.         pDibInfo->bmiColors[i  ].rgbGreen     =   0;
  2051.         pDibInfo->bmiColors[i  ].rgbRed       =   0;
  2052.         pDibInfo->bmiColors[i  ].rgbReserved  =   0;
  2053.         pDibInfo->bmiColors[i+1].rgbBlue      = 255;
  2054.         pDibInfo->bmiColors[i+1].rgbGreen     = 255;
  2055.         pDibInfo->bmiColors[i+1].rgbRed       = 255;
  2056.         pDibInfo->bmiColors[i+1].rgbReserved  =   0;
  2057.         }
  2058. }
  2059.  
  2060. default_dib_palette()
  2061. {
  2062. int i, k;        /* fill in the palette index values */
  2063. int far *palette_values;    /* pointer to palette values */
  2064.  
  2065.     palette_values = (int far *)&pDibInfo->bmiColors[0];
  2066.     k = 0;
  2067.     for (i = 0; i < 256; i++) {
  2068.         palette_values[i] = k;
  2069.         if (++k >= iNumColors)
  2070.            if (iNumColors > 0)
  2071.                k = 0;
  2072.         }
  2073.     return(0);
  2074. }
  2075.  
  2076. rgb_dib_palette()
  2077. {
  2078. int i;        /* fill in the palette index values */
  2079.  
  2080.     for (i = 0; i < 256; i++) {
  2081.         pDibInfo->bmiColors[i].rgbRed       = dacbox[i][0] << 2;
  2082.         pDibInfo->bmiColors[i].rgbGreen     = dacbox[i][1] << 2;
  2083.         pDibInfo->bmiColors[i].rgbBlue      = dacbox[i][2] << 2;
  2084.         pDibInfo->bmiColors[i].rgbReserved  =   0;
  2085.         }
  2086.     return(0);
  2087. }
  2088.  
  2089. win_copy_to_clipboard()
  2090. {
  2091. HWND hWnd;
  2092.  
  2093.     hWnd    = SecondaryhWnd;
  2094.  
  2095.     /* allocate the memory for the BITMAPINFO structure 
  2096.        (followed by the bitmap bits) */
  2097.     if (!(hClipboard1 = GlobalAlloc(GMEM_FIXED,
  2098.         sizeof(BITMAPINFOHEADER)+colors*sizeof(PALETTEENTRY)
  2099.         + win_bitmapsize))) {
  2100.         cant_clip();
  2101.         return(0);
  2102.         }
  2103.     if (!(lpClipboard1 =
  2104.         (LPSTR) GlobalLock(hClipboard1))) {
  2105.         GlobalFree(hClipboard1);
  2106.         cant_clip();
  2107.         return(0);
  2108.         }
  2109.     rgb_dib_palette();
  2110.     lmemcpy((char huge *)lpClipboard1, (char huge *)pDibInfo,
  2111.         sizeof(BITMAPINFOHEADER)+colors*sizeof(RGBQUAD)
  2112.         );
  2113.     lpClipboard1 += 
  2114.         (sizeof(BITMAPINFOHEADER))+
  2115.         (colors*sizeof(RGBQUAD));
  2116.     lmemcpy((char huge *)lpClipboard1, (char huge *)pixels,
  2117.         win_bitmapsize);
  2118.  
  2119.     GlobalUnlock(hClipboard1);
  2120.  
  2121.     /* allocate the memory for the palette info */
  2122.     if (!lpClipboard2) {
  2123.         if (!(hClipboard2 = GlobalAlloc (GMEM_FIXED,
  2124.             (sizeof (LOGPALETTE) +
  2125.             (sizeof (PALETTEENTRY) * (PALETTESIZE)))))) {
  2126.             GlobalFree(hClipboard1);
  2127.             cant_clip();
  2128.             return(0);
  2129.             }
  2130.         if (!(lpClipboard2 = 
  2131.             (LPSTR) GlobalLock(hClipboard2))) {
  2132.             GlobalFree(hClipboard1);
  2133.             GlobalFree(hClipboard2);
  2134.             cant_clip();
  2135.             return(0);
  2136.             }
  2137.         }
  2138.  
  2139.     /* fill in the palette info */
  2140.     lpClipboard2[0] = 0;
  2141.     lpClipboard2[1] = 3;
  2142.     lpClipboard2[2] = 0;
  2143.     lpClipboard2[3] = 1;
  2144.     lmemcpy((char huge *)&lpClipboard2[4],
  2145.         (char huge *)&pDibInfo->bmiColors[0],
  2146.         PALETTESIZE*sizeof(RGBQUAD)
  2147.         );
  2148.     hClipboard3 = CreatePalette ((LPLOGPALETTE) lpClipboard2);
  2149.  
  2150.     hDC = GetDC(hWnd);
  2151.     hBitmap = CreateDIBitmap(hDC, &pDibInfo->bmiHeader,
  2152.         CBM_INIT, (LPSTR)pixels, pDibInfo,
  2153.         DIB_RGB_COLORS);
  2154.     ReleaseDC(hWnd, hDC);
  2155.  
  2156.     if (OpenClipboard(hWnd)) {
  2157.         EmptyClipboard();
  2158.         SetClipboardData(CF_PALETTE, hClipboard3);
  2159.         SetClipboardData(CF_DIB, hClipboard1);
  2160.         if(hBitmap)
  2161.             SetClipboardData(CF_BITMAP, hBitmap);
  2162.         CloseClipboard();
  2163.         }
  2164.  
  2165.     default_dib_palette();
  2166. }
  2167.  
  2168. extern char win_funnyglasses_map_name[];
  2169.  
  2170. check_funnyglasses_name()
  2171. {
  2172.     if (win_funnyglasses_map_name[0] != 0) {
  2173.         if (ValidateLuts(win_funnyglasses_map_name) == 0) {
  2174.             win_savedac();
  2175.             }
  2176.         else {
  2177.             char temp[80];
  2178.             sprintf(temp,"Can't find map file: %s",
  2179.                 win_funnyglasses_map_name);
  2180.             stopmsg(0,temp);
  2181.             }
  2182.         }
  2183. }
  2184.  
  2185. void MakeHelpPathName(szFileName)
  2186. char * szFileName;
  2187. {
  2188.    char *  pcFileName;
  2189.    int     nFileNameLen;
  2190.  
  2191.    nFileNameLen = GetModuleFileName(hInst,szFileName,EXE_NAME_MAX_SIZE);
  2192.    pcFileName = szFileName + nFileNameLen;
  2193.  
  2194.    while (pcFileName > szFileName) {
  2195.        if (*pcFileName == '\\' || *pcFileName == ':') {
  2196.            *(++pcFileName) = '\0';
  2197.            break;
  2198.        }
  2199.    nFileNameLen--;
  2200.    pcFileName--;
  2201.    }
  2202.  
  2203.    if ((nFileNameLen+13) < EXE_NAME_MAX_SIZE) {
  2204.        lstrcat(szFileName, "winfract.hlp");
  2205.    }
  2206.  
  2207.    else {
  2208.        lstrcat(szFileName, "?");
  2209.    }
  2210.  
  2211.    return;
  2212. }
  2213.  
  2214. set_win_offset()
  2215. {
  2216. win_xoffset = ((long)xposition*((long)xdots-(long)xpagesize))/100L;
  2217. win_yoffset = ((long)yposition*((long)ydots-(long)ypagesize))/100L;
  2218. if (win_xoffset+xpagesize > xdots) win_xoffset = xdots-xpagesize;
  2219. if (win_yoffset+ypagesize > ydots) win_yoffset = ydots-ypagesize;
  2220. if (xpagesize >= xdots) win_xoffset = 0;
  2221. if (ypagesize >= ydots) win_yoffset = 0;
  2222. return(0);
  2223. }
  2224.  
  2225. win_savedac()
  2226. {
  2227.     memcpy(olddacbox,dacbox,256*3); /* save the DAC */
  2228.     colorpreloaded = 1;             /* indicate it needs to be restored */
  2229.  
  2230. }
  2231.  
  2232. /*
  2233.   Read a formula file, picking off the formula names.
  2234.   Formulas use the format "  name = { ... }  name = { ... } "
  2235. */
  2236.  
  2237. int get_formula_names()     /* get the fractal formula names */
  2238. {
  2239.    int numformulas, i;
  2240.    FILE *File;
  2241.    char msg[81], tempstring[201];
  2242.  
  2243.    FormName[0] = 0;        /* start by declaring failure */
  2244.    for (i = 0; i < MaxFormNameChoices; i++) {
  2245.       FormNameChoices[i][0] = 0;
  2246.       win_choices[i] = FormNameChoices[i];
  2247.       }
  2248.  
  2249.    if((File = fopen(FormFileName, "rt")) == NULL) {
  2250.       sprintf("I Can't find %s", FormFileName);
  2251.       stopmsg(1,msg);
  2252.       return(-1);
  2253.    }
  2254.  
  2255.    numformulas = 0;
  2256.    while(fscanf(File, " %20[^ \n\t({]", FormNameChoices[numformulas]) != EOF) {
  2257.       int c;
  2258.  
  2259.       while(c = getc(File)) {
  2260.      if(c == EOF || c == '{' || c == '\n')
  2261.         break;
  2262.       }
  2263.       if(c == EOF)
  2264.      break;
  2265.       else if(c != '\n'){
  2266.      numformulas++;
  2267.      if (numformulas >= MaxFormNameChoices) break;
  2268. skipcomments:
  2269.      if(fscanf(File, "%200[^}]", tempstring) == EOF) break;
  2270.      if (getc(File) != '}') goto skipcomments;
  2271.      if (stricmp(FormNameChoices[numformulas-1],"") == 0 ||
  2272.          stricmp(FormNameChoices[numformulas-1],"comment") == 0)
  2273.          numformulas--;
  2274.       }
  2275.    }
  2276.    fclose(File);
  2277.    win_numchoices = numformulas;
  2278.    qsort(FormNameChoices,win_numchoices,25,
  2279.          (int(*)(const void*, const void *))strcmp);
  2280.    return(0);
  2281. }
  2282.  
  2283. int parse_formula_names()     /* parse a fractal formula name */
  2284. {
  2285.  
  2286.    lstrcpy(FormName, win_choices[win_choicemade]);
  2287.  
  2288.    if (RunForm(FormName)) {
  2289.        FormName[0] = 0;     /* declare failure */
  2290.        stopmsg(0,"Can't Parse that Formula");
  2291.        return(0);
  2292.        }
  2293.  
  2294. return(1);
  2295. }
  2296.  
  2297. /* --------------------------------------------------------------------- */
  2298.  
  2299. get_lsys_name()        /* get the Lsystem formula name */
  2300. {
  2301.    int numentries, i;
  2302.    FILE *File;
  2303.    char buf[201];
  2304.    long point;
  2305.    long file_offset,name_offset;
  2306.  
  2307.    for (i = 0; i < MaxFormNameChoices; i++) {
  2308.       FormNameChoices[i][0] = 0;
  2309.       win_choices[i] = FormNameChoices[i];
  2310.       }
  2311.  
  2312.    if ((File = fopen(LFileName, "rb")) == NULL) {
  2313.       sprintf(buf,"I Can't find %s", LFileName);
  2314.       stopmsg(1,buf);
  2315.       LName[0] = 0;
  2316.       return(-1);
  2317.       }
  2318.  
  2319.    numentries = 0;
  2320.    file_offset = -1;
  2321.    while (1) {
  2322.       int c,len;
  2323.       do {
  2324.      ++file_offset;
  2325.      c = getc(File);
  2326.      } while (c == ' ' /* skip white space */
  2327.            || c == '\t' || c == '\n' || c == '\r');
  2328.       if (c == ';') {
  2329.      do {
  2330.         ++file_offset;
  2331.         c = getc(File);
  2332.         } while (c != '\n' && c != EOF && c != '\x1a');
  2333.      if (c == EOF || c == '\x1a') break;
  2334.      continue;
  2335.      }
  2336.       name_offset = file_offset;
  2337.       len = 0; /* next equiv roughly to fscanf(..,"%40[^ \n\r\t({\x1a]",buf) */
  2338.       while (c != ' ' && c != '\t' && c != '('
  2339.     && c != '{' && c != '\n' && c != '\r' && c != EOF && c != '\x1a') {
  2340.      if (len < 40) buf[len++] = c;
  2341.      c = getc(File);
  2342.      ++file_offset;
  2343.      }
  2344.       buf[len] = 0;
  2345.       while (c != '{' && c != '\n' && c != '\r' && c != EOF && c != '\x1a') {
  2346.      c = getc(File);
  2347.      ++file_offset;
  2348.      }
  2349.       if (c == '{') {
  2350.      while (c != '}' && c != EOF && c != '\x1a') {
  2351.         c = getc(File);
  2352.         ++file_offset;
  2353.         }
  2354.      if (c != '}') break;
  2355.      buf[ITEMNAMELEN] = 0;
  2356.      if (buf[0] != 0 && stricmp(buf,"comment") != 0) {
  2357.         lstrcpy(FormNameChoices[numentries],buf);
  2358.         memcpy((char *)&FormNameChoices[numentries][21],
  2359.             (char *)&name_offset,4);
  2360.         if (++numentries >= MaxFormNameChoices) {
  2361.            sprintf(buf,"Too many entries in file, first %d used",
  2362.                MaxFormNameChoices);
  2363.            stopmsg(0,buf);
  2364.            break;
  2365.            }
  2366.         }
  2367.      }
  2368.       else
  2369.      if (c == EOF || c == '\x1a') break;
  2370.       }
  2371.    fclose(File);
  2372.  
  2373.    win_numchoices = numentries;
  2374.    qsort(FormNameChoices,win_numchoices,25,
  2375.          (int(*)(const void *, const void *))strcmp);
  2376.    return(0);
  2377. }
  2378.  
  2379. cant_clip()
  2380. {
  2381. MessageBox (
  2382.    GetFocus(),
  2383.    winfract_msg99,
  2384.    winfract_msg01,
  2385.     MB_ICONSTOP | MB_OK);
  2386.     return(TRUE);
  2387. }
  2388.