home *** CD-ROM | disk | FTP | other *** search
/ NeXTSTEP 3.2 (Developer) / NS_dev_3.2.iso / NextDeveloper / Headers / drivers / event_status_driver.h
Text File  |  1992-07-13  |  5KB  |  134 lines

  1. /******************************************************************************
  2.     event_status_driver.h
  3.     API for the events status driver.
  4.     This file contains public API.
  5.     mpaque 11Oct91
  6.     
  7.     Copyright 1991 NeXT Computer, Inc.
  8.     
  9.     Modified:
  10.     
  11. ******************************************************************************/
  12.  
  13. #ifndef _DRIVERS_EVENT_STATUS_DRIVER_
  14. #define _DRIVERS_EVENT_STATUS_DRIVER_
  15.  
  16. #import <mach/port.h>
  17. #import <bsd/dev/machine/event.h>
  18. #import <objc/objc.h>        /* BOOL type */
  19. #import <bsd/dev/ev_types.h>
  20.  
  21.  
  22. /*
  23.  * Event System Handle:
  24.  *
  25.  * Information used by the system between calls to NXOpenEventSystem and
  26.  * NXCloseEventSystem.  The application should not
  27.  * access any of the elements of this structure.
  28.  */
  29. typedef struct _NXEventHandle_{
  30.     union {
  31.         int        fd;
  32.         port_t    port;
  33.     } var;
  34. } *NXEventHandle;
  35.  
  36. #ifndef _NXSIZE_    /* FIXME: Pull this when i386/event.h is in sync */
  37. /*
  38.  * Floating point co-ordinates for an event, in a format
  39.  * compatible with NXSize, as defined in dpsclient/event.h.
  40.  *
  41.  * We can't reference dpsclient/event.h directly here for ugly
  42.  * internal project management reasons.
  43.  */
  44. typedef float _NXCoord_;
  45.  
  46. typedef struct __NXSize_ {
  47.     _NXCoord_    width, height;
  48. } _NXSize_;
  49. #endif _NXSIZE_
  50.  
  51. /* Open and Close */
  52. NXEventHandle NXOpenEventStatus(void);
  53. void NXCloseEventStatus(NXEventHandle handle);
  54.  
  55. /* Status */
  56. extern NXEventSystemInfoType NXEventSystemInfo(NXEventHandle handle,
  57.                 char *flavor,
  58.                 int *evs_info,
  59.                 unsigned int *evs_info_cnt);
  60. /* Keyboard */
  61. extern void NXSetKeyRepeatInterval(NXEventHandle handle, double seconds);
  62. extern double NXKeyRepeatInterval(NXEventHandle handle);
  63. extern void NXSetKeyRepeatThreshold(NXEventHandle handle, double threshold);
  64. extern double NXKeyRepeatThreshold(NXEventHandle handle);
  65. extern NXKeyMapping *NXSetKeyMapping(NXEventHandle h, NXKeyMapping *keymap);
  66. extern int NXKeyMappingLength(NXEventHandle handle);
  67. extern NXKeyMapping *NXGetKeyMapping(NXEventHandle h, NXKeyMapping *keymap);
  68. extern void NXResetKeyboard(NXEventHandle handle);
  69.  
  70. /* Mouse */
  71. extern void NXSetClickTime(NXEventHandle handle, double seconds);
  72. extern double NXClickTime(NXEventHandle handle);
  73. extern void NXSetClickSpace(NXEventHandle handle, _NXSize_ *area);
  74. extern void NXGetClickSpace(NXEventHandle handle, _NXSize_ *area);
  75. extern void NXSetMouseScaling(NXEventHandle handle, NXMouseScaling *scaling);
  76. extern void NXGetMouseScaling(NXEventHandle handle, NXMouseScaling *scaling);
  77. extern void NXEnableMouseButton(NXEventHandle handle, NXMouseButton button);
  78. extern NXMouseButton NXMouseButtonEnabled(NXEventHandle handle);
  79. extern void NXResetMouse(NXEventHandle handle);
  80.  
  81. /* Screen Brightness and Auto-dimming */
  82. extern void NXSetAutoDimThreshold(NXEventHandle handle, double seconds);
  83. extern double NXAutoDimThreshold(NXEventHandle handle);
  84. extern double NXAutoDimTime(NXEventHandle handle);
  85. extern void NXSetAutoDimState(NXEventHandle handle, BOOL dimmed);
  86. extern BOOL NXAutoDimState(NXEventHandle handle);
  87. extern void NXSetScreenBrightness(NXEventHandle handle, double level);
  88. extern double NXScreenBrightness(NXEventHandle handle);
  89. extern void NXSetAutoDimBrightness(NXEventHandle handle, double level);
  90. extern double NXAutoDimBrightness(NXEventHandle handle);
  91.  
  92. /* Speaker Volume */
  93. extern void NXSetCurrentVolume(NXEventHandle handle, double volume);
  94. extern double NXCurrentVolume(NXEventHandle handle);
  95.  
  96. /* Wait Cursor */
  97. extern void NXSetWaitCursorThreshold(NXEventHandle handle, double seconds);
  98. extern double NXWaitCursorThreshold(NXEventHandle handle);
  99. extern void NXSetWaitCursorSustain(NXEventHandle handle, double seconds);
  100. extern double NXWaitCursorSustain(NXEventHandle handle);
  101. extern void NXSetWaitCursorFrameInterval(NXEventHandle handle, double seconds);
  102. extern double NXWaitCursorFrameInterval(NXEventHandle handle);
  103.  
  104. /*
  105.  * Generic calls.  Argument values are device and architecture dependent.
  106.  * This API is provided for the convenience of special device users.  Code
  107.  * which is intended to be portable across multiple platforms and architectures
  108.  * should not use the following functions.
  109.  */
  110. extern int NXEvSetParameterInt(NXEventHandle handle,
  111.             char *parameterName,
  112.             unsigned int *parameterArray,
  113.             unsigned int count);
  114.  
  115. extern int NXEvSetParameterChar(NXEventHandle handle,
  116.             char *parameterName,
  117.             unsigned char *parameterArray,
  118.             unsigned int count);
  119.  
  120. extern int NXEvGetParameterInt(NXEventHandle handle,
  121.             char *parameterName,
  122.             unsigned int maxCount,
  123.             unsigned int *parameterArray,
  124.             unsigned int *returnedCount);
  125.  
  126. extern int NXEvGetParameterChar(NXEventHandle handle,
  127.             char *parameterName,
  128.             unsigned int maxCount,
  129.             unsigned char *parameterArray,
  130.             unsigned int *returnedCount);
  131.  
  132. #endif /*_DRIVERS_EVENT_STATUS_DRIVER_ */
  133.  
  134.