X-Git-Url: http://deadsoftware.ru/gitweb?p=dsw-obn.git;a=blobdiff_plain;f=src%2Foberon.c;h=1b7f5d9b19315aa614ef96e1665f21c11054da9b;hp=83f39cd2cebea39ac30fd54f1125ba11151bb045;hb=afdfb61e64fb9c7d05a7612812739aa0d9a560fc;hpb=f4a67f6ba1dc6b2780e1cda553a1411469bf8b33 diff --git a/src/oberon.c b/src/oberon.c index 83f39cd..1b7f5d9 100644 --- a/src/oberon.c +++ b/src/oberon.c @@ -1088,6 +1088,12 @@ oberon_cast_expr(oberon_context_t * ctx, oberon_expr_t * expr, oberon_type_t * p cast = oberon_new_item(MODE_CHAR, ctx -> char_type, true); cast -> item.integer = expr -> item.string[0]; } + else if(oberon_is_record_type(pref) || oberon_is_pointer_to_record(pref)) + { + assert(expr -> is_item); + cast = oberon_new_item(MODE_AS, pref, expr -> read_only); + cast -> item.parent = (oberon_item_t *) expr; + } else if(!oberon_is_some_types(expr -> result, pref)) { cast = oberon_new_operator(OP_CAST, pref, expr, NULL); @@ -3940,7 +3946,6 @@ oberon_make_inc_call(oberon_context_t * ctx, int num_args, oberon_expr_t * list_ { step = list_args -> next; oberon_check_src(ctx, step); - oberon_check_const(ctx, step); if(!oberon_is_integer_type(step -> result)) { oberon_error(ctx, "expect integer"); @@ -4055,7 +4060,6 @@ oberon_make_dec_call(oberon_context_t * ctx, int num_args, oberon_expr_t * list_ { step = list_args -> next; oberon_check_src(ctx, step); - oberon_check_const(ctx, step); if(!oberon_is_integer_type(step -> result)) { oberon_error(ctx, "expect integer");