home *** CD-ROM | disk | FTP | other *** search
/ InfoMagic Source Code 1993 July / THE_SOURCE_CODE_CD_ROM.iso / X / mit / extensions / server / xinput / xchgfctl.c < prev    next >
Encoding:
C/C++ Source or Header  |  1991-05-14  |  14.6 KB  |  627 lines

  1. /* $Header: xchgfctl.c,v 1.13 91/05/14 12:21:54 rws Exp $ */
  2.  
  3. /************************************************************
  4. Copyright (c) 1989 by Hewlett-Packard Company, Palo Alto, California, and the 
  5. Massachusetts Institute of Technology, Cambridge, Massachusetts.
  6.  
  7.             All Rights Reserved
  8.  
  9. Permission to use, copy, modify, and distribute this software and its
  10. documentation for any purpose and without fee is hereby granted,
  11. provided that the above copyright notice appear in all copies and that
  12. both that copyright notice and this permission notice appear in
  13. supporting documentation, and that the names of Hewlett-Packard or MIT not be
  14. used in advertising or publicity pertaining to distribution of the
  15. software without specific, written prior permission.
  16.  
  17. HEWLETT-PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
  18. ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
  19. HEWLETT-PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
  20. ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
  21. WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
  22. ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
  23. SOFTWARE.
  24.  
  25. ********************************************************/
  26.  
  27. /********************************************************************
  28.  *
  29.  *  Change feedback control attributes for an extension device.
  30.  *
  31.  */
  32.  
  33. #define     NEED_EVENTS            /* for inputstr.h    */
  34. #define     NEED_REPLIES
  35. #include "X.h"                /* for inputstr.h    */
  36. #include "Xproto.h"            /* Request macro     */
  37. #include "inputstr.h"            /* DeviceIntPtr         */
  38. #include "XI.h"
  39. #include "XIproto.h"            /* control constants */
  40.  
  41. #define DO_ALL    (-1)
  42.  
  43. extern    int     IReqCode;
  44. extern    int    BadDevice;
  45. DeviceIntPtr    LookupDeviceIntRec();
  46.  
  47. /***********************************************************************
  48.  *
  49.  * This procedure changes the control attributes for an extension device,
  50.  * for clients on machines with a different byte ordering than the server.
  51.  *
  52.  */
  53.  
  54. int
  55. SProcXChangeFeedbackControl(client)
  56.     register ClientPtr client;
  57.     {
  58.     register char n;
  59.  
  60.     REQUEST(xChangeFeedbackControlReq);
  61.     swaps(&stuff->length, n);
  62.     swapl(&stuff->mask, n);
  63.     return(ProcXChangeFeedbackControl(client));
  64.     }
  65.  
  66. /***********************************************************************
  67.  *
  68.  * Change the control attributes.
  69.  *
  70.  */
  71.  
  72. ProcXChangeFeedbackControl(client)
  73.     ClientPtr client;
  74.     {
  75.     int len;
  76.     DeviceIntPtr dev;
  77.     KbdFeedbackPtr k;
  78.     PtrFeedbackPtr p;
  79.     IntegerFeedbackPtr i;
  80.     StringFeedbackPtr s;
  81.     BellFeedbackPtr b;
  82.     LedFeedbackPtr l;
  83.  
  84.     REQUEST(xChangeFeedbackControlReq);
  85.     REQUEST_AT_LEAST_SIZE(xChangeFeedbackControlReq);
  86.  
  87.     len = stuff->length - (sizeof(xChangeFeedbackControlReq) >>2);
  88.     dev = LookupDeviceIntRec (stuff->deviceid);
  89.     if (dev == NULL)
  90.     {
  91.     SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  92.         BadDevice);
  93.     return Success;
  94.     }
  95.  
  96.     switch (stuff->feedbackid)
  97.     {
  98.     case KbdFeedbackClass:
  99.         if (len != (sizeof(xKbdFeedbackCtl)>>2))
  100.         {
  101.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 
  102.             0, BadLength);
  103.         return Success;
  104.         }
  105.         for (k=dev->kbdfeed; k; k=k->next)
  106.         if (k->ctrl.id == ((xKbdFeedbackCtl *) &stuff[1])->id)
  107.             {
  108.             ChangeKbdFeedback (client, dev, stuff->mask, k, &stuff[1]);
  109.             return Success;
  110.             }
  111.         break;
  112.     case PtrFeedbackClass:
  113.         if (len != (sizeof(xPtrFeedbackCtl)>>2))
  114.         {
  115.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 
  116.             0, BadLength);
  117.         return Success;
  118.         }
  119.         for (p=dev->ptrfeed; p; p=p->next)
  120.         if (p->ctrl.id == ((xPtrFeedbackCtl *) &stuff[1])->id)
  121.             {
  122.             ChangePtrFeedback (client, dev, stuff->mask, p, &stuff[1]);
  123.             return Success;
  124.             }
  125.         break;
  126.     case StringFeedbackClass:
  127.         {
  128.         register char n;
  129.         xStringFeedbackCtl *f = ((xStringFeedbackCtl *) &stuff[1]);
  130.         if (client->swapped)
  131.         {
  132.         swaps(&f->num_keysyms,n);
  133.         }
  134.         if (len != ((sizeof(xStringFeedbackCtl)>>2) + f->num_keysyms))
  135.         {
  136.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 
  137.             0, BadLength);
  138.         return Success;
  139.         }
  140.         for (s=dev->stringfeed; s; s=s->next)
  141.         if (s->ctrl.id == ((xStringFeedbackCtl *) &stuff[1])->id)
  142.             {
  143.             ChangeStringFeedback (client, dev, stuff->mask,s,&stuff[1]);
  144.             return Success;
  145.             }
  146.         break;
  147.         }
  148.     case IntegerFeedbackClass:
  149.         if (len != (sizeof(xIntegerFeedbackCtl)>>2))
  150.         {
  151.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 
  152.             0, BadLength);
  153.         return Success;
  154.         }
  155.         for (i=dev->intfeed; i; i=i->next)
  156.         if (i->ctrl.id == ((xIntegerFeedbackCtl *) &stuff[1])->id)
  157.             {
  158.             ChangeIntegerFeedback (client, dev,stuff->mask,i,&stuff[1]);
  159.             return Success;
  160.             }
  161.         break;
  162.     case LedFeedbackClass:
  163.         if (len != (sizeof(xLedFeedbackCtl)>>2))
  164.         {
  165.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 
  166.             0, BadLength);
  167.         return Success;
  168.         }
  169.         for (l=dev->leds; l; l=l->next)
  170.         if (l->ctrl.id == ((xLedFeedbackCtl *) &stuff[1])->id)
  171.             {
  172.             ChangeLedFeedback (client, dev, stuff->mask, l, &stuff[1]);
  173.             return Success;
  174.             }
  175.         break;
  176.     case BellFeedbackClass:
  177.         if (len != (sizeof(xBellFeedbackCtl)>>2))
  178.         {
  179.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 
  180.             0, BadLength);
  181.         return Success;
  182.         }
  183.         for (b=dev->bell; b; b=b->next)
  184.         if (b->ctrl.id == ((xBellFeedbackCtl *) &stuff[1])->id)
  185.             {
  186.             ChangeBellFeedback (client, dev, stuff->mask, b, &stuff[1]);
  187.             return Success;
  188.             }
  189.         break;
  190.     default:
  191.         break;
  192.     }
  193.  
  194.     SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, BadMatch);
  195.     return Success;
  196.     } 
  197.  
  198. /******************************************************************************
  199.  *
  200.  * This procedure changes KbdFeedbackClass data.
  201.  *
  202.  */
  203.  
  204. ChangeKbdFeedback (client, dev, mask, k, f)
  205.     ClientPtr client;
  206.     DeviceIntPtr dev;
  207.     unsigned long     mask;
  208.     KbdFeedbackPtr    k;
  209.     xKbdFeedbackCtl     *f;
  210.     {
  211.     register char n;
  212.     KeybdCtrl kctrl;
  213.     int t;
  214.     int key = DO_ALL;
  215.  
  216.     if (client->swapped)
  217.     {
  218.     swaps(&f->length,n);
  219.     swaps(&f->pitch,n);
  220.     swaps(&f->duration,n);
  221.     swapl(&f->led_mask,n);
  222.     swapl(&f->led_values,n);
  223.     }
  224.  
  225.     kctrl = k->ctrl;
  226.     if (mask & DvKeyClickPercent)
  227.     {
  228.     t = f->click;
  229.     if (t == -1)
  230.         t = defaultKeyboardControl.click;
  231.     else if (t < 0 || t > 100)
  232.         {
  233.         client->errorValue = t;
  234.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  235.         BadValue);
  236.         return Success;
  237.         }
  238.     kctrl.click = t;
  239.         }
  240.  
  241.     if (mask & DvPercent)
  242.     {
  243.     t = f->percent;
  244.     if (t == -1)
  245.         t = defaultKeyboardControl.bell;
  246.     else if (t < 0 || t > 100)
  247.         {
  248.         client->errorValue = t;
  249.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  250.         BadValue);
  251.         return Success;
  252.         }
  253.     kctrl.bell = t;
  254.     }
  255.  
  256.     if (mask & DvPitch)
  257.     {
  258.     t = f->pitch;
  259.     if (t == -1)
  260.         t = defaultKeyboardControl.bell_pitch;
  261.     else if (t < 0)
  262.         {
  263.         client->errorValue = t;
  264.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  265.         BadValue);
  266.         return Success;
  267.         }
  268.     kctrl.bell_pitch = t;
  269.     }
  270.  
  271.     if (mask & DvDuration)
  272.     {
  273.     t = f->duration;
  274.     if (t == -1)
  275.         t = defaultKeyboardControl.bell_duration;
  276.     else if (t < 0)
  277.         {
  278.         client->errorValue = t;
  279.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  280.         BadValue);
  281.         return Success;
  282.         }
  283.     kctrl.bell_duration = t;
  284.         }
  285.  
  286.     if (mask & DvLed)
  287.         {
  288.     kctrl.leds &= ~(f->led_mask);
  289.     kctrl.leds |= (f->led_mask & f->led_values);
  290.         }
  291.  
  292.     if (mask & DvKey)
  293.     {
  294.     key = (KeyCode) f->key;
  295.     if (key < 8 || key > 255)
  296.         {
  297.         client->errorValue = key;
  298.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  299.         BadValue);
  300.         return Success;
  301.         }
  302.     if (!(mask & DvAutoRepeatMode))
  303.         {
  304.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  305.         BadMatch);
  306.         return Success;
  307.         }
  308.     }
  309.  
  310.     if (mask & DvAutoRepeatMode)
  311.     {
  312.     int index = (key >> 3);
  313.     int kmask = (1 << (key & 7));
  314.     t = (CARD8) f->auto_repeat_mode;
  315.     if (t == AutoRepeatModeOff)
  316.         {
  317.         if (key == DO_ALL)
  318.         kctrl.autoRepeat = FALSE;
  319.         else
  320.         kctrl.autoRepeats[index] &= ~kmask;
  321.         }
  322.     else if (t == AutoRepeatModeOn)
  323.         {
  324.         if (key == DO_ALL)
  325.         kctrl.autoRepeat = TRUE;
  326.         else
  327.         kctrl.autoRepeats[index] |= kmask;
  328.         }
  329.     else if (t == AutoRepeatModeDefault)
  330.         {
  331.         if (key == DO_ALL)
  332.         kctrl.autoRepeat = defaultKeyboardControl.autoRepeat;
  333.         else
  334.         kctrl.autoRepeats[index] &= ~kmask;
  335.         kctrl.autoRepeats[index] =
  336.             (kctrl.autoRepeats[index] & ~kmask) |
  337.             (defaultKeyboardControl.autoRepeats[index] & kmask);
  338.         }
  339.     else
  340.         {
  341.         client->errorValue = t;
  342.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  343.         BadValue);
  344.         return Success;
  345.         }
  346.         }
  347.  
  348.     k->ctrl = kctrl;
  349.     (*k->CtrlProc)(dev, &k->ctrl);
  350.     return Success;
  351.     }
  352.  
  353. /******************************************************************************
  354.  *
  355.  * This procedure changes PtrFeedbackClass data.
  356.  *
  357.  */
  358.  
  359. ChangePtrFeedback (client, dev, mask, p, f)
  360.     ClientPtr         client;
  361.     DeviceIntPtr     dev;
  362.     unsigned long     mask;
  363.     PtrFeedbackPtr     p;
  364.     xPtrFeedbackCtl     *f;
  365.     {
  366.     register char n;
  367.     PtrCtrl pctrl;        /* might get BadValue part way through */
  368.  
  369.     if (client->swapped)
  370.     {
  371.     swaps(&f->length,n);
  372.     swaps(&f->num,n);
  373.     swaps(&f->denom,n);
  374.     swaps(&f->thresh,n);
  375.     }
  376.  
  377.     pctrl = p->ctrl;
  378.     if (mask & DvAccelNum)
  379.     {
  380.     int    accelNum;
  381.  
  382.     accelNum = f->num;
  383.     if (accelNum == -1)
  384.         pctrl.num = defaultPointerControl.num;
  385.     else if (accelNum < 0)
  386.         {
  387.         client->errorValue = accelNum;
  388.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  389.         BadValue);
  390.         return Success;
  391.         }
  392.     else pctrl.num = accelNum;
  393.     }
  394.  
  395.     if (mask & DvAccelDenom)
  396.     {
  397.     int    accelDenom;
  398.  
  399.     accelDenom = f->denom;
  400.     if (accelDenom == -1)
  401.         pctrl.den = defaultPointerControl.den;
  402.     else if (accelDenom <= 0)
  403.         {
  404.         client->errorValue = accelDenom;
  405.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  406.         BadValue);
  407.         return Success;
  408.         }
  409.     else pctrl.den = accelDenom;
  410.         }
  411.  
  412.     if (mask & DvThreshold)
  413.     {
  414.     int    threshold;
  415.  
  416.     threshold = f->thresh;
  417.     if (threshold == -1)
  418.         pctrl.threshold = defaultPointerControl.threshold;
  419.     else if (threshold < 0)
  420.         {
  421.         client->errorValue = threshold;
  422.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  423.         BadValue);
  424.         return Success;
  425.         }
  426.     else pctrl.threshold = threshold;
  427.         }
  428.  
  429.     p->ctrl = pctrl;
  430.     (*p->CtrlProc)(dev, &p->ctrl);
  431.     return Success;
  432.     }
  433.  
  434. /******************************************************************************
  435.  *
  436.  * This procedure changes IntegerFeedbackClass data.
  437.  *
  438.  */
  439.  
  440. ChangeIntegerFeedback (client, dev, mask, i, f)
  441.     ClientPtr             client;
  442.     DeviceIntPtr         dev;
  443.     unsigned long         mask;
  444.     IntegerFeedbackPtr         i;
  445.     xIntegerFeedbackCtl     *f;
  446.     {
  447.     register char n;
  448.  
  449.     if (client->swapped)
  450.     {
  451.     swaps(&f->length,n);
  452.     swapl(&f->int_to_display,n);
  453.     }
  454.  
  455.     i->ctrl.integer_displayed = f->int_to_display;
  456.     (*i->CtrlProc)(dev, &i->ctrl);
  457.     return Success;
  458.     }
  459.  
  460. /******************************************************************************
  461.  *
  462.  * This procedure changes StringFeedbackClass data.
  463.  *
  464.  */
  465.  
  466. ChangeStringFeedback (client, dev, mask, s, f)
  467.     ClientPtr         client;
  468.     DeviceIntPtr     dev;
  469.     unsigned long     mask;
  470.     StringFeedbackPtr     s;
  471.     xStringFeedbackCtl     *f;
  472.     {
  473.     register char n;
  474.     register long *p;
  475.     int        i, j, len;
  476.     KeySym    *syms, *sup_syms;
  477.  
  478.     syms = (KeySym *) (f+1);
  479.     if (client->swapped)
  480.     {
  481.     swaps(&f->length,n);    /* swapped num_keysyms in calling proc */
  482.     p = (long *) (syms);
  483.     for (i=0; i<f->num_keysyms; i++)
  484.         {
  485.         swapl(p, n);
  486.         p++;
  487.         }
  488.     }
  489.  
  490.     if (f->num_keysyms > s->ctrl.max_symbols)
  491.     {
  492.     SendErrorToClient(client, IReqCode, X_ChangeFeedbackControl, 0, 
  493.         BadValue);
  494.     return Success;
  495.     }
  496.     sup_syms = s->ctrl.symbols_supported;
  497.     for (i=0; i<f->num_keysyms; i++)
  498.     {
  499.         for (j=0; j<s->ctrl.num_symbols_supported; j++)
  500.         if (*(syms+i) == *(sup_syms+j))
  501.         break;
  502.     if (j==s->ctrl.num_symbols_supported)
  503.         {
  504.         SendErrorToClient(client, IReqCode, X_ChangeFeedbackControl, 0, 
  505.         BadMatch);
  506.         return Success;
  507.         }
  508.     }
  509.  
  510.     s->ctrl.num_symbols_displayed  = f->num_keysyms;
  511.     for (i=0; i<f->num_keysyms; i++)
  512.     *(s->ctrl.symbols_displayed+i) = *(syms+i);
  513.     (*s->CtrlProc)(dev, &s->ctrl);
  514.     return Success;
  515.     }
  516.  
  517. /******************************************************************************
  518.  *
  519.  * This procedure changes BellFeedbackClass data.
  520.  *
  521.  */
  522.  
  523. ChangeBellFeedback (client, dev, mask, b, f)
  524.     ClientPtr         client;
  525.     DeviceIntPtr     dev;
  526.     unsigned long     mask;
  527.     BellFeedbackPtr     b;
  528.     xBellFeedbackCtl     *f;
  529.     {
  530.     register char n;
  531.     int t;
  532.     BellCtrl bctrl;        /* might get BadValue part way through */
  533.  
  534.     if (client->swapped)
  535.     {
  536.     swaps(&f->length,n);
  537.     swaps(&f->pitch,n);
  538.     swaps(&f->duration,n);
  539.     }
  540.  
  541.     bctrl = b->ctrl;
  542.     if (mask & DvPercent)
  543.     {
  544.     t = f->percent;
  545.     if (t == -1)
  546.         t = defaultKeyboardControl.bell;
  547.     else if (t < 0 || t > 100)
  548.         {
  549.         client->errorValue = t;
  550.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  551.         BadValue);
  552.         return Success;
  553.         }
  554.     bctrl.percent = t;
  555.     }
  556.  
  557.     if (mask & DvPitch)
  558.     {
  559.     t = f->pitch;
  560.     if (t == -1)
  561.         t = defaultKeyboardControl.bell_pitch;
  562.     else if (t < 0)
  563.         {
  564.         client->errorValue = t;
  565.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  566.         BadValue);
  567.         return Success;
  568.         }
  569.     bctrl.pitch = t;
  570.     }
  571.  
  572.     if (mask & DvDuration)
  573.     {
  574.     t = f->duration;
  575.     if (t == -1)
  576.         t = defaultKeyboardControl.bell_duration;
  577.     else if (t < 0)
  578.         {
  579.         client->errorValue = t;
  580.         SendErrorToClient (client, IReqCode, X_ChangeFeedbackControl, 0, 
  581.         BadValue);
  582.         return Success;
  583.         }
  584.     bctrl.duration = t;
  585.         }
  586.     b->ctrl = bctrl;
  587.     (*b->CtrlProc)(dev, &b->ctrl);
  588.     return Success;
  589.     }
  590.  
  591. /******************************************************************************
  592.  *
  593.  * This procedure changes LedFeedbackClass data.
  594.  *
  595.  */
  596.  
  597. ChangeLedFeedback (client, dev, mask, l, f)
  598.     ClientPtr         client;
  599.     DeviceIntPtr     dev;
  600.     unsigned long     mask;
  601.     LedFeedbackPtr     l;
  602.     xLedFeedbackCtl     *f;
  603.     {
  604.     register char n;
  605.     LedCtrl lctrl;        /* might get BadValue part way through */
  606.  
  607.     if (client->swapped)
  608.     {
  609.     swaps(&f->length,n);
  610.     swapl(&f->led_values,n);
  611.     swapl(&f->led_mask,n);
  612.     }
  613.  
  614.     f->led_mask &= l->ctrl.led_mask;    /* set only supported leds */
  615.     f->led_values &= l->ctrl.led_mask;    /* set only supported leds */
  616.     if (mask & DvLed)
  617.         {
  618.     lctrl.led_mask = f->led_mask;
  619.     lctrl.led_values = f->led_values;
  620.     (*l->CtrlProc)(dev, &lctrl);
  621.     l->ctrl.led_values &= ~(f->led_mask);        /* zero changed leds */
  622.     l->ctrl.led_values |= (f->led_mask & f->led_values);/* OR in set leds*/
  623.         }
  624.  
  625.     return Success;
  626.     }
  627.