|  | /* | 
|  | * This file is part of the UCB release of Plan 9. It is subject to the license | 
|  | * terms in the LICENSE file found in the top-level directory of this | 
|  | * distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No | 
|  | * part of the UCB release of Plan 9, including this file, may be copied, | 
|  | * modified, propagated, or distributed except according to the terms contained | 
|  | * in the LICENSE file. | 
|  | */ | 
|  | #include <stdlib.h> | 
|  |  | 
|  | #include <stdio.h> | 
|  | #include <parlib/parlib.h> | 
|  | #include <unistd.h> | 
|  | #include <signal.h> | 
|  | #include <fcntl.h> | 
|  | #include <iplib/iplib.h> | 
|  | #include <ndblib/ndb.h> | 
|  |  | 
|  | /* replace a in t with b, the line structure in b is lost, c'est la vie */ | 
|  | struct ndbtuple* | 
|  | ndbsubstitute(struct ndbtuple *t, struct ndbtuple *a, struct ndbtuple *b) | 
|  | { | 
|  | struct ndbtuple *nt; | 
|  |  | 
|  | if(a == b){ | 
|  | ndbsetmalloctag(t, getcallerpc(&t)); | 
|  | return t; | 
|  | } | 
|  | if(b == NULL){ | 
|  | t = ndbdiscard(t, a); | 
|  | ndbsetmalloctag(t, getcallerpc(&t)); | 
|  | return t; | 
|  | } | 
|  |  | 
|  | /* all pointers to a become pointers to b */ | 
|  | for(nt = t; nt != NULL; nt = nt->entry){ | 
|  | if(nt->line == a) | 
|  | nt->line = b; | 
|  | if(nt->entry == a) | 
|  | nt->entry = b; | 
|  | } | 
|  |  | 
|  | /* end of b chain points to a's successors */ | 
|  | for(nt = b; nt->entry; nt = nt->entry) | 
|  | nt->line = nt->entry; | 
|  | nt->line = a->line; | 
|  | nt->entry = a->entry; | 
|  |  | 
|  | a->entry = NULL; | 
|  | ndbfree(a); | 
|  |  | 
|  | if(a == t){ | 
|  | ndbsetmalloctag(b, getcallerpc(&t)); | 
|  | return b; | 
|  | }else{ | 
|  | ndbsetmalloctag(t, getcallerpc(&t)); | 
|  | return t; | 
|  | } | 
|  | } |