X-Git-Url: https://git.saurik.com/apple/security.git/blobdiff_plain/80e2389990082500d76eb566d4946be3e786c3ef..d8f41ccd20de16f8ebe2ccc84d47bf1cb2b26bbb:/libsecurity_utilities/lib/tqueue.h?ds=sidebyside diff --git a/libsecurity_utilities/lib/tqueue.h b/libsecurity_utilities/lib/tqueue.h deleted file mode 100644 index fe716f03..00000000 --- a/libsecurity_utilities/lib/tqueue.h +++ /dev/null @@ -1,141 +0,0 @@ -/* - * Copyright (c) 2000-2004 Apple Computer, 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, - * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, - * 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@ - */ - - -// -// tqueue.h -- timer queues -// -#ifndef _H_TQUEUE -#define _H_TQUEUE - -#include -#include - - -namespace Security { - - -// -// A TimerQueue is a container of elements that have relative "timer" positions. -// TimerQueues are concerned with shuffling these elements around as their "times" -// change, and with processing elements that fall off the front of the queue as -// "time" passes. -// We put "time" into quotes because nothing here really cares what kind of time -// you are playing with. It could be seconds, points scored, etc. The only requirement -// is that "time" doesn't ever flow backwards... -// -template -class ScheduleQueue { -public: - ScheduleQueue() { first.fwd = first.back = &first; } - virtual ~ScheduleQueue() { } - -public: - class Event { - friend class ScheduleQueue; - public: - Event() : mScheduled(false) { } - ~Event() { if (scheduled()) unschedule(); } - - void unschedule(); - - Time when() const { return fireTime; } - bool scheduled() const { return mScheduled; } - - private: - Time fireTime; // when will it happen? - bool mScheduled; // are we scheduled? - Event *back, *fwd; // doubly-linked interior list - - void putBefore(Event *ev) - { back = ev->back; fwd = ev; ev->back = back->fwd = this; mScheduled = true; } - }; - -public: - void schedule(Event *event, Time when); - void unschedule(Event *event) - { event->unschedule(); } - - bool empty() const { return first.fwd == &first; } - Time next() const { assert(!empty()); return first.fwd->fireTime; } - - Event *pop(Time now); - -private: - Event first; // root of active timers list -}; - -template -void ScheduleQueue