home *** CD-ROM | disk | FTP | other *** search
/ The Fred Fish Collection 1.5 / ffcollection-1-5-1992-11.iso / ff_disks / 200-299 / ff238a.lzh / DMouse / dmouse.c < prev    next >
C/C++ Source or Header  |  1989-08-24  |  7KB  |  267 lines

  1.  
  2. /*
  3.  *  DMOUSE.C    V1.20  3 August 1989
  4.  *
  5.  *  (c)Copyright 1989 by Matthew Dillon, All Rights Reserved
  6.  *
  7.  *  DMOUSE QUIT
  8.  *  DMOUSE -a# -t# -s# -m# -c# -p# -w# -Ln -lqqqq -Rqqqq -An -Kcccc -Qqqqq -C cmd
  9.  *       -d#
  10.  *
  11.  *  -a#     # = acceleration, default 3.    1 to disable
  12.  *  -t#     # = mouse threshold before acceleration takes effect, def. 0
  13.  *        (in pixels/event)
  14.  *  -s#     # = screen timeout, default 5min,    0 to disable
  15.  *  -m#     # = pointer timeout, default 5 secs,0 to disable
  16.  *  -c#     # = # of clicks to bring window to front
  17.  *  -p#     # = input device priority
  18.  *  -w#     1 = Use WindowToFront()/WindowToBack()  else    (workbench users)
  19.  *        0 = Use UpFrontLayer(), etc...                  (cli users)
  20.  *  -L0     Disable LeftMouseButton->WindowToFront (LMB+RMB->ToBack)
  21.  *  -L1     Enable it
  22.  *  -lqqqq  Set qualifier + LMB for Window to front (default none)
  23.  *  -Rqqqq  Set qualifier + RMB for Window/ScreenToBack (default LMB)
  24.  *  -A0     Disable Auto-Activate window on mouse move
  25.  *  -A1     Enable it, keyhit-auto-activate disabled    (bit 0 = mouse aa)
  26.  *  -A3     Enable it, keyhit-auto-activate enabled    (bit 1 = key aa)
  27.  *  -Kcccc  Set key code in hex that activates cmd, def is escape
  28.  *  -Qqqqq  Set key qualifier in hex for keycode, def is left-amiga
  29.  *  -C cmd  Set command (must be last option on command line), def NewCli
  30.  *
  31.  *  -d#     Debug mode    (if compiled in)
  32.  */
  33.  
  34. #include <stdio.h>
  35. #include "dmouse.h"
  36.  
  37. #define VERSION 20
  38.  
  39. #ifdef LATTICE
  40. #include <dos.h>
  41. #include <stdlib.h>
  42. #include <string.h>
  43.  
  44. int __stdargs CXBRK(void);
  45.  
  46. __stdargs    /*  bug in lcr.lib  */
  47. CXBRK()
  48. {
  49.     return(0);
  50. }
  51.  
  52. #else
  53. extern int Enable_Abort;    /*    CLI break enable    */
  54. #endif
  55.  
  56. long    ahtoi ARGS((char *));
  57. void    main ARGS((int, char **));
  58.  
  59. void
  60. main(ac, av)
  61. int ac;
  62. char *av[];
  63. {
  64.     reg short i, j, len;
  65.     reg long val;
  66.     reg char *ptr;
  67.     reg DMS  *dms = (DMS *)FindPort(PORTNAME);
  68.     short   exists = (dms != NULL);
  69.     short   create = (dms == NULL);
  70.     short   quit = 0;
  71.  
  72. #ifndef LATTICE
  73.     Enable_Abort = 0;
  74. #endif
  75.     if (create) {
  76.     dms = AllocMem(sizeof(DMS), MEMF_PUBLIC|MEMF_CLEAR);
  77.     dms->IPri = 51;
  78.     dms->Version = VERSION;
  79.     dms->Acc = 3;
  80.     dms->STo = 5*60;
  81.     dms->MTo = 5;
  82.     dms->Code = 0x45;
  83.     dms->Qual = 0x8040;
  84.     dms->RQual= 0x4000;
  85.     dms->Clicks = 1;
  86.     dms->CLeft = dms->Clicks;
  87.     strcpy(dms->Cmd, "newcli");
  88.     dms->LMBEnable = 1;
  89.     dms->AAEnable = 3;
  90.     dms->NoSprData = AllocMem(12, MEMF_PUBLIC|MEMF_CHIP|MEMF_CLEAR);
  91.     dms->NoSprData[0] = 0xFE00;
  92.     dms->NoSprData[1] = 0xFF00;
  93.     }
  94.  
  95.     for (i = 1; i < ac; ++i) {
  96.     ptr = av[i];
  97.     if (strcmp(ptr, "QUIT") == 0 || strcmp(ptr, "quit") == 0) {
  98.         quit = 1;
  99.         create = 0;
  100.         break;
  101.     }
  102.     val = atoi(ptr+2);
  103.     if (*ptr != '-')
  104.         goto def;
  105.  
  106.     switch(ptr[1]) {
  107.     case 'd':
  108.         dms->Debug = val;
  109.         break;
  110.     case 'a':
  111.         dms->Acc = val;
  112.         break;
  113.     case 'c':
  114.         if (val < 1)
  115.         val = 1;
  116.         dms->Clicks = dms->CLeft = val;
  117.         break;
  118.     case 'w':
  119.         dms->Workbench = val;
  120.         break;
  121.     case 'p':
  122.         dms->IPri = val;
  123.         break;
  124.     case 't':
  125.         dms->AThresh = val;
  126.         break;
  127.     case 's':
  128.         dms->STo = val;
  129.         break;
  130.     case 'm':
  131.         dms->MTo = val;
  132.         break;
  133.     case 'L':
  134.         dms->LMBEnable = val;
  135.         break;
  136.     case 'l':
  137.         dms->LQual = ahtoi(ptr+2);
  138.         break;
  139.     case 'R':
  140.         dms->RQual = ahtoi(ptr+2);
  141.         break;
  142.     case 'A':
  143.         dms->AAEnable = val;
  144.         break;
  145.     case 'K':
  146.         dms->Code = ahtoi(ptr+2);
  147.         break;
  148.     case 'Q':
  149.         dms->Qual = ahtoi(ptr+2) | 0x8000;
  150.         break;
  151.     case 'S':
  152.     case 'M':
  153.         puts("-S and -M options obsolete");
  154.         break;
  155.     case 'C':
  156.         for (len = strlen(ptr+2) + 2, j = i + 1; j < ac; ++j)
  157.         len += strlen(av[j]) + 1;
  158.         strcpy(dms->Cmd, ptr + 2);
  159.         for (j = i + 1; j < ac; ++j) {
  160.         if (dms->Cmd[0])
  161.             strcat(dms->Cmd, " ");
  162.         strcat(dms->Cmd, av[j]);
  163.         }
  164.         i = ac;
  165.         break;
  166.     default:    def:
  167.         puts("DMOUSE QUIT  or");
  168.         puts("DMOUSE -a# -t# -s# -m# -Ln -Rqqqq -An -Kcccc -Qqqqq -C cmd");
  169.         printf("DMouse (c)Copyright 1989, Matthew Dillon, All Rights Reserved\nV1.%02d, 3 August 1989\n\n", VERSION);
  170.         puts("Freeware, redistributable for non-profit only");
  171.         puts("  -a#     Acceleration (default 3)");
  172.         puts("  -t#     Accel. threshold (default 0)");
  173.         puts("  -s#     Screen timeout (default 300)");
  174.         puts("  -m#     Mouse timeout (default 5)");
  175.         puts("  -c#     Set # of clicks for wintofront (default 1)");
  176.         puts("  -p#     # = input device priority");
  177.         puts("  -w#     0 = use UpFrontLayer().. 1 = use WindowToFront()");
  178.         puts("  -L0/1   LMB disable/enable (default 1=enabled)");
  179.         puts("  -lqqqq  LMB qualifier wintofront (default 0=none)");
  180.         puts("  -Rqqqq  RMB qualifier wintoback (default 4000=LMB)");
  181.         puts("  -A0-3   Auto-Activate Window disable/enable. B0=mouse B1=keyboard");
  182.         puts("  -Kcccc  Command Key Code, default 45 = esc");
  183.         puts("  -Qqqqq  Command Key Qualifier, default 40 = Left Amiga");
  184.         puts("  -C cmd  cmd to run, must be last option");
  185.         puts("Note: LMB(or -R qualifier)(hold)+RMB = WindowToBack");
  186.         puts("\n");
  187.         puts("Additionaly, Most options may be modified while DMOUSE is active");
  188.         create = 0;
  189.         i = ac;
  190.         break;
  191.     }
  192.     }
  193.     dms->Reset = 1;
  194.     if (!exists && create) {
  195.     PROC *proc;
  196.     printf("Installing DMouse, ");
  197.     fflush(stdout);
  198.     dms->Port.mp_Flags = PA_IGNORE;
  199.     dms->Port.mp_Node.ln_Pri = 0;
  200.     dms->Port.mp_Node.ln_Type= NT_MSGPORT;
  201.     dms->Port.mp_Node.ln_Name= AllocMem(sizeof(PORTNAME), MEMF_PUBLIC);
  202.     strcpy(dms->Port.mp_Node.ln_Name, PORTNAME);
  203.     NewList(&dms->Port.mp_MsgList);
  204.     dms->Segment = (long)LoadSeg("l:DMouse-Handler");
  205.     if (!dms->Segment)
  206.         dms->Segment = (long)LoadSeg("DMouse-Handler");
  207.     if (!dms->Segment) {
  208.         puts("Unable to find L:DMouse-Handler");
  209.         FreeMem(dms->Port.mp_Node.ln_Name, sizeof(PORTNAME));
  210.         create = 0;
  211.     } else {
  212.         AddPort(&dms->Port);
  213.         dms->ShakeTask = FindTask(NULL);
  214.         dms->ShakeSig = AllocSignal(-1);
  215.         proc = (PROC *)CreateProc(dms->Port.mp_Node.ln_Name, 1, dms->Segment, 4096);
  216.         Wait(1 << dms->ShakeSig);
  217.         FreeSignal(dms->ShakeSig);
  218.         exists = 1;
  219.         quit = dms->StartupError;
  220.         if (quit)
  221.         puts("Handler error");
  222.         else
  223.         printf("ok.  DMouse V1.%02d, by Matthew Dillon.\n(c)Copyright 1989, Matthew Dillon, All Rights Reserved\n", VERSION);
  224.     }
  225.     }
  226.     if (quit) {
  227.     if (exists) {
  228.         printf("Removing, ");
  229.         fflush(stdout);
  230.         dms->ShakeTask = FindTask(NULL);
  231.         dms->ShakeSig = AllocSignal(-1);
  232.         Signal(dms->HandTask, SBF_C);
  233.         Wait(1 << dms->ShakeSig);
  234.         FreeSignal(dms->ShakeSig);
  235.         RemPort(&dms->Port);
  236.         FreeMem(dms->Port.mp_Node.ln_Name, sizeof(PORTNAME));
  237.         UnLoadSeg(dms->Segment);
  238.         puts("ok");
  239.     }
  240.     exists = 0;
  241.     create = 0;
  242.     }
  243.     if (!exists) {
  244.     FreeMem(dms->NoSprData, 12);
  245.     FreeMem(dms, sizeof(DMS));
  246.     }
  247. }
  248.  
  249. long
  250. ahtoi(str)
  251. reg char *str;
  252. {
  253.     reg long val = 0;
  254.     reg char c;
  255.     while (c = *str) {
  256.     val <<= 4;
  257.     if (c >= '0' && c <= '9')
  258.         val |= (c & 15);
  259.     else
  260.         val |= (c & 15) + 9;
  261.     ++str;
  262.     }
  263.     return(val);
  264. }
  265.  
  266.  
  267.