X-Git-Url: http://nitlanguage.org diff --git a/c_src/partial_order._sep.c b/c_src/partial_order._sep.c index 9a412c5..c86f9f8 100644 --- a/c_src/partial_order._sep.c +++ b/c_src/partial_order._sep.c @@ -1,491 +1,531 @@ /* This C file is generated by NIT to compile module partial_order. */ #include "partial_order._sep.h" -val_t partial_order___PartialOrder___roots(val_t self) { - struct trace_t trace = {NULL, NULL, 30, LOCATE_partial_order___PartialOrder___roots}; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - tracehead = trace.prev; - return ATTR_partial_order___PartialOrder____roots( self) /*PartialOrder::_roots*/; -} -val_t partial_order___PartialOrder___is_empty(val_t self) { - struct trace_t trace = {NULL, NULL, 35, LOCATE_partial_order___PartialOrder___is_empty}; - val_t variable0; +val_t partial_order___PartialOrder___iterator(val_t self) { + struct trace_t trace = {NULL, NULL, 54, LOCATE_partial_order___PartialOrder___iterator}; + val_t variable[3]; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; - variable0 = ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/; - variable0 = ((abstract_collection___Collection___is_empty_t)CALL(variable0,COLOR_abstract_collection___Collection___is_empty))(variable0) /*Collection::is_empty*/; + variable[0] = self; + variable[2] = variable[0]; + variable[2] = ATTR_partial_order___PartialOrder____elements_list(variable[2]) /*PartialOrder::_elements_list*/; + variable[2] = ((array___AbstractArray___iterator_t)CALL(variable[2],COLOR_abstract_collection___Collection___iterator))(variable[2]) /*AbstractArray::iterator*/; + variable[1] = variable[2]; goto return_label0; return_label0: while(false); tracehead = trace.prev; - return variable0; + return variable[1]; } -val_t partial_order___PartialOrder___length(val_t self) { - struct trace_t trace = {NULL, NULL, 37, LOCATE_partial_order___PartialOrder___length}; - val_t variable0; +val_t partial_order___PartialOrder___is_empty(val_t self) { + struct trace_t trace = {NULL, NULL, 35, LOCATE_partial_order___PartialOrder___is_empty}; + val_t variable[3]; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; - variable0 = ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/; - variable0 = ((abstract_collection___Collection___length_t)CALL(variable0,COLOR_abstract_collection___Collection___length))(variable0) /*Collection::length*/; + variable[0] = self; + variable[2] = variable[0]; + variable[2] = ATTR_partial_order___PartialOrder____elements(variable[2]) /*PartialOrder::_elements*/; + variable[2] = ((abstract_collection___Collection___is_empty_t)CALL(variable[2],COLOR_abstract_collection___Collection___is_empty))(variable[2]) /*Collection::is_empty*/; + variable[1] = variable[2]; goto return_label1; return_label1: while(false); tracehead = trace.prev; - return variable0; + return variable[1]; } -val_t partial_order___PartialOrder___first(val_t self) { - struct trace_t trace = {NULL, NULL, 39, LOCATE_partial_order___PartialOrder___first}; - val_t variable0; +val_t partial_order___PartialOrder___length(val_t self) { + struct trace_t trace = {NULL, NULL, 37, LOCATE_partial_order___PartialOrder___length}; + val_t variable[3]; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; - variable0 = ATTR_partial_order___PartialOrder____elements_list( self) /*PartialOrder::_elements_list*/; - variable0 = ((abstract_collection___IndexedCollection___first_t)CALL(variable0,COLOR_abstract_collection___Collection___first))(variable0) /*IndexedCollection::first*/; + variable[0] = self; + variable[2] = variable[0]; + variable[2] = ATTR_partial_order___PartialOrder____elements(variable[2]) /*PartialOrder::_elements*/; + variable[2] = ((abstract_collection___Collection___length_t)CALL(variable[2],COLOR_abstract_collection___Collection___length))(variable[2]) /*Collection::length*/; + variable[1] = variable[2]; goto return_label2; return_label2: while(false); tracehead = trace.prev; - return variable0; + return variable[1]; } val_t partial_order___PartialOrder___has(val_t self, val_t param0) { struct trace_t trace = {NULL, NULL, 41, LOCATE_partial_order___PartialOrder___has}; - val_t variable0; - val_t variable1; + val_t variable[4]; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/; - variable1 = ((abstract_collection___Map___has_key_t)CALL(variable1,COLOR_abstract_collection___Map___has_key))(variable1, variable0 /*e*/) /*Map::has_key*/; + variable[0] = self; + variable[1] = param0; + variable[3] = variable[0]; + variable[3] = ATTR_partial_order___PartialOrder____elements(variable[3]) /*PartialOrder::_elements*/; + variable[3] = ((abstract_collection___Map___has_key_t)CALL(variable[3],COLOR_abstract_collection___Map___has_key))(variable[3], variable[1] /*e*/) /*Map::has_key*/; + variable[2] = variable[3]; goto return_label3; return_label3: while(false); tracehead = trace.prev; - return variable1; + return variable[2]; } val_t partial_order___PartialOrder___has_only(val_t self, val_t param0) { struct trace_t trace = {NULL, NULL, 43, LOCATE_partial_order___PartialOrder___has_only}; - val_t variable0; - val_t variable1; - val_t variable2; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/; - variable1 = ((abstract_collection___Collection___length_t)CALL(variable1,COLOR_abstract_collection___Collection___length))(variable1) /*Collection::length*/; - variable1 = TAG_Bool((variable1)==( TAG_Int(1))); - variable2 = variable1; - if (UNTAG_Bool(variable2)) { /* and */ - variable2 = ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/; - variable2 = ((abstract_collection___Collection___first_t)CALL(variable2,COLOR_abstract_collection___Collection___first))(variable2) /*Collection::first*/; - variable2 = TAG_Bool((variable2 == variable0 /*e*/) || ((variable2 != NIT_NULL) && ((((kernel___Object_____eqeq_t)CALL(variable2,COLOR_kernel___Object_____eqeq))==kernel___Object_____eqeq)?(IS_EQUAL_NN(variable2, variable0 /*e*/)):(UNTAG_Bool(((kernel___Object_____eqeq_t)CALL(variable2,COLOR_kernel___Object_____eqeq))(variable2, variable0 /*e*/) /*Object::==*/))))); + val_t variable[5]; + void **closurevariable = NULL; + trace.prev = tracehead; tracehead = &trace; + trace.file = LOCATE_partial_order; + variable[0] = self; + variable[1] = param0; + variable[3] = variable[0]; + variable[3] = ATTR_partial_order___PartialOrder____elements(variable[3]) /*PartialOrder::_elements*/; + variable[3] = ((abstract_collection___Collection___length_t)CALL(variable[3],COLOR_abstract_collection___Collection___length))(variable[3]) /*Collection::length*/; + variable[3] = TAG_Bool((variable[3])==( TAG_Int(1))); + variable[4] = variable[3]; + if (UNTAG_Bool(variable[4])) { /* and */ + variable[4] = variable[0]; + variable[4] = ATTR_partial_order___PartialOrder____elements(variable[4]) /*PartialOrder::_elements*/; + variable[4] = ((abstract_collection___Collection___first_t)CALL(variable[4],COLOR_abstract_collection___Collection___first))(variable[4]) /*Collection::first*/; + variable[4] = TAG_Bool((variable[4] == variable[1] /*e*/) || ((variable[4] != NIT_NULL) && ((((kernel___Object_____eqeq_t)CALL(variable[4],COLOR_kernel___Object_____eqeq))==kernel___Object_____eqeq)?(IS_EQUAL_NN(variable[4], variable[1] /*e*/)):(UNTAG_Bool(((kernel___Object_____eqeq_t)CALL(variable[4],COLOR_kernel___Object_____eqeq))(variable[4], variable[1] /*e*/) /*Object::==*/))))); } - variable1 = variable2; + variable[3] = variable[4]; + variable[2] = variable[3]; goto return_label4; return_label4: while(false); tracehead = trace.prev; - return variable1; + return variable[2]; } val_t partial_order___PartialOrder___count(val_t self, val_t param0) { struct trace_t trace = {NULL, NULL, 45, LOCATE_partial_order___PartialOrder___count}; - val_t variable0; - val_t variable1; + val_t variable[4]; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = ((partial_order___PartialOrder___has_t)CALL( self,COLOR_abstract_collection___Collection___has))( self, variable0 /*e*/) /*PartialOrder::has*/; - if (UNTAG_Bool(variable1)) { /*if*/ - variable1 = TAG_Int(1); + variable[0] = self; + variable[1] = param0; + variable[3] = variable[0]; + variable[3] = ((partial_order___PartialOrder___has_t)CALL(variable[3],COLOR_abstract_collection___Collection___has))(variable[3], variable[1] /*e*/) /*PartialOrder::has*/; + if (UNTAG_Bool(variable[3])) { /*if*/ + variable[2] = TAG_Int(1); goto return_label5; } else { /*if*/ - variable1 = TAG_Int(0); + variable[2] = TAG_Int(0); goto return_label5; } return_label5: while(false); tracehead = trace.prev; - return variable1; + return variable[2]; } -val_t partial_order___PartialOrder___iterator(val_t self) { - struct trace_t trace = {NULL, NULL, 54, LOCATE_partial_order___PartialOrder___iterator}; - val_t variable0; +val_t partial_order___PartialOrder___first(val_t self) { + struct trace_t trace = {NULL, NULL, 39, LOCATE_partial_order___PartialOrder___first}; + val_t variable[3]; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; - variable0 = ATTR_partial_order___PartialOrder____elements_list( self) /*PartialOrder::_elements_list*/; - variable0 = ((array___AbstractArray___iterator_t)CALL(variable0,COLOR_abstract_collection___Collection___iterator))(variable0) /*AbstractArray::iterator*/; + variable[0] = self; + variable[2] = variable[0]; + variable[2] = ATTR_partial_order___PartialOrder____elements_list(variable[2]) /*PartialOrder::_elements_list*/; + variable[2] = ((abstract_collection___IndexedCollection___first_t)CALL(variable[2],COLOR_abstract_collection___Collection___first))(variable[2]) /*IndexedCollection::first*/; + variable[1] = variable[2]; goto return_label6; return_label6: while(false); tracehead = trace.prev; - return variable0; + return variable[1]; } -val_t partial_order___PartialOrder_____bra(val_t self, val_t param0) { - struct trace_t trace = {NULL, NULL, 58, LOCATE_partial_order___PartialOrder_____bra}; - val_t variable0; - val_t variable1; +val_t partial_order___PartialOrder___roots(val_t self) { + struct trace_t trace = {NULL, NULL, 30, LOCATE_partial_order___PartialOrder___roots}; + val_t *variable = NULL; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/; - variable1 = ((abstract_collection___Map___has_key_t)CALL(variable1,COLOR_abstract_collection___Map___has_key))(variable1, variable0 /*e*/) /*Map::has_key*/; - if (UNTAG_Bool(variable1)) { /*if*/ - variable1 = ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/; - variable1 = ((abstract_collection___Map_____bra_t)CALL(variable1,COLOR_abstract_collection___Map_____bra))(variable1, variable0 /*e*/) /*Map::[]*/; + tracehead = trace.prev; + return ATTR_partial_order___PartialOrder____roots( self) /*PartialOrder::_roots*/; +} +val_t partial_order___PartialOrder_____bra(val_t self, val_t param0) { + struct trace_t trace = {NULL, NULL, 58, LOCATE_partial_order___PartialOrder_____bra}; + val_t variable[4]; + void **closurevariable = NULL; + trace.prev = tracehead; tracehead = &trace; + trace.file = LOCATE_partial_order; + variable[0] = self; + variable[1] = param0; + variable[3] = variable[0]; + variable[3] = ATTR_partial_order___PartialOrder____elements(variable[3]) /*PartialOrder::_elements*/; + variable[3] = ((abstract_collection___Map___has_key_t)CALL(variable[3],COLOR_abstract_collection___Map___has_key))(variable[3], variable[1] /*e*/) /*Map::has_key*/; + if (UNTAG_Bool(variable[3])) { /*if*/ + variable[3] = variable[0]; + variable[3] = ATTR_partial_order___PartialOrder____elements(variable[3]) /*PartialOrder::_elements*/; + variable[3] = ((abstract_collection___Map_____bra_t)CALL(variable[3],COLOR_abstract_collection___Map_____bra))(variable[3], variable[1] /*e*/) /*Map::[]*/; + variable[2] = variable[3]; goto return_label7; } else { /*if*/ - variable1 = NIT_NULL /*null*/; + variable[2] = NIT_NULL /*null*/; goto return_label7; } return_label7: while(false); tracehead = trace.prev; - return variable1; + return variable[2]; } val_t partial_order___PartialOrder___to_dot(val_t self) { struct trace_t trace = {NULL, NULL, 68, LOCATE_partial_order___PartialOrder___to_dot}; - val_t variable0; - val_t variable1; - val_t variable2; - val_t variable3; - val_t variable4; - val_t variable5; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - variable1 = NEW_String_string___String___init(); /*new String*/ - variable0 = variable1; - variable1 = ((partial_order___PartialOrder___to_dot_header_t)CALL( self,COLOR_partial_order___PartialOrder___to_dot_header))( self) /*PartialOrder::to_dot_header*/; - ((string___String___append_t)CALL( variable0 /*s*/,COLOR_abstract_collection___IndexedCollection___append))( variable0 /*s*/, variable1) /*String::append*/; - variable1 = ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/; - variable1 = ((abstract_collection___Map___iterator_t)CALL(variable1,COLOR_abstract_collection___Collection___iterator))(variable1) /*Map::iterator*/; + val_t variable[11]; + void **closurevariable = NULL; + trace.prev = tracehead; tracehead = &trace; + trace.file = LOCATE_partial_order; + variable[0] = self; + variable[3] = NEW_String_string___String___init(); /*new String*/ + variable[2] = variable[3]; + variable[3] = variable[0]; + variable[3] = ((partial_order___PartialOrder___to_dot_header_t)CALL(variable[3],COLOR_partial_order___PartialOrder___to_dot_header))(variable[3]) /*PartialOrder::to_dot_header*/; + ((string___String___append_t)CALL( variable[2] /*s*/,COLOR_abstract_collection___IndexedCollection___append))( variable[2] /*s*/, variable[3]) /*String::append*/; + variable[3] = variable[0]; + variable[3] = ATTR_partial_order___PartialOrder____elements(variable[3]) /*PartialOrder::_elements*/; + variable[3] = ((abstract_collection___Map___iterator_t)CALL(variable[3],COLOR_abstract_collection___Collection___iterator))(variable[3]) /*Map::iterator*/; while (true) { /*for*/ - variable2 = ((abstract_collection___Iterator___is_ok_t)CALL(variable1,COLOR_abstract_collection___Iterator___is_ok))(variable1) /*Iterator::is_ok*/; - if (!UNTAG_Bool(variable2)) break; /*for*/ - variable2 = ((abstract_collection___Iterator___item_t)CALL(variable1,COLOR_abstract_collection___Iterator___item))(variable1) /*Iterator::item*/; - variable3 = ((partial_order___PartialOrderElement___value_t)CALL( variable2 /*e*/,COLOR_partial_order___PartialOrderElement___value))( variable2 /*e*/) /*PartialOrderElement::value*/; - variable3 = ((partial_order___PartialOrder___to_dot_node_t)CALL( self,COLOR_partial_order___PartialOrder___to_dot_node))( self, variable3) /*PartialOrder::to_dot_node*/; - ((string___String___append_t)CALL( variable0 /*s*/,COLOR_abstract_collection___IndexedCollection___append))( variable0 /*s*/, variable3) /*String::append*/; - variable3 = ((partial_order___PartialOrderElement___direct_greaters_t)CALL( variable2 /*e*/,COLOR_partial_order___PartialOrderElement___direct_greaters))( variable2 /*e*/) /*PartialOrderElement::direct_greaters*/; - variable3 = ((array___AbstractArray___iterator_t)CALL(variable3,COLOR_abstract_collection___Collection___iterator))(variable3) /*AbstractArray::iterator*/; + variable[4] = ((abstract_collection___Iterator___is_ok_t)CALL(variable[3],COLOR_abstract_collection___Iterator___is_ok))(variable[3]) /*Iterator::is_ok*/; + if (!UNTAG_Bool(variable[4])) break; /*for*/ + variable[4] = ((abstract_collection___Iterator___item_t)CALL(variable[3],COLOR_abstract_collection___Iterator___item))(variable[3]) /*Iterator::item*/; + variable[5] = variable[4]; + variable[6] = variable[0]; + variable[7] = ((partial_order___PartialOrderElement___value_t)CALL( variable[5] /*e*/,COLOR_partial_order___PartialOrderElement___value))( variable[5] /*e*/) /*PartialOrderElement::value*/; + variable[6] = ((partial_order___PartialOrder___to_dot_node_t)CALL(variable[6],COLOR_partial_order___PartialOrder___to_dot_node))(variable[6], variable[7]) /*PartialOrder::to_dot_node*/; + ((string___String___append_t)CALL( variable[2] /*s*/,COLOR_abstract_collection___IndexedCollection___append))( variable[2] /*s*/, variable[6]) /*String::append*/; + variable[6] = ((partial_order___PartialOrderElement___direct_greaters_t)CALL( variable[5] /*e*/,COLOR_partial_order___PartialOrderElement___direct_greaters))( variable[5] /*e*/) /*PartialOrderElement::direct_greaters*/; + variable[6] = ((array___AbstractArray___iterator_t)CALL(variable[6],COLOR_abstract_collection___Collection___iterator))(variable[6]) /*AbstractArray::iterator*/; while (true) { /*for*/ - variable4 = ((array___ArrayIterator___is_ok_t)CALL(variable3,COLOR_abstract_collection___Iterator___is_ok))(variable3) /*ArrayIterator::is_ok*/; - if (!UNTAG_Bool(variable4)) break; /*for*/ - variable4 = ((array___ArrayIterator___item_t)CALL(variable3,COLOR_abstract_collection___Iterator___item))(variable3) /*ArrayIterator::item*/; - variable5 = ((partial_order___PartialOrderElement___value_t)CALL( variable2 /*e*/,COLOR_partial_order___PartialOrderElement___value))( variable2 /*e*/) /*PartialOrderElement::value*/; - variable5 = ((partial_order___PartialOrder___to_dot_edge_t)CALL( self,COLOR_partial_order___PartialOrder___to_dot_edge))( self, variable5, variable4 /*d*/) /*PartialOrder::to_dot_edge*/; - ((string___String___append_t)CALL( variable0 /*s*/,COLOR_abstract_collection___IndexedCollection___append))( variable0 /*s*/, variable5) /*String::append*/; + variable[7] = ((array___ArrayIterator___is_ok_t)CALL(variable[6],COLOR_abstract_collection___Iterator___is_ok))(variable[6]) /*ArrayIterator::is_ok*/; + if (!UNTAG_Bool(variable[7])) break; /*for*/ + variable[7] = ((array___ArrayIterator___item_t)CALL(variable[6],COLOR_abstract_collection___Iterator___item))(variable[6]) /*ArrayIterator::item*/; + variable[8] = variable[7]; + variable[9] = variable[0]; + variable[10] = ((partial_order___PartialOrderElement___value_t)CALL( variable[5] /*e*/,COLOR_partial_order___PartialOrderElement___value))( variable[5] /*e*/) /*PartialOrderElement::value*/; + variable[9] = ((partial_order___PartialOrder___to_dot_edge_t)CALL(variable[9],COLOR_partial_order___PartialOrder___to_dot_edge))(variable[9], variable[10], variable[8] /*d*/) /*PartialOrder::to_dot_edge*/; + ((string___String___append_t)CALL( variable[2] /*s*/,COLOR_abstract_collection___IndexedCollection___append))( variable[2] /*s*/, variable[9]) /*String::append*/; continue_10: while(0); - ((array___ArrayIterator___next_t)CALL(variable3,COLOR_abstract_collection___Iterator___next))(variable3) /*ArrayIterator::next*/; + ((array___ArrayIterator___next_t)CALL(variable[6],COLOR_abstract_collection___Iterator___next))(variable[6]) /*ArrayIterator::next*/; } break_10: while(0); continue_9: while(0); - ((abstract_collection___Iterator___next_t)CALL(variable1,COLOR_abstract_collection___Iterator___next))(variable1) /*Iterator::next*/; + ((abstract_collection___Iterator___next_t)CALL(variable[3],COLOR_abstract_collection___Iterator___next))(variable[3]) /*Iterator::next*/; } break_9: while(0); - variable1 = NEW_String_string___String___with_native(BOX_NativeString("}\n"), TAG_Int(2)); /*new String*/ - ((string___String___append_t)CALL( variable0 /*s*/,COLOR_abstract_collection___IndexedCollection___append))( variable0 /*s*/, variable1) /*String::append*/; - variable0 = variable0 /*s*/; + variable[3] = NEW_String_string___String___with_native(BOX_NativeString("}\n"), TAG_Int(2)); /*new String*/ + ((string___String___append_t)CALL( variable[2] /*s*/,COLOR_abstract_collection___IndexedCollection___append))( variable[2] /*s*/, variable[3]) /*String::append*/; + variable[1] = variable[2] /*s*/; goto return_label8; return_label8: while(false); tracehead = trace.prev; - return variable0; + return variable[1]; } val_t partial_order___PartialOrder___to_dot_header(val_t self) { struct trace_t trace = {NULL, NULL, 83, LOCATE_partial_order___PartialOrder___to_dot_header}; - val_t variable0; + val_t variable[3]; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; - variable0 = NEW_String_string___String___with_native(BOX_NativeString("digraph G {\ngraph [rankdir=BT];\n"), TAG_Int(32)); /*new String*/ + variable[0] = self; + variable[2] = NEW_String_string___String___with_native(BOX_NativeString("digraph G {\ngraph [rankdir=BT];\n"), TAG_Int(32)); /*new String*/ + variable[1] = variable[2]; goto return_label11; return_label11: while(false); tracehead = trace.prev; - return variable0; + return variable[1]; } val_t partial_order___PartialOrder___to_dot_node(val_t self, val_t param0) { struct trace_t trace = {NULL, NULL, 89, LOCATE_partial_order___PartialOrder___to_dot_node}; - val_t variable0; - val_t variable1; - val_t variable2; - val_t variable3; - val_t variable4; - val_t variable5; - val_t variable6; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = NEW_String_string___String___init(); /*new String*/ - variable2 = NEW_String_string___String___with_native(BOX_NativeString("\""), TAG_Int(1)); /*new String*/ - variable3 = variable2; - ((string___String___append_t)CALL(variable1,COLOR_abstract_collection___IndexedCollection___append))(variable1, variable3) /*String::append*/; - variable4 = variable0 /*e*/; - variable4 = ((string___String___to_s_t)CALL(variable4,COLOR_string___Object___to_s))(variable4) /*String::to_s*/; - ((string___String___append_t)CALL(variable1,COLOR_abstract_collection___IndexedCollection___append))(variable1, variable4) /*String::append*/; - variable5 = NEW_String_string___String___with_native(BOX_NativeString("\";\n"), TAG_Int(3)); /*new String*/ - variable6 = variable5; - ((string___String___append_t)CALL(variable1,COLOR_abstract_collection___IndexedCollection___append))(variable1, variable6) /*String::append*/; + val_t variable[9]; + void **closurevariable = NULL; + trace.prev = tracehead; tracehead = &trace; + trace.file = LOCATE_partial_order; + variable[0] = self; + variable[1] = param0; + variable[3] = NEW_String_string___String___init(); /*new String*/ + variable[4] = NEW_String_string___String___with_native(BOX_NativeString("\""), TAG_Int(1)); /*new String*/ + variable[5] = variable[4]; + ((string___String___append_t)CALL(variable[3],COLOR_abstract_collection___IndexedCollection___append))(variable[3], variable[5]) /*String::append*/; + variable[6] = variable[1] /*e*/; + variable[6] = ((string___String___to_s_t)CALL(variable[6],COLOR_string___Object___to_s))(variable[6]) /*String::to_s*/; + ((string___String___append_t)CALL(variable[3],COLOR_abstract_collection___IndexedCollection___append))(variable[3], variable[6]) /*String::append*/; + variable[7] = NEW_String_string___String___with_native(BOX_NativeString("\";\n"), TAG_Int(3)); /*new String*/ + variable[8] = variable[7]; + ((string___String___append_t)CALL(variable[3],COLOR_abstract_collection___IndexedCollection___append))(variable[3], variable[8]) /*String::append*/; + variable[2] = variable[3]; goto return_label12; return_label12: while(false); tracehead = trace.prev; - return variable1; + return variable[2]; } val_t partial_order___PartialOrder___to_dot_edge(val_t self, val_t param0, val_t param1) { struct trace_t trace = {NULL, NULL, 95, LOCATE_partial_order___PartialOrder___to_dot_edge}; - val_t variable0; - val_t variable1; - val_t variable2; - val_t variable3; - val_t variable4; - val_t variable5; - val_t variable6; - val_t variable7; - val_t variable8; - val_t variable9; - val_t variable10; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = param1; - variable2 = NEW_String_string___String___init(); /*new String*/ - variable3 = NEW_String_string___String___with_native(BOX_NativeString("\""), TAG_Int(1)); /*new String*/ - variable4 = variable3; - ((string___String___append_t)CALL(variable2,COLOR_abstract_collection___IndexedCollection___append))(variable2, variable4) /*String::append*/; - variable5 = variable0 /*e1*/; - variable5 = ((string___String___to_s_t)CALL(variable5,COLOR_string___Object___to_s))(variable5) /*String::to_s*/; - ((string___String___append_t)CALL(variable2,COLOR_abstract_collection___IndexedCollection___append))(variable2, variable5) /*String::append*/; - variable6 = NEW_String_string___String___with_native(BOX_NativeString("\" -> \""), TAG_Int(6)); /*new String*/ - variable7 = variable6; - ((string___String___append_t)CALL(variable2,COLOR_abstract_collection___IndexedCollection___append))(variable2, variable7) /*String::append*/; - variable8 = variable1 /*e2*/; - variable8 = ((string___String___to_s_t)CALL(variable8,COLOR_string___Object___to_s))(variable8) /*String::to_s*/; - ((string___String___append_t)CALL(variable2,COLOR_abstract_collection___IndexedCollection___append))(variable2, variable8) /*String::append*/; - variable9 = NEW_String_string___String___with_native(BOX_NativeString("\";\n"), TAG_Int(3)); /*new String*/ - variable10 = variable9; - ((string___String___append_t)CALL(variable2,COLOR_abstract_collection___IndexedCollection___append))(variable2, variable10) /*String::append*/; + val_t variable[13]; + void **closurevariable = NULL; + trace.prev = tracehead; tracehead = &trace; + trace.file = LOCATE_partial_order; + variable[0] = self; + variable[1] = param0; + variable[2] = param1; + variable[4] = NEW_String_string___String___init(); /*new String*/ + variable[5] = NEW_String_string___String___with_native(BOX_NativeString("\""), TAG_Int(1)); /*new String*/ + variable[6] = variable[5]; + ((string___String___append_t)CALL(variable[4],COLOR_abstract_collection___IndexedCollection___append))(variable[4], variable[6]) /*String::append*/; + variable[7] = variable[1] /*e1*/; + variable[7] = ((string___String___to_s_t)CALL(variable[7],COLOR_string___Object___to_s))(variable[7]) /*String::to_s*/; + ((string___String___append_t)CALL(variable[4],COLOR_abstract_collection___IndexedCollection___append))(variable[4], variable[7]) /*String::append*/; + variable[8] = NEW_String_string___String___with_native(BOX_NativeString("\" -> \""), TAG_Int(6)); /*new String*/ + variable[9] = variable[8]; + ((string___String___append_t)CALL(variable[4],COLOR_abstract_collection___IndexedCollection___append))(variable[4], variable[9]) /*String::append*/; + variable[10] = variable[2] /*e2*/; + variable[10] = ((string___String___to_s_t)CALL(variable[10],COLOR_string___Object___to_s))(variable[10]) /*String::to_s*/; + ((string___String___append_t)CALL(variable[4],COLOR_abstract_collection___IndexedCollection___append))(variable[4], variable[10]) /*String::append*/; + variable[11] = NEW_String_string___String___with_native(BOX_NativeString("\";\n"), TAG_Int(3)); /*new String*/ + variable[12] = variable[11]; + ((string___String___append_t)CALL(variable[4],COLOR_abstract_collection___IndexedCollection___append))(variable[4], variable[12]) /*String::append*/; + variable[3] = variable[4]; goto return_label13; return_label13: while(false); tracehead = trace.prev; - return variable2; + return variable[3]; } val_t partial_order___PartialOrder___select_smallests(val_t self, val_t param0) { struct trace_t trace = {NULL, NULL, 101, LOCATE_partial_order___PartialOrder___select_smallests}; - val_t variable0; - val_t variable1; - val_t variable2; - val_t variable3; - val_t variable4; - val_t variable5; - val_t variable6; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = TAG_Bool(( variable0 /*c*/ == NIT_NULL /*null*/) || (( variable0 /*c*/ != NIT_NULL) && ((((kernel___Object_____eqeq_t)CALL( variable0 /*c*/,COLOR_kernel___Object_____eqeq))==kernel___Object_____eqeq)?(IS_EQUAL_NN( variable0 /*c*/, NIT_NULL /*null*/)):(UNTAG_Bool(((kernel___Object_____eqeq_t)CALL( variable0 /*c*/,COLOR_kernel___Object_____eqeq))( variable0 /*c*/, NIT_NULL /*null*/) /*Object::==*/))))); - if (UNTAG_Bool(variable1)) { /*if*/ - variable1 = NEW_Array_array___Array___init(); /*new Array[E]*/ + val_t variable[10]; + void **closurevariable = NULL; + trace.prev = tracehead; tracehead = &trace; + trace.file = LOCATE_partial_order; + variable[0] = self; + variable[1] = param0; + variable[3] = TAG_Bool(( variable[1] /*c*/ == NIT_NULL /*null*/) || (( variable[1] /*c*/ != NIT_NULL) && ((((kernel___Object_____eqeq_t)CALL( variable[1] /*c*/,COLOR_kernel___Object_____eqeq))==kernel___Object_____eqeq)?(IS_EQUAL_NN( variable[1] /*c*/, NIT_NULL /*null*/)):(UNTAG_Bool(((kernel___Object_____eqeq_t)CALL( variable[1] /*c*/,COLOR_kernel___Object_____eqeq))( variable[1] /*c*/, NIT_NULL /*null*/) /*Object::==*/))))); + if (UNTAG_Bool(variable[3])) { /*if*/ + variable[3] = NEW_Array_array___Array___init(); /*new Array[E]*/ + variable[2] = variable[3]; goto return_label14; } - variable1 = ((partial_order___PartialOrder___has_all_t)CALL( self,COLOR_partial_order___PartialOrder___has_all))( self, variable0 /*c*/) /*PartialOrder::has_all*/; - if (!UNTAG_Bool(variable1)) { fprintf(stderr, "Assert%s failed", ""); fprintf(stderr, " in %s (%s:%d)\n", LOCATE_partial_order___PartialOrder___select_smallests, LOCATE_partial_order, 105); nit_exit(1);} - variable2 = ((abstract_collection___Collection___length_t)CALL( variable0 /*c*/,COLOR_abstract_collection___Collection___length))( variable0 /*c*/) /*Collection::length*/; - variable3 = NEW_Array_array___Array___with_capacity(variable2); /*new Array[E]*/ - variable2 = variable3; - variable1 = variable2; - variable3 = ((abstract_collection___Collection___length_t)CALL( variable0 /*c*/,COLOR_abstract_collection___Collection___length))( variable0 /*c*/) /*Collection::length*/; - variable4 = NEW_Array_array___Array___with_capacity(variable3); /*new Array[E]*/ - variable3 = variable4; - variable2 = variable3; - variable3 = ((abstract_collection___Collection___iterator_t)CALL( variable0 /*c*/,COLOR_abstract_collection___Collection___iterator))( variable0 /*c*/) /*Collection::iterator*/; + variable[3] = variable[0]; + variable[3] = ((partial_order___PartialOrder___has_all_t)CALL(variable[3],COLOR_partial_order___PartialOrder___has_all))(variable[3], variable[1] /*c*/) /*PartialOrder::has_all*/; + if (!UNTAG_Bool(variable[3])) { fprintf(stderr, "Assert%s failed", ""); fprintf(stderr, " in %s (%s:%d)\n", LOCATE_partial_order___PartialOrder___select_smallests, LOCATE_partial_order, 105); nit_exit(1);} + variable[4] = ((abstract_collection___Collection___length_t)CALL( variable[1] /*c*/,COLOR_abstract_collection___Collection___length))( variable[1] /*c*/) /*Collection::length*/; + variable[5] = NEW_Array_array___Array___with_capacity(variable[4]); /*new Array[E]*/ + variable[4] = variable[5]; + variable[3] = variable[4]; + variable[5] = ((abstract_collection___Collection___length_t)CALL( variable[1] /*c*/,COLOR_abstract_collection___Collection___length))( variable[1] /*c*/) /*Collection::length*/; + variable[6] = NEW_Array_array___Array___with_capacity(variable[5]); /*new Array[E]*/ + variable[5] = variable[6]; + variable[4] = variable[5]; + variable[5] = ((abstract_collection___Collection___iterator_t)CALL( variable[1] /*c*/,COLOR_abstract_collection___Collection___iterator))( variable[1] /*c*/) /*Collection::iterator*/; while (true) { /*for*/ - variable4 = ((abstract_collection___Iterator___is_ok_t)CALL(variable3,COLOR_abstract_collection___Iterator___is_ok))(variable3) /*Iterator::is_ok*/; - if (!UNTAG_Bool(variable4)) break; /*for*/ - variable4 = ((abstract_collection___Iterator___item_t)CALL(variable3,COLOR_abstract_collection___Iterator___item))(variable3) /*Iterator::item*/; - variable6 = ((partial_order___PartialOrder___add_to_smallests_t)CALL( self,COLOR_partial_order___PartialOrder___add_to_smallests))( self, variable4 /*e*/, variable1 /*res*/, variable2 /*tmp*/) /*PartialOrder::add_to_smallests*/; - variable5 = variable6; - if (UNTAG_Bool( variable5 /*r*/)) { /*if*/ - variable6 = variable2 /*tmp*/; - variable2 = variable1 /*res*/ /*tmp=*/; - variable1 = variable6 /*t*/ /*res=*/; + variable[6] = ((abstract_collection___Iterator___is_ok_t)CALL(variable[5],COLOR_abstract_collection___Iterator___is_ok))(variable[5]) /*Iterator::is_ok*/; + if (!UNTAG_Bool(variable[6])) break; /*for*/ + variable[6] = ((abstract_collection___Iterator___item_t)CALL(variable[5],COLOR_abstract_collection___Iterator___item))(variable[5]) /*Iterator::item*/; + variable[7] = variable[6]; + variable[9] = variable[0]; + variable[9] = ((partial_order___PartialOrder___add_to_smallests_t)CALL(variable[9],COLOR_partial_order___PartialOrder___add_to_smallests))(variable[9], variable[7] /*e*/, variable[3] /*res*/, variable[4] /*tmp*/) /*PartialOrder::add_to_smallests*/; + variable[8] = variable[9]; + if (UNTAG_Bool( variable[8] /*r*/)) { /*if*/ + variable[9] = variable[4] /*tmp*/; + variable[4] = variable[3] /*res*/ /*tmp=*/; + variable[3] = variable[9] /*t*/ /*res=*/; } continue_15: while(0); - ((abstract_collection___Iterator___next_t)CALL(variable3,COLOR_abstract_collection___Iterator___next))(variable3) /*Iterator::next*/; + ((abstract_collection___Iterator___next_t)CALL(variable[5],COLOR_abstract_collection___Iterator___next))(variable[5]) /*Iterator::next*/; } break_15: while(0); - variable1 = variable1 /*res*/; + variable[2] = variable[3] /*res*/; goto return_label14; return_label14: while(false); tracehead = trace.prev; - return variable1; + return variable[2]; } val_t partial_order___PartialOrder___add(val_t self, val_t param0, val_t param1) { struct trace_t trace = {NULL, NULL, 122, LOCATE_partial_order___PartialOrder___add}; - val_t variable0; - val_t variable1; - val_t variable2; - val_t variable3; - val_t variable4; - val_t variable5; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = param1; - variable2 = ((partial_order___PartialOrder___has_t)CALL( self,COLOR_abstract_collection___Collection___has))( self, variable0 /*e*/) /*PartialOrder::has*/; - if (!UNTAG_Bool( TAG_Bool(!UNTAG_Bool(variable2)))) { fprintf(stderr, "Assert%s failed", ""); fprintf(stderr, " in %s (%s:%d)\n", LOCATE_partial_order___PartialOrder___add, LOCATE_partial_order, 125); nit_exit(1);} - variable2 = TAG_Bool(( variable1 /*supers*/ == NIT_NULL /*null*/) || (( variable1 /*supers*/ != NIT_NULL) && ((((kernel___Object_____eqeq_t)CALL( variable1 /*supers*/,COLOR_kernel___Object_____eqeq))==kernel___Object_____eqeq)?(IS_EQUAL_NN( variable1 /*supers*/, NIT_NULL /*null*/)):(UNTAG_Bool(((kernel___Object_____eqeq_t)CALL( variable1 /*supers*/,COLOR_kernel___Object_____eqeq))( variable1 /*supers*/, NIT_NULL /*null*/) /*Object::==*/))))); - variable3 = variable2; - if (!UNTAG_Bool(variable3)) { /* or */ - variable3 = ((partial_order___PartialOrder___has_all_t)CALL( self,COLOR_partial_order___PartialOrder___has_all))( self, variable1 /*supers*/) /*PartialOrder::has_all*/; + val_t variable[8]; + void **closurevariable = NULL; + trace.prev = tracehead; tracehead = &trace; + trace.file = LOCATE_partial_order; + variable[0] = self; + variable[1] = param0; + variable[2] = param1; + variable[4] = variable[0]; + variable[4] = ((partial_order___PartialOrder___has_t)CALL(variable[4],COLOR_abstract_collection___Collection___has))(variable[4], variable[1] /*e*/) /*PartialOrder::has*/; + if (!UNTAG_Bool( TAG_Bool(!UNTAG_Bool(variable[4])))) { fprintf(stderr, "Assert%s failed", ""); fprintf(stderr, " in %s (%s:%d)\n", LOCATE_partial_order___PartialOrder___add, LOCATE_partial_order, 125); nit_exit(1);} + variable[4] = TAG_Bool(( variable[2] /*supers*/ == NIT_NULL /*null*/) || (( variable[2] /*supers*/ != NIT_NULL) && ((((kernel___Object_____eqeq_t)CALL( variable[2] /*supers*/,COLOR_kernel___Object_____eqeq))==kernel___Object_____eqeq)?(IS_EQUAL_NN( variable[2] /*supers*/, NIT_NULL /*null*/)):(UNTAG_Bool(((kernel___Object_____eqeq_t)CALL( variable[2] /*supers*/,COLOR_kernel___Object_____eqeq))( variable[2] /*supers*/, NIT_NULL /*null*/) /*Object::==*/))))); + variable[5] = variable[4]; + if (!UNTAG_Bool(variable[5])) { /* or */ + variable[5] = variable[0]; + variable[5] = ((partial_order___PartialOrder___has_all_t)CALL(variable[5],COLOR_partial_order___PartialOrder___has_all))(variable[5], variable[2] /*supers*/) /*PartialOrder::has_all*/; } - variable2 = variable3; - if (!UNTAG_Bool(variable2)) { fprintf(stderr, "Assert%s failed", ""); fprintf(stderr, " in %s (%s:%d)\n", LOCATE_partial_order___PartialOrder___add, LOCATE_partial_order, 126); nit_exit(1);} - variable3 = ((partial_order___PartialOrder___select_smallests_t)CALL( self,COLOR_partial_order___PartialOrder___select_smallests))( self, variable1 /*supers*/) /*PartialOrder::select_smallests*/; - variable2 = variable3; - variable4 = ((partial_order___PartialOrder___new_poe_t)CALL( self,COLOR_partial_order___PartialOrder___new_poe))( self, variable0 /*e*/, variable2 /*directs*/) /*PartialOrder::new_poe*/; - variable3 = variable4; - variable4 = ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/; - ((abstract_collection___Map_____braeq_t)CALL(variable4,COLOR_abstract_collection___Map_____braeq))(variable4, variable0 /*e*/, variable3 /*poe*/) /*Map::[]=*/; - variable4 = ATTR_partial_order___PartialOrder____elements_list( self) /*PartialOrder::_elements_list*/; - ((array___AbstractArray___add_t)CALL(variable4,COLOR_abstract_collection___SimpleCollection___add))(variable4, variable0 /*e*/) /*AbstractArray::add*/; - variable4 = TAG_Bool(( variable1 /*supers*/ == NIT_NULL /*null*/) || (( variable1 /*supers*/ != NIT_NULL) && ((((kernel___Object_____eqeq_t)CALL( variable1 /*supers*/,COLOR_kernel___Object_____eqeq))==kernel___Object_____eqeq)?(IS_EQUAL_NN( variable1 /*supers*/, NIT_NULL /*null*/)):(UNTAG_Bool(((kernel___Object_____eqeq_t)CALL( variable1 /*supers*/,COLOR_kernel___Object_____eqeq))( variable1 /*supers*/, NIT_NULL /*null*/) /*Object::==*/))))); - variable5 = variable4; - if (!UNTAG_Bool(variable5)) { /* or */ - variable5 = ((abstract_collection___Collection___is_empty_t)CALL( variable1 /*supers*/,COLOR_abstract_collection___Collection___is_empty))( variable1 /*supers*/) /*Collection::is_empty*/; + variable[4] = variable[5]; + if (!UNTAG_Bool(variable[4])) { fprintf(stderr, "Assert%s failed", ""); fprintf(stderr, " in %s (%s:%d)\n", LOCATE_partial_order___PartialOrder___add, LOCATE_partial_order, 126); nit_exit(1);} + variable[5] = variable[0]; + variable[5] = ((partial_order___PartialOrder___select_smallests_t)CALL(variable[5],COLOR_partial_order___PartialOrder___select_smallests))(variable[5], variable[2] /*supers*/) /*PartialOrder::select_smallests*/; + variable[4] = variable[5]; + variable[6] = variable[0]; + variable[6] = ((partial_order___PartialOrder___new_poe_t)CALL(variable[6],COLOR_partial_order___PartialOrder___new_poe))(variable[6], variable[1] /*e*/, variable[4] /*directs*/) /*PartialOrder::new_poe*/; + variable[5] = variable[6]; + variable[6] = variable[0]; + variable[6] = ATTR_partial_order___PartialOrder____elements(variable[6]) /*PartialOrder::_elements*/; + ((abstract_collection___Map_____braeq_t)CALL(variable[6],COLOR_abstract_collection___Map_____braeq))(variable[6], variable[1] /*e*/, variable[5] /*poe*/) /*Map::[]=*/; + variable[6] = variable[0]; + variable[6] = ATTR_partial_order___PartialOrder____elements_list(variable[6]) /*PartialOrder::_elements_list*/; + ((array___AbstractArray___add_t)CALL(variable[6],COLOR_abstract_collection___SimpleCollection___add))(variable[6], variable[1] /*e*/) /*AbstractArray::add*/; + variable[6] = TAG_Bool(( variable[2] /*supers*/ == NIT_NULL /*null*/) || (( variable[2] /*supers*/ != NIT_NULL) && ((((kernel___Object_____eqeq_t)CALL( variable[2] /*supers*/,COLOR_kernel___Object_____eqeq))==kernel___Object_____eqeq)?(IS_EQUAL_NN( variable[2] /*supers*/, NIT_NULL /*null*/)):(UNTAG_Bool(((kernel___Object_____eqeq_t)CALL( variable[2] /*supers*/,COLOR_kernel___Object_____eqeq))( variable[2] /*supers*/, NIT_NULL /*null*/) /*Object::==*/))))); + variable[7] = variable[6]; + if (!UNTAG_Bool(variable[7])) { /* or */ + variable[7] = ((abstract_collection___Collection___is_empty_t)CALL( variable[2] /*supers*/,COLOR_abstract_collection___Collection___is_empty))( variable[2] /*supers*/) /*Collection::is_empty*/; } - variable4 = variable5; - if (UNTAG_Bool(variable4)) { /*if*/ - variable4 = ATTR_partial_order___PartialOrder____roots( self) /*PartialOrder::_roots*/; - ((array___AbstractArray___add_t)CALL(variable4,COLOR_abstract_collection___SimpleCollection___add))(variable4, variable0 /*e*/) /*AbstractArray::add*/; + variable[6] = variable[7]; + if (UNTAG_Bool(variable[6])) { /*if*/ + variable[6] = variable[0]; + variable[6] = ATTR_partial_order___PartialOrder____roots(variable[6]) /*PartialOrder::_roots*/; + ((array___AbstractArray___add_t)CALL(variable[6],COLOR_abstract_collection___SimpleCollection___add))(variable[6], variable[1] /*e*/) /*AbstractArray::add*/; } - variable2 = variable3 /*poe*/; + variable[3] = variable[5] /*poe*/; goto return_label16; return_label16: while(false); tracehead = trace.prev; - return variable2; + return variable[3]; } val_t partial_order___PartialOrder___has_all(val_t self, val_t param0) { struct trace_t trace = {NULL, NULL, 137, LOCATE_partial_order___PartialOrder___has_all}; - val_t variable0; - val_t variable1; - val_t variable2; - val_t variable3; + val_t variable[7]; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = ((abstract_collection___Collection___iterator_t)CALL( variable0 /*e*/,COLOR_abstract_collection___Collection___iterator))( variable0 /*e*/) /*Collection::iterator*/; + variable[0] = self; + variable[1] = param0; + variable[3] = ((abstract_collection___Collection___iterator_t)CALL( variable[1] /*e*/,COLOR_abstract_collection___Collection___iterator))( variable[1] /*e*/) /*Collection::iterator*/; while (true) { /*for*/ - variable2 = ((abstract_collection___Iterator___is_ok_t)CALL(variable1,COLOR_abstract_collection___Iterator___is_ok))(variable1) /*Iterator::is_ok*/; - if (!UNTAG_Bool(variable2)) break; /*for*/ - variable2 = ((abstract_collection___Iterator___item_t)CALL(variable1,COLOR_abstract_collection___Iterator___item))(variable1) /*Iterator::item*/; - variable3 = ((partial_order___PartialOrder___has_t)CALL( self,COLOR_abstract_collection___Collection___has))( self, variable2 /*i*/) /*PartialOrder::has*/; - if (UNTAG_Bool( TAG_Bool(!UNTAG_Bool(variable3)))) { /*if*/ - variable1 = TAG_Bool(false); + variable[4] = ((abstract_collection___Iterator___is_ok_t)CALL(variable[3],COLOR_abstract_collection___Iterator___is_ok))(variable[3]) /*Iterator::is_ok*/; + if (!UNTAG_Bool(variable[4])) break; /*for*/ + variable[4] = ((abstract_collection___Iterator___item_t)CALL(variable[3],COLOR_abstract_collection___Iterator___item))(variable[3]) /*Iterator::item*/; + variable[5] = variable[4]; + variable[6] = variable[0]; + variable[6] = ((partial_order___PartialOrder___has_t)CALL(variable[6],COLOR_abstract_collection___Collection___has))(variable[6], variable[5] /*i*/) /*PartialOrder::has*/; + if (UNTAG_Bool( TAG_Bool(!UNTAG_Bool(variable[6])))) { /*if*/ + variable[2] = TAG_Bool(false); goto return_label17; } continue_18: while(0); - ((abstract_collection___Iterator___next_t)CALL(variable1,COLOR_abstract_collection___Iterator___next))(variable1) /*Iterator::next*/; + ((abstract_collection___Iterator___next_t)CALL(variable[3],COLOR_abstract_collection___Iterator___next))(variable[3]) /*Iterator::next*/; } break_18: while(0); - variable1 = TAG_Bool(true); + variable[2] = TAG_Bool(true); goto return_label17; return_label17: while(false); tracehead = trace.prev; - return variable1; + return variable[2]; } val_t partial_order___PartialOrder___new_poe(val_t self, val_t param0, val_t param1) { struct trace_t trace = {NULL, NULL, 148, LOCATE_partial_order___PartialOrder___new_poe}; - val_t variable0; - val_t variable1; - val_t variable2; + val_t variable[6]; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = param1; - variable2 = NEW_PartialOrderElement_partial_order___PartialOrderElement___init( self, variable0 /*e*/, variable1 /*directs*/); /*new PartialOrderElement[E]*/ + variable[0] = self; + variable[1] = param0; + variable[2] = param1; + variable[4] = variable[0]; + variable[5] = NEW_PartialOrderElement_partial_order___PartialOrderElement___init(variable[4], variable[1] /*e*/, variable[2] /*directs*/); /*new PartialOrderElement[E]*/ + variable[4] = variable[5]; + variable[3] = variable[4]; goto return_label19; return_label19: while(false); tracehead = trace.prev; - return variable2; + return variable[3]; } val_t partial_order___PartialOrder___add_to_smallests(val_t self, val_t param0, val_t param1, val_t param2) { struct trace_t trace = {NULL, NULL, 154, LOCATE_partial_order___PartialOrder___add_to_smallests}; - val_t variable0; - val_t variable1; - val_t variable2; - val_t variable3; - val_t variable4; - val_t variable5; - val_t variable6; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = param1; - variable2 = param2; - ((array___AbstractArray___clear_t)CALL( variable2 /*to*/,COLOR_abstract_collection___RemovableCollection___clear))( variable2 /*to*/) /*AbstractArray::clear*/; - variable4 = ((partial_order___PartialOrder_____bra_t)CALL( self,COLOR_partial_order___PartialOrder_____bra))( self, variable0 /*e*/) /*PartialOrder::[]*/; - variable3 = variable4; - variable4 = ((array___AbstractArray___iterator_t)CALL( variable1 /*from*/,COLOR_abstract_collection___Collection___iterator))( variable1 /*from*/) /*AbstractArray::iterator*/; + val_t variable[10]; + void **closurevariable = NULL; + trace.prev = tracehead; tracehead = &trace; + trace.file = LOCATE_partial_order; + variable[0] = self; + variable[1] = param0; + variable[2] = param1; + variable[3] = param2; + ((array___AbstractArray___clear_t)CALL( variable[3] /*to*/,COLOR_abstract_collection___RemovableCollection___clear))( variable[3] /*to*/) /*AbstractArray::clear*/; + variable[6] = variable[0]; + variable[6] = ((partial_order___PartialOrder_____bra_t)CALL(variable[6],COLOR_partial_order___PartialOrder_____bra))(variable[6], variable[1] /*e*/) /*PartialOrder::[]*/; + variable[5] = variable[6]; + variable[6] = ((array___AbstractArray___iterator_t)CALL( variable[2] /*from*/,COLOR_abstract_collection___Collection___iterator))( variable[2] /*from*/) /*AbstractArray::iterator*/; while (true) { /*for*/ - variable5 = ((array___ArrayIterator___is_ok_t)CALL(variable4,COLOR_abstract_collection___Iterator___is_ok))(variable4) /*ArrayIterator::is_ok*/; - if (!UNTAG_Bool(variable5)) break; /*for*/ - variable5 = ((array___ArrayIterator___item_t)CALL(variable4,COLOR_abstract_collection___Iterator___item))(variable4) /*ArrayIterator::item*/; - variable6 = ((partial_order___PartialOrderElement_____g_t)CALL( variable3 /*poe*/,COLOR_partial_order___PartialOrderElement_____g))( variable3 /*poe*/, variable5 /*i*/) /*PartialOrderElement::>*/; - if (UNTAG_Bool(variable6)) { /*if*/ - variable3 = TAG_Bool(false); + variable[7] = ((array___ArrayIterator___is_ok_t)CALL(variable[6],COLOR_abstract_collection___Iterator___is_ok))(variable[6]) /*ArrayIterator::is_ok*/; + if (!UNTAG_Bool(variable[7])) break; /*for*/ + variable[7] = ((array___ArrayIterator___item_t)CALL(variable[6],COLOR_abstract_collection___Iterator___item))(variable[6]) /*ArrayIterator::item*/; + variable[8] = variable[7]; + variable[9] = ((partial_order___PartialOrderElement_____g_t)CALL( variable[5] /*poe*/,COLOR_partial_order___PartialOrderElement_____g))( variable[5] /*poe*/, variable[8] /*i*/) /*PartialOrderElement::>*/; + if (UNTAG_Bool(variable[9])) { /*if*/ + variable[4] = TAG_Bool(false); goto return_label20; } - variable6 = ((partial_order___PartialOrderElement_____l_t)CALL( variable3 /*poe*/,COLOR_partial_order___PartialOrderElement_____l))( variable3 /*poe*/, variable5 /*i*/) /*PartialOrderElement::<*/; - if (UNTAG_Bool( TAG_Bool(!UNTAG_Bool(variable6)))) { /*if*/ - ((array___AbstractArray___add_t)CALL( variable2 /*to*/,COLOR_abstract_collection___SimpleCollection___add))( variable2 /*to*/, variable5 /*i*/) /*AbstractArray::add*/; + variable[9] = ((partial_order___PartialOrderElement_____l_t)CALL( variable[5] /*poe*/,COLOR_partial_order___PartialOrderElement_____l))( variable[5] /*poe*/, variable[8] /*i*/) /*PartialOrderElement::<*/; + if (UNTAG_Bool( TAG_Bool(!UNTAG_Bool(variable[9])))) { /*if*/ + ((array___AbstractArray___add_t)CALL( variable[3] /*to*/,COLOR_abstract_collection___SimpleCollection___add))( variable[3] /*to*/, variable[8] /*i*/) /*AbstractArray::add*/; } continue_21: while(0); - ((array___ArrayIterator___next_t)CALL(variable4,COLOR_abstract_collection___Iterator___next))(variable4) /*ArrayIterator::next*/; + ((array___ArrayIterator___next_t)CALL(variable[6],COLOR_abstract_collection___Iterator___next))(variable[6]) /*ArrayIterator::next*/; } break_21: while(0); - ((array___AbstractArray___add_t)CALL( variable2 /*to*/,COLOR_abstract_collection___SimpleCollection___add))( variable2 /*to*/, variable0 /*e*/) /*AbstractArray::add*/; - variable3 = TAG_Bool(true); + ((array___AbstractArray___add_t)CALL( variable[3] /*to*/,COLOR_abstract_collection___SimpleCollection___add))( variable[3] /*to*/, variable[1] /*e*/) /*AbstractArray::add*/; + variable[4] = TAG_Bool(true); goto return_label20; return_label20: while(false); tracehead = trace.prev; - return variable3; + return variable[4]; } void partial_order___PartialOrder___compute_smallers_for(val_t self, val_t param0, val_t param1) { struct trace_t trace = {NULL, NULL, 175, LOCATE_partial_order___PartialOrder___compute_smallers_for}; - val_t variable0; - val_t variable1; - val_t variable2; - val_t variable3; - val_t variable4; - val_t variable5; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - variable0 = param0; - variable1 = param1; - variable3 = ((partial_order___PartialOrderElement___value_t)CALL( variable0 /*poe*/,COLOR_partial_order___PartialOrderElement___value))( variable0 /*poe*/) /*PartialOrderElement::value*/; - variable2 = variable3; - variable3 = ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/; - variable3 = ((abstract_collection___Map___iterator_t)CALL(variable3,COLOR_abstract_collection___Collection___iterator))(variable3) /*Map::iterator*/; + val_t variable[9]; + void **closurevariable = NULL; + trace.prev = tracehead; tracehead = &trace; + trace.file = LOCATE_partial_order; + variable[0] = self; + variable[1] = param0; + variable[2] = param1; + variable[5] = ((partial_order___PartialOrderElement___value_t)CALL( variable[1] /*poe*/,COLOR_partial_order___PartialOrderElement___value))( variable[1] /*poe*/) /*PartialOrderElement::value*/; + variable[4] = variable[5]; + variable[5] = variable[0]; + variable[5] = ATTR_partial_order___PartialOrder____elements(variable[5]) /*PartialOrder::_elements*/; + variable[5] = ((abstract_collection___Map___iterator_t)CALL(variable[5],COLOR_abstract_collection___Collection___iterator))(variable[5]) /*Map::iterator*/; while (true) { /*for*/ - variable4 = ((abstract_collection___Iterator___is_ok_t)CALL(variable3,COLOR_abstract_collection___Iterator___is_ok))(variable3) /*Iterator::is_ok*/; - if (!UNTAG_Bool(variable4)) break; /*for*/ - variable4 = ((abstract_collection___Iterator___item_t)CALL(variable3,COLOR_abstract_collection___Iterator___item))(variable3) /*Iterator::item*/; - variable5 = ((partial_order___PartialOrderElement_____l_t)CALL( variable4 /*s*/,COLOR_partial_order___PartialOrderElement_____l))( variable4 /*s*/, variable2 /*e*/) /*PartialOrderElement::<*/; - if (UNTAG_Bool(variable5)) { /*if*/ - variable5 = ((partial_order___PartialOrderElement___value_t)CALL( variable4 /*s*/,COLOR_partial_order___PartialOrderElement___value))( variable4 /*s*/) /*PartialOrderElement::value*/; - ((abstract_collection___SimpleCollection___add_t)CALL( variable1 /*set*/,COLOR_abstract_collection___SimpleCollection___add))( variable1 /*set*/, variable5) /*SimpleCollection::add*/; + variable[6] = ((abstract_collection___Iterator___is_ok_t)CALL(variable[5],COLOR_abstract_collection___Iterator___is_ok))(variable[5]) /*Iterator::is_ok*/; + if (!UNTAG_Bool(variable[6])) break; /*for*/ + variable[6] = ((abstract_collection___Iterator___item_t)CALL(variable[5],COLOR_abstract_collection___Iterator___item))(variable[5]) /*Iterator::item*/; + variable[7] = variable[6]; + variable[8] = ((partial_order___PartialOrderElement_____l_t)CALL( variable[7] /*s*/,COLOR_partial_order___PartialOrderElement_____l))( variable[7] /*s*/, variable[4] /*e*/) /*PartialOrderElement::<*/; + if (UNTAG_Bool(variable[8])) { /*if*/ + variable[8] = ((partial_order___PartialOrderElement___value_t)CALL( variable[7] /*s*/,COLOR_partial_order___PartialOrderElement___value))( variable[7] /*s*/) /*PartialOrderElement::value*/; + ((abstract_collection___SimpleCollection___add_t)CALL( variable[2] /*set*/,COLOR_abstract_collection___SimpleCollection___add))( variable[2] /*set*/, variable[8]) /*SimpleCollection::add*/; } continue_23: while(0); - ((abstract_collection___Iterator___next_t)CALL(variable3,COLOR_abstract_collection___Iterator___next))(variable3) /*Iterator::next*/; + ((abstract_collection___Iterator___next_t)CALL(variable[5],COLOR_abstract_collection___Iterator___next))(variable[5]) /*Iterator::next*/; } break_23: while(0); + return_label22: while(false); tracehead = trace.prev; return; } void partial_order___PartialOrder___init(val_t self, int* init_table) { struct trace_t trace = {NULL, NULL, 185, LOCATE_partial_order___PartialOrder___init}; - val_t variable0; + val_t variable[4]; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; + variable[0] = self; if (init_table[VAL2OBJ( self)->vft[INIT_TABLE_POS_PartialOrder].i]) return; - variable0 = NEW_HashMap_hash___HashMap___init(); /*new HashMap[E, PartialOrderElement[E]]*/ - ATTR_partial_order___PartialOrder____elements( self) /*PartialOrder::_elements*/ = variable0; - variable0 = NEW_Array_array___Array___init(); /*new Array[E]*/ - ATTR_partial_order___PartialOrder____elements_list( self) /*PartialOrder::_elements_list*/ = variable0; - variable0 = NEW_Array_array___Array___init(); /*new Array[E]*/ - ATTR_partial_order___PartialOrder____roots( self) /*PartialOrder::_roots*/ = variable0; + variable[2] = variable[0]; + variable[3] = NEW_HashMap_hash___HashMap___init(); /*new HashMap[E, PartialOrderElement[E]]*/ + ATTR_partial_order___PartialOrder____elements(variable[2]) /*PartialOrder::_elements*/ = variable[3]; + variable[2] = variable[0]; + variable[3] = NEW_Array_array___Array___init(); /*new Array[E]*/ + ATTR_partial_order___PartialOrder____elements_list(variable[2]) /*PartialOrder::_elements_list*/ = variable[3]; + variable[2] = variable[0]; + variable[3] = NEW_Array_array___Array___init(); /*new Array[E]*/ + ATTR_partial_order___PartialOrder____roots(variable[2]) /*PartialOrder::_roots*/ = variable[3]; + return_label24: while(false); init_table[VAL2OBJ( self)->vft[INIT_TABLE_POS_PartialOrder].i] = 1; tracehead = trace.prev; return; } val_t partial_order___PartialOrderElement___order(val_t self) { struct trace_t trace = {NULL, NULL, 194, LOCATE_partial_order___PartialOrderElement___order}; + val_t *variable = NULL; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; tracehead = trace.prev; @@ -493,6 +533,8 @@ val_t partial_order___PartialOrderElement___order(val_t self) { } val_t partial_order___PartialOrderElement___value(val_t self) { struct trace_t trace = {NULL, NULL, 197, LOCATE_partial_order___PartialOrderElement___value}; + val_t *variable = NULL; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; tracehead = trace.prev; @@ -500,6 +542,8 @@ val_t partial_order___PartialOrderElement___value(val_t self) { } val_t partial_order___PartialOrderElement___rank(val_t self) { struct trace_t trace = {NULL, NULL, 200, LOCATE_partial_order___PartialOrderElement___rank}; + val_t *variable = NULL; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; tracehead = trace.prev; @@ -507,6 +551,8 @@ val_t partial_order___PartialOrderElement___rank(val_t self) { } val_t partial_order___PartialOrderElement___direct_greaters(val_t self) { struct trace_t trace = {NULL, NULL, 206, LOCATE_partial_order___PartialOrderElement___direct_greaters}; + val_t *variable = NULL; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; tracehead = trace.prev; @@ -514,6 +560,8 @@ val_t partial_order___PartialOrderElement___direct_greaters(val_t self) { } val_t partial_order___PartialOrderElement___direct_smallers(val_t self) { struct trace_t trace = {NULL, NULL, 209, LOCATE_partial_order___PartialOrderElement___direct_smallers}; + val_t *variable = NULL; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; tracehead = trace.prev; @@ -521,6 +569,8 @@ val_t partial_order___PartialOrderElement___direct_smallers(val_t self) { } val_t partial_order___PartialOrderElement___greaters(val_t self) { struct trace_t trace = {NULL, NULL, 212, LOCATE_partial_order___PartialOrderElement___greaters}; + val_t *variable = NULL; + void **closurevariable = NULL; trace.prev = tracehead; tracehead = &trace; trace.file = LOCATE_partial_order; tracehead = trace.prev; @@ -528,302 +578,350 @@ val_t partial_order___PartialOrderElement___greaters(val_t self) { } val_t partial_order___PartialOrderElement___greaters_and_self(val_t self) { struct trace_t trace = {NULL, NULL, 218, LOCATE_partial_order___PartialOrderElement___greaters_and_self}; - val_t variable0; - val_t variable1; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - variable0 = ATTR_partial_order___PartialOrderElement____greaters_and_self_cache( self) /*PartialOrderElement::_greaters_and_self_cache*/; - variable0 = TAG_Bool((variable0 == NIT_NULL /*null*/) || ((variable0 != NIT_NULL) && UNTAG_Bool(((array___AbstractArray_____eqeq_t)CALL(variable0,COLOR_kernel___Object_____eqeq))(variable0, NIT_NULL /*null*/) /*AbstractArray::==*/))); - if (UNTAG_Bool(variable0)) { /*if*/ - variable0 = ATTR_partial_order___PartialOrderElement____greaters( self) /*PartialOrderElement::_greaters*/; - variable0 = ((array___Collection___to_a_t)CALL(variable0,COLOR_array___Collection___to_a))(variable0) /*Collection::to_a*/; - ATTR_partial_order___PartialOrderElement____greaters_and_self_cache( self) /*PartialOrderElement::_greaters_and_self_cache*/ = variable0; - variable0 = ATTR_partial_order___PartialOrderElement____greaters_and_self_cache( self) /*PartialOrderElement::_greaters_and_self_cache*/; - variable1 = ATTR_partial_order___PartialOrderElement____value( self) /*PartialOrderElement::_value*/; - ((array___AbstractArray___add_t)CALL(variable0,COLOR_abstract_collection___SimpleCollection___add))(variable0, variable1) /*AbstractArray::add*/; + val_t variable[4]; + void **closurevariable = NULL; + trace.prev = tracehead; tracehead = &trace; + trace.file = LOCATE_partial_order; + variable[0] = self; + variable[2] = variable[0]; + variable[2] = ATTR_partial_order___PartialOrderElement____greaters_and_self_cache(variable[2]) /*PartialOrderElement::_greaters_and_self_cache*/; + variable[2] = TAG_Bool((variable[2] == NIT_NULL /*null*/) || ((variable[2] != NIT_NULL) && UNTAG_Bool(((array___AbstractArray_____eqeq_t)CALL(variable[2],COLOR_kernel___Object_____eqeq))(variable[2], NIT_NULL /*null*/) /*AbstractArray::==*/))); + if (UNTAG_Bool(variable[2])) { /*if*/ + variable[2] = variable[0]; + variable[3] = variable[0]; + variable[3] = ATTR_partial_order___PartialOrderElement____greaters(variable[3]) /*PartialOrderElement::_greaters*/; + variable[3] = ((array___Collection___to_a_t)CALL(variable[3],COLOR_array___Collection___to_a))(variable[3]) /*Collection::to_a*/; + ATTR_partial_order___PartialOrderElement____greaters_and_self_cache(variable[2]) /*PartialOrderElement::_greaters_and_self_cache*/ = variable[3]; + variable[2] = variable[0]; + variable[2] = ATTR_partial_order___PartialOrderElement____greaters_and_self_cache(variable[2]) /*PartialOrderElement::_greaters_and_self_cache*/; + variable[3] = variable[0]; + variable[3] = ATTR_partial_order___PartialOrderElement____value(variable[3]) /*PartialOrderElement::_value*/; + ((array___AbstractArray___add_t)CALL(variable[2],COLOR_abstract_collection___SimpleCollection___add))(variable[2], variable[3]) /*AbstractArray::add*/; } - variable0 = ATTR_partial_order___PartialOrderElement____greaters_and_self_cache( self) /*PartialOrderElement::_greaters_and_self_cache*/; + variable[2] = variable[0]; + variable[2] = ATTR_partial_order___PartialOrderElement____greaters_and_self_cache(variable[2]) /*PartialOrderElement::_greaters_and_self_cache*/; + variable[1] = variable[2]; goto return_label25; return_label25: while(false); tracehead = trace.prev; - return variable0; + return variable[1]; } val_t partial_order___PartialOrderElement___smallers(val_t self) { struct trace_t trace = {NULL, NULL, 234, LOCATE_partial_order___PartialOrderElement___smallers}; - val_t variable0; - val_t variable1; - trace.prev = tracehead; tracehead = &trace; - trace.file = LOCATE_partial_order; - variable0 = ATTR_partial_order___PartialOrderElement____smallers_last_length( self) /*PartialOrderElement::_smallers_last_length*/; - variable1 = ATTR_partial_order___PartialOrderElement____order( self) /*PartialOrderElement::_order*/; - variable1 = ((partial_order___PartialOrder___length_t)CALL(variable1,COLOR_abstract_collection___Collection___length))(variable1) /*PartialOrder::length*/; - variable0 = TAG_Bool(UNTAG_Int(variable0)vft[INIT_TABLE_POS_PartialOrderElement].i]) return; - ATTR_partial_order___PartialOrderElement____order( self) /*PartialOrderElement::_order*/ = variable0 /*o*/; - ATTR_partial_order___PartialOrderElement____value( self) /*PartialOrderElement::_value*/ = variable1 /*e*/; - ATTR_partial_order___PartialOrderElement____direct_greaters( self) /*PartialOrderElement::_direct_greaters*/ = variable2 /*directs*/; - variable3 = NEW_Array_array___Array___init(); /*new Array[E]*/ - ATTR_partial_order___PartialOrderElement____direct_smallers( self) /*PartialOrderElement::_direct_smallers*/ = variable3; - variable3 = NEW_HashSet_hash___HashSet___init(); /*new HashSet[E]*/ - ATTR_partial_order___PartialOrderElement____greaters( self) /*PartialOrderElement::_greaters*/ = variable3; - variable3 = NEW_HashSet_hash___HashSet___init(); /*new HashSet[E]*/ - ATTR_partial_order___PartialOrderElement____smallers_cache( self) /*PartialOrderElement::_smallers_cache*/ = variable3; - variable4 = ATTR_partial_order___PartialOrderElement____greaters( self) /*PartialOrderElement::_greaters*/; - variable3 = variable4; - variable4 = TAG_Int(0); - variable5 = ((array___AbstractArray___iterator_t)CALL( variable2 /*directs*/,COLOR_abstract_collection___Collection___iterator))( variable2 /*directs*/) /*AbstractArray::iterator*/; + variable[5] = variable[0]; + ATTR_partial_order___PartialOrderElement____order(variable[5]) /*PartialOrderElement::_order*/ = variable[1] /*o*/; + variable[5] = variable[0]; + ATTR_partial_order___PartialOrderElement____value(variable[5]) /*PartialOrderElement::_value*/ = variable[2] /*e*/; + variable[5] = variable[0]; + ATTR_partial_order___PartialOrderElement____direct_greaters(variable[5]) /*PartialOrderElement::_direct_greaters*/ = variable[3] /*directs*/; + variable[5] = variable[0]; + variable[6] = NEW_Array_array___Array___init(); /*new Array[E]*/ + ATTR_partial_order___PartialOrderElement____direct_smallers(variable[5]) /*PartialOrderElement::_direct_smallers*/ = variable[6]; + variable[5] = variable[0]; + variable[6] = NEW_HashSet_hash___HashSet___init(); /*new HashSet[E]*/ + ATTR_partial_order___PartialOrderElement____greaters(variable[5]) /*PartialOrderElement::_greaters*/ = variable[6]; + variable[5] = variable[0]; + variable[6] = NEW_HashSet_hash___HashSet___init(); /*new HashSet[E]*/ + ATTR_partial_order___PartialOrderElement____smallers_cache(variable[5]) /*PartialOrderElement::_smallers_cache*/ = variable[6]; + variable[6] = variable[0]; + variable[6] = ATTR_partial_order___PartialOrderElement____greaters(variable[6]) /*PartialOrderElement::_greaters*/; + variable[5] = variable[6]; + variable[6] = TAG_Int(0); + variable[7] = ((array___AbstractArray___iterator_t)CALL( variable[3] /*directs*/,COLOR_abstract_collection___Collection___iterator))( variable[3] /*directs*/) /*AbstractArray::iterator*/; while (true) { /*for*/ - variable6 = ((array___ArrayIterator___is_ok_t)CALL(variable5,COLOR_abstract_collection___Iterator___is_ok))(variable5) /*ArrayIterator::is_ok*/; - if (!UNTAG_Bool(variable6)) break; /*for*/ - variable6 = ((array___ArrayIterator___item_t)CALL(variable5,COLOR_abstract_collection___Iterator___item))(variable5) /*ArrayIterator::item*/; - ((abstract_collection___SimpleCollection___add_t)CALL( variable3 /*g*/,COLOR_abstract_collection___SimpleCollection___add))( variable3 /*g*/, variable6 /*ee*/) /*SimpleCollection::add*/; - variable8 = ATTR_partial_order___PartialOrderElement____order( self) /*PartialOrderElement::_order*/; - variable8 = ((partial_order___PartialOrder_____bra_t)CALL(variable8,COLOR_partial_order___PartialOrder_____bra))(variable8, variable6 /*ee*/) /*PartialOrder::[]*/; - variable7 = variable8; - variable8 = ((partial_order___PartialOrderElement___rank_t)CALL( variable7 /*poee*/,COLOR_partial_order___PartialOrderElement___rank))( variable7 /*poee*/) /*PartialOrderElement::rank*/; - variable8 = TAG_Bool(UNTAG_Int(variable8)>=UNTAG_Int( variable4 /*r*/)); - if (UNTAG_Bool(variable8)) { /*if*/ - variable8 = ((partial_order___PartialOrderElement___rank_t)CALL( variable7 /*poee*/,COLOR_partial_order___PartialOrderElement___rank))( variable7 /*poee*/) /*PartialOrderElement::rank*/; - variable8 = TAG_Int(UNTAG_Int(variable8)+UNTAG_Int( TAG_Int(1))); - variable4 = variable8 /*r=*/; + variable[8] = ((array___ArrayIterator___is_ok_t)CALL(variable[7],COLOR_abstract_collection___Iterator___is_ok))(variable[7]) /*ArrayIterator::is_ok*/; + if (!UNTAG_Bool(variable[8])) break; /*for*/ + variable[8] = ((array___ArrayIterator___item_t)CALL(variable[7],COLOR_abstract_collection___Iterator___item))(variable[7]) /*ArrayIterator::item*/; + variable[9] = variable[8]; + ((abstract_collection___SimpleCollection___add_t)CALL( variable[5] /*g*/,COLOR_abstract_collection___SimpleCollection___add))( variable[5] /*g*/, variable[9] /*ee*/) /*SimpleCollection::add*/; + variable[11] = variable[0]; + variable[11] = ATTR_partial_order___PartialOrderElement____order(variable[11]) /*PartialOrderElement::_order*/; + variable[11] = ((partial_order___PartialOrder_____bra_t)CALL(variable[11],COLOR_partial_order___PartialOrder_____bra))(variable[11], variable[9] /*ee*/) /*PartialOrder::[]*/; + variable[10] = variable[11]; + variable[11] = ((partial_order___PartialOrderElement___rank_t)CALL( variable[10] /*poee*/,COLOR_partial_order___PartialOrderElement___rank))( variable[10] /*poee*/) /*PartialOrderElement::rank*/; + variable[11] = TAG_Bool(UNTAG_Int(variable[11])>=UNTAG_Int( variable[6] /*r*/)); + if (UNTAG_Bool(variable[11])) { /*if*/ + variable[11] = ((partial_order___PartialOrderElement___rank_t)CALL( variable[10] /*poee*/,COLOR_partial_order___PartialOrderElement___rank))( variable[10] /*poee*/) /*PartialOrderElement::rank*/; + variable[11] = TAG_Int(UNTAG_Int(variable[11])+UNTAG_Int( TAG_Int(1))); + variable[6] = variable[11] /*r=*/; } - ((partial_order___PartialOrderElement___register_direct_smallers_t)CALL( variable7 /*poee*/,COLOR_partial_order___PartialOrderElement___register_direct_smallers))( variable7 /*poee*/, variable1 /*e*/) /*PartialOrderElement::register_direct_smallers*/; - variable8 = ((partial_order___PartialOrderElement___greaters_t)CALL( variable7 /*poee*/,COLOR_partial_order___PartialOrderElement___greaters))( variable7 /*poee*/) /*PartialOrderElement::greaters*/; - variable8 = ((abstract_collection___Collection___iterator_t)CALL(variable8,COLOR_abstract_collection___Collection___iterator))(variable8) /*Collection::iterator*/; + ((partial_order___PartialOrderElement___register_direct_smallers_t)CALL( variable[10] /*poee*/,COLOR_partial_order___PartialOrderElement___register_direct_smallers))( variable[10] /*poee*/, variable[2] /*e*/) /*PartialOrderElement::register_direct_smallers*/; + variable[11] = ((partial_order___PartialOrderElement___greaters_t)CALL( variable[10] /*poee*/,COLOR_partial_order___PartialOrderElement___greaters))( variable[10] /*poee*/) /*PartialOrderElement::greaters*/; + variable[11] = ((abstract_collection___Collection___iterator_t)CALL(variable[11],COLOR_abstract_collection___Collection___iterator))(variable[11]) /*Collection::iterator*/; while (true) { /*for*/ - variable9 = ((abstract_collection___Iterator___is_ok_t)CALL(variable8,COLOR_abstract_collection___Iterator___is_ok))(variable8) /*Iterator::is_ok*/; - if (!UNTAG_Bool(variable9)) break; /*for*/ - variable9 = ((abstract_collection___Iterator___item_t)CALL(variable8,COLOR_abstract_collection___Iterator___item))(variable8) /*Iterator::item*/; - ((abstract_collection___SimpleCollection___add_t)CALL( variable3 /*g*/,COLOR_abstract_collection___SimpleCollection___add))( variable3 /*g*/, variable9 /*eee*/) /*SimpleCollection::add*/; + variable[12] = ((abstract_collection___Iterator___is_ok_t)CALL(variable[11],COLOR_abstract_collection___Iterator___is_ok))(variable[11]) /*Iterator::is_ok*/; + if (!UNTAG_Bool(variable[12])) break; /*for*/ + variable[12] = ((abstract_collection___Iterator___item_t)CALL(variable[11],COLOR_abstract_collection___Iterator___item))(variable[11]) /*Iterator::item*/; + variable[13] = variable[12]; + ((abstract_collection___SimpleCollection___add_t)CALL( variable[5] /*g*/,COLOR_abstract_collection___SimpleCollection___add))( variable[5] /*g*/, variable[13] /*eee*/) /*SimpleCollection::add*/; continue_39: while(0); - ((abstract_collection___Iterator___next_t)CALL(variable8,COLOR_abstract_collection___Iterator___next))(variable8) /*Iterator::next*/; + ((abstract_collection___Iterator___next_t)CALL(variable[11],COLOR_abstract_collection___Iterator___next))(variable[11]) /*Iterator::next*/; } break_39: while(0); continue_38: while(0); - ((array___ArrayIterator___next_t)CALL(variable5,COLOR_abstract_collection___Iterator___next))(variable5) /*ArrayIterator::next*/; + ((array___ArrayIterator___next_t)CALL(variable[7],COLOR_abstract_collection___Iterator___next))(variable[7]) /*ArrayIterator::next*/; } break_38: while(0); - ATTR_partial_order___PartialOrderElement____rank( self) /*PartialOrderElement::_rank*/ = variable4 /*r*/; + variable[7] = variable[0]; + ATTR_partial_order___PartialOrderElement____rank(variable[7]) /*PartialOrderElement::_rank*/ = variable[6] /*r*/; + return_label37: while(false); init_table[VAL2OBJ( self)->vft[INIT_TABLE_POS_PartialOrderElement].i] = 1; tracehead = trace.prev; return;