-val_t symbol___String___to_symbol(val_t self) {
- struct trace_t trace = {NULL, "symbol::String::to_symbol (bin/../lib/standard//symbol.nit:20,2--29:16)"};
- val_t variable0;
- val_t variable1;
- static val_t once_value_variable1_1; static int once_bool_variable1_1;
- val_t variable2;
- trace.prev = tracehead; tracehead = &trace;
- if (once_bool_variable1_1) variable1 = once_value_variable1_1;
- else {
- variable1 = NEW_hash___HashMap___init(); /*new HashMap[String, Symbol]*/
- once_value_variable1_1 = variable1;
- once_bool_variable1_1 = true;
+val_t symbol___String___to_symbol(val_t p0){
+ struct {struct stack_frame_t me; val_t MORE_REG[3];} fra;
+ val_t REGB0;
+ val_t tmp;
+ static val_t once_value_1; /* Once value */
+ fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+ fra.me.file = LOCATE_symbol;
+ fra.me.line = 20;
+ fra.me.meth = LOCATE_symbol___String___to_symbol;
+ fra.me.has_broke = 0;
+ fra.me.REG_size = 4;
+ fra.me.REG[0] = NIT_NULL;
+ fra.me.REG[1] = NIT_NULL;
+ fra.me.REG[2] = NIT_NULL;
+ fra.me.REG[3] = NIT_NULL;
+ fra.me.REG[0] = p0;
+ /* ./../lib/standard//symbol.nit:23 */
+ if (!once_value_1) {
+ fra.me.REG[1] = NEW_HashMap_hash_collection___HashMap___init();
+ once_value_1 = fra.me.REG[1];
+ register_static_object(&once_value_1);
+ } else fra.me.REG[1] = once_value_1;
+ REGB0 = CALL_abstract_collection___MapRead___has_key(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[0]);
+ /* ./../lib/standard//symbol.nit:24 */
+ if (UNTAG_Bool(REGB0)) {
+ fra.me.REG[2] = CALL_abstract_collection___MapRead_____bra(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[0]);
+ /* ./../lib/standard//symbol.nit:25 */
+ goto label2;
+ } else {
+ fra.me.REG[3] = NEW_Symbol_symbol___Symbol___init(fra.me.REG[0]);
+ /* ./../lib/standard//symbol.nit:28 */
+ CALL_abstract_collection___Map_____braeq(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[0], fra.me.REG[3]);
+ fra.me.REG[2] = fra.me.REG[3];
+ /* ./../lib/standard//symbol.nit:29 */
+ goto label2;