]> git.ipfire.org Git - thirdparty/gcc.git/blame - libgfortran/intrinsics/size.c
re PR fortran/37577 ([meta-bug] change internal array descriptor format for better...
[thirdparty/gcc.git] / libgfortran / intrinsics / size.c
CommitLineData
6de9cd9a 1/* Implementation of the size intrinsic.
748086b7 2 Copyright 2002, 2009 Free Software Foundation, Inc.
6de9cd9a
DN
3 Contributed by Paul Brook <paul@nowt.org>
4
57dea9f6 5This file is part of the GNU Fortran 95 runtime library (libgfortran).
6de9cd9a 6
57dea9f6
TM
7Libgfortran is free software; you can redistribute it and/or
8modify it under the terms of the GNU General Public
6de9cd9a 9License as published by the Free Software Foundation; either
748086b7 10version 3 of the License, or (at your option) any later version.
57dea9f6
TM
11
12Libgfortran is distributed in the hope that it will be useful,
6de9cd9a
DN
13but WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
57dea9f6 15GNU General Public License for more details.
6de9cd9a 16
748086b7
JJ
17Under Section 7 of GPL version 3, you are granted additional
18permissions described in the GCC Runtime Library Exception, version
193.1, as published by the Free Software Foundation.
20
21You should have received a copy of the GNU General Public License and
22a copy of the GCC Runtime Library Exception along with this program;
23see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
24<http://www.gnu.org/licenses/>. */
6de9cd9a
DN
25
26#include "libgfortran.h"
27
7d7b8bfe
RH
28index_type
29size0 (const array_t * array)
6de9cd9a
DN
30{
31 int n;
32 index_type size;
33 index_type len;
34
35 size = 1;
36 for (n = 0; n < GFC_DESCRIPTOR_RANK (array); n++)
37 {
dfb55fdc 38 len = GFC_DESCRIPTOR_EXTENT(array,n);
6de9cd9a
DN
39 if (len < 0)
40 len = 0;
41 size *= len;
42 }
43 return size;
44}
7d7b8bfe 45iexport(size0);
6de9cd9a 46
7d7b8bfe
RH
47extern index_type size1 (const array_t * array, index_type dim);
48export_proto(size1);
49
50index_type
51size1 (const array_t * array, index_type dim)
6de9cd9a
DN
52{
53 index_type size;
54
55 dim--;
56
dfb55fdc 57 size = GFC_DESCRIPTOR_EXTENT(array,dim);
6de9cd9a
DN
58 if (size < 0)
59 size = 0;
60 return size;
61}