scheduler-map.cc
上传用户:rrhhcc
上传日期:2015-12-11
资源大小:54129k
文件大小:4k
源码类别:

通讯编程

开发平台:

Visual C++

  1. /* -*- Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- */
  2. /*
  3.  * Copyright (c) 1994 Regents of the University of California.
  4.  * All rights reserved.
  5.  *
  6.  * Redistribution and use in source and binary forms, with or without
  7.  * modification, are permitted provided that the following conditions
  8.  * are met:
  9.  * 1. Redistributions of source code must retain the above copyright
  10.  *    notice, this list of conditions and the following disclaimer.
  11.  * 2. Redistributions in binary form must reproduce the above copyright
  12.  *    notice, this list of conditions and the following disclaimer in the
  13.  *    documentation and/or other materials provided with the distribution.
  14.  * 3. All advertising materials mentioning features or use of this software
  15.  *    must display the following acknowledgement:
  16.  * This product includes software developed by the Computer Systems
  17.  * Engineering Group at Lawrence Berkeley Laboratory.
  18.  * 4. Neither the name of the University nor of the Laboratory may be used
  19.  *    to endorse or promote products derived from this software without
  20.  *    specific prior written permission.
  21.  *
  22.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  23.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  24.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  25.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  26.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  27.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  28.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  29.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  30.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  31.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  32.  * SUCH DAMAGE.
  33.  *
  34.  */
  35. #include "config.h"
  36. #ifdef HAVE_STL
  37. // Event Scheduler using the standard library std::set
  38. // Contributed by George F. Riley, Georgia Tech.  Spring 2002
  39. #include <stdio.h>
  40. #include <set>
  41. #include "scheduler.h"
  42. class MapScheduler : public Scheduler {
  43. public:
  44. MapScheduler();
  45. ~MapScheduler();
  46. public:
  47. void cancel(Event*);
  48. void insert(Event*);
  49. Event* lookup(scheduler_uid_t uid);
  50. Event* deque();
  51. const Event *head() { return *EventQueue_.begin(); }
  52. private:
  53. struct event_less_adapter {
  54. bool operator()(const Event *e1, const Event *e2) const
  55. {
  56. return e1->time_ < e2->time_ ||
  57. (e1->time_ == e2->time_ && e1->uid_ < e2->uid_); // for FIFO
  58. }
  59. };
  60. typedef set<Event *, event_less_adapter> EventQueue_t;
  61. EventQueue_t EventQueue_; // The actual event list
  62. };
  63. static class MapSchedulerClass : public TclClass {
  64. public:
  65. MapSchedulerClass() : TclClass("Scheduler/Map") {}
  66. TclObject* create(int /* argc */, const char*const* /* argv */) {
  67. return (new MapScheduler);
  68. }
  69. } class_stl_sched;
  70. MapScheduler::MapScheduler()
  71. {
  72. }
  73. MapScheduler::~MapScheduler()
  74. {
  75. }
  76. void MapScheduler::cancel(Event* p)
  77. {
  78. EventQueue_t::iterator eIT = EventQueue_.find(p);
  79. if (eIT != EventQueue_.end()) {
  80. EventQueue_.erase(eIT);
  81. p->uid_ = -p->uid_; // Negate the uid for reuse
  82. }
  83. }
  84. void MapScheduler::insert(Event* p)
  85. {
  86. EventQueue_.insert(p);
  87. }
  88. Event* MapScheduler::lookup(scheduler_uid_t uid) // look for event
  89. {
  90. for (EventQueue_t::iterator eIT = EventQueue_.begin();
  91.      eIT != EventQueue_.end(); 
  92.      ++eIT) {
  93. if ((*eIT)->uid_ == uid) 
  94. return (*eIT);
  95. }
  96. return 0;
  97. }
  98. Event* MapScheduler::deque()
  99. {
  100. EventQueue_t::iterator eIT = EventQueue_.begin();
  101. if (eIT == EventQueue_.end()) 
  102. return 0;
  103. EventQueue_.erase(eIT);
  104. return *eIT;
  105. }
  106. #endif // HAVE_STL