]> git.saurik.com Git - apple/configd.git/blobdiff - configd.tproj/_notifychanges.c
configd-1109.101.1.tar.gz
[apple/configd.git] / configd.tproj / _notifychanges.c
index 80be21354f860747ee7d750f2e5761d328720fbd..31f64c7516ed5246d0fc01b8a69ec9c0dae0b9f3 100644 (file)
@@ -1,15 +1,15 @@
 /*
- * Copyright (c) 2000-2003 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2004, 2006, 2011, 2013, 2015, 2019 Apple Inc. All rights reserved.
  *
  * @APPLE_LICENSE_HEADER_START@
- * 
+ *
  * This file contains Original Code and/or Modifications of Original Code
  * as defined in and that are subject to the Apple Public Source License
  * Version 2.0 (the 'License'). You may not use this file except in
  * compliance with the License. Please obtain a copy of the License at
  * http://www.opensource.apple.com/apsl/ and read it before using this
  * file.
- * 
+ *
  * The Original Code and all software distributed under the License are
  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
@@ -17,7 +17,7 @@
  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
  * Please see the License for the specific language governing rights and
  * limitations under the License.
- * 
+ *
  * @APPLE_LICENSE_HEADER_END@
  */
 
@@ -38,38 +38,16 @@ __private_extern__
 int
 __SCDynamicStoreCopyNotifiedKeys(SCDynamicStoreRef store, CFArrayRef *notifierKeys)
 {
+       serverSessionRef                mySession;
        SCDynamicStorePrivateRef        storePrivate = (SCDynamicStorePrivateRef)store;
-       CFStringRef                     sessionKey;
-       CFDictionaryRef                 info;
-       CFMutableDictionaryRef          newInfo;
-
-       SCLog(_configd_verbose, LOG_DEBUG, CFSTR("__SCDynamicStoreCopyNotifiedKeys:"));
-
-       if (!store || (storePrivate->server == MACH_PORT_NULL)) {
-               return kSCStatusNoStoreSession; /* you must have an open session to play */
-       }
 
-       sessionKey = CFStringCreateWithFormat(NULL, NULL, CFSTR("%d"), storePrivate->server);
-       info = CFDictionaryGetValue(sessionData, sessionKey);
-       if ((info == NULL) ||
-           (CFDictionaryContainsKey(info, kSCDChangedKeys) == FALSE)) {
-               CFRelease(sessionKey);
-               *notifierKeys = CFArrayCreate(NULL, NULL, 0, &kCFTypeArrayCallBacks);;
-               return kSCStatusOK;
-       }
-       newInfo = CFDictionaryCreateMutableCopy(NULL, 0, info);
-
-       *notifierKeys = CFDictionaryGetValue(newInfo, kSCDChangedKeys);
-       CFRetain(*notifierKeys);
-
-       CFDictionaryRemoveValue(newInfo, kSCDChangedKeys);
-       if (CFDictionaryGetCount(newInfo) > 0) {
-               CFDictionarySetValue(sessionData, sessionKey, newInfo);
+       mySession = getSession(storePrivate->server);
+       if (mySession->changedKeys != NULL) {
+               *notifierKeys = mySession->changedKeys;
+               mySession->changedKeys = NULL;
        } else {
-               CFDictionaryRemoveValue(sessionData, sessionKey);
+               *notifierKeys = CFArrayCreate(NULL, NULL, 0, &kCFTypeArrayCallBacks);
        }
-       CFRelease(newInfo);
-       CFRelease(sessionKey);
 
        return kSCStatusOK;
 }
@@ -83,19 +61,15 @@ _notifychanges(mach_port_t                  server,
               int                              *sc_status
 )
 {
+       CFIndex                 len;
        serverSessionRef        mySession = getSession(server);
        CFArrayRef              notifierKeys;   /* array of CFStringRef's */
        Boolean                 ok;
 
-       if (_configd_verbose) {
-               SCLog(TRUE, LOG_DEBUG, CFSTR("List notification keys which have changed."));
-               SCLog(TRUE, LOG_DEBUG, CFSTR("  server = %d"), server);
-       }
-
        *listRef = NULL;
        *listLen = 0;
 
-       if (!mySession) {
+       if (mySession == NULL) {
                *sc_status = kSCStatusNoStoreSession;   /* you must have an open session to play */
                return KERN_SUCCESS;
        }
@@ -106,7 +80,8 @@ _notifychanges(mach_port_t                   server,
        }
 
        /* serialize the array of keys */
-       ok = _SCSerialize(notifierKeys, NULL, (void **)listRef, (CFIndex *)listLen);
+       ok = _SCSerialize(notifierKeys, NULL, (void **)listRef, &len);
+       *listLen = (mach_msg_type_number_t)len;
        CFRelease(notifierKeys);
        if (!ok) {
                *sc_status = kSCStatusFailed;