# 1 "treeseq.m"
struct _PRIVATE { struct _PRIVATE *isa; };
typedef struct _PRIVATE *id;
struct _SHARED {
id isa;
id clsSuper;
char *clsName;
char *clsTypes;
short clsSizInstance;
short clsSizDict;
struct _SLT *clsDispTable;
long clsStatus;
struct modDescriptor *clsMod;
unsigned clsVersion;
id clsCats;
id *clsGlbl;
};
extern id (* _imp(id,char*))();
extern id (* _impSuper(id,char*))();
extern struct modDescriptor *_OBJCBIND_treeseq(void);
static char **selTransTbl;
struct _SLT {char *_cmd;id (*_imp)();};
struct modDescriptor {
char *modName;
char *modVersion;
long modStatus;
char *modMinSel;
char *modMaxSel;
id *modClsLst;
short modSelRef;
char **modSelTbl;
struct methodDescriptor *modMapTbl;
};
extern struct modDescriptor treeseq_modDesc;
# 1 "../../util/stdarg.h"
#include <stdarg.h>
# 1 "../../util/stdio.h"
#include <stdio.h>
# 1 "../../util/stdio.h"
#include <stdio.h>
# 1 "../../util/stddef.h"
#include <stddef.h>
# 53 "../../include/objcrt/objcrt.h"
typedef char*SEL;
typedef char*STR;
typedef char BOOL;
typedef FILE*IOD;
typedef id SHR;
# 62 "../../include/objcrt/objcrt.h"
typedef id(*IMP)();
typedef void(*ARGIMP)(id,SEL,void*);
# 85 "../../include/objcrt/objcrt.h"
extern BOOL msgFlag;
extern FILE*msgIOD;
extern FILE*dbgIOD;
extern BOOL allocFlag;
extern BOOL dbgFlag;
extern BOOL noCacheFlag;
extern BOOL noNilRcvr;
# 98 "../../include/objcrt/objcrt.h"
SEL selUid(STR);
STR selName(SEL);
void dbg(char*fmt,...);
void prnstack(FILE*file);
void loadobjc(void*modPtr);
void unloadobjc(void*modPtr);
# 107 "../../include/objcrt/objcrt.h"
IMP fwdimp(id,SEL,IMP);
IMP fwdimpSuper(id,SEL,IMP);
void fwdmsg(id,SEL,void*,ARGIMP);
id selptrfwd(id,SEL,id,id,id,id);
id idincref(id obj);
id idassign(id*lhs,id rhs);
id iddecref(id obj);
extern id(*_fileIn)(FILE*);
extern BOOL(*_fileOut)(FILE*,id);
extern BOOL(*_storeOn)(STR,id);
extern id(*_readFrom)(STR);
void setfilein(id(*f)(FILE*));
void setfileout(BOOL(*f)(FILE*,id));
extern id(*_showOn)(id,unsigned);
void*OC_Malloc(size_t);
void*OC_MallocAtomic(size_t);
void*OC_Calloc(size_t);
void*OC_Realloc(void*,size_t);
void*OC_Free(void*data);
# 1 "../../util/string.h"
#include <string.h>
# 31 "sortcltn.h"
typedef struct objbbt
{
struct objbbt*ulink;
struct objbbt*rlink;
struct objbbt*llink;
int balance;
id key;
}*
objbbt_t;
# 28 "treeseq.h"
struct TreeSequence_PRIVATE {
# 42 "../../include/objcrt/Object.h"
id isa;
# 46 "../../include/objcrt/Object.h"
unsigned short attr;
unsigned short objID;
# 30 "treeseq.h"
objbbt_t top;
objbbt_t next;
objbbt_t prev;};
# 28 "treeseq.h"
extern id TreeSequence;
# 28 "treeseq.h"
extern struct _SHARED _TreeSequence;
extern struct _SHARED __TreeSequence;
# 27 "treeseq.m"
static objbbt_t
first(objbbt_t p)
{
while(p->llink)
p=p->llink;
return p;
}
static objbbt_t
last(objbbt_t p)
{
while(p->rlink)
p=p->rlink;
return p;
}
static id i_TreeSequence_setUpSort_(struct TreeSequence_PRIVATE *self,SEL _cmd,id aSort)
{
id objcT0;
self->
# 45 "treeseq.m"
top=(objcT0=aSort,(*(objbbt_t(*)(id,SEL))_imp(objcT0,selTransTbl[0]))(objcT0,selTransTbl[0]));self->
prev=NULL;self->
next=(self->top)?first(self->top):NULL;
return(id)self;
}
static id c_TreeSequence_over_(struct TreeSequence_PRIVATE *self,SEL _cmd,id aSort)
{
id objcT1,objcT2;
# 53 "treeseq.m"
id newObj=(objcT1=__TreeSequence.clsSuper,(*_impSuper(objcT1,selTransTbl[1]))((id)self,selTransTbl[1]));
(objcT2=newObj,(*_imp(objcT2,selTransTbl[2]))(objcT2,selTransTbl[2],aSort));
return newObj;
}
static id i_TreeSequence_copy(struct TreeSequence_PRIVATE *self,SEL _cmd)
{
id objcT3;
# 60 "treeseq.m"
return(objcT3=_TreeSequence.clsSuper,(*_impSuper(objcT3,selTransTbl[3]))((id)self,selTransTbl[3]));
}
static id i_TreeSequence_free(struct TreeSequence_PRIVATE *self,SEL _cmd)
{
id objcT4;
# 65 "treeseq.m"
return(objcT4=_TreeSequence.clsSuper,(*_impSuper(objcT4,selTransTbl[4]))((id)self,selTransTbl[4]));
}
static int
size(objbbt_t self)
{
int n=1;
if(self->llink)
n+=size(self->llink);
if(self->rlink)
n+=size(self->rlink);
return n;
}
static unsigned i_TreeSequence_size(struct TreeSequence_PRIVATE *self,SEL _cmd)
{
return(self->top)?size(self->top):0;
}
static objbbt_t
nextulink(objbbt_t p,objbbt_t top)
{
while(p!=top)
{
objbbt_t ulink;
ulink=p->ulink;
if(p==ulink->llink)
return ulink;
p=ulink;
}
return NULL;
}
static objbbt_t
nextnode(objbbt_t p,objbbt_t top)
{
objbbt_t link;
if((link=p->rlink))
{
return first(link);
}
else
{
return nextulink(p,top);
}
}
static id i_TreeSequence_next(struct TreeSequence_PRIVATE *self,SEL _cmd)
{
if(self->next)
{self->
prev=self->next;self->
next=nextnode(self->next,self->top);
return self->prev->key;
}
else
{
return(id)0;
}
}
static id i_TreeSequence_peek(struct TreeSequence_PRIVATE *self,SEL _cmd)
{
return(self->next)?self->next->key:(id)0;
}
static id i_TreeSequence_previous(struct TreeSequence_PRIVATE *self,SEL _cmd)
{
return(self->prev)?self->prev->key:(id)0;
}
static id i_TreeSequence_first(struct TreeSequence_PRIVATE *self,SEL _cmd)
{
if(self->top)
{
objbbt_t f=first(self->top);
return f->key;
}
else
{
return(id)0;
}
}
static id i_TreeSequence_last(struct TreeSequence_PRIVATE *self,SEL _cmd)
{
if(self->top)
{
objbbt_t l=last(self->top);
return l->key;
}
else
{
return(id)0;
}
}
extern id Object;
extern struct _SHARED _Object;
extern struct _SHARED __Object;
static struct _SLT _TreeSequence_clsDispatchTbl[] ={
{"over:",(id (*)())c_TreeSequence_over_},
{(char*)0,(id (*)())0}
};
static struct _SLT _TreeSequence_nstDispatchTbl[] ={
{"setUpSort:",(id (*)())i_TreeSequence_setUpSort_},
{"copy",(id (*)())i_TreeSequence_copy},
{"free",(id (*)())i_TreeSequence_free},
{"size",(id (*)())i_TreeSequence_size},
{"next",(id (*)())i_TreeSequence_next},
{"peek",(id (*)())i_TreeSequence_peek},
{"previous",(id (*)())i_TreeSequence_previous},
{"first",(id (*)())i_TreeSequence_first},
{"last",(id (*)())i_TreeSequence_last},
{(char*)0,(id (*)())0}
};
id TreeSequence = (id)&_TreeSequence;
id *OBJCCLASS_TreeSequence(void) { return &TreeSequence; }
struct _SHARED _TreeSequence = {
(id)&__TreeSequence,
(id)&_Object,
"TreeSequence",
0,
sizeof(struct TreeSequence_PRIVATE),
9,
_TreeSequence_nstDispatchTbl,
41,
&treeseq_modDesc,
0,
(id)0,
&TreeSequence,
};
id OBJCCFUNC_TreeSequence(void) { return (id)&_TreeSequence; }
id OBJCCSUPER_TreeSequence(void) { return _TreeSequence.clsSuper; }
struct _SHARED __TreeSequence = {
(id)&__Object,
(id)&__Object,
"TreeSequence",
0,
sizeof(struct _SHARED),
1,
_TreeSequence_clsDispatchTbl,
34,
&treeseq_modDesc,
0,
(id)0,
0,
};
id OBJCMFUNC_TreeSequence(void) { return (id)&__TreeSequence; }
id OBJCMSUPER_TreeSequence(void) { return __TreeSequence.clsSuper; }
static char *_selTransTbl[] ={
"objbbtTop",
"new",
"setUpSort:",
"copy",
"free",
0
};
struct modDescriptor treeseq_modDesc = {
"treeseq",
"objc3.2.8",
0L,
0,
0,
&TreeSequence,
5,
_selTransTbl,
0
};
struct modDescriptor *_OBJCBIND_treeseq(void)
{
selTransTbl = _selTransTbl;
return &treeseq_modDesc;
}
int _OBJCPOSTLINK_treeseq = 1;
syntax highlighted by Code2HTML, v. 0.9.1