ACC SHELL

Path : /var/lib/ntp/var/lib/ntp/proc/self/root/usr/share/slsh/
File Upload :
Current File : //var/lib/ntp/var/lib/ntp/proc/self/root/usr/share/slsh/stkcheck.sl

% This file adds BOS/EOS hooks to the interpreter to help debug stack problems.
% To use it, put the following at the top of a problematic file:
%   
%   require ("stkcheck");
%   enable_stack_check ();
%   
% To check only portions of a file, surround the suspect functions by:
% 
%   enable_stack_check ();
%      .
%      .
%   disable_stack_check ();
%
_boseos_info = 0;
private variable Stack = Struct_Type[512];
private variable Stack_Depth = 0;

private define output ()
{
   variable args = __pop_args (_NARGS);
#ifexists _jed_version
   if (BATCH == 0)
     {
	variable cbuf = whatbuf ();
	setbuf ("*traceback*");
	vinsert (__push_args(args));
	setbuf (cbuf);
	return;
     }
   () = fprintf (stderr, __push_args (args));
   return;
#else
   () = fprintf (stderr, __push_args (args));
#endif
}

private define bos_handler (file, line)
{
   if (Stack_Depth >= length (Stack))
     throw StackOverflowError, "BOS stack overflow";

   variable s = struct
     {
	file, line, depth
     };
   s.file = file;
   s.line = line;
   s.depth = _stkdepth ();
   Stack[Stack_Depth] = s;
   Stack_Depth++;
}

private define eos_handler ()
{
   if (Stack_Depth <= 0)
     return;
     %throw StackUnderflowError, "BOS stack depth underflow";
   Stack_Depth--;
   variable s = Stack[Stack_Depth];
   variable depth = _stkdepth ();
   if (depth != s.depth)
     {
	if (depth < s.depth)
	  ;
	else
	  output ("%s:%d: %d object(s) left on the stack\n", s.file, s.line, depth-s.depth);
     }
}

define enable_stack_check ()
{
   ()=_set_bos_handler (&bos_handler);
   ()=_set_eos_handler (&eos_handler);
   Stack_Depth = 0;
   _boseos_info = 1;
}

define disable_stack_check ()
{
   ()=_set_bos_handler (NULL);
   ()=_set_eos_handler (NULL);
   Stack_Depth = 0;
   _boseos_info = 0;
}

provide ("stkcheck");

ACC SHELL 2018