diff options
author | Thomas Gellekum <tg@FreeBSD.org> | 2000-09-18 12:55:15 +0000 |
---|---|---|
committer | Thomas Gellekum <tg@FreeBSD.org> | 2000-09-18 12:55:15 +0000 |
commit | 8d134d5311691beaca6add411963e6c7f0141ef3 (patch) | |
tree | b99fbe67a2ba8a0963a80fe6725994221c37a460 /devel/py-kjbuckets | |
parent | ef2aa55886066cc43963674b6d231d6319297981 (diff) | |
download | ports-8d134d5311691beaca6add411963e6c7f0141ef3.tar.gz ports-8d134d5311691beaca6add411963e6c7f0141ef3.zip |
Notes
Diffstat (limited to 'devel/py-kjbuckets')
-rw-r--r-- | devel/py-kjbuckets/Makefile | 10 | ||||
-rw-r--r-- | devel/py-kjbuckets/files/patch-aa | 4 | ||||
-rw-r--r-- | devel/py-kjbuckets/files/patch-ab | 2333 | ||||
-rw-r--r-- | devel/py-kjbuckets/pkg-plist | 4 |
4 files changed, 2329 insertions, 22 deletions
diff --git a/devel/py-kjbuckets/Makefile b/devel/py-kjbuckets/Makefile index d69e12232331..876e906848af 100644 --- a/devel/py-kjbuckets/Makefile +++ b/devel/py-kjbuckets/Makefile @@ -14,16 +14,14 @@ DISTNAME= kjb MAINTAINER= nectar@FreeBSD.org -BUILD_DEPENDS= python1.5:${PORTSDIR}/lang/python15 -RUN_DEPENDS= python1.5:${PORTSDIR}/lang/python15 - +USE_PYTHON= yes NO_WRKSUBDIR= yes +MAKE_ENV= PYTHON_VERSION=${PYTHON_VERSION} MAKEFILE= makefile do-install: - ${MKDIR} ${PREFIX}/lib/python1.5/site-packages - ${INSTALL_DATA} ${WRKSRC}/kjbucketsmodule.so \ - ${PREFIX}/lib/python1.5/site-packages/ + ${MKDIR} ${PYTHON_SITELIBDIR} + ${INSTALL_DATA} ${WRKSRC}/kjbucketsmodule.so ${PYTHON_SITELIBDIR} .if !defined(NOPORTDOCS) ${INSTALL_DATA} ${WRKSRC}/kjbuckets.html ${PREFIX}/share/doc/ .endif diff --git a/devel/py-kjbuckets/files/patch-aa b/devel/py-kjbuckets/files/patch-aa index 9739c96790ce..158f49a0c731 100644 --- a/devel/py-kjbuckets/files/patch-aa +++ b/devel/py-kjbuckets/files/patch-aa @@ -13,8 +13,8 @@ -srcdir= /usr/local/include/python1.4 -cfgdir= /usr/local/lib/python1.4/config -#objdir= /big/arw/Python-1.3/Objects -+srcdir= ${PREFIX}/include/python1.5 -+cfgdir= ${PREFIX}/lib/python1.5/config ++srcdir= ${PREFIX}/include/${PYTHON_VERSION} ++cfgdir= ${PREFIX}/lib/${PYTHON_VERSION}/config # Compiler flags -OPT= -g diff --git a/devel/py-kjbuckets/files/patch-ab b/devel/py-kjbuckets/files/patch-ab index 58197ca68b1d..9c914a4e2e79 100644 --- a/devel/py-kjbuckets/files/patch-ab +++ b/devel/py-kjbuckets/files/patch-ab @@ -1,6 +1,14 @@ ---- kjbucketsmodule.c.orig Thu Jun 26 09:06:40 1997 -+++ kjbucketsmodule.c Sat Mar 27 20:27:50 1999 -@@ -157,7 +157,7 @@ +--- kjbucketsmodule.c.orig Thu Jun 26 16:06:40 1997 ++++ kjbucketsmodule.c Wed Sep 13 19:45:45 2000 +@@ -90,7 +90,6 @@ + /* include a bunch of stuff */ + + #include "Python.h" +-#include "rename2.h" + /* #include "allobjects.h" */ + /* #include "modsupport.h" */ + /* #include "ceval.h" */ +@@ -157,7 +156,7 @@ ( (tp->entries * RESIZEFACTOR) < (tp->size * GSIZE) ) ) /* group states */ @@ -9,7 +17,230 @@ /* bucket behaviors, smaller is less general! */ enum BucketFlag { SETFLAG=0, DICTFLAG=1, GRAPHFLAG=2 }; -@@ -607,7 +607,7 @@ +@@ -172,11 +171,11 @@ + + #ifdef CACHE_HASH + #define GETHASH(hashvalue, object) \ +- if (!is_stringobject(object) || \ +- (hashvalue = ((stringobject *) object)->ob_shash) == -1)\ +- hashvalue = hashobject(object) ++ if (!PyString_Check(object) || \ ++ (hashvalue = ((PyStringObject *) object)->ob_shash) == -1)\ ++ hashvalue = PyObject_Hash(object) + #else +-#define GETHASH(hashvalue, object) hashvalue = hashobject(object) ++#define GETHASH(hashvalue, object) hashvalue = PyObject_Hash(object) + #endif + + /*********************************************************/ +@@ -185,14 +184,14 @@ + /* set bucket structure */ + typedef struct { + long hash; +- object * member; ++ PyObject * member; + } SetBucket; + + /* graph and dict bucket structure */ + typedef struct { + long hash; +- object * member; +- object * map; ++ PyObject * member; ++ PyObject * map; + } DiBucket; + + /* for passing general buckets around, with external flags */ +@@ -203,7 +202,7 @@ + + /* destructuring a bucket (macroized) */ + #define BPtrDestructure(/*Bucketptr*/ Bp, /*enum BucketFlag*/ flag,\ +- /*long*/ hp, /*object*/ memp, /*object*/ mapp)\ ++ /*long*/ hp, /*PyObject*/ memp, /*PyObject*/ mapp)\ + {\ + switch (flag) {\ + case SETFLAG:\ +@@ -225,17 +224,17 @@ + static long BPtrDump(Bucketptr Bp, enum BucketFlag flag, FILE *fp) + { + long h; +- object *mem, *map; ++ PyObject *mem, *map; + BPtrDestructure(Bp, flag, h, mem, map); + fprintf(fp, "Bkt[%ld, ",h); + if (mem == 0) { fprintf(fp, "NULL"); } + /*else { +- if (printobject(mem, fp, 0) != 0) { return -1; } ++ if (PyObject_Print(mem, fp, 0) != 0) { return -1; } + }*/ + fprintf(fp, "%ld, ",mem); + if (map == 0) { fprintf(fp, "NULL"); } + /*else { +- if (printobject(map, fp, 0) != 0) { return -1; } ++ if (PyObject_Print(map, fp, 0) != 0) { return -1; } + }*/ + fprintf(fp, "%ld] ",map); + return 0; +@@ -243,13 +242,13 @@ + #endif + + /* setting a bucket +- INCREFs handled here. ++ Py_INCREFs handled here. + assumes initial contents are null or garbage. (macroized) + */ + /* static long */ + #define BPtrSet( \ + /* Bucketptr */ Bp, /* enum BucketFlag */ flag,\ +- /* long */ h, /* object * */mem1, /* object * */map1)\ ++ /* long */ h, /* PyObject * */mem1, /* PyObject * */map1)\ + {\ + switch(flag) {\ + case SETFLAG:\ +@@ -257,15 +256,15 @@ + /* ignore map */\ + Bp.SBucketp->hash = h;\ + Bp.SBucketp->member = mem1;\ +- if (mem1 != 0) { XINCREF (mem1); }\ ++ if (mem1 != 0) { Py_XINCREF (mem1); }\ + break;\ + case DICTFLAG:\ + case GRAPHFLAG:\ + Bp.DBucketp->hash = h;\ + Bp.DBucketp->member = mem1;\ +- if (mem1 != 0) { XINCREF (mem1); }\ ++ if (mem1 != 0) { Py_XINCREF (mem1); }\ + Bp.DBucketp->map = map1;\ +- if (map1 != 0) { XINCREF (map1); }\ ++ if (map1 != 0) { Py_XINCREF (map1); }\ + break;\ + }\ + } +@@ -275,13 +274,13 @@ + */ + /*static long BPtrInit( Bucketptr Bp, enum BucketFlag flag ) + { +- object *dummy; ++ PyObject *dummy; + dummy = 0; + BPtrSet( Bp, flag, NOHASH, dummy, dummy ); + }*/ + + /* re-initialization assuming valid value +- DECREFs handled here. ++ Py_DECREFs handled here. + to save values in the bucket for use after reinitialization, + incref them first and decref after... + (macroized) +@@ -290,11 +289,11 @@ + #define BPtrReInit( /*Bucketptr*/ Bp, /*enum BucketFlag*/ flag )\ + {\ + long hashBBB;\ +- object *MemberBBB, *MapBBB, *dummyBBB;\ ++ PyObject *MemberBBB, *MapBBB, *dummyBBB;\ + BPtrDestructure( Bp, flag, hashBBB, MemberBBB, MapBBB );\ +- if ( MemberBBB != 0 ) { XDECREF(MemberBBB); }\ ++ if ( MemberBBB != 0 ) { Py_XDECREF(MemberBBB); }\ + /* don't decref map for sets!! */\ +- if ( (MapBBB != 0) && (flag != SETFLAG) ) { XDECREF(MapBBB); }\ ++ if ( (MapBBB != 0) && (flag != SETFLAG) ) { Py_XDECREF(MapBBB); }\ + dummyBBB = 0;\ + BPtrSet( Bp, flag, NOHASH, dummyBBB, dummyBBB );\ + } +@@ -308,14 +307,14 @@ + /*Bucketptr*/ Bp, \ + /*enum BucketFlag*/ flag,\ + /*long*/ h, \ +- /*object * */ Mm, \ +- /*object * */ Mp, \ ++ /*PyObject * */ Mm, \ ++ /*PyObject * */ Mp, \ + /*enum ForceFlag*/ Force,\ + /*long * */ newflag, \ + /*long * */ dirtyflag) \ + {\ + long hashAAA;\ +- object *MemberAAA, *MapAAA, *dummyAAA;\ ++ PyObject *MemberAAA, *MapAAA, *dummyAAA;\ + newflag = 0; /* default assumption */\ + result = 0; /* default: fail */\ + BPtrDestructure( Bp, flag, hashAAA, MemberAAA, MapAAA );\ +@@ -336,7 +335,7 @@ + if (h == NOHASH)\ + { result = 1; } /* bucket full, hash null == null match */\ + else { /* fully defined match */\ +- if ((h == hashAAA) && (cmpobject(Mm, MemberAAA)==0))\ ++ if ((h == hashAAA) && (PyObject_Compare(Mm, MemberAAA)==0))\ + { result = 1; } /* hash defined, all eq == match */\ + }\ + }\ +@@ -349,12 +348,12 @@ + /* Forced match succeeds if bucket is empty or members match */\ + if ((Force == FORCE) &&\ + ( (hashAAA == NOHASH) || \ +- ((h == hashAAA)&&(cmpobject(Mm, MemberAAA)==0)) ) ) {\ ++ ((h == hashAAA)&&(PyObject_Compare(Mm, MemberAAA)==0)) ) ) {\ + if ((Mm == 0) || (Mp == 0)) { result = -1; } /* error */\ + else {\ + if (hashAAA == NOHASH) { newflag = 1; } /* new if old was empty */\ + else {\ +- if (cmpobject(MapAAA,Mp)!=0) { /* overwriting: dirty */\ ++ if (PyObject_Compare(MapAAA,Mp)!=0) { /* overwriting: dirty */\ + dirtyflag = 1;\ + }\ + }\ +@@ -364,8 +363,8 @@ + }\ + } else {\ + if ( (h!=NOHASH) && (h==hashAAA) &&\ +- (Mm != 0) && (cmpobject(Mm, MemberAAA)==0) &&\ +- ( ( Mp == 0 ) || (cmpobject(MapAAA,Mp)==0) ) )\ ++ (Mm != 0) && (PyObject_Compare(Mm, MemberAAA)==0) &&\ ++ ( ( Mp == 0 ) || (PyObject_Compare(MapAAA,Mp)==0) ) )\ + { result = 1; } /* successful unforced match */\ + }\ + }\ +@@ -390,8 +389,8 @@ + } else {\ + /* unforced match, can match if Mm is null */\ + if (( hashAAA != NOHASH ) && ( hashAAA == h ) &&\ +- (Mm != 0) && ( cmpobject(Mm,MemberAAA)==0 ) && \ +- ( (Mp == 0) || ( cmpobject(MapAAA,Mp)==0 ))) {\ ++ (Mm != 0) && ( PyObject_Compare(Mm,MemberAAA)==0 ) && \ ++ ( (Mp == 0) || ( PyObject_Compare(MapAAA,Mp)==0 ))) {\ + Dprint(("graph unforced match\n")); \ + result = 1; /* successful unforced match */\ + }\ +@@ -483,7 +482,7 @@ + /*Groupptr*/ Eg, /*enum BucketFlag*/ Eflag)\ + {\ + long Eh;\ +- object *EMm, *EMp;\ ++ PyObject *EMm, *EMp;\ + Bucketptr EBp;\ + GetBucket(EBp, Eg, Eflag, 0);\ + BPtrDestructure(EBp, Eflag, Eh, EMm, EMp);\ +@@ -498,7 +497,7 @@ + #define Groupinit(/*Groupptr*/ Dg, /*enum BucketFlag*/ Dflag)\ + {\ + Bucketptr DBp;\ +- object *Ddummy;\ ++ PyObject *Ddummy;\ + long Di;\ + Ddummy = 0;\ + for (Di=0; Di<GSIZE; Di++) {\ +@@ -551,8 +550,8 @@ + /* Groupptr */ g, \ + /* enum BucketFlag */ flag,\ + /* long */ hash1, \ +- /* object * */ Member1, \ +- /* object * */ Map1, \ ++ /* PyObject * */ Member1, \ ++ /* PyObject * */ Map1, \ + /* enum ForceFlag */ Force, \ + /* long */ StartAfter,\ + /* long * */ index, /* use literal */\ +@@ -607,7 +606,7 @@ Nextptr = &(SGptr->mem.free.Next);\ break;\ case ROOT:\ @@ -18,7 +249,7 @@ case UNKNOWN:\ templateptr.sbp = &(SGptr->mem.group);\ Nextptr = &(SGptr->mem.group.Next);\ -@@ -623,7 +623,7 @@ +@@ -623,7 +622,7 @@ Nextptr = &(DGptr->mem.free.Next);\ break;\ case ROOT:\ @@ -27,7 +258,7 @@ case UNKNOWN:\ templateptr.dbp = &(DGptr->mem.group);\ Nextptr = &(DGptr->mem.group.Next);\ -@@ -739,7 +739,7 @@ +@@ -739,7 +738,7 @@ GArrayRef(Jarray,Jflag,Jprevious, Jgprev, JPrevState, JNextOfPrev);\ GArrayRef(Jarray,Jflag,Jtoindex, Jgother, JOtherState, JNextOfOther);\ *JNextOfOther = *JNext;\ @@ -36,7 +267,21 @@ GroupCopy(Jgother, Jg, Jflag);\ *JNextOfPrev = Jtoindex;\ Groupinit(Jg, Jflag);\ -@@ -879,7 +879,7 @@ +@@ -822,11 +821,11 @@ + (DiGroup *) calloc(sizeof(DiGroup), size); + break; + default: +- err_setstr(SystemError, "invalid internal table behavior flag"); ++ PyErr_SetString(PyExc_SystemError, "invalid internal table behavior flag"); + return 0; /* error */ + } + if (groups.Dgroups == NULL) { +- err_nomem(); ++ PyErr_NoMemory(); + return 0; /* error */ + } + /* initialize all states to unknown */ +@@ -879,7 +878,7 @@ fprintf(fp, "ROOT(next=%ld)",*Next); if (GroupDump(g,flag,fp)!=0) { return -1; } break; @@ -45,7 +290,7 @@ fprintf(fp, "OVFLW(next=%ld)",*Next); if (GroupDump(g,flag,fp)!=0) { return -1; } break; -@@ -903,7 +903,7 @@ +@@ -903,7 +902,7 @@ for (i=0; i<size; i++) { Dprint(("greinit at %ld\n",i)); GArrayRef(g, flag, i, groupp, State, d); @@ -54,7 +299,43 @@ for (j=0; j<GSIZE; j++) { GetBucket(Bp,groupp,flag,j); BPtrReInit(Bp, flag); -@@ -1056,7 +1056,7 @@ +@@ -921,7 +920,7 @@ + /* reinitialize all buckets */ + groupsReinit(g, flag, size); + /* now delete the array */ +- DEL(g.Sgroups); ++ PyMem_DEL(g.Sgroups); + } + + /* unfreeing a group in the Table *assumed free with garbage contents* */ +@@ -1001,7 +1000,7 @@ + */ + /* crazy idea: macroize this monster, and use stub only for recursive + calls... */ +-static long tableMatch( Table *tp, object *member1, object *map1, ++static long tableMatch( Table *tp, PyObject *member1, PyObject *map1, + enum ForceFlag Force, + long rootgroupI, long lastgroupI, long lastbucketI, long hsh, + /*outputs*/ long *rtgrp, long *nxtgrp, long *nxtbkt, Bucketptr *Bp, +@@ -1021,7 +1020,7 @@ + + /* sanity checks (comment out later?) */ + if ( (member1 == 0) && ( (rootgroupI < 0) || (Force == FORCE) ) ) { +- err_setstr(SystemError, "bug in kjbuckets implementation (tableMatch)"); ++ PyErr_SetString(PyExc_SystemError, "bug in kjbuckets implementation (tableMatch)"); + return -1; + } + +@@ -1036,7 +1035,7 @@ + /*if (tp->Free != -1) { + GArrayRef(groups, flag, tp->Free, root, state, rNext); + if (*state != FREE) { +- err_setstr(SystemError, "free index not free in table"); ++ PyErr_SetString(PyExc_SystemError, "free index not free in table"); + return -1; + } + }*/ +@@ -1056,7 +1055,7 @@ /* lastgroup and lastbucket must be none */ lastgroupI = lastbucketI = -1; /* otherwise must force an insert, need root group... */ @@ -63,7 +344,25 @@ /* swap out the overflow group */ Dprint(("root is overflow %ld\n",rootgroupI)); if (tp->Free == -1) { -@@ -1130,7 +1130,7 @@ +@@ -1076,7 +1075,7 @@ + Dprint(("unfreeing rootgroup %ld\n", rootgroupI)); + UnFreeTableIndex(rootgroupI, tp, rootgroupI); + } else { +- err_setstr(SystemError, "bad rootgroup state in tablematch"); ++ PyErr_SetString(PyExc_SystemError, "bad rootgroup state in tablematch"); + return -1; /* error */ + } + } +@@ -1107,7 +1106,7 @@ + if (found != 0) { + Dprint(("tm: found = %ld\n",found)); + if (found<0) { +- err_setstr(SystemError, "groupmatch abnormal return"); ++ PyErr_SetString(PyExc_SystemError, "groupmatch abnormal return"); + return -1; + } + if (*isnew != 0) { tp->entries++; } +@@ -1130,13 +1129,13 @@ } UnFreeTableIndex(AvailableI, tp, tp->Free); GArrayRef(groups, flag, AvailableI, avail, availState, availNext); @@ -72,7 +371,69 @@ *availNext = rootgroupI; *Next = AvailableI; groupmatch(found, avail,flag,hsh,member1,map1, -@@ -1235,7 +1235,7 @@ + Force, -1, (*nxtbkt), (*Bp), (*isnew), (*dirtyptr)); + if (found<0) { +- err_setstr(SystemError, "groupmatch abnormal return"); ++ PyErr_SetString(PyExc_SystemError, "groupmatch abnormal return"); + return -1; + } + *nxtgrp = AvailableI; +@@ -1149,16 +1148,16 @@ + /* some simple uses of table matching */ + + /* find (or set) a matching pair */ +-static long TableGet1( Table *tp, object *member1, object *map1, long hash, ++static long TableGet1( Table *tp, PyObject *member1, PyObject *map1, long hash, + enum ForceFlag Force, +- object **memout, object **mapout) ++ PyObject **memout, PyObject **mapout) + { + long hashout; + long rt, nxt, nxtb, isnew, found; + Bucketptr Bp; + enum BucketFlag flag = tp->flag; + if (member1 == NULL) { +- err_setstr(SystemError, "TableGet1 called with NULL??"); ++ PyErr_SetString(PyExc_SystemError, "TableGet1 called with NULL??"); + return -1; + } + Dprint(("tg1: calling tablematch\n")); +@@ -1167,7 +1166,7 @@ + &rt, &nxt, &nxtb, &Bp, &hashout, &isnew); + if (found == -1) { return -1; } + if (found == 0) { +- err_setval(KeyError, member1); ++ PyErr_SetObject(PyExc_KeyError, member1); + return -1; + } + BPtrDestructure(Bp, flag, hashout, *memout, *mapout); +@@ -1178,7 +1177,7 @@ + /* could macroize */ + long ReInsertGroup( Groupptr g, enum BucketFlag flag, Table *tp) + { +- object *Member, *Map; ++ PyObject *Member, *Map; + long i, rt, nxt, nxtb, isnew, test; + long hash, h; + Bucketptr Bp, Bpdummy; +@@ -1189,7 +1188,7 @@ + test = tableMatch(tp, Member, Map, FORCE, -1, -1, -1, hash, + &rt, &nxt, &nxtb, &Bpdummy, &h, &isnew); + if (test != 1) { +- err_setstr(SystemError, "unable to resize table"); ++ PyErr_SetString(PyExc_SystemError, "unable to resize table"); + return 0; + } + } +@@ -1228,14 +1227,14 @@ + if (*State != FREE) { + Dprint(("free ptr %ld corrupted in resize/alloc, State=%ld not %ld\n",\ + tp->Free,*State,FREE)); +- err_setstr(SystemError, "resize fail (1)"); ++ PyErr_SetString(PyExc_SystemError, "resize fail (1)"); + return 0; + } + }*/ /* now reinsert all former contents */ for (i=0; i<size; i++) { GArrayRef(oldgroups, flag, i, g, State, Next); @@ -81,7 +442,94 @@ if (ReInsertGroup(g, flag, tp) == 0) { success = 0; break; -@@ -1401,7 +1401,7 @@ +@@ -1247,7 +1246,7 @@ + Dprint((\ + "free ptr %ld corrupted in resize/reinsert %ld, State=%ld not %ld\n",\ + tp->Free,i,*State,FREE)); +- err_setstr(SystemError, "resize fail (2)"); ++ PyErr_SetString(PyExc_SystemError, "resize fail (2)"); + return 0; + }*/ + } +@@ -1261,7 +1260,7 @@ + if (*State != FREE) { + Dprint(("free ptr %ld corrupted in resize, State=%ld not %ld\n",tp->Free,\ + *State,FREE)); +- err_setstr(SystemError, "resize fail (3)"); ++ PyErr_SetString(PyExc_SystemError, "resize fail (3)"); + return 0; + }*/ + if (success==0) Dprint(("failing in tableresize\n")); +@@ -1269,9 +1268,9 @@ + } + + /* deleting a member from a group, deletes *all* matching members */ +-long deleteFromTable(Table *tp, object *member1, object *map1) ++long deleteFromTable(Table *tp, PyObject *member1, PyObject *map1) + { +- object *M, *Mp; ++ PyObject *M, *Mp; + enum BucketFlag flag = tp->flag; + GroupArray groups = tp->groups; + long hash, bhash; +@@ -1286,7 +1285,7 @@ + &rtgrp, &nxtgrp, &nxtbkt, &Bp, &hash, &isnew); + if (found == -1) { return 0; } /* external error */ + if (found == 0) { +- err_setval(KeyError, member1); ++ PyErr_SetObject(PyExc_KeyError, member1); + return 0; + } + /* mark the table as dirty */ +@@ -1310,20 +1309,20 @@ + while (found) { + BPtrDestructure(Bp, flag, hash, M, Mp); + tp->entries--; +- /* !!! NOTE: since BPtrReInit DECREFs the contents, must +- INCREF contents here to prevent deallocation of the ++ /* !!! NOTE: since BPtrReInit Py_DECREFs the contents, must ++ Py_INCREF contents here to prevent deallocation of the + members and decref after reinstallation in the table + !!! (kinda subtle python thing!) !!! */ +- XINCREF(M); +- XINCREF(Mp); ++ Py_XINCREF(M); ++ Py_XINCREF(Mp); + BPtrReInit(Bp,flag); + bfound = tableMatch(tp, M, Mp, + FORCE, brt, bnxtgrp, bnxtbkt, hash, + &brt, &bnxtgrp, &bnxtbkt, &bBp, &bhash, &bisnew); +- XDECREF(M); +- XDECREF(Mp); ++ Py_XDECREF(M); ++ Py_XDECREF(Mp); + if (found != 1) { +- err_setstr(SystemError, "?? cannot backfill on delete"); ++ PyErr_SetString(PyExc_SystemError, "?? cannot backfill on delete"); + return 0; + } + found = tableMatch(tp, 0, 0, +@@ -1370,8 +1369,8 @@ + long root; + long lastgroup; + long lastbucket; +- object *key; +- object *map; ++ PyObject *key; ++ PyObject *map; + long hash; + } TableWalker; + +@@ -1386,7 +1385,7 @@ + enum BucketFlag flag; + enum GState *State; + long *Next, size, found, isnew, dirtyptr; +- object *dummy; ++ PyObject *dummy; + Table *tp = twp->tp; + size = tp->size; + flag = tp->flag; +@@ -1401,7 +1400,7 @@ found = 0; do { GArrayRef(tp->groups, flag, twp->lastgroup, g, State, Next); @@ -90,3 +538,1864 @@ dummy = 0; groupmatch(found, g, flag, NOHASH, dummy, dummy, NOFORCE,\ (twp->lastbucket), (twp->lastbucket), \ +@@ -1438,7 +1437,7 @@ + static long Nextbykey(TableWalker *twp) + { + Bucketptr Bp; +- object *dummyk; ++ PyObject *dummyk; + long dummyh; + long isnew; + Dprint(("Nextbykey\n")); +@@ -1454,7 +1453,7 @@ + } + + /* could macroize */ +-static void Initbykey(TableWalker *twp, Table *tp, object *key, long hash) ++static void Initbykey(TableWalker *twp, Table *tp, PyObject *key, long hash) + { + Dprint(("Initbykey\n")); + twp->tp = tp; +@@ -1475,7 +1474,7 @@ + { + long test; + TableWalker tw; +- object *d1, *d2; ++ PyObject *d1, *d2; + /* walk through the source */ + (void) InitAll(&tw, source); + while (tw.valid == 1) { +@@ -1496,11 +1495,11 @@ + { + long test; + TableWalker tw; +- object *d1, *d2; ++ PyObject *d1, *d2; + enum BucketFlag tflag = target->flag; + /* source flag cannot be set */ + if (source->flag == SETFLAG) { +- err_setstr(TypeError, "Cannot transpose set"); ++ PyErr_SetString(PyExc_TypeError, "Cannot transpose set"); + return -1; /* error return */ + } + /* walk through the source */ +@@ -1535,7 +1534,7 @@ + long prelim) + { + TableWalker lwalker, rwalker; +- object *d1, *d2; ++ PyObject *d1, *d2; + long test, count, exclude, rt, nxt, nxtb, isnew; + Bucketptr Bp; + long hashout; +@@ -1592,7 +1591,7 @@ + long test, rt, nxt, nxtb, isnew, found, count; + Bucketptr Bp; + TableWalker tw; +- object *d1, *d2; ++ PyObject *d1, *d2; + /* walk through left */ + (void) InitAll(&tw, left); + count = 0; +@@ -1622,7 +1621,7 @@ + return 1 if found, else 0 (-1 on error). + */ + static long Tmindiff(Table *left, Table *right, +- object **mem, object **map, long *hash) ++ PyObject **mem, PyObject **map, long *hash) + { + long hashout; + long gotit, rt, nxt, nxtb, isnew, found, cmp; +@@ -1646,9 +1645,9 @@ + gotit = 1; + } else { + cmp = *hash - tw.hash; +- if (cmp == 0) { cmp = cmpobject( tw.key, *mem ); } ++ if (cmp == 0) { cmp = PyObject_Compare( tw.key, *mem ); } + if ((cmp>0) || +- ((cmp==0) && (tw.map!=0) && (cmpobject( tw.map, *map )>0))) { ++ ((cmp==0) && (tw.map!=0) && (PyObject_Compare( tw.map, *map )>0))) { + *mem = tw.key; + *map = tw.map; + *hash = tw.hash; +@@ -1683,7 +1682,7 @@ + /* general structure for all table behaviors */ + + typedef struct { +- OB_VARHEAD ++ PyObject_VAR_HEAD + /* the hash flag */ + /* IF THIS IS NOT NOHASH THE TABLE SHOULD BE IMMUTABLE */ + long hashvalue; +@@ -1692,9 +1691,9 @@ + } TableWrapper; + + /* predeclarations of type objects */ +-staticforward typeobject kjSettype; +-staticforward typeobject kjDicttype; +-staticforward typeobject kjGraphtype; ++staticforward PyTypeObject kjSettype; ++staticforward PyTypeObject kjDicttype; ++staticforward PyTypeObject kjGraphtype; + + /* type test macros */ + #define is_kjSetobject(op) ((op)->ob_type == &kjSettype) +@@ -1710,14 +1709,14 @@ + if (in->rep.Dirty!=0) out->rep.Dirty = 1 + + /* internal allocation function for table wrappers */ +-static object * newWrapper(long expectedsize, enum BucketFlag flag) ++static PyObject * newWrapper(long expectedsize, enum BucketFlag flag) + { + /* allocate one wrapper */ + TableWrapper *wp; + Dprint(("WnewWrapper\n")); +- wp = NEW(TableWrapper, 1); ++ wp = PyMem_NEW(TableWrapper, 1); + if (wp == NULL) { +- return err_nomem(); /* allocation failure */ ++ return PyErr_NoMemory(); /* allocation failure */ + } + switch (flag) { + case SETFLAG: +@@ -1727,28 +1726,28 @@ + case GRAPHFLAG: + wp->ob_type = &kjGraphtype; break; + default: +- err_setstr(SystemError, "invalid internal table flag"); ++ PyErr_SetString(PyExc_SystemError, "invalid internal table flag"); + return NULL; + } + /* initialize the internal table */ + if (initTable(&(wp->rep), flag, expectedsize) == 0) { + /* initialization failed, assume an appropriate error is set */ +- DEL(wp); ++ PyMem_DEL(wp); + return NULL; + } + Dprint(("WnewWrapper: table initialized\n")); + wp->hashvalue = NOHASH; + /* INITIALIZE THE REFERENCE COUNT FOR THE NEW OBJECT */ +- NEWREF(wp); +- return (object *) wp; ++ _Py_NewReference(wp); ++ return (PyObject *) wp; + } + + /* *almost* an external python constructor for wrappers */ +-static object * makeWrapper(object *module, object *args, ++static PyObject * makeWrapper(PyObject *module, PyObject *args, + enum BucketFlag flag) + { + TableWrapper *result, *initWrapper; +- object *initlist, *pair, *key, *map, *d1, *d2; ++ PyObject *initlist, *pair, *key, *map, *d1, *d2; + long len, members, valid, index, islist, iskjtable, istuple; + Table *tp; + islist = 0; +@@ -1761,15 +1760,15 @@ + if (args == NULL) { + members = 0; + } else { /* some args: check it and determine its length */ +- valid = getargs(args, "i", &members); ++ valid = PyArg_Parse(args, "i", &members); + if (!valid) { +- err_clear(); +- valid = getargs(args, "O", &initlist); ++ PyErr_Clear(); ++ valid = PyArg_Parse(args, "O", &initlist); + if (valid) { +- islist = is_listobject(initlist); ++ islist = PyList_Check(initlist); + if (islist) { + Dprint(("makeWrapper from list\n")); +- len = getlistsize(initlist); ++ len = PyList_Size(initlist); + } else { + iskjtable = is_kjTable(initlist); + if (iskjtable) { +@@ -1777,10 +1776,10 @@ + initWrapper = (TableWrapper *) initlist; + len = initWrapper->rep.entries; + } else { +- istuple = is_tupleobject(initlist); ++ istuple = PyTuple_Check(initlist); + if (istuple) { + Dprint(("makeWrapper from tuple\n")); +- len = gettuplesize(initlist); ++ len = PyTuple_Size(initlist); + } else { + valid = 0; + } +@@ -1788,7 +1787,7 @@ + } + } + if (!valid) { +- err_setstr(TypeError, ++ PyErr_SetString(PyExc_TypeError, + "initializer must be integer or list or tuple or kj-Table"); + return NULL; + } +@@ -1806,24 +1805,24 @@ + tp = &(result->rep); + for (index = 0; index<len; index++) { + if ( islist ) { +- pair = getlistitem(initlist, index); ++ pair = PyList_GetItem(initlist, index); + } else { +- pair = gettupleitem(initlist, index); ++ pair = PyTuple_GetItem(initlist, index); + } + if (flag == SETFLAG) { + valid = TableGet1(tp, pair, 0, NOHASH, FORCE, &d1, &d2); + if (valid == -1) { +- DECREF(result); ++ Py_DECREF(result); + return NULL; + } + } else { +- if (!getargs(pair, "(OO)", &key, &map)) { +- DECREF(result); ++ if (!PyArg_Parse(pair, "(OO)", &key, &map)) { ++ Py_DECREF(result); + return NULL; + } + valid = TableGet1(tp, key, map, NOHASH, FORCE, &d1, &d2); + if (valid == -1) { +- DECREF(result); ++ Py_DECREF(result); + return NULL; + } + } +@@ -1833,39 +1832,39 @@ + /* initWrapper = (TableWrapper *) initlist; already done... */ + valid = Taugment( &(result->rep), &(initWrapper->rep) ); + if (valid!=0) { +- DECREF(result); ++ Py_DECREF(result); + return NULL; + } + } + } +- return (object *) result; ++ return (PyObject *) result; + } + + /* specialization for sets */ +-static object * makekjSet(object *module, object *args) ++static PyObject * makekjSet(PyObject *module, PyObject *args) + { + return makeWrapper(module, args, SETFLAG); + } + + /* specialization for graphs */ +-static object * makekjGraph(object *module, object *args) ++static PyObject * makekjGraph(PyObject *module, PyObject *args) + { + return makeWrapper(module, args, GRAPHFLAG); + } + + /* specialization for dicts */ +-static object * makekjDict(object *module, object *args) ++static PyObject * makekjDict(PyObject *module, PyObject *args) + { + return makeWrapper(module, args, DICTFLAG); + } + + #ifdef KJBDEBUG +-static object * Wdebug( object *m, object *a) ++static PyObject * Wdebug( PyObject *m, PyObject *a) + { + if (DebugLevel) { DebugLevel = 0; } + else { DebugLevel = 1; } +- INCREF(None); +- return None; ++ Py_INCREF(Py_None); ++ return Py_None; + } + #endif + +@@ -1873,7 +1872,7 @@ + { + /* must properly decref references... */ + groupsDealloc( wp->rep.groups, wp->rep.flag, wp->rep.size ); +- DEL(wp); ++ PyMem_DEL(wp); + } + + /* hash value: symmetrical on members, a symmetrical within pairs */ +@@ -1898,7 +1897,7 @@ + to keep this of "fix" it. Hmmm. */ + if ( (flag != SETFLAG) &&(tw.map != 0)) { + GETHASH(that,tw.map); +- if (that == -1) { err_clear(); } ++ if (that == -1) { PyErr_Clear(); } + this += (that*23); + } + result ^= this; +@@ -1910,18 +1909,18 @@ + return result; + } + +-static object * WrapperItems1(TableWrapper *wp, object *args, ++static PyObject * WrapperItems1(TableWrapper *wp, PyObject *args, + long dokey, long domap) + { +- object *resultlist, *membertuple; ++ PyObject *resultlist, *membertuple; + TableWalker tw; + long index, entries; + Dprint(("WItems1\n")); + +- if (!getnoarg(args)) { return NULL; } /* error */ ++ if (!PyArg_Parse(args, "")) { return NULL; } /* error */ + entries = wp->rep.entries; + /* make a list for all entries */ +- resultlist = newlistobject( entries ); ++ resultlist = PyList_New( entries ); + if (resultlist == NULL) { return NULL; } /* error */ + /* walk through the table */ + (void) InitAll(&tw, &(wp->rep)); +@@ -1929,44 +1928,44 @@ + while (tw.valid == 1) { + /* sanity check */ + if (index >= entries) { +- DECREF(resultlist); +- err_setstr(SystemError, "loop overflowing in WrapperItems"); ++ Py_DECREF(resultlist); ++ PyErr_SetString(PyExc_SystemError, "loop overflowing in WrapperItems"); + return NULL; /* error */ + } + /* get only the key, if requested */ + if ((dokey != 0) && (domap == 0)) { +- XINCREF(tw.key); +- setlistitem(resultlist, index, tw.key); ++ Py_XINCREF(tw.key); ++ PyList_SetItem(resultlist, index, tw.key); + } else { + /* get only the map, if requested */ + if ((domap != 0) && (dokey == 0)) { +- XINCREF(tw.map); +- setlistitem(resultlist, index, tw.map); ++ Py_XINCREF(tw.map); ++ PyList_SetItem(resultlist, index, tw.map); + } else { + /* otherwise get both */ +- membertuple = newtupleobject(2); ++ membertuple = PyTuple_New(2); + if (membertuple == NULL) { +- DECREF(resultlist); ++ Py_DECREF(resultlist); + return NULL; /* error */ + } +- XINCREF(tw.key); +- settupleitem(membertuple, 0, tw.key); +- XINCREF(tw.map); +- settupleitem(membertuple, 1, tw.map); +- setlistitem(resultlist, index, membertuple); ++ Py_XINCREF(tw.key); ++ PyTuple_SetItem(membertuple, 0, tw.key); ++ Py_XINCREF(tw.map); ++ PyTuple_SetItem(membertuple, 1, tw.map); ++ PyList_SetItem(resultlist, index, membertuple); + } + } + index++; + (void) NextAll(&tw); + } + if (tw.valid == -1) { +- DECREF(resultlist); ++ Py_DECREF(resultlist); + return NULL; /* error */ + } + return resultlist; + } + +-static object * WrapperItems(TableWrapper *wp, object *args) ++static PyObject * WrapperItems(TableWrapper *wp, PyObject *args) + { + Dprint(("WItems\n")); + if (wp->rep.flag == SETFLAG) { +@@ -1981,7 +1980,7 @@ + /* prlong function with debug option */ + static long WrapperPrint(TableWrapper *wp, FILE *fp, long flags) + { +- object * items; ++ PyObject * items; + #ifdef WDEBUGPRINT + if (WDEBUGPRINT) { + return TableDump((wp->rep), fp); +@@ -2002,15 +2001,15 @@ + fprintf(fp, "??couldn't allocate items??\n"); + return -1; + } +- if (printobject(items, fp, 0) != 0) { return -1; } +- DECREF(items); ++ if (PyObject_Print(items, fp, 0) != 0) { return -1; } ++ Py_DECREF(items); + fprintf(fp, ")"); + return 0; + } + +-static object* WrapperRepr(TableWrapper *wp) ++static PyObject* WrapperRepr(TableWrapper *wp) + { +- object *items, *result, *itemstring; ++ PyObject *items, *result, *itemstring; + char buf[256]; + switch (wp->rep.flag) { + case SETFLAG: +@@ -2020,18 +2019,18 @@ + case GRAPHFLAG: + sprintf(buf, "kjGraph("); break; + default: +- err_setstr(SystemError, "Bad flag in table"); ++ PyErr_SetString(PyExc_SystemError, "Bad flag in table"); + return NULL; + } +- result = newstringobject(buf); ++ result = PyString_FromString(buf); + items = WrapperItems(wp, NULL); + if (items == NULL) { + return NULL; + } +- itemstring = reprobject(items); +- DECREF(items); +- joinstring_decref(&result, itemstring); +- joinstring_decref(&result, newstringobject(")")); ++ itemstring = PyObject_Repr(items); ++ Py_DECREF(items); ++ PyString_ConcatAndDel(&result, itemstring); ++ PyString_ConcatAndDel(&result, PyString_FromString(")")); + return result; + } + +@@ -2053,7 +2052,7 @@ + */ + static long Wcompare(TableWrapper *left, TableWrapper *right) + { +- object *lmem, *lmap, *rmem, *rmap; ++ PyObject *lmem, *lmap, *rmem, *rmap; + long lhash, rhash; + long lentries, rentries, lfound, rfound, cmp; + Table *ltable, *rtable; +@@ -2078,54 +2077,54 @@ + if ((lfound == 0) && (rfound == 0)) { return 0; } + /* otherwise compare min differences */ + cmp = lhash - rhash; +- if (cmp == 0) { cmp = cmpobject( lmem, rmem ); } ++ if (cmp == 0) { cmp = PyObject_Compare( lmem, rmem ); } + if (cmp < 0) { return -1; } + if (cmp > 0) { return 1; } + /* mems are identical, try maps */ + if ( (lmap != 0) && (rmap != 0) ) { + /* if we get this far the following shouldn't return 0, ever. */ +- return cmpobject(lmap,rmap); ++ return PyObject_Compare(lmap,rmap); + } + /* this should be an error, but it can't be done?? */ + return 0; + } + + +-static object * Whas_key(TableWrapper *wp, object *args) ++static PyObject * Whas_key(TableWrapper *wp, PyObject *args) + { + long test, rt, nxt, nxtb, isnew; + long hashout; + Bucketptr Bp; +- object *key; ++ PyObject *key; + Dprint(("Whas_key\n")); +- if ((args == NULL) || !getargs(args, "O", &key)) { +- err_setstr(TypeError, "table method has_key requires an argument"); ++ if ((args == NULL) || !PyArg_Parse(args, "O", &key)) { ++ PyErr_SetString(PyExc_TypeError, "table method has_key requires an argument"); + return NULL; + } + test = tableMatch(&(wp->rep), key, 0, NOFORCE, + -1, -1, -1, NOHASH, + &rt, &nxt, &nxtb, &Bp, &hashout, &isnew); + if (test == -1) { return NULL; } /* error */ +- return newintobject((long) test); ++ return PyInt_FromLong((long) test); + } + + /* + Get the neighbors of a node in a graph. + */ +-static object *Gneighbors(TableWrapper *wp, object *args) ++static PyObject *Gneighbors(TableWrapper *wp, PyObject *args) + { +- object *key, *resultlist; ++ PyObject *key, *resultlist; + Table *tp; + TableWalker tw; + long count, index; + Dprint(("Gneighbors\n")); +- if ((args == NULL) || !getargs(args, "O", &key)) { +- err_setstr(TypeError, "table method neighbors requires an argument"); ++ if ((args == NULL) || !PyArg_Parse(args, "O", &key)) { ++ PyErr_SetString(PyExc_TypeError, "table method neighbors requires an argument"); + return NULL; + } + tp = &(wp->rep); + if ( tp->flag == SETFLAG ) { +- err_setstr(TypeError, "neighbors not defined for table of this type"); ++ PyErr_SetString(PyExc_TypeError, "neighbors not defined for table of this type"); + return NULL; + } + /* find out how many neighbors there are */ +@@ -2139,7 +2138,7 @@ + if (tw.valid == -1) { return NULL; } /* error */ + /* make a list large enough */ + Dprint(("Gneighbors: making resultlist\n")); +- resultlist = newlistobject( count ); ++ resultlist = PyList_New( count ); + if (resultlist == NULL) { return NULL; } /* failure to allocate */ + /* record neighbors in list */ + (void) Initbykey(&tw, tp, key, NOHASH); +@@ -2147,17 +2146,17 @@ + Dprint(("Gneighbors: storing results\n")); + while (tw.valid == 1) { + if (index >= count) { +- DECREF(resultlist); +- err_setstr(SystemError, "loop overflow in neighbors calculation"); ++ Py_DECREF(resultlist); ++ PyErr_SetString(PyExc_SystemError, "loop overflow in neighbors calculation"); + return NULL; + } +- XINCREF(tw.map); +- setlistitem(resultlist, index, tw.map); ++ Py_XINCREF(tw.map); ++ PyList_SetItem(resultlist, index, tw.map); + index++; + (void) Nextbykey(&tw); + } + if (tw.valid == -1) { +- DECREF(resultlist); ++ Py_DECREF(resultlist); + return NULL; + } + return resultlist; +@@ -2167,18 +2166,18 @@ + if domaps is set this will get maps uniquely *only if + all maps are hashable!* + */ +-static object *Wparts(TableWrapper *wp, object *args, long domaps) ++static PyObject *Wparts(TableWrapper *wp, PyObject *args, long domaps) + { + TableWalker tw; + Table *tp, *Settp; + TableWrapper *tempSet; +- object *mem, *map, *items; ++ PyObject *mem, *map, *items; + long test; + Dprint(("Wparts\n")); +- if (!getnoarg(args)) { return NULL; } /* error */ ++ if (!PyArg_Parse(args, "")) { return NULL; } /* error */ + tp = &(wp->rep); + if (tp->flag == SETFLAG) { +- err_setstr(TypeError, "keys/values not defined for sets"); ++ PyErr_SetString(PyExc_TypeError, "keys/values not defined for sets"); + return NULL; + } + /* initialize a temp set to hold the keys */ +@@ -2198,21 +2197,21 @@ + (void) NextAll(&tw); + } + if ((test == -1) || (tw.valid == -1)) { +- XDECREF(tempSet); ++ Py_XDECREF(tempSet); + return NULL; + } + items = WrapperItems(tempSet, NULL); +- XDECREF(tempSet); ++ Py_XDECREF(tempSet); + return items; + } + +-static object *Wkeys(TableWrapper *wp, object *args) ++static PyObject *Wkeys(TableWrapper *wp, PyObject *args) + { + Dprint(("Wkeys\n")); + return Wparts(wp, args, 0); + } + +-static object *Wvalues(TableWrapper *wp, object *args) ++static PyObject *Wvalues(TableWrapper *wp, PyObject *args) + { + Dprint(("Wvalues\n")); + /* return Wparts(wp, args, 1); -- wrong! */ +@@ -2220,25 +2219,25 @@ + } + + /* choose an arbitrary key from the table or raise an indexerror if none */ +-static object *Wchoose_key(TableWrapper *wp, object *args) ++static PyObject *Wchoose_key(TableWrapper *wp, PyObject *args) + { + TableWalker tw; + Dprint(("Wchoose_key\n")); +- if (!getnoarg(args)) { return NULL; } /* error */ ++ if (!PyArg_Parse(args, "")) { return NULL; } /* error */ + (void) InitAll(&tw, &(wp->rep)); + if (tw.valid == 1) { +- XINCREF(tw.key); ++ Py_XINCREF(tw.key); + return tw.key; + } + if (tw.valid == 0) { +- err_setstr(IndexError, "table is empty"); ++ PyErr_SetString(PyExc_IndexError, "table is empty"); + return NULL; + } + /* external error otherwise (tw.valid == -1) */ + return NULL; + } + +-static object *WSubset(TableWrapper *subset, object *args) ++static PyObject *WSubset(TableWrapper *subset, PyObject *args) + { + TableWrapper *superset; + long hashout; +@@ -2249,12 +2248,12 @@ + Dprint(("WSubset\n")); + /* verify argument */ + if (args == NULL) { +- err_setstr(TypeError, "Subset test requires argument"); ++ PyErr_SetString(PyExc_TypeError, "Subset test requires argument"); + return NULL; + } +- if (!getargs(args, "O", &superset)) { return NULL; } ++ if (!PyArg_Parse(args, "O", &superset)) { return NULL; } + if ( !is_kjTable(superset)) { +- err_setstr(TypeError, "Subset defined only between kj-tables"); ++ PyErr_SetString(PyExc_TypeError, "Subset defined only between kj-tables"); + return NULL; + } + /* walk through subset, test for membership of all members */ +@@ -2267,18 +2266,18 @@ + if (found == -1) { return NULL; } /* error */ + if (found == 0) { + /* subset test fails */ +- return newintobject((long) 0); ++ return PyInt_FromLong((long) 0); + } + (void) NextAll(&tw); + } + if (tw.valid == -1) { return NULL; } /* error */ + /* otherwise, success */ +- return newintobject((long) 1); ++ return PyInt_FromLong((long) 1); + } + + /* transitive closure of a graph */ + /* algorithm could be made faster, KISS for now. */ +-static object *Wtransclose(TableWrapper *wp, object *args) ++static PyObject *Wtransclose(TableWrapper *wp, PyObject *args) + { + Table *source, *target, Delta; + TableWrapper *closure; +@@ -2286,11 +2285,11 @@ + long count, test, abort; + + Dprint(("Wtransclose\n")); +- if (!getnoarg(args)) { return NULL; } /* error */ ++ if (!PyArg_Parse(args, "")) { return NULL; } /* error */ + source = &(wp->rep); + flag = source->flag; + if (flag != GRAPHFLAG) { +- err_setstr(TypeError, ++ PyErr_SetString(PyExc_TypeError, + "transitive closure not defined for this table type"); + return NULL; + } +@@ -2303,7 +2302,7 @@ + Dprint(("tc: augmenting closure\n")); + test = Taugment( target, source ); + if (test != 0) { +- DECREF(closure); ++ Py_DECREF(closure); + return NULL; + } + /* initialize temp table Delta for transitive arcs */ +@@ -2330,27 +2329,27 @@ + Dprint(("tc: deallocating Delta\n")); + groupsDealloc(Delta.groups, flag, Delta.size); + if (abort != 0) { +- DECREF(closure); ++ Py_DECREF(closure); + return NULL; + } +- return (object *) closure; ++ return (PyObject *) closure; + } + + static void Wset_hash_error() + { +- err_setstr(TypeError, "table has been hashed, it is now immutable"); ++ PyErr_SetString(PyExc_TypeError, "table has been hashed, it is now immutable"); + } + +-static object * Wdelete_arc(TableWrapper *wp, object *args) ++static PyObject * Wdelete_arc(TableWrapper *wp, PyObject *args) + { +- object *key, *map; ++ PyObject *key, *map; + Dprint(("Wdelete_arc\n")); +- if ((args == NULL) || !getargs(args, "(OO)", &key, &map)) { +- err_setstr(TypeError, "delete_arc requires two arguments"); ++ if ((args == NULL) || !PyArg_Parse(args, "(OO)", &key, &map)) { ++ PyErr_SetString(PyExc_TypeError, "delete_arc requires two arguments"); + return NULL; + } + if (wp->rep.flag == SETFLAG) { +- err_setstr(TypeError, "delete_arc not defined on sets"); ++ PyErr_SetString(PyExc_TypeError, "delete_arc not defined on sets"); + return NULL; + } + if (wp->hashvalue != NOHASH) { +@@ -2358,14 +2357,14 @@ + return NULL; + } + if (deleteFromTable(&(wp->rep), key, map) == 0) { return NULL; } +- INCREF(None); +- return None; ++ Py_INCREF(Py_None); ++ return Py_None; + } + + /* simple membership test */ +-static object * Wmember1(TableWrapper *wp, object *args, long insert) ++static PyObject * Wmember1(TableWrapper *wp, PyObject *args, long insert) + { +- object *key, *map; ++ PyObject *key, *map; + Table *tp; + enum BucketFlag flag; + long hashout; +@@ -2376,7 +2375,7 @@ + flag = tp->flag; + /* determine key and map */ + if (args == NULL) { +- err_setstr(TypeError, "membership test requires argument(s)"); ++ PyErr_SetString(PyExc_TypeError, "membership test requires argument(s)"); + return NULL; + } + if ((insert!=0) & (wp->hashvalue!=NOHASH)) { +@@ -2384,48 +2383,48 @@ + return NULL; + } + if (flag == SETFLAG) { +- if (!getargs(args, "O", &key)) { return NULL; } ++ if (!PyArg_Parse(args, "O", &key)) { return NULL; } + map = 0; + } else { +- if (!getargs(args, "(OO)", &key, &map)) { return NULL; } ++ if (!PyArg_Parse(args, "(OO)", &key, &map)) { return NULL; } + } + if (insert == 0) { + found = tableMatch(tp, key, map, NOFORCE, + -1, -1, -1, NOHASH, + &rt, &nxt, &nxtb, &Bp, &hashout, &isnew); +- return newintobject((long) found); ++ return PyInt_FromLong((long) found); + } else { + found = TableGet1(tp, key, map, NOHASH, FORCE, &key, &map); + if (found == -1) { return NULL; } +- INCREF(None); +- return None; ++ Py_INCREF(Py_None); ++ return Py_None; + } + } + +-static object * Wmember(TableWrapper *wp, object *args) ++static PyObject * Wmember(TableWrapper *wp, PyObject *args) + { + Dprint(("Wmember\n")); + return Wmember1(wp, args, 0); + } + +-static object * Waddmember(TableWrapper *wp, object *args) ++static PyObject * Waddmember(TableWrapper *wp, PyObject *args) + { + Dprint(("Waddmember\n")); + return Wmember1(wp, args, 1); + } + + /* generate identity graph from a set */ +-static object * Gidentity(TableWrapper *SourceSet, object *args) ++static PyObject * Gidentity(TableWrapper *SourceSet, PyObject *args) + { + TableWrapper *resultGraph; + Table *Graphtp; + TableWalker tw; + long test; +- object *d1, *d2; ++ PyObject *d1, *d2; + Dprint(("Gidentity\n")); +- if (!getnoarg(args)) { return NULL; } ++ if (!PyArg_Parse(args, "")) { return NULL; } + if (SourceSet->rep.flag != SETFLAG) { +- err_setstr(TypeError, "graph identity not defined for table of this type"); ++ PyErr_SetString(PyExc_TypeError, "graph identity not defined for table of this type"); + return NULL; + } + /* make a new DICTIONARY for result, may waste space for graphs */ +@@ -2441,26 +2440,26 @@ + (void) NextAll(&tw); + } + if ((test == -1) || (tw.valid == -1)) { +- DECREF(resultGraph); ++ Py_DECREF(resultGraph); + return NULL; + } +- return (object *) resultGraph; ++ return (PyObject *) resultGraph; + } + +-static object * Greachable(TableWrapper *graph, object *args) ++static PyObject * Greachable(TableWrapper *graph, PyObject *args) + { +- object *key, *d1, *d2; ++ PyObject *key, *d1, *d2; + TableWrapper *resultSet, *tempSet, *deltaSet; + Table *resulttp, *temptp, *deltatp, *graphtp; + TableWalker deltaW, graphW; + long test, fail; + Dprint(("Greachable\n")); + if (graph->rep.flag == SETFLAG) { +- err_setstr(TypeError, "reachable not defined for this table type"); ++ PyErr_SetString(PyExc_TypeError, "reachable not defined for this table type"); + return NULL; + } +- if ((args == NULL) || (!getargs(args, "O", &key))) { +- err_setstr(TypeError, "reachable requires key argument"); ++ if ((args == NULL) || (!PyArg_Parse(args, "O", &key))) { ++ PyErr_SetString(PyExc_TypeError, "reachable requires key argument"); + return NULL; + } + /* make result and temporary sets for computation */ +@@ -2468,9 +2467,9 @@ + tempSet = (TableWrapper *) newWrapper(0, SETFLAG); + deltaSet = (TableWrapper *) newWrapper(0, SETFLAG); + if ((deltaSet == NULL) || (resultSet == NULL) || (tempSet == NULL)) { +- XDECREF(deltaSet); +- XDECREF(resultSet); +- XDECREF(tempSet); ++ Py_XDECREF(deltaSet); ++ Py_XDECREF(resultSet); ++ Py_XDECREF(tempSet); + return NULL; + } + propagateDirt(graph, resultSet); +@@ -2513,48 +2512,48 @@ + } + } /* endwhile delta has entries... */ + /* get rid of temporaries */ +- DECREF(tempSet); +- DECREF(deltaSet); ++ Py_DECREF(tempSet); ++ Py_DECREF(deltaSet); + if (fail != 0) { +- DECREF(resultSet); ++ Py_DECREF(resultSet); + return NULL; + } +- return (object *) resultSet; ++ return (PyObject *) resultSet; + } + + /* Clean filter: returns argument if the table + is clean, otherwise NULL */ +-static object * WClean(TableWrapper *wp, object *args) ++static PyObject * WClean(TableWrapper *wp, PyObject *args) + { + Dprint(("WClean\n")); +- if (!getnoarg(args)) { return NULL; } ++ if (!PyArg_Parse(args, "")) { return NULL; } + if (wp->rep.Dirty) { +- INCREF(None); +- return None; ++ Py_INCREF(Py_None); ++ return Py_None; + } else { +- INCREF(wp); +- return (object *) wp; ++ Py_INCREF(wp); ++ return (PyObject *) wp; + } + } + + /* force a table to be dirty */ +-static object * WSoil(TableWrapper *wp, object *args) ++static PyObject * WSoil(TableWrapper *wp, PyObject *args) + { + Dprint(("WSoil\n")); +- if (!getnoarg(args)) { return NULL; } ++ if (!PyArg_Parse(args, "")) { return NULL; } + wp->rep.Dirty = 1; +- INCREF(None); +- return None; ++ Py_INCREF(Py_None); ++ return Py_None; + } + + /* force a table to be clean */ +-static object * WWash(TableWrapper *wp, object *args) ++static PyObject * WWash(TableWrapper *wp, PyObject *args) + { + Dprint(("WWash\n")); +- if (!getnoarg(args)) { return NULL; } ++ if (!PyArg_Parse(args, "")) { return NULL; } + wp->rep.Dirty = 0; +- INCREF(None); +- return None; ++ Py_INCREF(Py_None); ++ return Py_None; + } + + /* remap remaps a dictionary using a table which represents +@@ -2563,22 +2562,22 @@ + If the result is "dirty" (ie, if name/value collisions) + None is returned. + */ +-static object * Dremap(TableWrapper *wp, object *args) ++static PyObject * Dremap(TableWrapper *wp, PyObject *args) + { + TableWrapper *remapper, *result; + long count; + Dprint(("Dremap\n")); + if (!is_kjDictobject(wp)) { +- err_setstr(TypeError, "remap only defined for kjDicts"); ++ PyErr_SetString(PyExc_TypeError, "remap only defined for kjDicts"); + return NULL; + } + if (args == NULL) { +- err_setstr(TypeError, "remap requires equality table argument"); ++ PyErr_SetString(PyExc_TypeError, "remap requires equality table argument"); + return NULL; + } +- if (!getargs(args, "O", &remapper)) { return NULL; } ++ if (!PyArg_Parse(args, "O", &remapper)) { return NULL; } + if ( !is_kjTable(remapper)) { +- err_setstr(TypeError, "remap defined only between kj-tables"); ++ PyErr_SetString(PyExc_TypeError, "remap defined only between kj-tables"); + return NULL; + } + /* don't assume anything about size of result */ +@@ -2588,75 +2587,75 @@ + propagateDirt(remapper, result); + /* return NONE if result is dirty (save some work) */ + if (result->rep.Dirty != 0) { +- DECREF(result); +- INCREF(None); +- return None; ++ Py_DECREF(result); ++ Py_INCREF(Py_None); ++ return Py_None; + } + count = Tcompose( &(result->rep), &(remapper->rep), &(wp->rep), 0, 0); + if (count<0) { +- DECREF(result); ++ Py_DECREF(result); + return NULL; /* error */ + } + /* return NONE if result is dirty after composition */ + if (result->rep.Dirty != 0) { +- DECREF(result); +- INCREF(None); +- return None; ++ Py_DECREF(result); ++ Py_INCREF(Py_None); ++ return Py_None; + } +- return (object *) result; ++ return (PyObject *) result; + } + + /* forward declarations needed below */ +-static object * kjDict_subscript(TableWrapper *Set, object *key); +-static long kjDict_ass_subscript(object *Set, object *key, object *thing); ++static PyObject * kjDict_subscript(TableWrapper *Set, PyObject *key); ++static long kjDict_ass_subscript(PyObject *Set, PyObject *key, PyObject *thing); + + /* for dumping a dictionary to a tuple */ + /* D.dump(tup) produces D[tup[0]] if tup of len 1 + or (D[tup[0]], D[tup[1]],...) if tup of len > 1 + or keyerror if keys aren't present. + */ +-static object * kjDictDump(TableWrapper *wp, object *args) ++static PyObject * kjDictDump(TableWrapper *wp, PyObject *args) + { +- object *result, *input, *key, *map; ++ PyObject *result, *input, *key, *map; + long valid, index, length; + Dprint(("kjDictDump\n")); + if (!is_kjDictobject(wp) && !is_kjGraphobject(wp)) { +- err_setstr(TypeError, "dump only defined for kjDicts"); ++ PyErr_SetString(PyExc_TypeError, "dump only defined for kjDicts"); + return NULL; + } + if (args == NULL) { +- err_setstr(TypeError, "dictionary dump requires tuple argument"); ++ PyErr_SetString(PyExc_TypeError, "dictionary dump requires tuple argument"); + return NULL; + } +- valid = getargs(args, "O", &input); +- if (valid && (is_tupleobject(input))) { +- length = gettuplesize(input); ++ valid = PyArg_Parse(args, "O", &input); ++ if (valid && (PyTuple_Check(input))) { ++ length = PyTuple_Size(input); + if (length < 1) { +- err_setstr(TypeError, "dictionary dump requires nonempty tuple arg"); ++ PyErr_SetString(PyExc_TypeError, "dictionary dump requires nonempty tuple arg"); + return NULL; + } + if (length == 1) { + /* return D[input[0]] */ +- key = gettupleitem(input, 0); ++ key = PyTuple_GetItem(input, 0); + return kjDict_subscript(wp, key); /* incref done by function */ + } else { + /* return ( D[input[0]], D[input[1]], ..., D[input[n]] ) */ +- result = newtupleobject(length); ++ result = PyTuple_New(length); + if (result == NULL) { return NULL; } /* failure to allocate */ + for (index = 0; index<length; index++) { +- key = gettupleitem(input, index); ++ key = PyTuple_GetItem(input, index); + map = kjDict_subscript(wp, key); /* incref done by function */ + if (map == NULL) { +- DECREF(result); ++ Py_DECREF(result); + return NULL; /* keyerror, normally */ + } + /* map was increfed by kjDict_subscript already */ +- settupleitem(result, index, map); ++ PyTuple_SetItem(result, index, map); + } + return result; + } + } else { +- err_setstr(TypeError, "dictionary dump arg must be tuple"); ++ PyErr_SetString(PyExc_TypeError, "dictionary dump arg must be tuple"); + return NULL; + } + } +@@ -2667,24 +2666,24 @@ + kjDict( [ (tup[0], thing[0]), (tup[1], thing[1]) ] ) + if tup of len>1 and thing of same len, or error + */ +-static object * kjUndumpToDict(object *self, object *args) ++static PyObject * kjUndumpToDict(PyObject *self, PyObject *args) + { + TableWrapper *result; +- object *tup, *thing, *key, *map; ++ PyObject *tup, *thing, *key, *map; + long valid, index, length; + Dprint(("kjUndump\n")); + if (args == NULL) { +- err_setstr(TypeError, "kjUndump called with no args"); ++ PyErr_SetString(PyExc_TypeError, "kjUndump called with no args"); + return NULL; + } +- valid = getargs(args, "(OO)", &tup, &thing); ++ valid = PyArg_Parse(args, "(OO)", &tup, &thing); + if (valid) { +- valid = is_tupleobject(tup); ++ valid = PyTuple_Check(tup); + } + if (valid) { +- length = gettuplesize(tup); ++ length = PyTuple_Size(tup); + if (length<1) { +- err_setstr(ValueError, "kjUndump: tuple must be non-empty"); ++ PyErr_SetString(PyExc_ValueError, "kjUndump: tuple must be non-empty"); + return NULL; + } + /* try to save a little space */ +@@ -2692,39 +2691,39 @@ + if (result == NULL) { return NULL; } /* allocation failure */ + if (length == 1) { + /* return D[tup[0]] = thing */ +- key = gettupleitem(tup, 0); +- valid = kjDict_ass_subscript((object *) result, key, thing); ++ key = PyTuple_GetItem(tup, 0); ++ valid = kjDict_ass_subscript((PyObject *) result, key, thing); + if (valid == -1) { +- DECREF(result); ++ Py_DECREF(result); + return NULL; + } +- return (object *) result; ++ return (PyObject *) result; + } else { + /* return for i in len(tup): + D[tup[i]] = thing[i] + */ +- if (is_tupleobject(thing)) { +- if (gettuplesize(thing) != length) { +- err_setstr(TypeError,"kjUndump -- tuple lengths don't match"); ++ if (PyTuple_Check(thing)) { ++ if (PyTuple_Size(thing) != length) { ++ PyErr_SetString(PyExc_TypeError,"kjUndump -- tuple lengths don't match"); + return NULL; + } + for (index = 0; index<length; index++) { +- key = gettupleitem(tup, index); +- map = gettupleitem(thing, index); +- valid = kjDict_ass_subscript((object *) result, key, map); ++ key = PyTuple_GetItem(tup, index); ++ map = PyTuple_GetItem(thing, index); ++ valid = kjDict_ass_subscript((PyObject *) result, key, map); + if (valid == -1){ +- DECREF(result); ++ Py_DECREF(result); + return NULL; + } + } +- return (object *) result; ++ return (PyObject *) result; + } else { +- err_setstr(TypeError,"kjUndump -- nonunary tuple with non-tuple"); ++ PyErr_SetString(PyExc_TypeError,"kjUndump -- nonunary tuple with non-tuple"); + return NULL; + } + } + } else { +- err_setstr(TypeError,"kjUndump requires 2 args, first must be tuple"); ++ PyErr_SetString(PyExc_TypeError,"kjUndump requires 2 args, first must be tuple"); + return NULL; + } + } +@@ -2737,21 +2736,21 @@ + + but faster, doesn't allocate unneeded set + */ +-static object * kjWRestrict(TableWrapper *wp, object *args) ++static PyObject * kjWRestrict(TableWrapper *wp, PyObject *args) + { + long test; + TableWrapper *result, *compare; +- object *d1, *d2; /* dummies */ ++ PyObject *d1, *d2; /* dummies */ + enum BucketFlag flag; + TableWalker compareWalker, wpWalker; + Table *tp, *resulttp, *comparetp; +- if ((args == NULL) || (!getargs(args, "O", &compare))) { +- err_setstr(TypeError, ++ if ((args == NULL) || (!PyArg_Parse(args, "O", &compare))) { ++ PyErr_SetString(PyExc_TypeError, + "restriction function requires one kjTable argument"); + return NULL; + } + if (!is_kjTable(compare)) { +- err_setstr(TypeError, "restrict function requires kjTable argument"); ++ PyErr_SetString(PyExc_TypeError, "restrict function requires kjTable argument"); + return NULL; + } + flag = wp->rep.flag; +@@ -2807,11 +2806,11 @@ + } + /* test for error cases */ + if (test == -1) { +- XDECREF(result); ++ Py_XDECREF(result); + return NULL; + } + /* otherwise just return result */ +- return (object *) result; ++ return (PyObject *) result; + } + + /* special function for retrieving from dict-dumped indices +@@ -2831,7 +2830,7 @@ + (may retrieve "too many neighbors" for key of None or (None,) + + defined benieth following utility function as +- static object * kjWdget(TableWrapper *wp, object *args) ++ static PyObject * kjWdget(TableWrapper *wp, PyObject *args) + + */ + +@@ -2839,27 +2838,27 @@ + return 1 if neighbors set is nonempty, else, 0 + */ + /* #ifndef PYTHON1DOT2 */ +-static object * kjWdget1(TableWrapper *wp, object *args, long testonly) ++static PyObject * kjWdget1(TableWrapper *wp, PyObject *args, long testonly) + { +- object *d, *dumper, *result, *err_type /*, *err_value */; ++ PyObject *d, *dumper, *result, *err_type /*, *err_value */; + TableWrapper *dict; + /* get and verify args */ + if (args == NULL) { +- err_setstr(TypeError, "dget requires 2 arguments"); ++ PyErr_SetString(PyExc_TypeError, "dget requires 2 arguments"); + return NULL; + } +- if (!getargs(args, "(OO)", &dict, &dumper)) { +- err_setstr(TypeError, ++ if (!PyArg_Parse(args, "(OO)", &dict, &dumper)) { ++ PyErr_SetString(PyExc_TypeError, + "dget requires dict, dumper"); + return NULL; + } + if (!((is_kjDictobject(dict)) || (is_kjGraphobject(dict)))) { +- err_setstr(TypeError, ++ PyErr_SetString(PyExc_TypeError, + "first arg of dget must be kjDict or kjGraph"); + return NULL; + } +- if (!is_tupleobject(dumper)) { +- err_setstr(TypeError, ++ if (!PyTuple_Check(dumper)) { ++ PyErr_SetString(PyExc_TypeError, + "second arg of dget must be tuple"); + return NULL; + } +@@ -2869,16 +2868,16 @@ + /* unable to dump */ + /* check that error was a keyerror ??? */ + /* err_get(&err_type, &err_value); */ +- err_type = err_occurred(); +- if (err_type != KeyError) { ++ err_type = PyErr_Occurred(); ++ if (err_type != PyExc_KeyError) { + /* some other error... abort */ +- /* err_setval(err_type, err_value); */ ++ /* PyErr_SetObject(err_type, err_value); */ + return NULL; + } +- err_clear(); +- /* in case of KeyError, just return None */ +- INCREF(None); +- return None; ++ PyErr_Clear(); ++ /* in case of PyExc_KeyError, just return None */ ++ Py_INCREF(Py_None); ++ return Py_None; + } + /* if dump was successful, return neighbors */ + /* ??? should return d also ??? */ +@@ -2887,7 +2886,7 @@ + } else { + result = Whas_key(wp, d); + } +- XDECREF(d); ++ Py_XDECREF(d); + return result; + } + /* #endif */ +@@ -2903,13 +2902,13 @@ + except KeyError: return None + */ + /* #ifndef PYTHON1DOT2 */ +-static object * kjWdtest(TableWrapper *wp, object *args) ++static PyObject * kjWdtest(TableWrapper *wp, PyObject *args) + { + return kjWdget1(wp, args, 1); /* test only */ + } + /* #endif + #ifndef PYTHON1DOT2 */ +-static object * kjWdget(TableWrapper *wp, object *args) ++static PyObject * kjWdget(TableWrapper *wp, PyObject *args) + { + return kjWdget1(wp, args, 0); /* don't test only */ + } +@@ -2918,67 +2917,67 @@ + /* + miscellaneous methods for these types + */ +-static struct methodlist Wrapper_methods[] = { +- {"member", (method)Wmember}, +- {"add", (method)Waddmember}, +- {"delete_arc", (method)Wdelete_arc}, +- {"has_key", (method)Whas_key}, +- {"choose_key", (method)Wchoose_key}, +- {"Clean", (method)WClean}, +- {"neighbors", (method)Gneighbors}, +- {"dump", (method)kjDictDump}, ++static struct PyMethodDef Wrapper_methods[] = { ++ {"member", (PyCFunction)Wmember}, ++ {"add", (PyCFunction)Waddmember}, ++ {"delete_arc", (PyCFunction)Wdelete_arc}, ++ {"has_key", (PyCFunction)Whas_key}, ++ {"choose_key", (PyCFunction)Wchoose_key}, ++ {"Clean", (PyCFunction)WClean}, ++ {"neighbors", (PyCFunction)Gneighbors}, ++ {"dump", (PyCFunction)kjDictDump}, + /* #ifndef PYTHON1DOT2 */ +- {"dget", (method)kjWdget}, +- {"dtest", (method)kjWdtest}, ++ {"dget", (PyCFunction)kjWdget}, ++ {"dtest", (PyCFunction)kjWdtest}, + /* #endif */ +- {"reachable", (method)Greachable}, +- {"subset", (method)WSubset}, +- {"items", (method)WrapperItems}, +- {"keys", (method)Wkeys}, +- {"values", (method)Wvalues}, +- {"ident", (method)Gidentity}, +- {"remap", (method)Dremap}, +- {"restrict", (method)kjWRestrict}, +- {"tclosure", (method)Wtransclose}, +- {"Soil", (method)WSoil}, +- {"Wash", (method)WWash}, ++ {"reachable", (PyCFunction)Greachable}, ++ {"subset", (PyCFunction)WSubset}, ++ {"items", (PyCFunction)WrapperItems}, ++ {"keys", (PyCFunction)Wkeys}, ++ {"values", (PyCFunction)Wvalues}, ++ {"ident", (PyCFunction)Gidentity}, ++ {"remap", (PyCFunction)Dremap}, ++ {"restrict", (PyCFunction)kjWRestrict}, ++ {"tclosure", (PyCFunction)Wtransclose}, ++ {"Soil", (PyCFunction)WSoil}, ++ {"Wash", (PyCFunction)WWash}, + {NULL, NULL} /* sentinel */ + }; + + /* getattr snarfed from mappingobject.c */ +-static object * Wrapper_getattr(object *mp, char *name) ++static PyObject * Wrapper_getattr(PyObject *mp, char *name) + { +- return findmethod(Wrapper_methods, (object *)mp, name); ++ return Py_FindMethod(Wrapper_methods, (PyObject *)mp, name); + } + + + /* methods for special behaviors as number and mapping */ + + /* undefined operations */ +-static object * undefbin(object *v, object *w) ++static PyObject * undefbin(PyObject *v, PyObject *w) + { +- err_setstr(TypeError, "op not valid for table of this type"); ++ PyErr_SetString(PyExc_TypeError, "op not valid for table of this type"); + return NULL; + } +-static object * undefter(object *v, object *w, object *z) ++static PyObject * undefter(PyObject *v, PyObject *w, PyObject *z) + { +- err_setstr(TypeError, "op not valid for table of this type"); ++ PyErr_SetString(PyExc_TypeError, "op not valid for table of this type"); + return NULL; + } +-static object * undefun(object *v) ++static PyObject * undefun(PyObject *v) + { +- err_setstr(TypeError, "op not valid for table of this type"); ++ PyErr_SetString(PyExc_TypeError, "op not valid for table of this type"); + return NULL; + } + + /* transpose of non 1:1 dict will have nondeterministic results */ +-static object *Wtranspose(TableWrapper *source) ++static PyObject *Wtranspose(TableWrapper *source) + { + TableWrapper *result; + long size, test; + Dprint(("Wtranspose\n")); + if (source->rep.flag == SETFLAG) { +- err_setstr(TypeError, "Cannot transpose set"); ++ PyErr_SetString(PyExc_TypeError, "Cannot transpose set"); + return NULL; + } + /* conservative estimate of size (may save space, maybe not) */ +@@ -2989,22 +2988,22 @@ + propagateDirt(source, result); + test = Ttranspose( &(result->rep), &(source->rep) ); + if (test!=0) { +- DECREF(result); ++ Py_DECREF(result); + return NULL; + } +- return (object *) result; ++ return (PyObject *) result; + } + +-static object *Wunion(TableWrapper *left, TableWrapper *right) ++static PyObject *Wunion(TableWrapper *left, TableWrapper *right) + { + enum BucketFlag flag; + TableWrapper *result; + long size, test; + Dprint(("Wunion\n")); + /* None unioned with anything returns None (universal set) */ +- if (((object *) left == None) || ((object *) right == None)) { +- INCREF(None); +- return None; ++ if (((PyObject *) left == Py_None) || ((PyObject *) right == Py_None)) { ++ Py_INCREF(Py_None); ++ return Py_None; + } + /* arbitrary size heuristic */ + if (left->rep.entries > right->rep.entries) +@@ -3015,7 +3014,7 @@ + /* determine coercion if possible, default=more general */ + test = FlagCoercion(left->rep.flag, right->rep.flag, &flag, 1); + if (test != 1) { +- err_setstr(TypeError, "incompatible types for table union"); ++ PyErr_SetString(PyExc_TypeError, "incompatible types for table union"); + return NULL; + } + /* allocate a wrapper and augment it with both inputs */ +@@ -3028,14 +3027,14 @@ + test = Taugment( &(result->rep), &(right->rep) ); + } + if (test!=0) { +- DECREF(result); ++ Py_DECREF(result); + return NULL; + } +- return (object *) result; ++ return (PyObject *) result; + } + + /* utility function for intersection and difference */ +-static object * Wintdiff(TableWrapper *left, TableWrapper *right, ++static PyObject * Wintdiff(TableWrapper *left, TableWrapper *right, + long include, enum BucketFlag flagout) + { + TableWrapper *result; +@@ -3053,23 +3052,23 @@ + propagateDirt( right, result ); + count = Tintdiff(&(result->rep), &(left->rep), &(right->rep), include, 0); + if (count < 0) { +- DECREF(result); ++ Py_DECREF(result); + return NULL; + } +- return (object *) result; ++ return (PyObject *) result; + } + + /* intersection */ +-static object * Wintersect(TableWrapper *left, TableWrapper *right) ++static PyObject * Wintersect(TableWrapper *left, TableWrapper *right) + { + long test; + enum BucketFlag flag, lflag, rflag; + Dprint(("Wintersect\n")); + /* None intersected with anything returns copy of anything... */ +- if ((object *)left == None) { ++ if ((PyObject *)left == Py_None) { + return Wunion(right, right); + } +- if ((object *)right == None) { ++ if ((PyObject *)right == Py_None) { + return Wunion(left, left); + } + /* determine flag: default to less general */ +@@ -3078,12 +3077,12 @@ + /* coerce to more general, unless one arg is a set, + in which case coerce to set */ + if ( (rflag != lflag) && ((rflag == SETFLAG)||(lflag == SETFLAG)) ) { +- err_setstr(TypeError, "mixed intersection not allowed with kjSet"); ++ PyErr_SetString(PyExc_TypeError, "mixed intersection not allowed with kjSet"); + return NULL; + } + test = FlagCoercion(left->rep.flag, right->rep.flag, &flag, -1); + if (test!=1) { +- err_setstr(TypeError, "unable to coerce for intersection"); ++ PyErr_SetString(PyExc_TypeError, "unable to coerce for intersection"); + return NULL; + } + /* iterate over the smaller argument */ +@@ -3095,32 +3094,32 @@ + } + + /* difference */ +-static object * Wdifference(TableWrapper *left, TableWrapper *right) ++static PyObject * Wdifference(TableWrapper *left, TableWrapper *right) + { + enum BucketFlag lflag, rflag; + /* left cannot be None */ + Dprint(("Wdifference\n")); +- if ((object *)left == None) { +- err_setstr(TypeError, "cannot difference from None"); ++ if ((PyObject *)left == Py_None) { ++ PyErr_SetString(PyExc_TypeError, "cannot difference from None"); + return NULL; + } + /* if right is None return empty */ +- if ((object *)right == None) { +- return (object *) newWrapper(0, left->rep.flag); ++ if ((PyObject *)right == Py_None) { ++ return (PyObject *) newWrapper(0, left->rep.flag); + } + rflag = right->rep.flag; + lflag = left->rep.flag; + /* diff default coerce to whatever left is, unless one arg is a + set, in which case raise an error */ + if ( (rflag != lflag) && ((rflag == SETFLAG)||(lflag == SETFLAG)) ) { +- err_setstr(TypeError, "mixed difference not allowed with kjSet"); ++ PyErr_SetString(PyExc_TypeError, "mixed difference not allowed with kjSet"); + return NULL; + } + return Wintdiff(left, right, 0, lflag); + } + + /* composition of two tables */ +-static object * Wcompose(TableWrapper *left, TableWrapper *right) ++static PyObject * Wcompose(TableWrapper *left, TableWrapper *right) + { + enum BucketFlag flag; + TableWrapper *result; +@@ -3128,8 +3127,8 @@ + Table *Ltable, *Rtable; + Dprint(("Wcompose\n")); + /* neither arg may be None */ +- if (((object *)left == None) || ((object *)right == None)) { +- err_setstr(TypeError, "cannot compose None"); ++ if (((PyObject *)left == Py_None) || ((PyObject *)right == Py_None)) { ++ PyErr_SetString(PyExc_TypeError, "cannot compose None"); + return NULL; + } + Ltable = &(left->rep); +@@ -3137,7 +3136,7 @@ + /* find coercion, prefer more general */ + test = FlagCoercion(Ltable->flag, Rtable->flag, &flag, 1); + if (test!=1) { +- err_setstr(TypeError, "incompatible types for composition"); ++ PyErr_SetString(PyExc_TypeError, "incompatible types for composition"); + return NULL; + } + /* DON'T determine required table size, (not easily done correctly) */ +@@ -3154,10 +3153,10 @@ + propagateDirt( right, result ); + count = Tcompose(&(result->rep), Ltable, Rtable, 0, 0); + if (count < 0) { +- DECREF(result); ++ Py_DECREF(result); + return NULL; /* error */ + } +- return (object *) result; ++ return (PyObject *) result; + } + + /* coercion: +@@ -3165,16 +3164,16 @@ + all other logic is at the function level + (None == universal set) + */ +-static long Wrapper_coerce(object **pv, object **pw) ++static long Wrapper_coerce(PyObject **pv, PyObject **pw) + { +- object *w; ++ PyObject *w; + w = *pw; + Dprint(("Wcoerce\n")); +- if ( (w == None) || ++ if ( (w == Py_None) || + is_kjTable(w) ) { + /* both w and *pv are "returned", hence must be increfed */ +- INCREF(w); +- INCREF(*pv); ++ Py_INCREF(w); ++ Py_INCREF(*pv); + return 0; /* okay */ + } + return 1; /* Nope! */ +@@ -3183,7 +3182,7 @@ + + + /* the number methods structure for all kjSets, kjDicts, kjGraphs */ +-static number_methods kjSet_as_number = { ++static PyNumberMethods kjSet_as_number = { + (binaryfunc)Wunion, /*nb_add*/ + (binaryfunc)Wdifference, /*nb_subtract*/ + (binaryfunc)Wcompose, /*nb_multiply*/ +@@ -3209,19 +3208,19 @@ + (unaryfunc)undefun, /*nb_hex*/ + }; + +-static object * kjSet_subscript(TableWrapper *Set, object *key) ++static PyObject * kjSet_subscript(TableWrapper *Set, PyObject *key) + { +- object *mem, *map; ++ PyObject *mem, *map; + long test; + Dprint(("kjSet_subscript\n")); + test = TableGet1(&(Set->rep), key, 0, NOHASH, NOFORCE, &mem, &map); + if (test == -1) { return NULL; } +- return newintobject((long) 1); ++ return PyInt_FromLong((long) 1); + } + +-static long kjSet_ass_subscript(object *Set, object *key, object *thing) ++static long kjSet_ass_subscript(PyObject *Set, PyObject *key, PyObject *thing) + { +- object *mem, *map; ++ PyObject *mem, *map; + TableWrapper *S; + Dprint(("kjSet_ass_subscript\n")); + S = (TableWrapper *) Set; +@@ -3239,20 +3238,20 @@ + } + } + +-static object * kjDict_subscript(TableWrapper *Set, object *key) ++static PyObject * kjDict_subscript(TableWrapper *Set, PyObject *key) + { +- object *mem, *map; ++ PyObject *mem, *map; + long test; + Dprint(("kjDict_subscript\n")); + test = TableGet1(&(Set->rep), key, 0, NOHASH, NOFORCE, &mem, &map); + if (test == -1) { return NULL; } +- XINCREF(map); ++ Py_XINCREF(map); + return map; + } + +-static long kjDict_ass_subscript(object *Set, object *key, object *thing) ++static long kjDict_ass_subscript(PyObject *Set, PyObject *key, PyObject *thing) + { +- object *mem, *map; ++ PyObject *mem, *map; + TableWrapper *S; + Dprint(("kjDict_ass_subscript\n")); + S = (TableWrapper *) Set; +@@ -3276,7 +3275,7 @@ + } + + /* mapping methods for jkSets */ +-static mapping_methods kjSet_as_mapping = { ++static PyMappingMethods kjSet_as_mapping = { + (inquiry)Wrapper_length, /*mp_length*/ + (binaryfunc)kjSet_subscript, /*mp_subscript*/ + (objobjargproc)kjSet_ass_subscript, /*mp_ass_subscript*/ +@@ -3284,15 +3283,15 @@ + + + /* mapping methods for kjDicts AND kjGraphs */ +-static mapping_methods kjDict_as_mapping = { ++static PyMappingMethods kjDict_as_mapping = { + (inquiry)Wrapper_length, /*mp_length*/ + (binaryfunc)kjDict_subscript, /*mp_subscript*/ + (objobjargproc)kjDict_ass_subscript, /*mp_ass_subscript*/ + }; + + /* THE TYPE OBJECT FOR SETS */ +-static typeobject kjSettype = { +- OB_HEAD_INIT(&Typetype) ++static PyTypeObject kjSettype = { ++ PyObject_HEAD_INIT(&PyType_Type) + 0, + (char *) "kjSet", /*tp_name for printing */ + (unsigned int) sizeof(TableWrapper), /*tp_basicsize */ +@@ -3303,16 +3302,16 @@ + (setattrfunc)NULL, /*tp_setattr*/ + (cmpfunc)Wcompare, /*tp_compare*/ + (reprfunc)WrapperRepr, /*tp_repr*/ +- (number_methods *)&kjSet_as_number, /*tp_as_number*/ +- (sequence_methods *)NULL, /*tp_as_sequence*/ +- (mapping_methods *)&kjSet_as_mapping, /*tp_as_mapping*/ ++ (PyNumberMethods *)&kjSet_as_number, /*tp_as_number*/ ++ (PySequenceMethods *)NULL, /*tp_as_sequence*/ ++ (PyMappingMethods *)&kjSet_as_mapping, /*tp_as_mapping*/ + (hashfunc)Wrapper_hash, /*tp_hash*/ +- (binaryfunc)NULL, /*tp_call*/ ++ (ternaryfunc)NULL, /*tp_call*/ + }; + + /* THE TYPE OBJECT FOR DICTS */ +-static typeobject kjDicttype = { +- OB_HEAD_INIT(&Typetype) ++static PyTypeObject kjDicttype = { ++ PyObject_HEAD_INIT(&PyType_Type) + 0, + (char *) "kjDict", /*tp_name for printing */ + (unsigned int) sizeof(TableWrapper), /*tp_basicsize */ +@@ -3323,16 +3322,16 @@ + (setattrfunc)0, /*tp_setattr*/ + (cmpfunc)Wcompare, /*tp_compare*/ + (reprfunc)WrapperRepr, /*tp_repr*/ +- (number_methods *)&kjSet_as_number, /*tp_as_number*/ +- (sequence_methods *)0, /*tp_as_sequence*/ +- (mapping_methods *)&kjDict_as_mapping, /*tp_as_mapping*/ ++ (PyNumberMethods *)&kjSet_as_number, /*tp_as_number*/ ++ (PySequenceMethods *)0, /*tp_as_sequence*/ ++ (PyMappingMethods *)&kjDict_as_mapping, /*tp_as_mapping*/ + (hashfunc)Wrapper_hash, /*tp_hash*/ +- (binaryfunc)0, /*tp_call*/ ++ (ternaryfunc)0, /*tp_call*/ + }; + + /* THE TYPE OBJECT FOR GRAPHSS */ +-static typeobject kjGraphtype = { +- OB_HEAD_INIT(&Typetype) ++static PyTypeObject kjGraphtype = { ++ PyObject_HEAD_INIT(&PyType_Type) + 0, + (char *) "kjGraph", /*tp_name for printing */ + (unsigned int) sizeof(TableWrapper), /*tp_basicsize */ +@@ -3343,11 +3342,11 @@ + (setattrfunc)0, /*tp_setattr*/ + (cmpfunc)Wcompare, /*tp_compare*/ + (reprfunc)WrapperRepr, /*tp_repr*/ +- (number_methods *)&kjSet_as_number, /*tp_as_number*/ +- (sequence_methods *)0, /*tp_as_sequence*/ +- (mapping_methods *)&kjDict_as_mapping, /*tp_as_mapping*/ ++ (PyNumberMethods *)&kjSet_as_number, /*tp_as_number*/ ++ (PySequenceMethods *)0, /*tp_as_sequence*/ ++ (PyMappingMethods *)&kjDict_as_mapping, /*tp_as_mapping*/ + (hashfunc)Wrapper_hash, /*tp_hash*/ +- (binaryfunc)0, /*tp_call*/ ++ (ternaryfunc)0, /*tp_call*/ + }; + + /* special method for adding to a "dumped index" +@@ -3376,39 +3375,39 @@ + nullbag is kjDict or kjGraph + */ + /* #ifndef PYTHON1DOT2 */ +-static object * kjKeyPut(object *self, object *args) ++static PyObject * kjKeyPut(PyObject *self, PyObject *args) + { + long valid; + TableWrapper *dict, *index, *nullbag; +- object *dumper, *psuedokey, *d, *pair, *err_type /*, *err_value */; ++ PyObject *dumper, *psuedokey, *d, *pair, *err_type /*, *err_value */; + /* get and verify args */ + if (args == NULL) { +- err_setstr(TypeError, "KeyPut requires 5 arguments"); ++ PyErr_SetString(PyExc_TypeError, "KeyPut requires 5 arguments"); + return NULL; + } +- if (!getargs(args, "(OOOOO)", ++ if (!PyArg_Parse(args, "(OOOOO)", + &dict, &dumper, &index, &psuedokey, &nullbag)) { +- err_setstr(TypeError, ++ PyErr_SetString(PyExc_TypeError, + "KeyPut requires dict, dumper, index, psuedokey, nullbag"); + return NULL; + } + if (!((is_kjDictobject(dict)) || (is_kjGraphobject(dict)))) { +- err_setstr(TypeError, ++ PyErr_SetString(PyExc_TypeError, + "first arg of KeyPut must be kjDict or kjGraph"); + return NULL; + } + if (!((is_kjDictobject(index)) || (is_kjGraphobject(index)))) { +- err_setstr(TypeError, ++ PyErr_SetString(PyExc_TypeError, + "third arg of KeyPut must be kjDict or kjGraph"); + return NULL; + } + if (!((is_kjDictobject(nullbag)) || (is_kjGraphobject(nullbag)))) { +- err_setstr(TypeError, ++ PyErr_SetString(PyExc_TypeError, + "fifth arg of KeyPut must be kjDict or kjGraph"); + return NULL; + } +- if (!is_tupleobject(dumper)) { +- err_setstr(TypeError, ++ if (!PyTuple_Check(dumper)) { ++ PyErr_SetString(PyExc_TypeError, + "second arg of KeyPut must be tuple"); + return NULL; + } +@@ -3418,43 +3417,43 @@ + /* unable to dump */ + /* check that error was a keyerror ??? */ + /* err_get(&err_type, &err_value); */ +- err_type = err_occurred(); +- if (err_type != KeyError) { ++ err_type = PyErr_Occurred(); ++ if (err_type != PyExc_KeyError) { + /* some other error... abort */ +- /* err_setval(err_type, err_value); */ ++ /* PyErr_SetObject(err_type, err_value); */ + return NULL; + } +- /* in case of KeyError, augment the Nullbag, return None */ +- err_clear(); +- valid = kjDict_ass_subscript((object *) nullbag, +- psuedokey, (object *) dict); ++ /* in case of PyExc_KeyError, augment the Nullbag, return None */ ++ PyErr_Clear(); ++ valid = kjDict_ass_subscript((PyObject *) nullbag, ++ psuedokey, (PyObject *) dict); + if (valid == -1) { + return NULL; + } +- INCREF(None); +- return None; ++ Py_INCREF(Py_None); ++ return Py_None; + } + /* if dump succeeded... */ +- /* initialize pair, INCREF components */ +- pair = newtupleobject(2); ++ /* initialize pair, Py_INCREF components */ ++ pair = PyTuple_New(2); + if (pair == NULL) { return NULL; } +- settupleitem(pair, 0, psuedokey); +- INCREF(psuedokey); +- settupleitem(pair, 1, (object *) dict); +- INCREF(dict); ++ PyTuple_SetItem(pair, 0, psuedokey); ++ Py_INCREF(psuedokey); ++ PyTuple_SetItem(pair, 1, (PyObject *) dict); ++ Py_INCREF(dict); + /* remap None to (None,) if needed */ +- if (d == None) { ++ if (d == Py_None) { + /* preserve extra reference to None... */ +- d = newtupleobject(1); +- settupleitem(d, 0, None); ++ d = PyTuple_New(1); ++ PyTuple_SetItem(d, 0, Py_None); + } + /* set index[d] = pair, creates an extra ref to pair */ +- valid = kjDict_ass_subscript((object *) index, d, pair); ++ valid = kjDict_ass_subscript((PyObject *) index, d, pair); + if (valid == -1) { +- XDECREF(pair); ++ Py_XDECREF(pair); + return NULL; + } +- XDECREF(pair); /* dispose of extra ref to pair */ ++ Py_XDECREF(pair); /* dispose of extra ref to pair */ + return d; + } + /* #endif */ +@@ -3462,16 +3461,16 @@ + /* THE "METHODS" FOR THIS MODULE */ + /* These are the basic external interfaces for python to + access this module. */ +-static struct methodlist kjbuckets_methods[] = { +- {"kjSet", (method)makekjSet}, +- {"kjDict", (method)makekjDict}, +- {"kjGraph", (method)makekjGraph}, +- {"kjUndump", (method)kjUndumpToDict}, ++static struct PyMethodDef kjbuckets_methods[] = { ++ {"kjSet", (PyCFunction)makekjSet}, ++ {"kjDict", (PyCFunction)makekjDict}, ++ {"kjGraph", (PyCFunction)makekjGraph}, ++ {"kjUndump", (PyCFunction)kjUndumpToDict}, + /* #ifndef PYTHON1DOT2 */ +- {"kjKeyPut", (method)kjKeyPut}, ++ {"kjKeyPut", (PyCFunction)kjKeyPut}, + /* #endif */ + #ifdef KJBDEBUG +- {"debug", (method)Wdebug}, ++ {"debug", (PyCFunction)Wdebug}, + #endif + {NULL, NULL} /* sentinel */ + }; +@@ -3479,7 +3478,7 @@ + void + initkjbuckets() + { +- initmodule("kjbuckets", kjbuckets_methods); ++ Py_InitModule("kjbuckets", kjbuckets_methods); + } + + /* end of kjbuckets module by Aaron Watters */ diff --git a/devel/py-kjbuckets/pkg-plist b/devel/py-kjbuckets/pkg-plist index 9aab0c6c39ef..ab72c5c42954 100644 --- a/devel/py-kjbuckets/pkg-plist +++ b/devel/py-kjbuckets/pkg-plist @@ -1,3 +1,3 @@ -@exec mkdir -p %D/lib/python1.5/site-packages -lib/python1.5/site-packages/kjbucketsmodule.so +@exec mkdir -p %D/lib/%%PYTHON_VERSION%%/site-packages +lib/%%PYTHON_VERSION%%/site-packages/kjbucketsmodule.so share/doc/kjbuckets.html |