Retired Document
Important: This sample code may not represent best practices for current development. The project may use deprecated symbols and illustrate technologies and techniques that are no longer recommended.
HID_Queue_Utilities.h
// |
// File: HID_Queue_Utilities.h |
// |
// Disclaimer: IMPORTANT: This Apple software is supplied to you by Apple Inc. ("Apple") |
// in consideration of your agreement to the following terms, and your use, |
// installation, modification or redistribution of this Apple software |
// constitutes acceptance of these terms. If you do not agree with these |
// terms, please do not use, install, modify or redistribute this Apple |
// software. |
// |
// In consideration of your agreement to abide by the following terms, and |
// subject to these terms, Apple grants you a personal, non - exclusive |
// license, under Apple's copyrights in this original Apple software ( the |
// "Apple Software" ), to use, reproduce, modify and redistribute the Apple |
// Software, with or without modifications, in source and / or binary forms; |
// provided that if you redistribute the Apple Software in its entirety and |
// without modifications, you must retain this notice and the following text |
// and disclaimers in all such redistributions of the Apple Software. Neither |
// the name, trademarks, service marks or logos of Apple Inc. may be used to |
// endorse or promote products derived from the Apple Software without specific |
// prior written permission from Apple. Except as expressly stated in this |
// notice, no other rights or licenses, express or implied, are granted by |
// Apple herein, including but not limited to any patent rights that may be |
// infringed by your derivative works or by other works in which the Apple |
// Software may be incorporated. |
// |
// The Apple Software is provided by Apple on an "AS IS" basis. APPLE MAKES NO |
// WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED |
// WARRANTIES OF NON - INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A |
// PARTICULAR PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND OPERATION |
// ALONE OR IN COMBINATION WITH YOUR PRODUCTS. |
// |
// IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR |
// CONSEQUENTIAL DAMAGES ( INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
// INTERRUPTION ) ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, MODIFICATION |
// AND / OR DISTRIBUTION OF THE APPLE SOFTWARE, HOWEVER CAUSED AND WHETHER |
// UNDER THEORY OF CONTRACT, TORT ( INCLUDING NEGLIGENCE ), STRICT LIABILITY OR |
// OTHERWISE, EVEN IF APPLE HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
// |
// Copyright ( C ) 2001-2008 Apple Inc. All Rights Reserved. |
// |
#ifndef _HID_Queue_Utilities_h_ |
#define _HID_Queue_Utilities_h_ |
#include "HID_Utilities.h" |
// ================================== |
#ifdef __cplusplus |
extern "C" { |
#endif |
// ================================== |
enum |
{ |
kDeviceQueueSize = 50 // this is wired kernel memory so should be set to as small as possible |
// but should account for the maximum possible events in the queue |
// USB updates will likely occur at 100 Hz so one must account for this rate of |
// if states change quickly (updates are only posted on state changes) |
}; |
// ================================== |
// Create and open an interface to device, required prior to extracting values or building queues |
// int HIDCreateOpenDeviceInterface (void * hidDevice, pRecDevice pDevice); |
// queues specific element, performing any device queue set up required |
int HIDQueueElement (pRecDevice pDevice, pRecElement pElement); |
// adds all elements to queue, performing any device queue set up required |
int HIDQueueDevice (pRecDevice pDevice); |
// removes element for queue, if last element in queue will release queue and device |
int HIDDequeueElement (pRecDevice pDevice, pRecElement pElement); |
// completely removes all elements from queue and releases queue and device |
int HIDDequeueDevice (pRecDevice pDevice); |
// releases all device queues for quit or rebuild (must be called) |
int HIDReleaseAllDeviceQueues (void); |
// releases interface to device, should be done prior to exiting application (called from ReleaseHIDDeviceList) |
int HIDCloseReleaseInterface (pRecDevice pDevice); |
// returns true if an event is avialable for the element and fills out *pHIDEvent structure, returns false otherwise |
// pHIDEvent is a poiner to a IOHIDEventStruct, using void here for compatibility, users can cast a required |
unsigned char HIDGetEvent (pRecDevice pDevice, void * pHIDEvent); |
// returns current value for element, creating device interface as required, polling element |
// Note: this DOES NOT release the inteface so applications must properly release devices via ReleaseHIDDeviceList |
int HIDGetElementValue (pRecDevice pDevice, pRecElement pElement); |
#ifdef __cplusplus |
} |
#endif |
#endif // _HID_Queue_Utilities_h_ |
Copyright © 2008 Apple Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2008-02-08