551 lines
15 KiB
C
551 lines
15 KiB
C
/*
|
|
File: CMDeviceIntegration.h
|
|
|
|
Contains: Color Management Device Interfaces
|
|
|
|
Version: QuickTime 7.3
|
|
|
|
Copyright: (c) 2007 (c) 2000-2001 by Apple Computer, Inc., all rights reserved.
|
|
|
|
Bugs?: For bug reports, consult the following page on
|
|
the World Wide Web:
|
|
|
|
http://developer.apple.com/bugreporter/
|
|
|
|
*/
|
|
#ifndef __CMDEVICEINTEGRATION__
|
|
#define __CMDEVICEINTEGRATION__
|
|
|
|
#ifndef __MACTYPES__
|
|
#include <MacTypes.h>
|
|
#endif
|
|
|
|
#ifndef __CFSTRING__
|
|
#include <CFString.h>
|
|
#endif
|
|
|
|
#ifndef __CMAPPLICATION__
|
|
#include <CMApplication.h>
|
|
#endif
|
|
|
|
#ifndef __CMICCPROFILE__
|
|
#include <CMICCProfile.h>
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if PRAGMA_ONCE
|
|
#pragma once
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#if PRAGMA_IMPORT
|
|
#pragma import on
|
|
#endif
|
|
|
|
#if PRAGMA_STRUCT_ALIGN
|
|
#pragma options align=mac68k
|
|
#elif PRAGMA_STRUCT_PACKPUSH
|
|
#pragma pack(push, 2)
|
|
#elif PRAGMA_STRUCT_PACK
|
|
#pragma pack(2)
|
|
#endif
|
|
|
|
/*
|
|
The current versions of the data structure
|
|
containing information on registered devices.
|
|
*/
|
|
enum {
|
|
cmDeviceInfoVersion1 = 0x00010000,
|
|
cmDeviceProfileInfoVersion1 = 0x00010000,
|
|
cmDeviceProfileInfoVersion2 = 0x00020000
|
|
};
|
|
|
|
enum {
|
|
cmCurrentDeviceInfoVersion = cmDeviceInfoVersion1,
|
|
cmCurrentProfileInfoVersion = cmDeviceProfileInfoVersion1
|
|
};
|
|
|
|
/*
|
|
Certain APIs require a device ID or profile ID.
|
|
In some cases, a "default ID" can be used.
|
|
*/
|
|
enum {
|
|
cmDefaultDeviceID = 0,
|
|
cmDefaultProfileID = 0
|
|
};
|
|
|
|
/*
|
|
Possible values for device states accessible by the
|
|
CMGetDeviceState() and CMSetDeviceState() APIs.
|
|
*/
|
|
enum {
|
|
cmDeviceStateDefault = 0x00000000,
|
|
cmDeviceStateOffline = 0x00000001,
|
|
cmDeviceStateBusy = 0x00000002,
|
|
cmDeviceStateForceNotify = (long)0x80000000,
|
|
cmDeviceStateDeviceRsvdBits = 0x00FF0000,
|
|
cmDeviceStateAppleRsvdBits = (long)0xFF00FFFF
|
|
};
|
|
|
|
/*
|
|
Possible values for flags passed to the
|
|
CMIterateDeviceProfiles() API.
|
|
|
|
"Factory" profiles are registered via the
|
|
CMSetDeviceFactoryProfiles() API.
|
|
|
|
"Custom" profiles are those which are meant to take
|
|
the place of the factory profiles, as a result of
|
|
customization or calibration. These profiles are
|
|
registered via the CMSetDeviceProfiles() API.
|
|
|
|
To retrieve all of the the former for all devices,
|
|
use cmIterateFactoryDeviceProfiles as the flags
|
|
value when calling CMIterateDeviceProfiles().
|
|
|
|
To retrieve only the latter for all devices, use
|
|
the cmIterateCustomDeviceProfiles, as the flags
|
|
value when calling CMIterateDeviceProfiles().
|
|
|
|
To get the profiles in use for all devices, use
|
|
cmIterateCurrentDeviceProfiles as the flags value.
|
|
This will replace the factory profiles with any
|
|
overrides, yielding the currently used set.
|
|
|
|
To get all profiles, without replacement, use
|
|
cmIterateAllDeviceProfiles.
|
|
*/
|
|
enum {
|
|
cmIterateFactoryDeviceProfiles = 0x00000001,
|
|
cmIterateCustomDeviceProfiles = 0x00000002,
|
|
cmIterateCurrentDeviceProfiles = 0x00000003,
|
|
cmIterateAllDeviceProfiles = 0x00000004,
|
|
cmIterateDeviceProfilesMask = 0x0000000F
|
|
};
|
|
|
|
/*
|
|
Errors returned by CMDeviceIntegration APIs
|
|
*/
|
|
enum {
|
|
cmDeviceDBNotFoundErr = -4227, /* Prefs not found/loaded */
|
|
cmDeviceAlreadyRegistered = -4228, /* Re-registration of device */
|
|
cmDeviceNotRegistered = -4229, /* Device not found */
|
|
cmDeviceProfilesNotFound = -4230, /* Profiles not found */
|
|
cmInternalCFErr = -4231 /* CoreFoundation failure */
|
|
};
|
|
|
|
|
|
/*
|
|
Clients can register for notifications of device evolutions:
|
|
|
|
DeviceRegistered A new device was registered
|
|
DeviceUnregistered A device was unregistered
|
|
DeviceOnline Change to Online as a result of CMSetDeviceState
|
|
DeviceOffline Change to Offline as a result of CMSetDeviceState
|
|
DeviceState Any change to a device state
|
|
DefaultDevice A default device for any device class changed
|
|
DeviceProfiles Any change to any device's profiles
|
|
DefaultDeviceProfile The default profile for any device changed
|
|
*/
|
|
#define kCMDeviceRegisteredNotification CFSTR("CMDeviceRegisteredNotification")
|
|
#define kCMDeviceUnregisteredNotification CFSTR("CMDeviceUnregisteredNotification")
|
|
#define kCMDeviceOnlineNotification CFSTR("CMDeviceOnlineNotification")
|
|
#define kCMDeviceOfflineNotification CFSTR("CMDeviceOfflineNotification")
|
|
#define kCMDeviceStateNotification CFSTR("CMDeviceStateNotification")
|
|
#define kCMDefaultDeviceNotification CFSTR("CMDefaultDeviceNotification")
|
|
#define kCMDeviceProfilesNotification CFSTR("CMDeviceProfilesNotification")
|
|
#define kCMDefaultDeviceProfileNotification CFSTR("CMDefaultDeviceProfileNotification")
|
|
|
|
/*
|
|
Device state data.
|
|
*/
|
|
typedef UInt32 CMDeviceState;
|
|
/*
|
|
A CMDeviceID must be unique within a device's class.
|
|
*/
|
|
typedef UInt32 CMDeviceID;
|
|
/*
|
|
A CMDeviceProfileID must only be unique per device.
|
|
*/
|
|
typedef UInt32 CMDeviceProfileID;
|
|
/*
|
|
DeviceClass type.
|
|
*/
|
|
enum {
|
|
cmScannerDeviceClass = FOUR_CHAR_CODE('scnr'),
|
|
cmCameraDeviceClass = FOUR_CHAR_CODE('cmra'),
|
|
cmDisplayDeviceClass = FOUR_CHAR_CODE('mntr'),
|
|
cmPrinterDeviceClass = FOUR_CHAR_CODE('prtr'),
|
|
cmProofDeviceClass = FOUR_CHAR_CODE('pruf')
|
|
};
|
|
|
|
typedef OSType CMDeviceClass;
|
|
/*
|
|
CMDeviceScope
|
|
Structure specifying a device's or a device setting's scope.
|
|
*/
|
|
struct CMDeviceScope {
|
|
CFStringRef deviceUser; /* kCFPreferencesCurrentUser | _AnyUser */
|
|
CFStringRef deviceHost; /* kCFPreferencesCurrentHost | _AnyHost */
|
|
};
|
|
typedef struct CMDeviceScope CMDeviceScope;
|
|
typedef CMDeviceScope CMDeviceProfileScope;
|
|
/*
|
|
CMDeviceInfo
|
|
Structure containing information on a given device.
|
|
*/
|
|
struct CMDeviceInfo {
|
|
UInt32 dataVersion; /* cmDeviceInfoVersion1 */
|
|
CMDeviceClass deviceClass; /* device class */
|
|
CMDeviceID deviceID; /* device ID */
|
|
CMDeviceScope deviceScope; /* device's scope */
|
|
CMDeviceState deviceState; /* Device State flags */
|
|
CMDeviceProfileID defaultProfileID; /* Can change */
|
|
CFDictionaryRef * deviceName; /* Ptr to storage for CFDictionary of */
|
|
/* localized device names (could be nil) */
|
|
UInt32 profileCount; /* Count of registered profiles */
|
|
UInt32 reserved; /* Reserved for use by ColorSync */
|
|
};
|
|
typedef struct CMDeviceInfo CMDeviceInfo;
|
|
typedef CMDeviceInfo * CMDeviceInfoPtr;
|
|
/*
|
|
CMDeviceProfileInfo
|
|
Structure containing information on a device profile.
|
|
*/
|
|
struct CMDeviceProfileInfo {
|
|
UInt32 dataVersion; /* cmDeviceProfileInfoVersion1 */
|
|
CMDeviceProfileID profileID; /* The identifier for this profile */
|
|
CMProfileLocation profileLoc; /* The profile's location */
|
|
CFDictionaryRef profileName; /* CFDictionary of localized profile names */
|
|
UInt32 reserved; /* Reserved for use by ColorSync */
|
|
};
|
|
typedef struct CMDeviceProfileInfo CMDeviceProfileInfo;
|
|
struct NCMDeviceProfileInfo {
|
|
UInt32 dataVersion; /* cmDeviceProfileInfoVersion2 */
|
|
CMDeviceProfileID profileID; /* The identifier for this profile */
|
|
CMProfileLocation profileLoc; /* The profile's location */
|
|
CFDictionaryRef profileName; /* CFDictionary of localized profile names */
|
|
CMDeviceProfileScope profileScope; /* The scope this profile applies to */
|
|
UInt32 reserved; /* Reserved for use by ColorSync */
|
|
};
|
|
typedef struct NCMDeviceProfileInfo NCMDeviceProfileInfo;
|
|
/*
|
|
CMDeviceProfileArray
|
|
Structure containing the profiles for a device.
|
|
*/
|
|
struct CMDeviceProfileArray {
|
|
UInt32 profileCount; /* Count of profiles in array */
|
|
CMDeviceProfileInfo profiles[1]; /* The profile info records */
|
|
};
|
|
typedef struct CMDeviceProfileArray CMDeviceProfileArray;
|
|
typedef CMDeviceProfileArray * CMDeviceProfileArrayPtr;
|
|
/*
|
|
Caller-supplied iterator functions
|
|
*/
|
|
typedef CALLBACK_API_C( OSErr , CMIterateDeviceInfoProcPtr )(const CMDeviceInfo *deviceInfo, void *refCon);
|
|
typedef CALLBACK_API_C( OSErr , CMIterateDeviceProfileProcPtr )(const CMDeviceInfo *deviceInfo, const NCMDeviceProfileInfo *profileInfo, void *refCon);
|
|
/*
|
|
Device Registration
|
|
*/
|
|
/*
|
|
* CMRegisterColorDevice()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMRegisterColorDevice(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
CFDictionaryRef deviceName,
|
|
const CMDeviceScope * deviceScope);
|
|
|
|
|
|
/*
|
|
* CMUnregisterColorDevice()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMUnregisterColorDevice(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID);
|
|
|
|
|
|
/*
|
|
Default Device accessors
|
|
*/
|
|
/*
|
|
* CMSetDefaultDevice()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMSetDefaultDevice(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID);
|
|
|
|
|
|
/*
|
|
* CMGetDefaultDevice()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMGetDefaultDevice(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID * deviceID);
|
|
|
|
|
|
/*
|
|
Device Profile Registration & Access
|
|
*/
|
|
/*
|
|
* CMSetDeviceFactoryProfiles()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMSetDeviceFactoryProfiles(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
CMDeviceProfileID defaultProfID,
|
|
const CMDeviceProfileArray * deviceProfiles);
|
|
|
|
|
|
/*
|
|
* CMGetDeviceFactoryProfiles()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMGetDeviceFactoryProfiles(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
CMDeviceProfileID * defaultProfID,
|
|
UInt32 * arraySize,
|
|
CMDeviceProfileArray * deviceProfiles);
|
|
|
|
|
|
/*
|
|
* CMSetDeviceProfiles()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMSetDeviceProfiles(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
const CMDeviceProfileScope * profileScope,
|
|
const CMDeviceProfileArray * deviceProfiles);
|
|
|
|
|
|
/*
|
|
* CMGetDeviceProfiles()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMGetDeviceProfiles(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
UInt32 * arraySize,
|
|
CMDeviceProfileArray * deviceProfiles);
|
|
|
|
|
|
/*
|
|
* CMSetDeviceDefaultProfileID()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMSetDeviceDefaultProfileID(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
CMDeviceProfileID defaultProfID);
|
|
|
|
|
|
/*
|
|
* CMGetDeviceDefaultProfileID()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMGetDeviceDefaultProfileID(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
CMDeviceProfileID * defaultProfID);
|
|
|
|
|
|
/*
|
|
* CMGetDeviceProfile()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMGetDeviceProfile(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
CMDeviceProfileID profileID,
|
|
CMProfileLocation * deviceProfLoc);
|
|
|
|
|
|
/*
|
|
* CMSetDeviceProfile()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMSetDeviceProfile(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
const CMDeviceProfileScope * profileScope,
|
|
CMDeviceProfileID profileID,
|
|
const CMProfileLocation * deviceProfLoc);
|
|
|
|
|
|
/*
|
|
Other Device State/Info accessors
|
|
*/
|
|
/*
|
|
* CMSetDeviceState()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMSetDeviceState(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
CMDeviceState deviceState);
|
|
|
|
|
|
/*
|
|
* CMGetDeviceState()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMGetDeviceState(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
CMDeviceState * deviceState);
|
|
|
|
|
|
/*
|
|
* CMGetDeviceInfo()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMGetDeviceInfo(
|
|
CMDeviceClass deviceClass,
|
|
CMDeviceID deviceID,
|
|
CMDeviceInfo * deviceInfo);
|
|
|
|
|
|
/*
|
|
Device Info & Profile Iterators
|
|
*/
|
|
/*
|
|
* CMIterateColorDevices()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMIterateColorDevices(
|
|
CMIterateDeviceInfoProcPtr proc,
|
|
UInt32 * seed,
|
|
UInt32 * count,
|
|
void * refCon);
|
|
|
|
|
|
/*
|
|
* CMIterateDeviceProfiles()
|
|
*
|
|
* Availability:
|
|
* Non-Carbon CFM: not available
|
|
* CarbonLib: not available
|
|
* Mac OS X: in version 10.1 and later
|
|
*/
|
|
EXTERN_API( CMError )
|
|
CMIterateDeviceProfiles(
|
|
CMIterateDeviceProfileProcPtr proc,
|
|
UInt32 * seed,
|
|
UInt32 * count,
|
|
UInt32 flags,
|
|
void * refCon);
|
|
|
|
|
|
|
|
#if PRAGMA_STRUCT_ALIGN
|
|
#pragma options align=reset
|
|
#elif PRAGMA_STRUCT_PACKPUSH
|
|
#pragma pack(pop)
|
|
#elif PRAGMA_STRUCT_PACK
|
|
#pragma pack()
|
|
#endif
|
|
|
|
#ifdef PRAGMA_IMPORT_OFF
|
|
#pragma import off
|
|
#elif PRAGMA_IMPORT
|
|
#pragma import reset
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __CMDEVICEINTEGRATION__ */
|
|
|