⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gbx_stack.c

📁 Gambas is a graphical development environment based on a Basic interpreter, like Visual Basic. It us
💻 C
字号:
/***************************************************************************  stack.c  Stack management  (c) 2000-2004 Beno顃 Minisini <gambas@users.sourceforge.net>  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 1, 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.  You should have received a copy of the GNU General Public License  along with this program; if not, write to the Free Software  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.***************************************************************************/#define __GBX_STACK_C#include "gb_common.h"#include "gb_error.h"#include "gb_alloc.h"#include "gbx_exec.h"#include "gb_error.h"#include "gbx_string.h"#include "gbx_stack.h"PUBLIC long STACK_size = 16384L;PUBLIC char *STACK_base = NULL;PUBLIC char *STACK_limit = NULL;PUBLIC STACK_CONTEXT *STACK_frame;PUBLIC int STACK_frame_count;PUBLIC void STACK_init(void){  ALLOC_ZERO(&STACK_base, STACK_size, "STACK_init");  STACK_limit = (STACK_base + STACK_size);  STACK_frame = (STACK_CONTEXT *)STACK_limit;  STACK_frame_count = 0;  SP = (VALUE *)STACK_base;}PUBLIC void STACK_exit(void){  if (STACK_base)    FREE(&STACK_base, "STACK_exit");}PUBLIC void STACK_check(int need){#if DEBUG_STACK  static VALUE *old = NULL;  if (SP > old)  {    printf("STACK = %d bytes\n", ((char *)SP - STACK_base));    old = SP;  }#endif  if ((char *)(SP + need) >= STACK_limit)    THROW(E_STACK);}PUBLIC void STACK_push_frame(STACK_CONTEXT *context){  if (((char *)SP + sizeof(STACK_CONTEXT)) >= (char *)STACK_frame)    THROW(E_STACK);  STACK_frame--;  *STACK_frame = *context;  STACK_frame_count++;  STACK_limit = (char *)STACK_frame;  /*printf("STACK_push_frame: PC = %p  FP = %p (%s)\n", context->pc, context->fp,    context->fp ? (context->fp->debug ? context->fp->debug->name : 0) : 0);*/}PUBLIC void STACK_pop_frame(STACK_CONTEXT *context){  if (STACK_frame_count <= 0)    ERROR_panic("STACK_pop_frame: Stack frame is void");  *context = *STACK_frame;  STACK_frame++;  STACK_frame_count--;  STACK_limit = (char *)STACK_frame;  /*printf("STACK_pop_frame: PC = %p  FP = %p (%s)\n", context->pc, context->fp,    context->fp ? (context->fp->debug ? context->fp->debug->name : 0) : 0);*/}PUBLIC boolean STACK_has_error_handler(void){  int i;  for (i = 0; i < STACK_frame_count; i++)    if (STACK_frame[i].ec != NULL)      return TRUE;  return FALSE;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -