+ function canTop(cls, rec) {
+
+ rec = rec || 0;
+ //print('CANTOP: ' + cls + ' =' + rec);
+ if (rec > 5) {
+ // print('SKIP : ' + cls);
+ }
+ if (typeof(tops[cls]) == 'undefined') {
+ return false;
+ }
+ for (var i =0; i < tops[cls].length; i++) {
+ if (tops[cls][i] == '*top') {
+ return true;
+ }
+ if (cls == tops[cls][i]) {
+ continue;
+ }
+ if (canTop(tops[cls][i], rec+1)) {
+ return true;
+ }
+ }
+ return false;
+
+ }
+ var nusage = {};
+ var usage_left = {};
+ for(var par in usage) {
+ // see if the parent can be added to something.
+ if (!canTop(par)) {
+ continue;
+ }
+ var duped = true;
+ for(var dupe in usage) {
+ if (usage[par].join(',') == usage[dupe].join(',') &&
+ typeof(nusage[par]) != 'undefined') {
+ duped = true;
+ if (usage_left[dupe] == 'undefined') {
+ usage_left[dupe] = [];
+ }
+ usage_left[dupe].pushUnique(par);
+ break;
+ }
+ }
+ if (typeof(usage_left[par]) != 'undefined') {
+ continue;
+ }
+ nusage[par] = usage[par];
+
+ }