QueueClass.hpp
Go to the documentation of this file.
1 /*----------------------------------------------------------------------------*/
2 /* */
3 /* Copyright (c) 1995, 2004 IBM Corporation. All rights reserved. */
4 /* Copyright (c) 2005-2009 Rexx Language Association. All rights reserved. */
5 /* */
6 /* This program and the accompanying materials are made available under */
7 /* the terms of the Common Public License v1.0 which accompanies this */
8 /* distribution. A copy is also available at the following address: */
9 /* http://www.oorexx.org/license.html */
10 /* */
11 /* Redistribution and use in source and binary forms, with or */
12 /* without modification, are permitted provided that the following */
13 /* conditions are met: */
14 /* */
15 /* Redistributions of source code must retain the above copyright */
16 /* notice, this list of conditions and the following disclaimer. */
17 /* Redistributions in binary form must reproduce the above copyright */
18 /* notice, this list of conditions and the following disclaimer in */
19 /* the documentation and/or other materials provided with the distribution. */
20 /* */
21 /* Neither the name of Rexx Language Association nor the names */
22 /* of its contributors may be used to endorse or promote products */
23 /* derived from this software without specific prior written permission. */
24 /* */
25 /* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS */
26 /* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT */
27 /* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS */
28 /* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT */
29 /* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, */
30 /* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED */
31 /* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, */
32 /* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY */
33 /* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING */
34 /* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS */
35 /* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */
36 /* */
37 /*----------------------------------------------------------------------------*/
38 /******************************************************************************/
39 /* REXX Kernel QueueClass.hpp */
40 /* */
41 /* Primitive Queue Class Definitions */
42 /* */
43 /******************************************************************************/
44 #ifndef Included_RexxQueue
45 #define Included_RexxQueue
46 
47 #include "ListClass.hpp"
48 
49 class RexxQueue : public RexxList {
50  public:
51 
52  void *operator new(size_t);
53  inline void *operator new(size_t size, void *ptr) {return ptr;};
54  inline RexxQueue() {;};
55  inline RexxQueue(RESTORETYPE restoreType) { ; };
64  RexxObject *peek();
66  RexxObject *newRexx(RexxObject **, size_t, size_t);
67  RexxQueue *ofRexx(RexxObject **, size_t, size_t);
75  size_t entryToIndex(size_t target);
79 
80  inline RexxObject *pop() { return this->removeFirst();};
81  inline void push(RexxObject *obj) { this->addFirst(obj);};
82  inline void queue(RexxObject *obj) { this->addLast(obj);};
83 
84  static void createInstance();
86 
87 };
88 
89 inline RexxQueue *new_queue() { return new RexxQueue; }
90 #endif
RESTORETYPE
Definition: ObjectClass.hpp:82
RexxQueue * new_queue()
Definition: QueueClass.hpp:89
size_t size
Definition: ListClass.hpp:142
RexxObject * removeFirst()
Definition: ListClass.hpp:109
void addLast(RexxObject *value)
Definition: ListClass.cpp:455
void addFirst(RexxObject *value)
Definition: ListClass.cpp:486
RexxObject * next(RexxObject *)
Definition: QueueClass.cpp:427
RexxObject * insert(RexxObject *, RexxObject *)
Definition: QueueClass.cpp:211
RexxObject * peek()
Definition: QueueClass.cpp:317
LISTENTRY * locateEntry(RexxObject *, RexxObject *)
Definition: QueueClass.cpp:121
RexxObject * remove(RexxObject *)
Definition: QueueClass.cpp:294
RexxObject * lastRexx()
Definition: QueueClass.cpp:410
static void createInstance()
Definition: QueueClass.cpp:58
RexxObject * index(RexxObject *)
Definition: QueueClass.cpp:370
RexxObject * sectionSubclass(LISTENTRY *, size_t)
Definition: QueueClass.cpp:563
RexxObject * firstRexx()
Definition: QueueClass.cpp:393
RexxObject * pushRexx(RexxObject *)
Definition: QueueClass.cpp:78
void push(RexxObject *obj)
Definition: QueueClass.hpp:81
RexxObject * hasindex(RexxObject *)
Definition: QueueClass.cpp:305
RexxObject * supplier()
Definition: QueueClass.cpp:326
RexxObject * at(RexxObject *)
Definition: QueueClass.cpp:181
static RexxClass * classInstance
Definition: QueueClass.hpp:85
RexxObject * previous(RexxObject *)
Definition: QueueClass.cpp:453
RexxObject * section(RexxObject *, RexxObject *)
Definition: QueueClass.cpp:512
size_t entryToIndex(size_t target)
Definition: QueueClass.cpp:486
RexxObject * pullRexx()
Definition: QueueClass.cpp:64
RexxArray * allIndexes()
Definition: QueueClass.cpp:345
RexxObject * put(RexxObject *, RexxObject *)
Definition: QueueClass.cpp:162
RexxQueue(RESTORETYPE restoreType)
Definition: QueueClass.hpp:55
RexxObject * newRexx(RexxObject **, size_t, size_t)
Definition: QueueClass.cpp:586
RexxObject * pop()
Definition: QueueClass.hpp:80
void queue(RexxObject *obj)
Definition: QueueClass.hpp:82
RexxQueue * ofRexx(RexxObject **, size_t, size_t)
Definition: QueueClass.cpp:611
RexxObject * append(RexxObject *)
Definition: QueueClass.cpp:99
RexxObject * queueRexx(RexxObject *)
Definition: QueueClass.cpp:109