]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/fortran/intrinsic.h
re PR fortran/36874 (Add shape checks to cshift/eoshift)
[thirdparty/gcc.git] / gcc / fortran / intrinsic.h
CommitLineData
6de9cd9a
DN
1/* Header file for intrinsics check, resolve and simplify function
2 prototypes.
8b791297 3 Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
f439764f 4 Free Software Foundation, Inc.
6de9cd9a
DN
5 Contributed by Andy Vaught & Katherine Holcomb
6
9fc4d79b 7This file is part of GCC.
6de9cd9a 8
9fc4d79b
TS
9GCC is free software; you can redistribute it and/or modify it under
10the terms of the GNU General Public License as published by the Free
d234d788 11Software Foundation; either version 3, or (at your option) any later
9fc4d79b 12version.
6de9cd9a 13
9fc4d79b
TS
14GCC is distributed in the hope that it will be useful, but WITHOUT ANY
15WARRANTY; without even the implied warranty of MERCHANTABILITY or
16FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17for more details.
6de9cd9a
DN
18
19You should have received a copy of the GNU General Public License
d234d788
NC
20along with GCC; see the file COPYING3. If not see
21<http://www.gnu.org/licenses/>. */
6de9cd9a
DN
22
23/* Expression returned when simplification fails. */
24
25extern gfc_expr gfc_bad_expr;
26
27
28/* Check functions. */
17b1d2a0
KG
29gfc_try gfc_check_a_ikind (gfc_expr *, gfc_expr *);
30gfc_try gfc_check_a_xkind (gfc_expr *, gfc_expr *);
31gfc_try gfc_check_a_p (gfc_expr *, gfc_expr *);
32gfc_try gfc_check_x_yd (gfc_expr *, gfc_expr *);
6de9cd9a 33
17b1d2a0
KG
34gfc_try gfc_check_abs (gfc_expr *);
35gfc_try gfc_check_access_func (gfc_expr *, gfc_expr *);
36gfc_try gfc_check_achar (gfc_expr *, gfc_expr *);
37gfc_try gfc_check_all_any (gfc_expr *, gfc_expr *);
38gfc_try gfc_check_allocated (gfc_expr *);
39gfc_try gfc_check_associated (gfc_expr *, gfc_expr *);
40gfc_try gfc_check_atan2 (gfc_expr *, gfc_expr *);
41gfc_try gfc_check_besn (gfc_expr *, gfc_expr *);
42gfc_try gfc_check_btest (gfc_expr *, gfc_expr *);
43gfc_try gfc_check_char (gfc_expr *, gfc_expr *);
44gfc_try gfc_check_chdir (gfc_expr *);
45gfc_try gfc_check_chmod (gfc_expr *, gfc_expr *);
46gfc_try gfc_check_cmplx (gfc_expr *, gfc_expr *, gfc_expr *);
47gfc_try gfc_check_complex (gfc_expr *, gfc_expr *);
48gfc_try gfc_check_count (gfc_expr *, gfc_expr *, gfc_expr *);
49gfc_try gfc_check_cshift (gfc_expr *, gfc_expr *, gfc_expr *);
50gfc_try gfc_check_ctime (gfc_expr *);
51gfc_try gfc_check_datan2 (gfc_expr *, gfc_expr *);
52gfc_try gfc_check_dcmplx (gfc_expr *, gfc_expr *);
53gfc_try gfc_check_dble (gfc_expr *);
54gfc_try gfc_check_digits (gfc_expr *);
55gfc_try gfc_check_dot_product (gfc_expr *, gfc_expr *);
56gfc_try gfc_check_dprod (gfc_expr *, gfc_expr *);
57gfc_try gfc_check_eoshift (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
58gfc_try gfc_check_dtime_etime (gfc_expr *);
59gfc_try gfc_check_fgetputc (gfc_expr *, gfc_expr *);
60gfc_try gfc_check_fgetput (gfc_expr *);
61gfc_try gfc_check_fstat (gfc_expr *, gfc_expr *);
62gfc_try gfc_check_ftell (gfc_expr *);
63gfc_try gfc_check_fn_c (gfc_expr *);
64gfc_try gfc_check_fn_d (gfc_expr *);
65gfc_try gfc_check_fn_r (gfc_expr *);
66gfc_try gfc_check_fn_rc (gfc_expr *);
67gfc_try gfc_check_fnum (gfc_expr *);
68gfc_try gfc_check_hostnm (gfc_expr *);
69gfc_try gfc_check_huge (gfc_expr *);
70gfc_try gfc_check_hypot (gfc_expr *, gfc_expr *);
71gfc_try gfc_check_i (gfc_expr *);
72gfc_try gfc_check_iand (gfc_expr *, gfc_expr *);
73gfc_try gfc_check_and (gfc_expr *, gfc_expr *);
74gfc_try gfc_check_ibclr (gfc_expr *, gfc_expr *);
75gfc_try gfc_check_ibits (gfc_expr *, gfc_expr *, gfc_expr *);
76gfc_try gfc_check_ibset (gfc_expr *, gfc_expr *);
77gfc_try gfc_check_ichar_iachar (gfc_expr *, gfc_expr *);
78gfc_try gfc_check_idnint (gfc_expr *);
79gfc_try gfc_check_ieor (gfc_expr *, gfc_expr *);
80gfc_try gfc_check_index (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
81gfc_try gfc_check_int (gfc_expr *, gfc_expr *);
82gfc_try gfc_check_intconv (gfc_expr *);
83gfc_try gfc_check_ior (gfc_expr *, gfc_expr *);
84gfc_try gfc_check_irand (gfc_expr *);
85gfc_try gfc_check_isatty (gfc_expr *);
86gfc_try gfc_check_isnan (gfc_expr *);
87gfc_try gfc_check_ishft (gfc_expr *, gfc_expr *);
88gfc_try gfc_check_ishftc (gfc_expr *, gfc_expr *, gfc_expr *);
89gfc_try gfc_check_kill (gfc_expr *, gfc_expr *);
90gfc_try gfc_check_kind (gfc_expr *);
91gfc_try gfc_check_lbound (gfc_expr *, gfc_expr *, gfc_expr *);
92gfc_try gfc_check_len_lentrim (gfc_expr *, gfc_expr *);
93gfc_try gfc_check_link (gfc_expr *, gfc_expr *);
94gfc_try gfc_check_lge_lgt_lle_llt (gfc_expr *, gfc_expr *);
95gfc_try gfc_check_loc (gfc_expr *);
96gfc_try gfc_check_logical (gfc_expr *, gfc_expr *);
97gfc_try gfc_check_min_max (gfc_actual_arglist *);
98gfc_try gfc_check_min_max_integer (gfc_actual_arglist *);
99gfc_try gfc_check_min_max_real (gfc_actual_arglist *);
100gfc_try gfc_check_min_max_double (gfc_actual_arglist *);
101gfc_try gfc_check_malloc (gfc_expr *);
102gfc_try gfc_check_matmul (gfc_expr *, gfc_expr *);
103gfc_try gfc_check_merge (gfc_expr *, gfc_expr *, gfc_expr *);
104gfc_try gfc_check_minloc_maxloc (gfc_actual_arglist *);
105gfc_try gfc_check_minval_maxval (gfc_actual_arglist *);
106gfc_try gfc_check_nearest (gfc_expr *, gfc_expr *);
107gfc_try gfc_check_new_line (gfc_expr *);
108gfc_try gfc_check_null (gfc_expr *);
109gfc_try gfc_check_pack (gfc_expr *, gfc_expr *, gfc_expr *);
110gfc_try gfc_check_precision (gfc_expr *);
111gfc_try gfc_check_present (gfc_expr *);
112gfc_try gfc_check_product_sum (gfc_actual_arglist *);
113gfc_try gfc_check_radix (gfc_expr *);
114gfc_try gfc_check_rand (gfc_expr *);
115gfc_try gfc_check_range (gfc_expr *);
116gfc_try gfc_check_real (gfc_expr *, gfc_expr *);
117gfc_try gfc_check_rename (gfc_expr *, gfc_expr *);
118gfc_try gfc_check_repeat (gfc_expr *, gfc_expr *);
119gfc_try gfc_check_reshape (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
120gfc_try gfc_check_scale (gfc_expr *, gfc_expr *);
121gfc_try gfc_check_scan (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
122gfc_try gfc_check_second_sub (gfc_expr *);
123gfc_try gfc_check_secnds (gfc_expr *);
124gfc_try gfc_check_selected_char_kind (gfc_expr *);
125gfc_try gfc_check_selected_int_kind (gfc_expr *);
126gfc_try gfc_check_selected_real_kind (gfc_expr *, gfc_expr *);
127gfc_try gfc_check_set_exponent (gfc_expr *, gfc_expr *);
128gfc_try gfc_check_shape (gfc_expr *);
129gfc_try gfc_check_size (gfc_expr *, gfc_expr *, gfc_expr *);
130gfc_try gfc_check_sign (gfc_expr *, gfc_expr *);
131gfc_try gfc_check_signal (gfc_expr *, gfc_expr *);
132gfc_try gfc_check_sizeof (gfc_expr *);
133gfc_try gfc_check_spread (gfc_expr *, gfc_expr *, gfc_expr *);
134gfc_try gfc_check_srand (gfc_expr *);
135gfc_try gfc_check_stat (gfc_expr *, gfc_expr *);
136gfc_try gfc_check_sum (gfc_expr *, gfc_expr *, gfc_expr *);
137gfc_try gfc_check_symlnk (gfc_expr *, gfc_expr *);
138gfc_try gfc_check_transfer (gfc_expr *, gfc_expr *, gfc_expr *);
139gfc_try gfc_check_transpose (gfc_expr *);
140gfc_try gfc_check_trim (gfc_expr *);
141gfc_try gfc_check_ttynam (gfc_expr *);
142gfc_try gfc_check_ubound (gfc_expr *, gfc_expr *, gfc_expr *);
143gfc_try gfc_check_umask (gfc_expr *);
144gfc_try gfc_check_unlink (gfc_expr *);
145gfc_try gfc_check_unpack (gfc_expr *, gfc_expr *, gfc_expr *);
146gfc_try gfc_check_verify (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
147gfc_try gfc_check_x (gfc_expr *);
6de9cd9a
DN
148
149
150/* Intrinsic subroutines. */
17b1d2a0
KG
151gfc_try gfc_check_alarm_sub (gfc_expr *, gfc_expr *, gfc_expr *);
152gfc_try gfc_check_chdir_sub (gfc_expr *, gfc_expr *);
153gfc_try gfc_check_chmod_sub (gfc_expr *, gfc_expr *, gfc_expr *);
154gfc_try gfc_check_cpu_time (gfc_expr *);
155gfc_try gfc_check_ctime_sub (gfc_expr *, gfc_expr *);
156gfc_try gfc_check_system_clock (gfc_expr *, gfc_expr *, gfc_expr *);
157gfc_try gfc_check_date_and_time (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
158gfc_try gfc_check_exit (gfc_expr *);
159gfc_try gfc_check_fdate_sub (gfc_expr *);
160gfc_try gfc_check_flush (gfc_expr *);
161gfc_try gfc_check_free (gfc_expr *);
162gfc_try gfc_check_fstat_sub (gfc_expr *, gfc_expr *, gfc_expr *);
163gfc_try gfc_check_gerror (gfc_expr *);
164gfc_try gfc_check_getarg (gfc_expr *, gfc_expr *);
165gfc_try gfc_check_getlog (gfc_expr *);
166gfc_try gfc_check_move_alloc (gfc_expr *, gfc_expr *);
167gfc_try gfc_check_mvbits (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *,
6de9cd9a 168 gfc_expr *);
17b1d2a0
KG
169gfc_try gfc_check_random_number (gfc_expr *);
170gfc_try gfc_check_random_seed (gfc_expr *, gfc_expr *, gfc_expr *);
171gfc_try gfc_check_dtime_etime_sub (gfc_expr *, gfc_expr *);
172gfc_try gfc_check_fgetputc_sub (gfc_expr *, gfc_expr *, gfc_expr *);
173gfc_try gfc_check_fgetput_sub (gfc_expr *, gfc_expr *);
174gfc_try gfc_check_fseek_sub (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
175gfc_try gfc_check_ftell_sub (gfc_expr *, gfc_expr *);
176gfc_try gfc_check_getcwd_sub (gfc_expr *, gfc_expr *);
177gfc_try gfc_check_hostnm_sub (gfc_expr *, gfc_expr *);
178gfc_try gfc_check_itime_idate (gfc_expr *);
179gfc_try gfc_check_kill_sub (gfc_expr *, gfc_expr *, gfc_expr *);
180gfc_try gfc_check_ltime_gmtime (gfc_expr *, gfc_expr *);
181gfc_try gfc_check_perror (gfc_expr *);
182gfc_try gfc_check_rename_sub (gfc_expr *, gfc_expr *, gfc_expr *);
183gfc_try gfc_check_link_sub (gfc_expr *, gfc_expr *, gfc_expr *);
184gfc_try gfc_check_symlnk_sub (gfc_expr *, gfc_expr *, gfc_expr *);
185gfc_try gfc_check_signal_sub (gfc_expr *, gfc_expr *, gfc_expr *);
186gfc_try gfc_check_sleep_sub (gfc_expr *);
187gfc_try gfc_check_stat_sub (gfc_expr *, gfc_expr *, gfc_expr *);
188gfc_try gfc_check_system_sub (gfc_expr *, gfc_expr *);
189gfc_try gfc_check_ttynam_sub (gfc_expr *, gfc_expr *);
190gfc_try gfc_check_umask_sub (gfc_expr *, gfc_expr *);
191gfc_try gfc_check_unlink_sub (gfc_expr *, gfc_expr *);
6de9cd9a
DN
192
193
194/* Simplification functions. */
195gfc_expr *gfc_simplify_abs (gfc_expr *);
719e72fb 196gfc_expr *gfc_simplify_achar (gfc_expr *, gfc_expr *);
6de9cd9a 197gfc_expr *gfc_simplify_acos (gfc_expr *);
1e399e23 198gfc_expr *gfc_simplify_acosh (gfc_expr *);
6de9cd9a
DN
199gfc_expr *gfc_simplify_adjustl (gfc_expr *);
200gfc_expr *gfc_simplify_adjustr (gfc_expr *);
201gfc_expr *gfc_simplify_aimag (gfc_expr *);
202gfc_expr *gfc_simplify_aint (gfc_expr *, gfc_expr *);
203gfc_expr *gfc_simplify_dint (gfc_expr *);
204gfc_expr *gfc_simplify_anint (gfc_expr *, gfc_expr *);
205gfc_expr *gfc_simplify_dnint (gfc_expr *);
5d723e54 206gfc_expr *gfc_simplify_and (gfc_expr *, gfc_expr *);
6de9cd9a 207gfc_expr *gfc_simplify_asin (gfc_expr *);
1e399e23 208gfc_expr *gfc_simplify_asinh (gfc_expr *);
6de9cd9a 209gfc_expr *gfc_simplify_atan (gfc_expr *);
1e399e23 210gfc_expr *gfc_simplify_atanh (gfc_expr *);
6de9cd9a 211gfc_expr *gfc_simplify_atan2 (gfc_expr *, gfc_expr *);
3c3f4265
TB
212gfc_expr *gfc_simplify_bessel_j0 (gfc_expr *);
213gfc_expr *gfc_simplify_bessel_j1 (gfc_expr *);
214gfc_expr *gfc_simplify_bessel_jn (gfc_expr *, gfc_expr *);
215gfc_expr *gfc_simplify_bessel_y0 (gfc_expr *);
216gfc_expr *gfc_simplify_bessel_y1 (gfc_expr *);
217gfc_expr *gfc_simplify_bessel_yn (gfc_expr *, gfc_expr *);
6de9cd9a
DN
218gfc_expr *gfc_simplify_bit_size (gfc_expr *);
219gfc_expr *gfc_simplify_btest (gfc_expr *, gfc_expr *);
220gfc_expr *gfc_simplify_ceiling (gfc_expr *, gfc_expr *);
221gfc_expr *gfc_simplify_char (gfc_expr *, gfc_expr *);
222gfc_expr *gfc_simplify_cmplx (gfc_expr *, gfc_expr *, gfc_expr *);
5d723e54 223gfc_expr *gfc_simplify_complex (gfc_expr *, gfc_expr *);
6de9cd9a
DN
224gfc_expr *gfc_simplify_conjg (gfc_expr *);
225gfc_expr *gfc_simplify_cos (gfc_expr *);
226gfc_expr *gfc_simplify_cosh (gfc_expr *);
227gfc_expr *gfc_simplify_dcmplx (gfc_expr *, gfc_expr *);
228gfc_expr *gfc_simplify_dble (gfc_expr *);
229gfc_expr *gfc_simplify_digits (gfc_expr *);
230gfc_expr *gfc_simplify_dim (gfc_expr *, gfc_expr *);
231gfc_expr *gfc_simplify_dprod (gfc_expr *, gfc_expr *);
8ec259c1 232gfc_expr *gfc_simplify_dot_product (gfc_expr *, gfc_expr *);
6de9cd9a 233gfc_expr *gfc_simplify_epsilon (gfc_expr *);
fdc54e88
FXC
234gfc_expr *gfc_simplify_erf (gfc_expr *);
235gfc_expr *gfc_simplify_erfc (gfc_expr *);
9b33a6a1 236gfc_expr *gfc_simplify_erfc_scaled (gfc_expr *);
6de9cd9a
DN
237gfc_expr *gfc_simplify_exp (gfc_expr *);
238gfc_expr *gfc_simplify_exponent (gfc_expr *);
239gfc_expr *gfc_simplify_float (gfc_expr *);
240gfc_expr *gfc_simplify_floor (gfc_expr *, gfc_expr *);
241gfc_expr *gfc_simplify_fraction (gfc_expr *);
75be5dc0 242gfc_expr *gfc_simplify_gamma (gfc_expr *);
6de9cd9a 243gfc_expr *gfc_simplify_huge (gfc_expr *);
f489fba1 244gfc_expr *gfc_simplify_hypot (gfc_expr *, gfc_expr *);
5cda5098 245gfc_expr *gfc_simplify_iachar (gfc_expr *, gfc_expr *);
6de9cd9a
DN
246gfc_expr *gfc_simplify_iand (gfc_expr *, gfc_expr *);
247gfc_expr *gfc_simplify_ibclr (gfc_expr *, gfc_expr *);
248gfc_expr *gfc_simplify_ibits (gfc_expr *, gfc_expr *, gfc_expr *);
249gfc_expr *gfc_simplify_ibset (gfc_expr *, gfc_expr *);
5cda5098 250gfc_expr *gfc_simplify_ichar (gfc_expr *, gfc_expr *);
6de9cd9a 251gfc_expr *gfc_simplify_ieor (gfc_expr *, gfc_expr *);
5cda5098 252gfc_expr *gfc_simplify_index (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a 253gfc_expr *gfc_simplify_int (gfc_expr *, gfc_expr *);
bf3fb7e4
FXC
254gfc_expr *gfc_simplify_int2 (gfc_expr *);
255gfc_expr *gfc_simplify_int8 (gfc_expr *);
256gfc_expr *gfc_simplify_long (gfc_expr *);
6de9cd9a
DN
257gfc_expr *gfc_simplify_ifix (gfc_expr *);
258gfc_expr *gfc_simplify_idint (gfc_expr *);
259gfc_expr *gfc_simplify_ior (gfc_expr *, gfc_expr *);
260gfc_expr *gfc_simplify_ishft (gfc_expr *, gfc_expr *);
261gfc_expr *gfc_simplify_ishftc (gfc_expr *, gfc_expr *, gfc_expr *);
262gfc_expr *gfc_simplify_kind (gfc_expr *);
5cda5098 263gfc_expr *gfc_simplify_lbound (gfc_expr *, gfc_expr *, gfc_expr *);
414f00e9 264gfc_expr *gfc_simplify_leadz (gfc_expr *);
5cda5098
FXC
265gfc_expr *gfc_simplify_len (gfc_expr *, gfc_expr *);
266gfc_expr *gfc_simplify_len_trim (gfc_expr *, gfc_expr *);
75be5dc0 267gfc_expr *gfc_simplify_lgamma (gfc_expr *);
6de9cd9a
DN
268gfc_expr *gfc_simplify_lge (gfc_expr *, gfc_expr *);
269gfc_expr *gfc_simplify_lgt (gfc_expr *, gfc_expr *);
270gfc_expr *gfc_simplify_lle (gfc_expr *, gfc_expr *);
271gfc_expr *gfc_simplify_llt (gfc_expr *, gfc_expr *);
272gfc_expr *gfc_simplify_log (gfc_expr *);
273gfc_expr *gfc_simplify_log10 (gfc_expr *);
274gfc_expr *gfc_simplify_logical (gfc_expr *, gfc_expr *);
8ec259c1 275gfc_expr *gfc_simplify_matmul (gfc_expr *, gfc_expr *);
8f2b565d 276gfc_expr *gfc_simplify_merge (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a 277gfc_expr *gfc_simplify_min (gfc_expr *);
5a0193ee 278gfc_expr *gfc_simplify_minval (gfc_expr *, gfc_expr*, gfc_expr*);
6de9cd9a 279gfc_expr *gfc_simplify_max (gfc_expr *);
5a0193ee 280gfc_expr *gfc_simplify_maxval (gfc_expr *, gfc_expr*, gfc_expr*);
6de9cd9a
DN
281gfc_expr *gfc_simplify_maxexponent (gfc_expr *);
282gfc_expr *gfc_simplify_minexponent (gfc_expr *);
283gfc_expr *gfc_simplify_mod (gfc_expr *, gfc_expr *);
284gfc_expr *gfc_simplify_modulo (gfc_expr *, gfc_expr *);
285gfc_expr *gfc_simplify_mvbits (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *,
286 gfc_expr *);
287gfc_expr *gfc_simplify_nearest (gfc_expr *, gfc_expr *);
bec93d79 288gfc_expr *gfc_simplify_new_line (gfc_expr *);
6de9cd9a
DN
289gfc_expr *gfc_simplify_nint (gfc_expr *, gfc_expr *);
290gfc_expr *gfc_simplify_null (gfc_expr *);
291gfc_expr *gfc_simplify_idnint (gfc_expr *);
292gfc_expr *gfc_simplify_not (gfc_expr *);
5d723e54 293gfc_expr *gfc_simplify_or (gfc_expr *, gfc_expr *);
7ba8c18c 294gfc_expr *gfc_simplify_pack (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
295gfc_expr *gfc_simplify_precision (gfc_expr *);
296gfc_expr *gfc_simplify_radix (gfc_expr *);
297gfc_expr *gfc_simplify_range (gfc_expr *);
298gfc_expr *gfc_simplify_real (gfc_expr *, gfc_expr *);
6970fcc8 299gfc_expr *gfc_simplify_realpart (gfc_expr *);
6de9cd9a
DN
300gfc_expr *gfc_simplify_repeat (gfc_expr *, gfc_expr *);
301gfc_expr *gfc_simplify_reshape (gfc_expr *, gfc_expr *, gfc_expr *,
302 gfc_expr *);
303gfc_expr *gfc_simplify_rrspacing (gfc_expr *);
304gfc_expr *gfc_simplify_scale (gfc_expr *, gfc_expr *);
5cda5098 305gfc_expr *gfc_simplify_scan (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
a39fafac 306gfc_expr *gfc_simplify_selected_char_kind (gfc_expr *);
6de9cd9a
DN
307gfc_expr *gfc_simplify_selected_int_kind (gfc_expr *);
308gfc_expr *gfc_simplify_selected_real_kind (gfc_expr *, gfc_expr *);
309gfc_expr *gfc_simplify_set_exponent (gfc_expr *, gfc_expr *);
310gfc_expr *gfc_simplify_sign (gfc_expr *, gfc_expr *);
311gfc_expr *gfc_simplify_shape (gfc_expr *);
312gfc_expr *gfc_simplify_sin (gfc_expr *);
313gfc_expr *gfc_simplify_sinh (gfc_expr *);
5cda5098 314gfc_expr *gfc_simplify_size (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
315gfc_expr *gfc_simplify_sngl (gfc_expr *);
316gfc_expr *gfc_simplify_spacing (gfc_expr *);
317gfc_expr *gfc_simplify_sqrt (gfc_expr *);
318gfc_expr *gfc_simplify_tan (gfc_expr *);
319gfc_expr *gfc_simplify_tanh (gfc_expr *);
320gfc_expr *gfc_simplify_tiny (gfc_expr *);
414f00e9 321gfc_expr *gfc_simplify_trailz (gfc_expr *);
a4a11197 322gfc_expr *gfc_simplify_transfer (gfc_expr *, gfc_expr *, gfc_expr *);
8ec259c1 323gfc_expr *gfc_simplify_transpose (gfc_expr *);
6de9cd9a 324gfc_expr *gfc_simplify_trim (gfc_expr *);
5cda5098
FXC
325gfc_expr *gfc_simplify_ubound (gfc_expr *, gfc_expr *, gfc_expr *);
326gfc_expr *gfc_simplify_verify (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
5d723e54 327gfc_expr *gfc_simplify_xor (gfc_expr *, gfc_expr *);
6de9cd9a
DN
328
329/* Constant conversion simplification. */
330gfc_expr *gfc_convert_constant (gfc_expr *, bt, int);
d393bbd7 331gfc_expr *gfc_convert_char_constant (gfc_expr *, bt, int);
6de9cd9a
DN
332
333
334/* Resolution functions. */
335void gfc_resolve_abs (gfc_expr *, gfc_expr *);
a119fc1c 336void gfc_resolve_access (gfc_expr *, gfc_expr *, gfc_expr *);
d393bbd7
FXC
337void gfc_resolve_adjustl (gfc_expr *, gfc_expr *);
338void gfc_resolve_adjustr (gfc_expr *, gfc_expr *);
719e72fb 339void gfc_resolve_achar (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a 340void gfc_resolve_acos (gfc_expr *, gfc_expr *);
1e399e23 341void gfc_resolve_acosh (gfc_expr *, gfc_expr *);
6de9cd9a
DN
342void gfc_resolve_aimag (gfc_expr *, gfc_expr *);
343void gfc_resolve_aint (gfc_expr *, gfc_expr *, gfc_expr *);
344void gfc_resolve_dint (gfc_expr *, gfc_expr *);
345void gfc_resolve_all (gfc_expr *, gfc_expr *, gfc_expr *);
346void gfc_resolve_anint (gfc_expr *, gfc_expr *, gfc_expr *);
347void gfc_resolve_dnint (gfc_expr *, gfc_expr *);
5d723e54 348void gfc_resolve_and (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
349void gfc_resolve_any (gfc_expr *, gfc_expr *, gfc_expr *);
350void gfc_resolve_asin (gfc_expr *, gfc_expr *);
1e399e23 351void gfc_resolve_asinh (gfc_expr *, gfc_expr *);
6de9cd9a 352void gfc_resolve_atan (gfc_expr *, gfc_expr *);
1e399e23 353void gfc_resolve_atanh (gfc_expr *, gfc_expr *);
6de9cd9a 354void gfc_resolve_atan2 (gfc_expr *, gfc_expr *, gfc_expr *);
e8525382 355void gfc_resolve_besn (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
356void gfc_resolve_btest (gfc_expr *, gfc_expr *, gfc_expr *);
357void gfc_resolve_ceiling (gfc_expr *, gfc_expr *, gfc_expr *);
358void gfc_resolve_char (gfc_expr *, gfc_expr *, gfc_expr *);
f77b6ca3 359void gfc_resolve_chdir (gfc_expr *, gfc_expr *);
a119fc1c 360void gfc_resolve_chmod (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
361void gfc_resolve_cmplx (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
362void gfc_resolve_dcmplx (gfc_expr *, gfc_expr *, gfc_expr *);
5d723e54 363void gfc_resolve_complex (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
364void gfc_resolve_conjg (gfc_expr *, gfc_expr *);
365void gfc_resolve_cos (gfc_expr *, gfc_expr *);
366void gfc_resolve_cosh (gfc_expr *, gfc_expr *);
5cda5098 367void gfc_resolve_count (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a 368void gfc_resolve_cshift (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
35059811 369void gfc_resolve_ctime (gfc_expr *, gfc_expr *);
6de9cd9a
DN
370void gfc_resolve_dble (gfc_expr *, gfc_expr *);
371void gfc_resolve_dim (gfc_expr *, gfc_expr *, gfc_expr *);
372void gfc_resolve_dot_product (gfc_expr *, gfc_expr *, gfc_expr *);
373void gfc_resolve_dprod (gfc_expr *, gfc_expr *, gfc_expr *);
a1ba31ce 374void gfc_resolve_dtime_sub (gfc_code *);
6de9cd9a
DN
375void gfc_resolve_eoshift (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *,
376 gfc_expr *);
2bd74949 377void gfc_resolve_etime_sub (gfc_code *);
6de9cd9a
DN
378void gfc_resolve_exp (gfc_expr *, gfc_expr *);
379void gfc_resolve_exponent (gfc_expr *, gfc_expr *);
35059811 380void gfc_resolve_fdate (gfc_expr *);
6de9cd9a 381void gfc_resolve_floor (gfc_expr *, gfc_expr *, gfc_expr *);
df65f093 382void gfc_resolve_fnum (gfc_expr *, gfc_expr *);
6de9cd9a 383void gfc_resolve_fraction (gfc_expr *, gfc_expr *);
df65f093 384void gfc_resolve_fstat (gfc_expr *, gfc_expr *, gfc_expr *);
5d723e54
FXC
385void gfc_resolve_ftell (gfc_expr *, gfc_expr *);
386void gfc_resolve_fgetc (gfc_expr *, gfc_expr *, gfc_expr *);
387void gfc_resolve_fget (gfc_expr *, gfc_expr *);
388void gfc_resolve_fputc (gfc_expr *, gfc_expr *, gfc_expr *);
389void gfc_resolve_fput (gfc_expr *, gfc_expr *);
e8525382 390void gfc_resolve_g77_math1 (gfc_expr *, gfc_expr *);
75be5dc0 391void gfc_resolve_gamma (gfc_expr *, gfc_expr *);
2124d608 392void gfc_resolve_getcwd (gfc_expr *, gfc_expr *);
4c0c6b9f
SK
393void gfc_resolve_getgid (gfc_expr *);
394void gfc_resolve_getpid (gfc_expr *);
395void gfc_resolve_getuid (gfc_expr *);
f77b6ca3 396void gfc_resolve_hostnm (gfc_expr *, gfc_expr *);
f489fba1 397void gfc_resolve_hypot (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
398void gfc_resolve_iand (gfc_expr *, gfc_expr *, gfc_expr *);
399void gfc_resolve_ibclr (gfc_expr *, gfc_expr *, gfc_expr *);
400void gfc_resolve_ibits (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
401void gfc_resolve_ibset (gfc_expr *, gfc_expr *, gfc_expr *);
5cda5098
FXC
402void gfc_resolve_index_func (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *,
403 gfc_expr *);
f77b6ca3 404void gfc_resolve_ierrno (gfc_expr *);
6de9cd9a 405void gfc_resolve_ieor (gfc_expr *, gfc_expr *, gfc_expr *);
5cda5098
FXC
406void gfc_resolve_ichar (gfc_expr *, gfc_expr *, gfc_expr *);
407void gfc_resolve_iachar (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
408void gfc_resolve_idnint (gfc_expr *, gfc_expr *);
409void gfc_resolve_int (gfc_expr *, gfc_expr *, gfc_expr *);
bf3fb7e4
FXC
410void gfc_resolve_int2 (gfc_expr *, gfc_expr *);
411void gfc_resolve_int8 (gfc_expr *, gfc_expr *);
412void gfc_resolve_long (gfc_expr *, gfc_expr *);
6de9cd9a 413void gfc_resolve_ior (gfc_expr *, gfc_expr *, gfc_expr *);
ae8b8789 414void gfc_resolve_isatty (gfc_expr *, gfc_expr *);
a119fc1c
FXC
415void gfc_resolve_rshift (gfc_expr *, gfc_expr *, gfc_expr *);
416void gfc_resolve_lshift (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
417void gfc_resolve_ishft (gfc_expr *, gfc_expr *, gfc_expr *);
418void gfc_resolve_ishftc (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
f77b6ca3 419void gfc_resolve_kill (gfc_expr *, gfc_expr *, gfc_expr *);
5cda5098
FXC
420void gfc_resolve_lbound (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
421void gfc_resolve_len (gfc_expr *, gfc_expr *, gfc_expr *);
422void gfc_resolve_len_trim (gfc_expr *, gfc_expr *, gfc_expr *);
75be5dc0 423void gfc_resolve_lgamma (gfc_expr *, gfc_expr *);
f77b6ca3 424void gfc_resolve_link (gfc_expr *, gfc_expr *, gfc_expr *);
83d890b9 425void gfc_resolve_loc (gfc_expr *, gfc_expr *);
6de9cd9a
DN
426void gfc_resolve_log (gfc_expr *, gfc_expr *);
427void gfc_resolve_log10 (gfc_expr *, gfc_expr *);
428void gfc_resolve_logical (gfc_expr *, gfc_expr *, gfc_expr *);
bf3fb7e4 429void gfc_resolve_lstat (gfc_expr *, gfc_expr *, gfc_expr *);
0d519038 430void gfc_resolve_malloc (gfc_expr *, gfc_expr *);
6de9cd9a
DN
431void gfc_resolve_matmul (gfc_expr *, gfc_expr *, gfc_expr *);
432void gfc_resolve_max (gfc_expr *, gfc_actual_arglist *);
433void gfc_resolve_maxloc (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
434void gfc_resolve_maxval (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
bf3fb7e4
FXC
435void gfc_resolve_mclock (gfc_expr *);
436void gfc_resolve_mclock8 (gfc_expr *);
6de9cd9a
DN
437void gfc_resolve_merge (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
438void gfc_resolve_min (gfc_expr *, gfc_actual_arglist *);
439void gfc_resolve_minloc (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
440void gfc_resolve_minval (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
441void gfc_resolve_mod (gfc_expr *, gfc_expr *, gfc_expr *);
442void gfc_resolve_modulo (gfc_expr *, gfc_expr *, gfc_expr *);
8765339d 443void gfc_resolve_nearest (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
444void gfc_resolve_nint (gfc_expr *, gfc_expr *, gfc_expr *);
445void gfc_resolve_not (gfc_expr *, gfc_expr *);
5d723e54 446void gfc_resolve_or (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
447void gfc_resolve_pack (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
448void gfc_resolve_product (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
449void gfc_resolve_real (gfc_expr *, gfc_expr *, gfc_expr *);
6970fcc8 450void gfc_resolve_realpart (gfc_expr *, gfc_expr *);
f77b6ca3 451void gfc_resolve_rename (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
452void gfc_resolve_repeat (gfc_expr *, gfc_expr *, gfc_expr *);
453void gfc_resolve_reshape (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *,
454 gfc_expr *);
455void gfc_resolve_rrspacing (gfc_expr *, gfc_expr *);
456void gfc_resolve_scale (gfc_expr *, gfc_expr *, gfc_expr *);
5cda5098
FXC
457void gfc_resolve_scan (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *,
458 gfc_expr *);
2bd74949 459void gfc_resolve_second_sub (gfc_code *);
53096259 460void gfc_resolve_secnds (gfc_expr *, gfc_expr *);
6de9cd9a
DN
461void gfc_resolve_set_exponent (gfc_expr *, gfc_expr *, gfc_expr *);
462void gfc_resolve_shape (gfc_expr *, gfc_expr *);
463void gfc_resolve_sign (gfc_expr *, gfc_expr *, gfc_expr *);
185d7d97 464void gfc_resolve_signal (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
465void gfc_resolve_sin (gfc_expr *, gfc_expr *);
466void gfc_resolve_sinh (gfc_expr *, gfc_expr *);
5cda5098 467void gfc_resolve_size (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
468void gfc_resolve_spacing (gfc_expr *, gfc_expr *);
469void gfc_resolve_spread (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
470void gfc_resolve_sqrt (gfc_expr *, gfc_expr *);
df65f093 471void gfc_resolve_stat (gfc_expr *, gfc_expr *, gfc_expr *);
2bd74949 472void gfc_resolve_srand (gfc_code *);
6de9cd9a 473void gfc_resolve_sum (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
f77b6ca3 474void gfc_resolve_symlnk (gfc_expr *, gfc_expr *, gfc_expr *);
5b1374e9 475void gfc_resolve_system (gfc_expr *, gfc_expr *);
6de9cd9a
DN
476void gfc_resolve_tan (gfc_expr *, gfc_expr *);
477void gfc_resolve_tanh (gfc_expr *, gfc_expr *);
f77b6ca3
FXC
478void gfc_resolve_time (gfc_expr *);
479void gfc_resolve_time8 (gfc_expr *);
6de9cd9a
DN
480void gfc_resolve_transfer (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
481void gfc_resolve_transpose (gfc_expr *, gfc_expr *);
482void gfc_resolve_trim (gfc_expr *, gfc_expr *);
25fc05eb 483void gfc_resolve_ttynam (gfc_expr *, gfc_expr *);
5cda5098 484void gfc_resolve_ubound (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
d8fe26b2
SK
485void gfc_resolve_umask (gfc_expr *, gfc_expr *);
486void gfc_resolve_unlink (gfc_expr *, gfc_expr *);
6de9cd9a 487void gfc_resolve_unpack (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *);
5cda5098
FXC
488void gfc_resolve_verify (gfc_expr *, gfc_expr *, gfc_expr *, gfc_expr *,
489 gfc_expr *);
5d723e54 490void gfc_resolve_xor (gfc_expr *, gfc_expr *, gfc_expr *);
6de9cd9a
DN
491
492
493/* Intrinsic subroutine resolution. */
185d7d97 494void gfc_resolve_alarm_sub (gfc_code *);
f77b6ca3 495void gfc_resolve_chdir_sub (gfc_code *);
a119fc1c 496void gfc_resolve_chmod_sub (gfc_code *);
6de9cd9a 497void gfc_resolve_cpu_time (gfc_code *);
35059811 498void gfc_resolve_ctime_sub (gfc_code *);
d8fe26b2 499void gfc_resolve_exit (gfc_code *);
5d723e54 500void gfc_resolve_fdate_sub (gfc_code *);
df65f093 501void gfc_resolve_flush (gfc_code *);
0d519038 502void gfc_resolve_free (gfc_code *);
dcdc26df 503void gfc_resolve_fseek_sub (gfc_code *);
df65f093 504void gfc_resolve_fstat_sub (gfc_code *);
5d723e54
FXC
505void gfc_resolve_ftell_sub (gfc_code *);
506void gfc_resolve_fgetc_sub (gfc_code *);
507void gfc_resolve_fget_sub (gfc_code *);
508void gfc_resolve_fputc_sub (gfc_code *);
509void gfc_resolve_fput_sub (gfc_code *);
f77b6ca3 510void gfc_resolve_gerror (gfc_code *);
b41b2534 511void gfc_resolve_getarg (gfc_code *);
a8c60d7f 512void gfc_resolve_getcwd_sub (gfc_code *);
f77b6ca3 513void gfc_resolve_getlog (gfc_code *);
b41b2534
JB
514void gfc_resolve_get_command (gfc_code *);
515void gfc_resolve_get_command_argument (gfc_code *);
aa6fc635 516void gfc_resolve_get_environment_variable (gfc_code *);
a119fc1c 517void gfc_resolve_gmtime (gfc_code *);
f77b6ca3 518void gfc_resolve_hostnm_sub (gfc_code *);
12197210
FXC
519void gfc_resolve_idate (gfc_code *);
520void gfc_resolve_itime (gfc_code *);
f77b6ca3 521void gfc_resolve_kill_sub (gfc_code *);
a119fc1c
FXC
522void gfc_resolve_lstat_sub (gfc_code *);
523void gfc_resolve_ltime (gfc_code *);
d8fe26b2 524void gfc_resolve_mvbits (gfc_code *);
f77b6ca3 525void gfc_resolve_perror (gfc_code *);
d8fe26b2 526void gfc_resolve_random_number (gfc_code *);
34b4bc5c 527void gfc_resolve_random_seed (gfc_code *);
f77b6ca3
FXC
528void gfc_resolve_rename_sub (gfc_code *);
529void gfc_resolve_link_sub (gfc_code *);
530void gfc_resolve_symlnk_sub (gfc_code *);
185d7d97 531void gfc_resolve_signal_sub (gfc_code *);
f77b6ca3 532void gfc_resolve_sleep_sub (gfc_code *);
df65f093 533void gfc_resolve_stat_sub (gfc_code *);
d8fe26b2
SK
534void gfc_resolve_system_clock (gfc_code *);
535void gfc_resolve_system_sub (gfc_code *);
ae8b8789 536void gfc_resolve_ttynam_sub (gfc_code *);
d8fe26b2
SK
537void gfc_resolve_umask_sub (gfc_code *);
538void gfc_resolve_unlink_sub (gfc_code *);
6de9cd9a
DN
539
540
541/* The mvbits() subroutine requires the most arguments: five. */
542
543#define MAX_INTRINSIC_ARGS 5
544
cb9e4f55
TS
545extern const char *gfc_current_intrinsic;
546extern const char *gfc_current_intrinsic_arg[MAX_INTRINSIC_ARGS];
6de9cd9a 547extern locus *gfc_current_intrinsic_where;