]> git.saurik.com Git - apple/configd.git/blob - SystemConfiguration.fproj/SCPreferencesPrivate.h
configd-130.tar.gz
[apple/configd.git] / SystemConfiguration.fproj / SCPreferencesPrivate.h
1 /*
2 * Copyright (c) 2000-2003 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
11 * file.
12 *
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 */
23
24 #ifndef _SCPREFERENCESPRIVATE_H
25 #define _SCPREFERENCESPRIVATE_H
26
27
28 #include <sys/cdefs.h>
29 #include <AvailabilityMacros.h>
30 #include <CoreFoundation/CoreFoundation.h>
31 #include <SystemConfiguration/SCPreferences.h>
32
33
34 /*!
35 @header SCPreferencesPrivate
36 */
37
38 /*!
39 @enum SCPreferencesKeyType
40 @discussion Used with the SCDynamicStoreKeyCreatePreferences() function
41 to describe the resulting CFStringRef argument.
42 @constant kSCPreferencesKeyLock Key used when exclusive access to the
43 stored preferences is obtained or released.
44 @constant kSCPreferencesKeyCommit Key used when new preferences are
45 committed to the store
46 @constant kSCPreferencesKeyApply Key used when new preferences are
47 to be applied to the active system configuration.
48 */
49 enum {
50 kSCPreferencesKeyLock = 1,
51 kSCPreferencesKeyCommit = 2,
52 kSCPreferencesKeyApply = 3
53 };
54 typedef int32_t SCPreferencesKeyType;
55
56
57 __BEGIN_DECLS
58
59 /*!
60 @function SCDynamicStoreKeyCreatePreferences
61 @discussion Creates a key that can be used by the SCDynamicStoreSetNotificationKeys()
62 function to receive notifications of changes to the saved
63 preferences.
64 @param allocator ...
65 @param prefsID A string that identifies the name of the
66 group of preferences to be accessed/updated.
67 @param keyType A kSCPreferencesKeyType indicating the type a notification
68 key to be returned.
69 @result A notification string for the specified preference identifier.
70 */
71 CFStringRef
72 SCDynamicStoreKeyCreatePreferences (
73 CFAllocatorRef allocator,
74 CFStringRef prefsID,
75 SCPreferencesKeyType keyType
76 ) AVAILABLE_MAC_OS_X_VERSION_10_1_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4;
77
78 SCPreferencesRef
79 SCUserPreferencesCreate (
80 CFAllocatorRef allocator,
81 CFStringRef name,
82 CFStringRef prefsID,
83 CFStringRef user
84 );
85
86 CFStringRef
87 SCDynamicStoreKeyCreateUserPreferences (
88 CFAllocatorRef allocator,
89 CFStringRef prefsID,
90 CFStringRef user,
91 SCPreferencesKeyType keyType
92 );
93
94 __END_DECLS
95
96 #endif /* _SCPREFERENCESPRIVATE_H */