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

example.c

/* Scheme In One Defun, but in C this time.
 
 *                    COPYRIGHT (c) 1988-1994 BY                            *
 *        PARADIGM ASSOCIATES INCORPORATED, CAMBRIDGE, MASSACHUSETTS.       *
 *        See the source file SLIB.C for more information.                  *

*/

/*

gjc@world.std.com gjc@paradigm.com 

Paradigm Associates Inc          Phone: 617-492-6079
29 Putnam Ave, Suite 6
Cambridge, MA 02138

An example main-program call with some customized subrs.

  */

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#ifdef THINK_C
#include <console.h>
#endif

#include "siod.h"

static void init_siod_version(void)
{setvar(cintern("*siod-version*"),
      cintern("$Id: example.c,v 1.1.1.1 2000/12/09 01:57:11 thhsieh Exp $"),
      NIL);}

LISP my_one;
LISP my_two;
LISP my_99;
LISP my_0;

LISP cfib(LISP x);
LISP clooptest(LISP x,LISP f);

static char *standard_fib = "\
                             \
(define (fib x)              \
  (if (< x 2)                \
      x                      \
    (+ (fib (- x 1))         \
       (fib (- x 2)))))      ";

int main(int argc,char **argv)
{int j,xflag = 0,retval = 0;
 char *linebuffer = NULL,*ptr,*iobuff;
 print_welcome();
#ifdef THINK_C
 argc = ccommand(&argv);
#endif
 for(j=1;j<argc;++j)
   if (strcmp(argv[j],"x") == 0)
     xflag = 1;
   else if (strcmp(argv[j],"xx") == 0)
     xflag = 3;
   else if (strncmp(argv[j],"-e",2) == 0)
     {xflag = 2;
      linebuffer = &argv[j][2];}
 process_cla(argc,argv,(xflag) ? 0 : 1);
 print_hs_1();
 init_storage();
 init_subrs();
 init_trace();
 init_siod_version();
 my_one = flocons((double) 1.0);
 my_two = flocons((double) 2.0);
 my_99 = flocons((double) 99.0);
 my_0 = flocons((double) 0.0);
 gc_protect(&my_one);
 gc_protect(&my_two);
 gc_protect(&my_99);
 gc_protect(&my_0);
 init_subr_1("cfib",cfib);
 init_subr_2("cloop-test",clooptest);
 repl_c_string(standard_fib,0,0,0);
 switch(xflag)
   {case 0:
      retval = repl_driver(1,1,NULL);
      break;
    case 1:
      printf("Using repl_c_string\n");
      linebuffer = (char *) malloc(256);
      while(fgets(linebuffer,256,stdin))
      {if ((ptr = strchr(linebuffer,'\n'))) *ptr = 0;
       retval = repl_c_string(linebuffer,1,xflag,0);
       xflag = 0;}
      break;
    case 2:
      retval = repl_c_string(linebuffer,1,xflag,1);
      break;
   case 3:
     printf("Using repl_c_string I/O case\n");
      linebuffer = (char *) malloc(256);
      iobuff = (char *) malloc(1024);
      while(fgets(linebuffer,256,stdin))
      {if ((ptr = strchr(linebuffer,'\n'))) *ptr = 0;
       sprintf(iobuff,"(*catch 'errobj (begin %s))",linebuffer);
       retval = repl_c_string(iobuff,1,xflag,1024);
       printf("retval = %d\n%s\n",retval,iobuff);
       xflag = 0;}
      break;}
 printf("EXIT\n");
 exit(retval);
 return(0);}

/* This is cfib, (compiled fib). Test to see what the overhead
   of interpretation actually is in a given implementation benchmark
   standard-fib against cfib. */

LISP cfib(LISP x)
{if NNULLP(lessp(x,my_two))
   return(x);
 else
   return(plus(cfib(difference(x,my_one)),
             cfib(difference(x,my_two))));}

/* compiled version of loop-test from siod.scm
   This won't number-cons for n up to 99 (with default arguments).
   Another test of overhead of interpretation */

LISP clooptest(LISP n,LISP f)
{LISP j,k,m,result;
 j = my_0;
 result = NIL;
 while(NNULLP(lessp(j,n)))
   {j = plus(j,my_one);
    k = my_0;
    while(NNULLP(lessp(k,my_99)))
      {k = plus(k,my_one);
       m = my_0;
       while(NNULLP(lessp(m,my_99)))
       {m = plus(m,my_one);
        if NNULLP(f) result = cons(NIL,result);}}}
 return(result);}


Generated by  Doxygen 1.6.0   Back to index