552 lines
15 KiB
C
Raw Permalink Normal View History

2020-04-22 12:56:21 -04:00
/*
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__ */