home *** CD-ROM | disk | FTP | other *** search
/ The World of Computer Software / World_Of_Computer_Software-02-385-Vol-1of3.iso / i / iv26_w_3.zip / EXAMPLES / IDRAW / LISTBOOL.H < prev    next >
C/C++ Source or Header  |  1980-01-05  |  3KB  |  86 lines

  1. /*
  2.  * Copyright (c) 1987, 1988, 1989 Stanford University
  3.  *
  4.  * Permission to use, copy, modify, distribute, and sell this software and its
  5.  * documentation for any purpose is hereby granted without fee, provided
  6.  * that the above copyright notice appear in all copies and that both that
  7.  * copyright notice and this permission notice appear in supporting
  8.  * documentation, and that the name of Stanford not be used in advertising or
  9.  * publicity pertaining to distribution of the software without specific,
  10.  * written prior permission.  Stanford makes no representations about
  11.  * the suitability of this software for any purpose.  It is provided "as is"
  12.  * without express or implied warranty.
  13.  *
  14.  * STANFORD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
  15.  * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS.
  16.  * IN NO EVENT SHALL STANFORD BE LIABLE FOR ANY SPECIAL, INDIRECT OR
  17.  * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
  18.  * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
  19.  * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
  20.  * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  21.  */
  22.  
  23. // $Header: listboolean.h,v 1.8 89/10/09 14:48:36 linton Exp $
  24. // declares classes booleanNode and booleanList.
  25.  
  26. #ifndef listboolean_h
  27. #define listboolean_h
  28.  
  29. #include "list.h"
  30.  
  31. // A booleanNode contains a boolean value.
  32.  
  33. class booleanNode : public BaseNode {
  34. public:
  35.  
  36.     booleanNode (boolean v) { value = v; }
  37.     boolean GetBoolean () { return value; }
  38.  
  39. protected:
  40.  
  41.     boolean value;        // contains a boolean value
  42.  
  43. };
  44.  
  45. // A booleanList manages a list of booleanNodes.
  46.  
  47. class booleanList : public BaseList {
  48. public:
  49.  
  50.     booleanNode* First();
  51.     booleanNode* Last();
  52.     booleanNode* Prev();
  53.     booleanNode* Next();
  54.     booleanNode* GetCur();
  55.     booleanNode* Index(int);
  56.  
  57. };
  58.  
  59. // Cast these functions to return booleanNodes instead of BaseNodes.
  60.  
  61. inline booleanNode* booleanList::First () {
  62.     return (booleanNode*) BaseList::First();
  63. }
  64.  
  65. inline booleanNode* booleanList::Last () {
  66.     return (booleanNode*) BaseList::Last();
  67. }
  68.  
  69. inline booleanNode* booleanList::Prev () {
  70.     return (booleanNode*) BaseList::Prev();
  71. }
  72.  
  73. inline booleanNode* booleanList::Next () {
  74.     return (booleanNode*) BaseList::Next();
  75. }
  76.  
  77. inline booleanNode* booleanList::GetCur () {
  78.     return (booleanNode*) BaseList::GetCur();
  79. }
  80.  
  81. inline booleanNode* booleanList::Index (int index) {
  82.     return (booleanNode*) BaseList::Index(index);
  83. }
  84.  
  85. #endif
  86.