sclass WebNode implements _SetField { Web web; O labels; public void _setField(S f, O x) { if (f.equals('web)) web = (Web) x; else if (f.equals('labels)) labels = (L) x; } *() {} *(Web *web) { web.fireNewNode(this); } void addLabel(S label) { labels = smallestList_add(labels, label); } void addLabel(Lisp label) { addLabel(web.unparseLabel(label)); } void addLabels(Collection l) { for (Lisp lbl : l) addLabel(lbl); } void addStrings(Collection l) { for (S lbl : l) addLabel(lbl); } bool hasLabel(Lisp label) { ret hasLabel(web.unparseLabel(label)); } bool hasLabel(S label) { ret smallestList_contains(labels, label); } toString { ret l(labels) == 1 ? str(smallestList_first(labels)) : str(smallestList_toList(labels)); } int count() { ret 1 + l(labels); } S text() { ret (S) smallestList_first(labels); } L texts() { ret smallestList_toList(labels); } void relation(S arrow, S b) { web.getRelation(this, web.node(b)).addLabel(arrow); } Lisp parseLabel(S l) { ret web.parseLabel(l); } S unparseLabel(Lisp l) { ret web.unparseLabel(l); } L labels() { ret web.parseLabels(texts()); } bool hasLabels() { ret smallestList_nempty(labels); } void setLabel(int i, Lisp l) { labels = smallestList_set(labels, i, web.unparseLabel(l)); } O visInfo() { ret null; } void visInfo(O o) {} }