diff options
author | janus <janus@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-11-09 10:39:46 +0000 |
---|---|---|
committer | janus <janus@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-11-09 10:39:46 +0000 |
commit | 607ae6891efda4e9705b24d25f9cd07d467447dd (patch) | |
tree | 14d1f54316ef0bc517c72a674952cb7d233fd288 /gcc/fortran/trans-intrinsic.c | |
parent | 8838b9d46cc7e0820f0bd390886b5b8bae38d51b (diff) | |
download | gcc-607ae6891efda4e9705b24d25f9cd07d467447dd.tar.gz |
2010-11-09 Janus Weil <janus@gcc.gnu.org>
PR fortran/46313
* gfortran.h (gfc_add_data_component,gfc_add_vptr_component,
gfc_add_hash_component,gfc_add_size_component,
gfc_add_def_init_component): New macros.
* class.c (gfc_add_component_ref): Renamed data component.
(get_unique_type_string): New function.
(gfc_build_class_symbol): Use 'get_unique_type_string' to construct
uniques names for the class containers. Rename components.
(gfc_find_derived_vtab): Use 'get_unique_type_string' to construct
uniques names for the vtab symbols. Rename components.
* decl.c (attr_decl1): Renamed class container components.
* iresolve.c (gfc_resolve_extends_type_of): Ditto.
* match.c (select_type_set_tmp): Renamed temporaries.
* module.c (read_module): Renamed vtab and vtype symbols.
* resolve.c (resolve_structure_cons,resolve_typebound_function,
resolve_typebound_subroutine,resolve_deallocate_expr,
resolve_select_type,resolve_fl_derived): Renamed class container and
vtab components.
* trans-array.c (structure_alloc_comps): Ditto.
* trans-decl.c (gfc_trans_deferred_vars): Ditto.
* trans-expr.c (gfc_conv_derived_to_class,gfc_conv_structure,
gfc_trans_class_init_assign,gfc_trans_class_assign): Ditto.
* trans-intrinsic.c (gfc_conv_intrinsic_sizeof,
gfc_conv_intrinsic_storage_size,gfc_conv_allocated,gfc_conv_associated,
gfc_conv_same_type_as): Ditto.
* trans-stmt.c (gfc_trans_allocate): Ditto.
2010-11-09 Janus Weil <janus@gcc.gnu.org>
PR fortran/46313
* gfortran.dg/class_29.f03: New.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@166480 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/fortran/trans-intrinsic.c')
-rw-r--r-- | gcc/fortran/trans-intrinsic.c | 20 |
1 files changed, 10 insertions, 10 deletions
diff --git a/gcc/fortran/trans-intrinsic.c b/gcc/fortran/trans-intrinsic.c index 5a0a43ee033..502a8153d5d 100644 --- a/gcc/fortran/trans-intrinsic.c +++ b/gcc/fortran/trans-intrinsic.c @@ -4547,7 +4547,7 @@ gfc_conv_intrinsic_sizeof (gfc_se *se, gfc_expr *expr) if (ss == gfc_ss_terminator) { if (arg->ts.type == BT_CLASS) - gfc_add_component_ref (arg, "$data"); + gfc_add_data_component (arg); gfc_conv_expr_reference (&argse, arg); @@ -4618,8 +4618,8 @@ gfc_conv_intrinsic_storage_size (gfc_se *se, gfc_expr *expr) { if (arg->ts.type == BT_CLASS) { - gfc_add_component_ref (arg, "$vptr"); - gfc_add_component_ref (arg, "$size"); + gfc_add_vptr_component (arg); + gfc_add_size_component (arg); gfc_conv_expr (&argse, arg); tmp = fold_convert (result_type, argse.expr); goto done; @@ -5070,7 +5070,7 @@ gfc_conv_allocated (gfc_se *se, gfc_expr *expr) /* Allocatable scalar. */ arg1se.want_pointer = 1; if (arg1->expr->ts.type == BT_CLASS) - gfc_add_component_ref (arg1->expr, "$data"); + gfc_add_data_component (arg1->expr); gfc_conv_expr (&arg1se, arg1->expr); tmp = arg1se.expr; } @@ -5111,7 +5111,7 @@ gfc_conv_associated (gfc_se *se, gfc_expr *expr) gfc_init_se (&arg2se, NULL); arg1 = expr->value.function.actual; if (arg1->expr->ts.type == BT_CLASS) - gfc_add_component_ref (arg1->expr, "$data"); + gfc_add_data_component (arg1->expr); arg2 = arg1->next; ss1 = gfc_walk_expr (arg1->expr); @@ -5141,7 +5141,7 @@ gfc_conv_associated (gfc_se *se, gfc_expr *expr) { /* An optional target. */ if (arg2->expr->ts.type == BT_CLASS) - gfc_add_component_ref (arg2->expr, "$data"); + gfc_add_data_component (arg2->expr); ss2 = gfc_walk_expr (arg2->expr); nonzero_charlen = NULL_TREE; @@ -5228,8 +5228,8 @@ gfc_conv_same_type_as (gfc_se *se, gfc_expr *expr) if (a->ts.type == BT_CLASS) { - gfc_add_component_ref (a, "$vptr"); - gfc_add_component_ref (a, "$hash"); + gfc_add_vptr_component (a); + gfc_add_hash_component (a); } else if (a->ts.type == BT_DERIVED) a = gfc_get_int_expr (gfc_default_integer_kind, NULL, @@ -5237,8 +5237,8 @@ gfc_conv_same_type_as (gfc_se *se, gfc_expr *expr) if (b->ts.type == BT_CLASS) { - gfc_add_component_ref (b, "$vptr"); - gfc_add_component_ref (b, "$hash"); + gfc_add_vptr_component (b); + gfc_add_hash_component (b); } else if (b->ts.type == BT_DERIVED) b = gfc_get_int_expr (gfc_default_integer_kind, NULL, |