ndbsubstitute.c 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. /*
  2. * This file is part of the UCB release of Plan 9. It is subject to the license
  3. * terms in the LICENSE file found in the top-level directory of this
  4. * distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No
  5. * part of the UCB release of Plan 9, including this file, may be copied,
  6. * modified, propagated, or distributed except according to the terms contained
  7. * in the LICENSE file.
  8. */
  9. #include <u.h>
  10. #include <libc.h>
  11. #include <bio.h>
  12. #include <ndb.h>
  13. /* replace a in t with b, the line structure in b is lost, c'est la vie */
  14. Ndbtuple*
  15. ndbsubstitute(Ndbtuple *t, Ndbtuple *a, Ndbtuple *b)
  16. {
  17. Ndbtuple *nt;
  18. if(a == b){
  19. ndbsetmalloctag(t, getcallerpc());
  20. return t;
  21. }
  22. if(b == nil){
  23. t = ndbdiscard(t, a);
  24. ndbsetmalloctag(t, getcallerpc());
  25. return t;
  26. }
  27. /* all pointers to a become pointers to b */
  28. for(nt = t; nt != nil; nt = nt->entry){
  29. if(nt->line == a)
  30. nt->line = b;
  31. if(nt->entry == a)
  32. nt->entry = b;
  33. }
  34. /* end of b chain points to a's successors */
  35. for(nt = b; nt->entry; nt = nt->entry)
  36. nt->line = nt->entry;
  37. nt->line = a->line;
  38. nt->entry = a->entry;
  39. a->entry = nil;
  40. ndbfree(a);
  41. if(a == t){
  42. ndbsetmalloctag(b, getcallerpc());
  43. return b;
  44. }else{
  45. ndbsetmalloctag(t, getcallerpc());
  46. return t;
  47. }
  48. }