------- Additional Comments From cvs-commit at gcc dot gnu dot org  2005-09-09 
06:01 -------
Subject: Bug 12840

CVSROOT:        /cvs/gcc
Module name:    gcc
Changes by:     [EMAIL PROTECTED]       2005-09-09 06:00:41

Modified files:
        gcc/fortran    : ChangeLog trans.h trans-decl.c trans-array.h 
                         trans-array.c trans-expr.c 
        gcc/testsuite  : ChangeLog 
        libgfortran    : ChangeLog 
        libgfortran/runtime: memory.c 
Added files:
        gcc/testsuite/gfortran.dg: array_constructor_6.f90 
                                   array_constructor_7.f90 
                                   array_constructor_8.f90 
                                   array_constructor_9.f90 
                                   array_constructor_10.f90 
                                   array_constructor_11.f90 
                                   array_constructor_12.f90 

Log message:
        PR fortran/12840
        * trans.h (gfor_fndecl_internal_realloc): Declare.
        (gfor_fndecl_internal_realloc64): Declare.
        * trans-decl.c (gfor_fndecl_internal_realloc): New variable.
        (gfor_fndecl_internal_realloc64): New variable.
        (gfc_build_builtin_function_decls): Initialize them.
        * trans-array.h (gfc_trans_allocate_temp_array): Add a fourth argument.
        * trans-array.c (gfc_trans_allocate_array_storage): Add an argument
        to say whether the array can grow later.  Don't allocate the array
        on the stack if so.  Don't call malloc for zero-sized arrays.
        (gfc_trans_allocate_temp_array): Add a similar argument here.
        Pass it along to gfc_trans_allocate_array_storage.
        (gfc_get_iteration_count, gfc_grow_array): New functions.
        (gfc_iterator_has_dynamic_bounds): New function.
        (gfc_get_array_constructor_element_size): New function.
        (gfc_get_array_constructor_size): New function.
        (gfc_trans_array_ctor_element): Replace pointer argument with
        a descriptor tree.
        (gfc_trans_array_constructor_subarray): Likewise.  Take an extra
        argument to say whether the variable-sized part of the constructor
        must be allocated using realloc.  Grow the array when this
        argument is true.
        (gfc_trans_array_constructor_value): Likewise.
        (gfc_get_array_cons_size): Delete.
        (gfc_trans_array_constructor): If the loop bound has not been set,
        split the allocation into a static part and a dynamic part.  Set
        loop->to to the bounds for static part before allocating the
        temporary.  Adjust call to gfc_trans_array_constructor_value.
        (gfc_conv_loop_setup): Allow any constructor to determine the
        loop bounds.  Check whether the constructor has a dynamic size
        and prefer to use something else if so.  Expect the loop bound
        to be set later.  Adjust call to gfc_trans_allocate_temp_array.
        * trans-expr.c (gfc_conv_function_call): Adjust another call here.

Patches:
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/fortran/ChangeLog.diff?cvsroot=gcc&r1=1.544&r2=1.545
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/fortran/trans.h.diff?cvsroot=gcc&r1=1.32&r2=1.33
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/fortran/trans-decl.c.diff?cvsroot=gcc&r1=1.68&r2=1.69
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/fortran/trans-array.h.diff?cvsroot=gcc&r1=1.12&r2=1.13
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/fortran/trans-array.c.diff?cvsroot=gcc&r1=1.57&r2=1.58
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/fortran/trans-expr.c.diff?cvsroot=gcc&r1=1.60&r2=1.61
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/testsuite/ChangeLog.diff?cvsroot=gcc&r1=1.6035&r2=1.6036
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/libgfortran/ChangeLog.diff?cvsroot=gcc&r1=1.297&r2=1.298
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/libgfortran/runtime/memory.c.diff?cvsroot=gcc&r1=1.8&r2=1.9
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/testsuite/gfortran.dg/array_constructor_6.f90.diff?cvsroot=gcc&r1=NONE&r2=1.1
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/testsuite/gfortran.dg/array_constructor_7.f90.diff?cvsroot=gcc&r1=NONE&r2=1.1
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/testsuite/gfortran.dg/array_constructor_8.f90.diff?cvsroot=gcc&r1=NONE&r2=1.1
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/testsuite/gfortran.dg/array_constructor_9.f90.diff?cvsroot=gcc&r1=NONE&r2=1.1
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/testsuite/gfortran.dg/array_constructor_10.f90.diff?cvsroot=gcc&r1=NONE&r2=1.1
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/testsuite/gfortran.dg/array_constructor_11.f90.diff?cvsroot=gcc&r1=NONE&r2=1.1
http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/testsuite/gfortran.dg/array_constructor_12.f90.diff?cvsroot=gcc&r1=NONE&r2=1.1



-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=12840

Reply via email to