Click on stack.h to get source.
/* File: CExamples/OO_pgm_in_C_new/stack.h */
/* This is the abstract data object; initialize by calling new_stack
                                     remove by calling delete_stack */
typedef struct stackstruct
  { void *objptr; /* address of data structure */
    /* abstract methods;
       the actual data structure of the stack is accessed as self->objptr
       In C++ self is the keyword this; self is from Smalltalk */
    int (*is_empty)(struct stackstruct* self); /* returns 0 if *self is empty */
    void(*push)    (int, struct stackstruct* self);
    int (*pop)     (struct stackstruct* self);
    /* object manipulation; see also new_stack, delete_stack below */
    struct stackstruct* (*clone) (struct stackstruct* self); /* make a copy */
  } stack,  *stackptr;
  
/* a generic function */
extern void print_stack(stack s);
/* the following functions are specific to the data structure used:
   therefore, there can only be one data structure used by a program, which is a
   restriction.  One could overcome this restriction by placing pointers to delete
   inside struct stackstruct and using the clone a prototype empty stack
   implemented a given datastructure as newstack (see main2.c); however, in the
   current model the function main() is also generic via the linking mechanism.
   for more on these different forms of genericity, see:
   http://www.math.ncsu.edu/~kaltofen/bibliography/index.html#EKM96</a> */
extern stackptr new_stack(void); extern void delete_stack(stackptr);