Logo Search packages:      
Sourcecode: oaklisp version File versions  Download package

stacks.h

// This file is part of Oaklisp.
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as
// published by the Free Software Foundation; either version 2 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// The GNU GPL is available at http://www.gnu.org/licenses/gpl.html
// or from the Free Software Foundation, 59 Temple Place - Suite 330,
// Boston, MA 02111-1307, USA


/**********************************************************************
 *  Copyright (c) by Barak A. Pearlmutter and Kevin J. Lang, 1987-99. *
 *  Copyright (c) by Alex Stuebinger, 1998-99.                        *
 *  Distributed under the GNU General Public License v2 or later      *
 **********************************************************************/

#ifndef _STACKS_H_INCLUDED
#define _STACKS_H_INCLUDED

#include "config.h"
#include "gc.h"
#include "data.h"

extern int max_segment_size;


/* flushed stack segment.  Allocated and gc'ed in the oaklisp heap. */
typedef struct {
  /* Do not rearange this structure or you'll be sorry! */
  ref_t type_field;
  ref_t length_field;
  ref_t previous_segment;
  ref_t data[1];
} segment_t;

#define SEGMENT_HEADER_LENGTH (sizeof(segment_t)/sizeof(ref_t)-1)

/* stack type */

typedef struct {
  int size;             /* size of stack buffer */
  int filltarget;       /* how high to fill buffer ideally */
  ref_t *bp;                  /* pointer to this stack's "buffer" */
  ref_t *sp;                  /* pointer to top element in stack */
  ref_t segment;        /* head of linked list of flushed segments */
  int pushed_count;           /* number of ref's in flushed segment list */
} oakstack;

#ifdef THREADS
extern oakstack *value_stack_array[];
extern oakstack *cntxt_stack_array[];
#else
extern oakstack value_stack;
extern oakstack context_stack;
#endif

extern void init_stacks(void);
extern void stack_flush(oakstack * stack_p, int amount_to_leave);
extern void stack_unflush(oakstack * stack_p, int n);
extern void dump_stack(oakstack * stack_p);

#endif

Generated by  Doxygen 1.6.0   Back to index