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

通讯编程

开发平台:

Visual C++

  1. /*
  2.  * Copyright (c) 1991,1993 Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  * 1. Redistributions of source code must retain the above copyright
  9.  *    notice, this list of conditions and the following disclaimer.
  10.  * 2. Redistributions in binary form must reproduce the above copyright
  11.  *    notice, this list of conditions and the following disclaimer in the
  12.  *    documentation and/or other materials provided with the distribution.
  13.  * 3. All advertising materials mentioning features or use of this software
  14.  *    must display the following acknowledgement:
  15.  * This product includes software developed by the Computer Systems
  16.  * Engineering Group at Lawrence Berkeley Laboratory.
  17.  * 4. Neither the name of the University nor of the Laboratory may be used
  18.  *    to endorse or promote products derived from this software without
  19.  *    specific prior written permission.
  20.  *
  21.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  22.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  23.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  24.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  25.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  26.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  27.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  28.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  29.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  30.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  31.  * SUCH DAMAGE.
  32.  *
  33.  * @(#) $Header: /cvsroot/nsnam/nam-1/queue.h,v 1.11 2002/10/15 18:06:08 difa Exp $ (LBL)
  34.  */
  35. #ifndef nam_queue_h
  36. #define nam_queue_h
  37. #include "animation.h"
  38. class View;
  39. //class PSView;
  40. class Drop;
  41. class Queue;
  42. class Monitor;
  43. class QueueItem : public Animation {
  44. friend class Queue;
  45.  public:
  46.   QueueItem(const PacketAttr&, double, long);
  47. ~QueueItem();
  48. virtual float distance(float x, float y) const;
  49. void position(float&, float&);
  50. virtual void draw(View* nv, double time);
  51.   // virtual void draw(PSView*, double) const;
  52. virtual void update_bb();
  53. void locate(float x, float y, float dx, float dy);
  54. //virtual int inside(double now, float px, float py) const;
  55. virtual const char* info() const;
  56. virtual const char* getname() const;
  57. void monitor(Monitor *m, double now, char *result, int len);
  58. MonState *monitor_state();
  59. inline int id() const { return pkt_.id; }
  60. inline int size() const { return pkt_.size; }
  61. inline const char* type() const { return (pkt_.type); }
  62. inline const char* convid() const { return (pkt_.convid); }
  63.  private:
  64. QueueItem* qnext_;
  65. float px_[4];
  66. float py_[4];
  67. PacketAttr pkt_;
  68. };
  69. #define QUEUE_HEAD 1
  70. #define QUEUE_TAIL 2
  71. class Queue {
  72.  public:
  73. Queue(float angle);
  74. virtual int classid() const { return ClassQueueItemID; }
  75. virtual void reset(double);
  76. QueueItem* remove(const PacketAttr& p, int& position);
  77. QueueItem* remove(const PacketAttr& p) { int d; return remove(p, d); }
  78. inline int size() const { return (cnt_); }
  79. void enque(QueueItem*, int mode);
  80. void relocate();
  81. void place(double psize, double x, double y);
  82. inline QueueItem *head() const { return head_; }
  83. Queue* next_;
  84.  private:
  85. int cnt_; /* current size of queue */
  86. QueueItem* head_;
  87. QueueItem** tail_;
  88. /*XXX get rid of this */
  89. float psize_; /* packet size */
  90. int nb_;     /* aggregate bytes in queue */
  91. float angle_;
  92. float qx_, qy_; /* coord of head of queue */
  93. float dx_, dy_; /* space between packets */
  94. float px_, py_; /* size of each packet */
  95. };
  96. #endif