1: #ifndef lint
   2: static char *rcsid =
   3:    "$Header: lam1.c,v 1.7 85/03/24 11:04:00 sklower Exp $";
   4: #endif
   5: 
   6: /*					-[Fri Feb 17 16:44:24 1984 by layer]-
   7:  * 	lam1.c				$Locker:  $
   8:  * lambda functions
   9:  *
  10:  * (c) copyright 1982, Regents of the University of California
  11:  */
  12: 
  13: # include "global.h"
  14: # include <sgtty.h>
  15: # include "chkrtab.h"
  16: # include "frame.h"
  17: 
  18: lispval
  19: Leval()
  20: {
  21:     register lispval temp;
  22: 
  23:     chkarg(1,"eval");
  24:     temp = lbot->val;
  25:         return(eval(temp));
  26: }
  27: 
  28: lispval
  29: Lxcar()
  30: {   register int typ;
  31:     register lispval temp, result;
  32: 
  33:     chkarg(1,"xcar");
  34:     temp = lbot->val;
  35:     if (((typ = TYPE(temp)) == DTPR) || (typ == ATOM) || HUNKP(temp))
  36:         return(temp->d.car);
  37:     else if(typ == SDOT) {
  38:         result = inewint(temp->i);
  39:         return(result);
  40:     } else if(Schainp!=nil && typ==ATOM)
  41:         return(nil);
  42:     else
  43:         return(error("Bad arg to car",FALSE));
  44: 
  45: }
  46: 
  47: lispval
  48: Lxcdr()
  49: {   register int typ;
  50:     register lispval temp;
  51: 
  52:     chkarg(1,"xcdr");
  53:     temp = lbot->val;
  54:     if(temp==nil) return (nil);
  55: 
  56:     if (((typ = TYPE(temp)) == DTPR) || HUNKP(temp))
  57:         return(temp->d.cdr);
  58:     else if(typ==SDOT) {
  59:         if(temp->s.CDR==0) return(nil);
  60:         temp = temp->s.CDR;
  61:         if(TYPE(temp)==DTPR)
  62:             errorh1(Vermisc,"Fell off the end of a bignum",nil,FALSE,5,lbot->val);
  63:         return(temp);
  64:     } else if(Schainp!=nil && typ==ATOM)
  65:         return(nil);
  66:     else
  67:         return(error("Bad arg to cdr", FALSE));
  68: }
  69: 
  70: lispval
  71: cxxr(as,ds)
  72: register int as,ds;
  73: {
  74: 
  75:     register lispval temp, temp2;
  76:     int i, typ;
  77:     lispval errorh();
  78: 
  79:     chkarg(1,"c{ad}+r");
  80:     temp = lbot->val;
  81: 
  82:     for( i=0 ; i<ds ; i++)
  83:     {
  84:         if( temp != nil)
  85:         {
  86:         typ = TYPE(temp);
  87:         if ((typ == DTPR) || HUNKP(temp))
  88:             temp = temp->d.cdr;
  89:         else
  90:             if(typ==SDOT)
  91:             {
  92:             if(temp->s.CDR==0)
  93:                 temp = nil;
  94:             else
  95:                 temp = temp->s.CDR;
  96:             if(TYPE(temp)==DTPR)
  97:                     errorh1(Vermisc,"Fell off the end of a bignum",nil,FALSE,5,lbot->val);
  98:             }
  99:         else
 100:             if(Schainp!=nil && typ==ATOM)
 101:             return(nil);
 102:         else
 103:             return(errorh1(Vermisc,"Bad arg to cdr",nil,FALSE,5,temp));
 104:         }
 105:     }
 106: 
 107:     for( i=0 ; i<as ; i++)
 108:     {
 109:         if( temp != nil )
 110:         {
 111:         typ = TYPE(temp);
 112:         if ((typ == DTPR) || HUNKP(temp))
 113:             temp = temp->d.car;
 114:         else if(typ == SDOT)
 115:             temp2 = inewint(temp->i), temp = temp2;
 116:         else if(Schainp!=nil && typ==ATOM)
 117:             return(nil);
 118:         else
 119:             return(errorh1(Vermisc,"Bad arg to car",nil,FALSE,5,temp));
 120:         }
 121:     }
 122: 
 123:     return(temp);
 124: }
 125: 
 126: lispval
 127: Lcar()
 128: {   return(cxxr(1,0)); }
 129: 
 130: lispval
 131: Lcdr()
 132: {   return(cxxr(0,1)); }
 133: 
 134: lispval
 135: Lcadr()
 136: {   return(cxxr(1,1)); }
 137: 
 138: lispval
 139: Lcaar()
 140: {   return(cxxr(2,0)); }
 141: 
 142: lispval
 143: Lc02r()
 144: {   return(cxxr(0,2)); }    /* cddr */
 145: 
 146: lispval
 147: Lc12r()
 148: {   return(cxxr(1,2)); }    /* caddr */
 149: 
 150: lispval
 151: Lc03r()
 152: {   return(cxxr(0,3)); }    /* cdddr */
 153: 
 154: lispval
 155: Lc13r()
 156: {   return(cxxr(1,3)); }    /* cadddr */
 157: 
 158: lispval
 159: Lc04r()
 160: {   return(cxxr(0,4)); }    /* cddddr */
 161: 
 162: lispval
 163: Lc14r()
 164: {   return(cxxr(1,4)); }    /* caddddr */
 165: 
 166: /*
 167:  *
 168:  *	(nthelem num list)
 169:  *
 170:  * Returns the num'th element of the list, by doing a caddddd...ddr
 171:  * where there are num-1 d's. If num<=0 or greater than the length of
 172:  * the list, we return nil.
 173:  *
 174:  */
 175: 
 176: lispval
 177: Lnthelem()
 178: {
 179:     register lispval temp;
 180:     register int i;
 181: 
 182:     chkarg(2,"nthelem");
 183: 
 184:     if( TYPE(temp = lbot->val) != INT)
 185:     return (error ("First arg to nthelem must be a fixnum",FALSE));
 186: 
 187:     i = temp->i;    /* pick up the first arg */
 188: 
 189:     if( i <= 0) return(nil);
 190: 
 191:     ++lbot;         /* fix lbot for call to cxxr() 'cadddd..r' */
 192:     temp = cxxr(1,i-1);
 193:     --lbot;
 194: 
 195:     return(temp);
 196: }
 197: 
 198: lispval
 199: Lscons()
 200: {
 201:     register struct argent *argp = lbot;
 202:     register lispval retp, handy;
 203: 
 204:     chkarg(2,"scons");
 205:     retp = newsdot();
 206:     handy = (argp) -> val;
 207:     if(TYPE(handy)!=INT)
 208:         error("First arg to scons must be an int.",FALSE);
 209:     retp->s.I = handy->i;
 210:     handy = (argp+1)->val;
 211:     if(handy==nil)
 212:         retp->s.CDR = (lispval) 0;
 213:     else {
 214:         if(TYPE(handy)!=SDOT)
 215:             error("Currently you may only link sdots to sdots.",FALSE);
 216:         retp->s.CDR = handy;
 217:     }
 218:     return(retp);
 219: }
 220: 
 221: lispval
 222: Lbigtol(){
 223:     register lispval handy,newp;
 224: 
 225:     chkarg(1,"Bignum-to-list");
 226:     handy = lbot->val;
 227:     while(TYPE(handy)!=SDOT)
 228:         handy = errorh1(Vermisc,
 229:                 "Non bignum argument to Bignum-to-list",
 230:                 nil,TRUE,5755,handy);
 231:     protect(newp = newdot());
 232:     while(handy) {
 233:         newp->d.car = inewint((long)handy->s.I);
 234:         if(handy->s.CDR==(lispval) 0) break;
 235:         newp->d.cdr = newdot();
 236:         newp = newp->d.cdr;
 237:         handy = handy->s.CDR;
 238:     }
 239:     handy = (--np)->val;
 240:     return(handy);
 241: }
 242: 
 243: lispval
 244: Lcons()
 245: {
 246:     register lispval retp;
 247:     register struct argent *argp;
 248: 
 249:     chkarg(2,"cons");
 250:     retp = newdot();
 251:     retp->d.car = ((argp = lbot) -> val);
 252:     retp->d.cdr = argp[1].val;
 253:     return(retp);
 254: }
 255: #define CA 0
 256: #define CD 1
 257: 
 258: lispval
 259: rpla(what)
 260: int what;
 261: {   register struct argent *argp;
 262:     register int typ; register lispval first, second;
 263: 
 264:     chkarg(2,"rplac[ad]");
 265:     argp = np-1;
 266:     first = (argp-1)->val;
 267:     while(first==nil)
 268:         first = error("Attempt to rplac[ad] nil.",TRUE);
 269:     second = argp->val;
 270:     if (((typ = TYPE(first)) == DTPR) || (typ == ATOM) || HUNKP(first)) {
 271:         if (what == CA)
 272:             first->d.car = second;
 273:         else
 274:             first->d.cdr = second;
 275:         return(first);
 276:     }
 277:     if (typ==SDOT) {
 278:         if(what == CA) {
 279:             typ = TYPE(second);
 280:             if(typ!=INT) error("Rplacca of a bignum will only replace INTS",FALSE);
 281:             first->s.I = second->i;
 282:         } else {
 283:             if(second==nil)
 284:                 first->s.CDR = (lispval) 0;
 285:             else
 286:                 first->s.CDR = second;
 287:         }
 288:         return(first);
 289:     }
 290:     return(error("Bad arg to rpla",FALSE));
 291: }
 292: lispval
 293: Lrplca()
 294: {   return(rpla(CA));   }
 295: 
 296: lispval
 297: Lrplcd()
 298: {   return(rpla(CD));   }
 299: 
 300: 
 301: lispval
 302: Leq()
 303: {
 304:     register struct argent *mynp = lbot + AD;
 305: 
 306:     chkarg(2,"eq");
 307:     if(mynp->val==(mynp+1)->val) return(tatom);
 308:     return(nil);
 309: }
 310: 
 311: 
 312: 
 313: lispval
 314: Lnull()
 315: {   chkarg(1,"null");
 316:     return ((lbot->val == nil) ? tatom : nil);
 317: }
 318: 
 319: 
 320: 
 321: /* Lreturn **************************************************************/
 322: /* Returns the first argument - which is nill if not specified.		*/
 323: 
 324: lispval
 325: Lreturn()
 326: {
 327:     if(lbot==np) protect (nil);
 328:     Inonlocalgo(C_RET,lbot->val,nil);
 329:     /* NOT REACHED */
 330: }
 331: 
 332: 
 333: lispval
 334: Linfile()
 335: {
 336:     FILE *port;
 337:     register lispval name;
 338: 
 339:     chkarg(1,"infile");
 340:     name = lbot->val;
 341: loop:
 342:     name = verify(name,"infile: file name must be atom or string");
 343:     /* return nil if file couldnt be opened
 344: 	if ((port = fopen((char *)name,"r")) == NULL) return(nil); */
 345: 
 346:     if ((port = fopen((char *)name,"r")) == NULL) {
 347:         name = errorh1(Vermisc,"Unable to open file for reading.",nil,TRUE,31,name);
 348:         goto loop;
 349:     }
 350:     ioname[PN(port)] = (lispval) inewstr((char *)name); /* remember name */
 351:     return(P(port));
 352: }
 353: 
 354: /* outfile - open a file for writing.
 355:  * 27feb81 [jkf] - modifed to accept two arguments, the second one being a
 356:  *   string or atom, which if it begins with an `a' tells outfile to open the
 357:  *   file in append mode
 358:  */
 359: lispval
 360: Loutfile()
 361: {
 362:     FILE *port; register lispval name;
 363:     char *mode ="w";    /* mode is w for create new file, a for append */
 364:     char *given;
 365: 
 366:     if(lbot+1== np) protect(nil);
 367:     chkarg(2,"outfile");
 368:     name = lbot->val;
 369:     given = (char *)verify((lbot+1)->val,"Illegal file open mode.");
 370:     if(*given == 'a') mode = "a";
 371: loop:
 372:     name = verify(name,"Please supply atom or string name for port.");
 373: #ifdef  os_vms
 374:     /*
 375: 	 *	If "w" mode, open it as a "txt" file for convenience in VMS
 376: 	 */
 377:     if (strcmp(mode,"w") == 0) {
 378:         int fd;
 379: 
 380:         if ((fd = creat(name,0777,"txt")) < 0) {
 381:             name = errorh1(Vermisc,"Unable to open file for writing.",nil,TRUE,31,name);
 382:             goto loop;
 383:         }
 384:         port = fdopen(fd,mode);
 385:     } else
 386: #endif
 387:     if ((port = fopen((char *)name,mode)) == NULL) {
 388:         name = errorh1(Vermisc,"Unable to open file for writing.",nil,TRUE,31,name);
 389:         goto loop;
 390:     }
 391:     ioname[PN(port)] = (lispval) inewstr((char *)name);
 392:     return(P(port));
 393: }
 394: 
 395: lispval
 396: Lterpr()
 397: {
 398:     register lispval handy;
 399:     FILE *port;
 400: 
 401:     if(lbot==np) handy = nil;
 402:     else
 403:     {
 404:         chkarg(1,"terpr");
 405:         handy = lbot->val;
 406:     }
 407: 
 408:     port = okport(handy,okport(Vpoport->a.clb,stdout));
 409:     putc('\n',port);
 410:     fflush(port);
 411:     return(nil);
 412: }
 413: 
 414: lispval
 415: Lclose()
 416: {
 417:     lispval port;
 418: 
 419:     chkarg(1,"close");
 420:     port = lbot->val;
 421:     if((TYPE(port))==PORT) {
 422:         fclose(port->p);
 423:         ioname[PN(port->p)] = nil;
 424:         return(tatom);
 425:     }
 426:     errorh1(Vermisc,"close:Non-port",nil,FALSE,987,port);
 427:     /* not reached */
 428: }
 429: 
 430: lispval
 431: Ltruename()
 432: {
 433:     chkarg(1,"truename");
 434:     if(TYPE(lbot->val) != PORT)
 435:         errorh1(Vermisc,"truename: non port argument",nil,FALSE,0,lbot->val);
 436: 
 437:     return(ioname[PN(lbot->val->p)]);
 438: }
 439: 
 440: lispval
 441: Lnwritn()
 442: {
 443:     register FILE *port;
 444:     register value;
 445:     register lispval handy;
 446: 
 447:     if(lbot==np) handy = nil;
 448:     else
 449:     {
 450:         chkarg(1,"nwritn");
 451:         handy = lbot->val;
 452:     }
 453: 
 454:     port = okport(handy,okport(Vpoport->a.clb,stdout));
 455:     value = port->_ptr - port->_base;
 456:     return(inewint(value));
 457: }
 458: 
 459: lispval
 460: Ldrain()
 461: {
 462:     register FILE *port;
 463:     register int iodes;
 464:     register lispval handy;
 465:     struct sgttyb arg;
 466: 
 467:     if(lbot==np) handy = nil;
 468:     else
 469:     {
 470:         chkarg(1,"nwritn");
 471:         handy = lbot->val;
 472:     }
 473:     port = okport(handy, okport(Vpoport->a.clb,stdout));
 474:     if(port->_flag & _IOWRT) {
 475:         fflush(port);
 476:         return(nil);
 477:     }
 478:     if(! port->_flag & _IOREAD) return(nil);
 479:     port->_cnt = 0;
 480:     port->_ptr = port->_base;
 481:     iodes = fileno(port);
 482:     if(gtty(iodes,&arg) != -1) stty(iodes,&arg);
 483:     return(P(port));
 484: }
 485: 
 486: lispval
 487: Llist()
 488: {
 489:     /* added for the benefit of mapping functions. */
 490:     register struct argent *ulim, *namptr;
 491:     register lispval temp, result;
 492:     Savestack(4);
 493: 
 494:     ulim = np;
 495:     namptr = lbot + AD;
 496:     temp = result = (lispval) np;
 497:     protect(nil);
 498:     for(; namptr < ulim;) {
 499:         temp = temp->l = newdot();
 500:         temp->d.car = (namptr++)->val;
 501:     }
 502:     temp->l = nil;
 503:     Restorestack();
 504:     return(result->l);
 505: }
 506: 
 507: lispval
 508: Lnumberp()
 509: {
 510:     chkarg(1,"numberp");
 511:     switch(TYPE(lbot->val)) {
 512:     case INT: case DOUB: case SDOT:
 513:         return(tatom);
 514:     }
 515:     return(nil);
 516: }
 517: 
 518: lispval
 519: Latom()
 520: {
 521:     register struct argent *lb = lbot;
 522:     chkarg(1,"atom");
 523:     if(TYPE(lb->val)==DTPR || (HUNKP(lb->val)))
 524:         return(nil);
 525:     else
 526:         return(tatom);
 527: }
 528: 
 529: lispval
 530: Ltype()
 531: {
 532:     chkarg(1,"type");
 533:     switch(TYPE(lbot->val)) {
 534:     case INT:
 535:         return(int_name);
 536:     case ATOM:
 537:         return(atom_name);
 538:     case SDOT:
 539:         return(sdot_name);
 540:     case DOUB:
 541:         return(doub_name);
 542:     case DTPR:
 543:         return(dtpr_name);
 544:     case STRNG:
 545:         return(str_name);
 546:     case ARRAY:
 547:         return(array_name);
 548:     case BCD:
 549:         return(funct_name);
 550:     case OTHER:
 551:         return(other_name);
 552: 
 553:     case HUNK2:
 554:         return(hunk_name[0]);
 555:     case HUNK4:
 556:         return(hunk_name[1]);
 557:     case HUNK8:
 558:         return(hunk_name[2]);
 559:     case HUNK16:
 560:         return(hunk_name[3]);
 561:     case HUNK32:
 562:         return(hunk_name[4]);
 563:     case HUNK64:
 564:         return(hunk_name[5]);
 565:     case HUNK128:
 566:         return(hunk_name[6]);
 567: 
 568:     case VECTOR:
 569:         return(vect_name);
 570:     case VECTORI:
 571:         return(vecti_name);
 572: 
 573:     case VALUE:
 574:         return(val_name);
 575:     case PORT:
 576:         return(port_name);
 577:     }
 578:     return(nil);
 579: }
 580: 
 581: lispval
 582: Ldtpr()
 583: {
 584:     chkarg(1,"dtpr");
 585:     return(typred(DTPR, lbot->val));
 586: }
 587: 
 588: lispval
 589: Lbcdp()
 590: {
 591:     chkarg(1,"bcdp");
 592:     return(typred(BCD, lbot->val));
 593: }
 594: 
 595: lispval
 596: Lportp()
 597: {
 598:     chkarg(1,"portp");
 599:     return(typred(PORT, lbot->val));
 600: }
 601: 
 602: lispval
 603: Larrayp()
 604: {
 605:     chkarg(1,"arrayp");
 606:     return(typred(ARRAY, lbot->val));
 607: }
 608: 
 609: /*
 610:  *	(hunkp 'g_arg1)
 611:  * Returns t if g_arg1 is a hunk, otherwise returns nil.
 612:  */
 613: 
 614: lispval
 615: Lhunkp()
 616: {
 617:     chkarg(1,"hunkp");
 618:     if (HUNKP(lbot->val))
 619:         return(tatom);      /* If a hunk, return t */
 620:     else
 621:         return(nil);        /* else nil */
 622: }
 623: 
 624: lispval
 625: Lset()
 626: {
 627:     lispval varble;
 628: 
 629:     chkarg(2,"set");
 630:     varble = lbot->val;
 631:     switch(TYPE(varble))
 632:         {
 633:     case ATOM:  return(varble->a.clb = lbot[1].val);
 634: 
 635:     case VALUE: return(varble->l = lbot[1].val);
 636:         }
 637: 
 638:     error("IMPROPER USE OF SET",FALSE);
 639:     /* NOTREACHED */
 640: }
 641: 
 642: lispval
 643: Lequal()
 644: {
 645:     register lispval first, second;
 646:     register type1, type2;
 647:     lispval Lsub(),Lzerop();
 648:     long *oldsp;
 649:     Keepxs();
 650:     chkarg(2,"equal");
 651: 
 652: 
 653:     if(lbot->val==lbot[1].val) return(tatom);
 654: 
 655:     oldsp=sp(); stack((long)lbot->val);stack((long)lbot[1].val);
 656:     for(;oldsp > sp();) {
 657: 
 658:         first = (lispval) unstack(); second = (lispval) unstack();
 659:     again:
 660:         if(first==second) continue;
 661: 
 662:         type1=TYPE(first); type2=TYPE(second);
 663:         if(type1!=type2) {
 664:         if((type1==SDOT&&type2==INT)||(type1==INT&&type2==SDOT))
 665:             goto dosub;
 666:         {Freexs(); return(nil);}
 667:         }
 668:         switch(type1) {
 669:         case DTPR:
 670:         stack((long)first->d.cdr); stack((long)second->d.cdr);
 671:         first = first->d.car; second = second->d.car;
 672:         goto again;
 673:         case DOUB:
 674:         if(first->r!=second->r)
 675:             {Freexs(); return(nil);}
 676:         continue;
 677:         case INT:
 678:         if(first->i!=second->i)
 679:             {Freexs(); return(nil);}
 680:         continue;
 681:         case VECTOR:
 682:             if(!vecequal(first,second)) {Freexs(); return(nil);}
 683:         continue;
 684:         case VECTORI:
 685:             if(!veciequal(first,second)) {Freexs(); return(nil);}
 686:         continue;
 687:     dosub:
 688:         case SDOT: {
 689:         lispval temp;
 690:         struct argent *OLDlbot = lbot;
 691:         lbot = np;
 692:         np++->val = first;
 693:         np++->val = second;
 694:         temp = Lsub();
 695:         np = lbot;
 696:         lbot = OLDlbot;
 697:         if(TYPE(temp)!=INT || temp->i!=0)
 698:             {Freexs(); return(nil);}
 699:         }
 700:         continue;
 701:         case VALUE:
 702:         if(first->l!=second->l)
 703:             {Freexs(); return(nil);}
 704:         continue;
 705:         case STRNG:
 706:         if(strcmp((char *)first,(char *)second)!=0)
 707:             {Freexs(); return(nil);}
 708:         continue;
 709: 
 710:         default:
 711:         {Freexs(); return(nil);}
 712:         }
 713:     }
 714:     {Freexs(); return(tatom);}
 715: }
 716: lispval
 717: oLequal()
 718: {
 719:     chkarg(2,"equal");
 720: 
 721:     if( lbot[1].val == lbot->val ) return(tatom);
 722:     if(Iequal(lbot[1].val,lbot->val)) return(tatom); else return(nil);
 723: }
 724: 
 725: Iequal(first,second)
 726: register lispval first, second;
 727: {
 728:     register type1, type2;
 729:     lispval Lsub(),Lzerop();
 730: 
 731:     if(first==second)
 732:         return(1);
 733:     type1=TYPE(first);
 734:     type2=TYPE(second);
 735:     if(type1!=type2) {
 736:         if((type1==SDOT&&type2==INT)||(type1==INT&&type2==SDOT))
 737:             goto dosub;
 738:         return(0);
 739:     }
 740:     switch(type1) {
 741:     case DTPR:
 742:          return(
 743:             Iequal(first->d.car,second->d.car) &&
 744:             Iequal(first->d.cdr,second->d.cdr) );
 745:     case DOUB:
 746:         return(first->r==second->r);
 747:     case INT:
 748:         return( (first->i==second->i));
 749: dosub:
 750:     case SDOT:
 751:     {
 752:         lispval temp;
 753:         struct argent *OLDlbot = lbot;
 754:         lbot = np;
 755:         np++->val = first;
 756:         np++->val = second;
 757:         temp = Lsub();
 758:         np = lbot;
 759:         lbot = OLDlbot;
 760:         return(TYPE(temp)==INT&& temp->i==0);
 761:     }
 762:     case VALUE:
 763:         return( first->l==second->l );
 764:     case STRNG:
 765:         return(strcmp((char *)first,(char *)second)==0);
 766:     }
 767:     return(0);
 768: }
 769: lispval
 770: Zequal()
 771: {
 772:     register lispval first, second;
 773:     register type1, type2;
 774:     lispval Lsub(),Lzerop();
 775:     long *oldsp;
 776:     Keepxs();
 777:     chkarg(2,"equal");
 778: 
 779: 
 780:     if(lbot->val==lbot[1].val) return(tatom);
 781: 
 782:     oldsp=sp(); stack((long)lbot->val);stack((long)lbot[1].val);
 783: 
 784:     for(;oldsp > sp();) {
 785: 
 786:         first = (lispval) unstack(); second = (lispval) unstack();
 787:     again:
 788:         if(first==second) continue;
 789: 
 790:         type1=TYPE(first); type2=TYPE(second);
 791:         if(type1!=type2) {
 792:         if((type1==SDOT&&type2==INT)||(type1==INT&&type2==SDOT))
 793:             goto dosub;
 794:         {Freexs(); return(nil);}
 795:         }
 796:         switch(type1) {
 797:         case DTPR:
 798:         stack((long)first->d.cdr); stack((long)second->d.cdr);
 799:         first = first->d.car; second = second->d.car;
 800:         goto again;
 801:         case DOUB:
 802:         if(first->r!=second->r)
 803:             {Freexs(); return(nil);}
 804:         continue;
 805:         case INT:
 806:         if(first->i!=second->i)
 807:             {Freexs(); return(nil);}
 808:         continue;
 809:     dosub:
 810:         case SDOT:
 811:         {
 812:         lispval temp;
 813:         struct argent *OLDlbot = lbot;
 814:         lbot = np;
 815:         np++->val = first;
 816:         np++->val = second;
 817:         temp = Lsub();
 818:         np = lbot;
 819:         lbot = OLDlbot;
 820:         if(TYPE(temp)!=INT || temp->i!=0)
 821:             {Freexs(); return(nil);}
 822:         }
 823:         continue;
 824:         case VALUE:
 825:         if(first->l!=second->l)
 826:             {Freexs(); return(nil);}
 827:         continue;
 828:         case STRNG:
 829:         if(strcmp((char *)first,(char *)second)!=0)
 830:             {Freexs(); return(nil);}
 831:         continue;
 832:         }
 833:     }
 834:     {Freexs(); return(tatom);}
 835: }
 836: 
 837: /*
 838:  * (print 'expression ['port]) prints the given expression to the given
 839:  * port or poport if no port is given.  The amount of structure
 840:  * printed is a function of global lisp variables plevel and
 841:  * plength.
 842:  */
 843: lispval
 844: Lprint()
 845: {
 846:     register lispval handy;
 847:     extern int plevel,plength;
 848: 
 849: 
 850:     handy = nil;            /* port is optional, default nil */
 851:     switch(np-lbot)
 852:     {
 853:         case 2: handy = lbot[1].val;
 854:         case 1: break;
 855:         default: argerr("print");
 856:     }
 857: 
 858:     chkrtab(Vreadtable->a.clb);
 859:     if(TYPE(Vprinlevel->a.clb) == INT)
 860:     {
 861:        plevel = Vprinlevel->a.clb->i;
 862:     }
 863:     else plevel = -1;
 864:     if(TYPE(Vprinlength->a.clb) == INT)
 865:     {
 866:         plength = Vprinlength->a.clb->i;
 867:     }
 868:     else plength = -1;
 869:     printr(lbot->val,okport(handy,okport(Vpoport->a.clb,poport)));
 870:     return(nil);
 871: }
 872: 
 873: /* patom does not use plevel or plength
 874:  *
 875:  * form is (patom 'value ['port])
 876:  */
 877: lispval
 878: Lpatom()
 879: {
 880:     register lispval temp;
 881:     register lispval handy;
 882:     register int typ;
 883:     FILE *port;
 884: 
 885:     handy = nil;            /* port is optional, default nil */
 886:     switch(np-lbot)
 887:     {
 888:         case 2: handy = lbot[1].val;
 889:         case 1: break;
 890:         default: argerr("patom");
 891:     }
 892: 
 893:     temp = Vreadtable->a.clb;
 894:     chkrtab(temp);
 895:     port = okport(handy, okport(Vpoport->a.clb,stdout));
 896:     if ((typ= TYPE((temp = (lbot)->val))) == ATOM)
 897:         fputs(temp->a.pname, port);
 898:     else if(typ == STRNG)
 899:         fputs((char *)temp,port);
 900:     else
 901:     {
 902:             if(TYPE(Vprinlevel->a.clb) == INT)
 903:         {
 904:             plevel = Vprinlevel->a.clb->i;
 905:         }
 906:         else plevel = -1;
 907:         if(TYPE(Vprinlength->a.clb) == INT)
 908:         {
 909:             plength = Vprinlength->a.clb->i;
 910:         }
 911:         else plength = -1;
 912: 
 913:         printr(temp, port);
 914:     }
 915:     return(temp);
 916: }
 917: 
 918: /*
 919:  * (pntlen thing) returns the length it takes to print out
 920:  * an atom or number.
 921:  */
 922: 
 923: lispval
 924: Lpntlen()
 925: {
 926:     return(inewint((long)Ipntlen()));
 927: }
 928: Ipntlen()
 929: {
 930:     register lispval temp;
 931:     register char *handy;
 932:     char *sprintf();
 933: 
 934:     temp = np[-1].val;
 935: loop:   switch(TYPE(temp)) {
 936: 
 937:     case ATOM:
 938:         handy = temp->a.pname;
 939:         break;
 940: 
 941:     case STRNG:
 942:         handy = (char *) temp;
 943:         break;
 944: 
 945:     case INT:
 946:         sprintf(strbuf,"%d",temp->i);
 947:         handy =strbuf;
 948:         break;
 949: 
 950:     case DOUB:
 951:         sprintf(strbuf,"%g",temp->r);
 952:         handy =strbuf;
 953:         break;
 954: 
 955:     default:
 956:         temp = error("Non atom or number to pntlen\n",TRUE);
 957:         goto loop;
 958:     }
 959: 
 960:     return( strlen(handy));
 961: }
 962: #undef okport
 963: FILE *
 964: okport(arg,proper)
 965: lispval arg;
 966: FILE *proper;
 967: {
 968:     if(TYPE(arg)!=PORT)
 969:         return(proper);
 970:     else
 971:         return(arg->p);
 972: }

Defined functions

Iequal defined in line 725; used 3 times
Ipntlen defined in line 928; used 2 times
Larrayp defined in line 602; never used
Latom defined in line 518; never used
Lbcdp defined in line 588; never used
Lbigtol defined in line 221; never used
Lc02r defined in line 142; never used
Lc03r defined in line 150; never used
Lc04r defined in line 158; never used
Lc12r defined in line 146; never used
Lc13r defined in line 154; never used
Lc14r defined in line 162; never used
Lcaar defined in line 138; never used
Lcadr defined in line 134; never used
Lcar defined in line 126; never used
Lcdr defined in line 130; never used
Lclose defined in line 414; never used
Lcons defined in line 243; used 1 times
Ldrain defined in line 459; never used
Ldtpr defined in line 581; never used
Leq defined in line 301; never used
Lequal defined in line 642; used 3 times
Leval defined in line 18; never used
Lhunkp defined in line 614; never used
Linfile defined in line 333; never used
Llist defined in line 486; used 2 times
Lnthelem defined in line 176; never used
Lnull defined in line 313; never used
Lnumberp defined in line 507; never used
Lnwritn defined in line 440; never used
Loutfile defined in line 359; never used
Lpatom defined in line 877; used 1 times
Lpntlen defined in line 923; never used
Lportp defined in line 595; never used
Lprint defined in line 843; used 1 times
Lreturn defined in line 324; never used
Lrplca defined in line 292; never used
Lrplcd defined in line 296; never used
Lscons defined in line 198; never used
Lset defined in line 624; never used
Lterpr defined in line 395; never used
Ltruename defined in line 430; never used
Ltype defined in line 529; never used
Lxcar defined in line 28; never used
Lxcdr defined in line 47; never used
Zequal defined in line 769; never used
cxxr defined in line 70; used 11 times
oLequal defined in line 716; never used
okport defined in line 963; used 25 times
rpla defined in line 258; used 2 times

Defined variables

rcsid defined in line 2; never used

Defined macros

CA defined in line 255; used 3 times
CD defined in line 256; used 1 times
Last modified: 1985-08-14
Generated: 2016-12-26
Generated by src2html V0.67
page hit count: 2557
Valid CSS Valid XHTML 1.0 Strict