summaryrefslogtreecommitdiff
path: root/libgfortran/generated/any_l8.c
diff options
context:
space:
mode:
authorVictor Leikehman <lei@il.ibm.com>2004-08-04 14:30:46 +0000
committerPaul Brook <pbrook@gcc.gnu.org>2004-08-04 14:30:46 +0000
commit6c167c45b1059150631362a647864ee0ca900a91 (patch)
tree4227da0c8f70c91f8b20b53d9be0ca661b7f838a /libgfortran/generated/any_l8.c
parent2acc29bdd3bc49da5eca42a0f1c014f972e9ef20 (diff)
* libgfortran.h (array_t, size0) New declarations.
* m4/ifunction.m4, m4/transpose.m4, intrinsics/cshift0.c: Allocate space if return value descriptor has NULL in its data field, and initialize bounds and stride. * intrinsics/size.c (array_t, size0): Declarations moved to libgfortran.h. * generated/*.c: Regenerate. From-SVN: r85558
Diffstat (limited to 'libgfortran/generated/any_l8.c')
-rw-r--r--libgfortran/generated/any_l8.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/libgfortran/generated/any_l8.c b/libgfortran/generated/any_l8.c
index e6ac3f5919d..c9f418dcd07 100644
--- a/libgfortran/generated/any_l8.c
+++ b/libgfortran/generated/any_l8.c
@@ -63,6 +63,23 @@ __any_l8 (gfc_array_l8 * retarray, gfc_array_l8 *array, index_type *pdim)
array->dim[n + 1].ubound + 1 - array->dim[n + 1].lbound;
}
+ if (retarray->data == NULL)
+ {
+ for (n = 0; n < rank; n++)
+ {
+ retarray->dim[n].lbound = 0;
+ retarray->dim[n].ubound = extent[n]-1;
+ if (n == 0)
+ retarray->dim[n].stride = 1;
+ else
+ retarray->dim[n].stride = retarray->dim[n-1].stride * extent[n-1];
+ }
+
+ retarray->data = internal_malloc (sizeof (GFC_LOGICAL_8) *
+ (retarray->dim[rank-1].stride * extent[rank-1]));
+ retarray->base = 0;
+ }
+
for (n = 0; n < rank; n++)
{
count[n] = 0;