*/
/* IOArray.h created by rsulack on Thu 11-Sep-1997 */
-#include <libkern/c++/OSCollectionIterator.h>
-#include <libkern/c++/OSCollection.h>
+#define IOKIT_ENABLE_SHARED_PTR
+
#include <libkern/c++/OSArray.h>
+#include <libkern/c++/OSCollection.h>
+#include <libkern/c++/OSCollectionIterator.h>
#include <libkern/c++/OSLib.h>
+#include <libkern/c++/OSSharedPtr.h>
#define super OSIterator
return false;
}
- inColl->retain();
- collection = inColl;
- collIterator = 0;
+ collection.reset(inColl, OSRetain);
+ collIterator = NULL;
initialUpdateStamp = 0;
valid = false;
return true;
}
-OSCollectionIterator *
+OSSharedPtr<OSCollectionIterator>
OSCollectionIterator::withCollection(const OSCollection *inColl)
{
- OSCollectionIterator *me = new OSCollectionIterator;
+ OSSharedPtr<OSCollectionIterator> me = OSMakeShared<OSCollectionIterator>();
if (me && !me->initWithCollection(inColl)) {
- me->release();
- return 0;
+ return nullptr;
}
return me;
if (collIterator) {
kfree(collIterator, collection->iteratorSize());
OSCONTAINER_ACCUMSIZE(-((size_t) collection->iteratorSize()));
- collIterator = 0;
+ collIterator = NULL;
}
- if (collection) {
- collection->release();
- collection = 0;
- }
+ collection.reset();
super::free();
}
bool retVal;
if (!isValid()) {
- return 0;
+ return NULL;
}
retVal = collection->getNextObjectForIterator(collIterator, &retObj);
- return (retVal)? retObj : 0;
+ return (retVal)? retObj : NULL;
}