Annotation of 43BSD/contrib/B/src/bsmall/B1obj.c, revision 1.1.1.1

1.1       root        1: /* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1984. */
                      2: /* $Header: B1obj.c,v 1.1 84/06/28 00:48:57 timo Exp $ */
                      3: 
                      4: /* General operations on objects */
                      5: 
                      6: #include "b.h"
                      7: #include "b1obj.h"
                      8: #include "B1tlt.h"
                      9: 
                     10: #define Sgn(d) (d)
                     11: 
                     12: Visible relation compare(v, w) value v, w; {
                     13:        literal vt= v->type, wt= w->type;
                     14:        register intlet vlen= Length(v), wlen= Length(w), len, k;
                     15:        value message;
                     16:        if (v == w) return 0;
                     17:        if (!(vt == wt && !(vt == Com && vlen != wlen) ||
                     18:                            vt == ELT && (wt == Lis || wt == Tab) ||
                     19:                            wt == ELT && (vt == Lis || vt == Tab))) {
                     20:                message= concat(mk_text("incompatible types: "),
                     21:                         concat(convert((value) valtype(v), No, No),
                     22:                         concat(mk_text(" and "),
                     23:                         convert((value) valtype(w), No, No))));
                     24:                error(Str(message)); /*doesn't return: so can't release message*/
                     25:        }
                     26:        if (vt != Num && (vlen == 0 || wlen == 0))
                     27:                return Sgn(vlen-wlen);
                     28:        switch (vt) {
                     29:        case Num: return numcomp(v, w);
                     30:        case Tex: return strcmp(Str(v), Str(w));
                     31: 
                     32:        case Com:
                     33:        case Lis:
                     34:        case Tab:
                     35:        case ELT:
                     36:                {value *vp= Ats(v), *wp= Ats(w);
                     37:                 relation c;
                     38:                        len= vlen < wlen ? vlen : wlen;
                     39:                        Overall if ((c= compare(*vp++, *wp++)) != 0) return c;
                     40:                        return Sgn(vlen-wlen);
                     41:                }
                     42:        default:
                     43:                syserr("comparison of unknown types");
                     44:                return (intlet) Dummy;
                     45:        }
                     46: }
                     47: 
                     48: Visible double hash(v) value v; {
                     49:        literal t= v->type; intlet len= Length(v), k; double d= t+.404*len;
                     50:        switch (t) {
                     51:        case Num: return numhash(v);
                     52:        case Tex:
                     53:                {string vp= Str(v);
                     54:                        Overall d= .987*d+.277*(*vp++);
                     55:                        return d;
                     56:                }
                     57:        case Com:
                     58:        case Lis:
                     59:        case Tab:
                     60:        case ELT:
                     61:                {value *vp= Ats(v);
                     62:                        if (len == 0) return .909;
                     63:                        Overall d= .874*d+.310*hash(*vp++);
                     64:                        return d;
                     65:                }
                     66:        default:
                     67:                syserr("hash called with unknown type");
                     68:                return (double) Dummy;
                     69:        }
                     70: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.