3 * (c) Copyright 1988 by the Massachusetts Institute of Technology.
4 * For copying and distribution information, please see the file
8 #include <mit-copyright.h>
13 static char phase3_qc_rcsid[] = "$Header$";
16 empty_list_check(id, l, hint)
20 if (l->members == 0 && l->list_id != 0)
21 printf("Warning: List %s is empty\n", l->name);
25 /* Used by other parts of the program to check that a string_id is good.
26 * This returns TRUE if it is, or FALSE if it is not, and as a side effect
27 * increments the string reference count.
33 register struct string *s;
35 s = (struct string *) hash_lookup(strings, id);
43 unref_string_check(id, s, hint)
48 printf("Unreferenced string %s id %d\n", s->name, id);
49 if (single_fix("Delete", 1))
50 single_delete("strings", "string_id", id);
55 noclu_mach_check(id, m, hint)
59 if (m->clucount == 0 && m->mach_id != 0)
60 printf("Warning: machine %s is not in any clusters\n", m->name);
66 printf("Phase 3 - Finding unused objects\n");
69 dprintf("Checking machines...\n");
70 hash_step(machines, noclu_mach_check, NULL);
72 dprintf("Checking lists...\n");
73 hash_step(lists, empty_list_check, NULL);
76 dprintf("Checking strings...\n");
77 hash_step(strings, unref_string_check, NULL);