#include <stdio.h> #include <string.h> #include "config.h" #include "lint.h" #include "interpret.h" #include "object.h" #include "exec.h" /* * Write statistics about objects on file. */ extern struct object *obj_list; static int svalue_size(struct svalue *v) { int i, total; switch(v->type) { case T_OBJECT: case T_NUMBER: return 0; case T_STRING: return strlen(v->u.string) + 4; /* Includes some malloc overhead. */ case T_POINTER: for (i = 0, total = 0; i < v->u.vec->size; i++) { total += svalue_size(&v->u.vec->item[i]) + sizeof (struct svalue); } return total; default: fatal("Illegal type: %d\n", v->type); } /*NOTREACHED*/ #ifdef lint return 0; #endif } static int data_size(struct object *ob) { int total = 0, i; if (ob->prog) { for (i = 0; i < (int)ob->prog->num_variables + (int)ob->prog->inherit[ob->prog->num_inherited - 1].variable_index_offset; i++) total += svalue_size(&ob->variables[i]) + sizeof (struct svalue); } return total; } void dumpstat() { FILE *f; struct object *ob; f = fopen("OBJ_DUMP", "w"); if (f == 0) return; add_message("Dumping to OBJ_DUMP ..."); for (ob = obj_list; ob; ob = ob->next_all) { int tmp; if (ob->prog && (ob->prog->ref == 1 || !(ob->flags & O_CLONE))) tmp = ob->prog->total_size; else tmp = 0; fprintf(f, "%-20s %5d ref %2d %s (%ld) %s %s\n", ob->name, tmp + data_size(ob) + sizeof (struct object), ob->ref, ob->super ? ob->super->name : "--",ob->prog->cpu, "", ob->swap_num > 0 ? "SWAP" : ""); } add_message("done.\n"); fclose(f); }