e576bb | 2002-10-11 | Martin Nilsson | | |
d2361e | 2003-06-30 | Martin Stjernholm | | || $Id: cyclic.c,v 1.11 2003/06/30 17:06:08 mast Exp $
|
e576bb | 2002-10-11 | Martin Nilsson | | */
|
1b10db | 2002-10-08 | Martin Nilsson | |
|
24ddc7 | 1998-03-28 | Henrik Grubbström (Grubba) | | #include "global.h"
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | #include "cyclic.h"
|
d2361e | 2003-06-30 | Martin Stjernholm | | RCSID("$Id: cyclic.c,v 1.11 2003/06/30 17:06:08 mast Exp $");
|
24ddc7 | 1998-03-28 | Henrik Grubbström (Grubba) | |
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | #define CYCLIC_HASH_SIZE 4711
CYCLIC *cyclic_hash[CYCLIC_HASH_SIZE];
|
545ca8 | 1997-10-07 | Fredrik Hübinette (Hubbe) | | static void low_unlink_cyclic(CYCLIC *c)
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | {
|
c7241b | 2000-08-10 | Henrik Grubbström (Grubba) | | size_t h;
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | CYCLIC **p;
|
d2361e | 2003-06-30 | Martin Stjernholm | | h=PTR_TO_INT(c->id);
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | h*=33;
|
d2361e | 2003-06-30 | Martin Stjernholm | | h|=PTR_TO_INT(c->a);
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | h*=33;
|
d2361e | 2003-06-30 | Martin Stjernholm | | h|=PTR_TO_INT(c->b);
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | h*=33;
|
d2361e | 2003-06-30 | Martin Stjernholm | | h|=PTR_TO_INT(c->th);
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | h*=33;
h%=CYCLIC_HASH_SIZE;
for(p=cyclic_hash+h;*p;p=&(p[0]->next))
{
if(c == *p)
{
*p=c->next;
|
3b6bff | 2002-12-01 | Martin Stjernholm | | #ifdef CYCLIC_DEBUG
fprintf (stderr, "%s: END_CYCLIC a=%p b=%p: no cycle\n", c->id, c->a, c->b);
#endif
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | return;
}
}
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Unlink cyclic on lost cyclic struct.\n");
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | }
|
545ca8 | 1997-10-07 | Fredrik Hübinette (Hubbe) | | void unlink_cyclic(CYCLIC *c)
{
UNSET_ONERROR(c->onerr);
low_unlink_cyclic(c);
}
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | void *begin_cyclic(CYCLIC *c,
|
3b6bff | 2002-12-01 | Martin Stjernholm | | char *id,
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | void *th,
void *a,
void *b)
{
|
c7241b | 2000-08-10 | Henrik Grubbström (Grubba) | | size_t h;
|
14bb59 | 2000-05-06 | Fredrik Hübinette (Hubbe) | | void *ret=0;
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | CYCLIC *p;
|
d2361e | 2003-06-30 | Martin Stjernholm | | h=PTR_TO_INT(id);
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | h*=33;
|
d2361e | 2003-06-30 | Martin Stjernholm | | h|=PTR_TO_INT(a);
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | h*=33;
|
d2361e | 2003-06-30 | Martin Stjernholm | | h|=PTR_TO_INT(b);
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | h*=33;
|
d2361e | 2003-06-30 | Martin Stjernholm | | h|=PTR_TO_INT(th);
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | h*=33;
h%=CYCLIC_HASH_SIZE;
for(p=cyclic_hash[h];p;p=p->next)
|
14bb59 | 2000-05-06 | Fredrik Hübinette (Hubbe) | | {
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | if(a == p->a && b==p->b && id==p->id)
|
14bb59 | 2000-05-06 | Fredrik Hübinette (Hubbe) | | {
|
3b6bff | 2002-12-01 | Martin Stjernholm | | #ifdef CYCLIC_DEBUG
fprintf (stderr, "%s: BEGIN_CYCLIC a=%p b=%p: found cycle\n", id, a, b);
#endif
|
14bb59 | 2000-05-06 | Fredrik Hübinette (Hubbe) | | ret=p->ret;
break;
}
}
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | |
|
c7241b | 2000-08-10 | Henrik Grubbström (Grubba) | | c->ret=(void *)(ptrdiff_t)1;
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | c->a=a;
c->b=b;
c->id=id;
c->th=th;
c->next=cyclic_hash[h];
cyclic_hash[h]=c;
|
545ca8 | 1997-10-07 | Fredrik Hübinette (Hubbe) | | SET_ONERROR(c->onerr, low_unlink_cyclic, c);
|
3b6bff | 2002-12-01 | Martin Stjernholm | | #ifdef CYCLIC_DEBUG
if (!ret) fprintf (stderr, "%s: BEGIN_CYCLIC a=%p b=%p: no cycle\n", id, a, b);
#endif
|
14bb59 | 2000-05-06 | Fredrik Hübinette (Hubbe) | | return ret;
|
fc3345 | 1997-10-02 | Fredrik Hübinette (Hubbe) | | }
|