dump.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. #include "stdinc.h"
  2. #include "dat.h"
  3. #include "fns.h"
  4. void
  5. printindex(int fd, Index *ix)
  6. {
  7. int i;
  8. fprint(fd, "index=%s version=%d blocksize=%d tabsize=%d\n",
  9. ix->name, ix->version, ix->blocksize, ix->tabsize);
  10. fprint(fd, "\tbuckets=%d div=%d\n", ix->buckets, ix->div);
  11. for(i = 0; i < ix->nsects; i++)
  12. fprint(fd, "\tsect=%s for buckets [%lld,%lld)\n", ix->smap[i].name, ix->smap[i].start, ix->smap[i].stop);
  13. for(i = 0; i < ix->narenas; i++)
  14. fprint(fd, "\tarena=%s at [%lld,%lld)\n", ix->amap[i].name, ix->amap[i].start, ix->amap[i].stop);
  15. }
  16. void
  17. printarenapart(int fd, ArenaPart *ap)
  18. {
  19. int i;
  20. fprint(fd, "arena partition=%s\n\tversion=%d blocksize=%d arenas=%d\n\tsetbase=%d setsize=%d\n",
  21. ap->part->name, ap->version, ap->blocksize, ap->narenas, ap->tabbase, ap->tabsize);
  22. for(i = 0; i < ap->narenas; i++)
  23. fprint(fd, "\tarena=%s at [%lld,%lld)\n", ap->map[i].name, ap->map[i].start, ap->map[i].stop);
  24. }
  25. void
  26. printarena(int fd, Arena *arena)
  27. {
  28. fprint(fd, "arena='%s' [%lld,%lld)\n\tversion=%d created=%d modified=%d",
  29. arena->name, arena->base, arena->base + arena->size + 2 * arena->blocksize,
  30. arena->version, arena->ctime, arena->wtime);
  31. if(arena->memstats.sealed)
  32. fprint(2, " sealed\n");
  33. else
  34. fprint(2, "\n");
  35. if(scorecmp(zeroscore, arena->score) != 0)
  36. fprint(2, "\tscore=%V\n", arena->score);
  37. fprint(fd, "\tclumps=%,d compressed clumps=%,d data=%,lld compressed data=%,lld disk storage=%,lld\n",
  38. arena->memstats.clumps, arena->memstats.cclumps, arena->memstats.uncsize,
  39. arena->memstats.used - arena->memstats.clumps * ClumpSize,
  40. arena->memstats.used + arena->memstats.clumps * ClumpInfoSize);
  41. }