//
//  NAME
//    plist.h
//
//  DESCRIPTION
//   This file contains the type definitions and function prototypes
//   exported by the Person-List module.
//   This module maintains a list of people.  The list is unsorted,
//   and people are added to the end of the list.  The current 
//   position in the list is maintained, and the functions getFirst()
//   and getNext() move this current position.  The function atEnd()
//   determines if the current position is at the end of the list.
//   The list is emptied by the function clearList().
//


#ifndef _plist_h_
#define _plist_h_


//
//  Include files.
//

#include "bool.h"
#include "person.h"


//
//  NAME
//    addToEnd
//
//  DESCRIPTION
//    This function adds the given person to the end of the person list.
//
//  PARAMETERS
//    p  (in) - the person to add to the list.
//
//  RETURNS
//    (none)
//

void addToEnd(person& p);


//
//  NAME
//    getFirst
//
//  DESCRIPTION
//    This function gets the first person in the person list.  If
//    the person was retrieved successfully, then the function 
//    returns true.  If the person could not be retrieved (for 
//    example, the person list is empty), then false is returned.
//    The "current position" in the list is moved to the second 
//    person in the list (if there is one).
//
//  PARAMETERS
//    p  (out) - person retrieved from the list.
//
//  RETURNS
//    true   - if the person was retrieved successfully.
//    false  - if the person could not be retrieved.
//

bool getFirst(person& p);


//
//  NAME
//    getNext
//
//  DESCRIPTION
//    This function gets the next person in the person list, that
//    is, the person at the "current position" in the list.  If
//    the person was retrieved successfully, then the function 
//    returns true.  If the person could not be retrieved (for 
//    example, the person list is empty), then false is returned.
//    The "current position" in the list is moved to the next
//    person in the list.
//
//  PARAMETERS
//    p  (out) - person retrieved from the list.
//
//  RETURNS
//    true   - if the person was retrieved successfully.
//    false  - if the person could not be retrieved.
//

bool getNext(person& p);


//
//  NAME
//    atEnd
//
//  DESCRIPTION
//    This function determines if the "current position" in the
//    list is at the end of the list.  If this function returns
//    false, then a call to getNext() will return a person.  If this
//    function returns true, then a call to getNext() will not
//    return a person.
//
//  PARAMETERS
//    (none)
//
//  RETURNS
//    true   - if the "current position" is at the end of the list.
//    false  - if the "current position" is not at the end of the
//               list.
//

bool atEnd();


//
//  NAME
//    clearList
//
//  DESCRIPTION
//    This function empties the list.  After a call to this function,
//    both getFirst() and getNext() will not return a person and
//    atEnd() will return true.
//
//  PARAMETERS
//    (none)
//
//  RETURNS
//    (none)
//

void clearList();


#endif