parameter.c
1 //! @file parameter.c
2 //! @author J. Marcel van der Veer
3 //
4 //! @section Copyright
5 //
6 // This file is part of VIF - vintage FORTRAN compiler.
7 // Copyright 2020-2025 J. Marcel van der Veer <algol68g@xs4all.nl>.
8 //
9 //! @section License
10 //
11 // This program is free software; you can redistribute it and/or modify it
12 // under the terms of the GNU General Public License as published by the
13 // Free Software Foundation; either version 3 of the License, or
14 // (at your option) any later version.
15 //
16 // This program is distributed in the hope that it will be useful, but
17 // WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
18 // or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
19 // more details. You should have received a copy of the GNU General Public
20 // License along with this program. If not, see <http://www.gnu.org/licenses/>.
21
22 //! @section Synopsis
23 //!
24 //! Compile PARAMETER statement.
25
26 #include <vif.h>
27
28 void parameter (void)
29 {
30 int_4 rc, go_on = TRUE;
31 rc = scan (EXPECT_NONE);
32 if (!TOKEN ("(")) {
33 EXPECT (2401, "(");
34 return;
35 }
36 while (go_on) {
37 rc = scan (EXPECT_NONE);
38 if (TOKEN (")")) {
39 break;
40 }
41 if (rc != WORD) {
42 EXPECT (2402, "variable");
43 }
44 // IBM VS Fortran - idf must have been specified, explicitly or implicitly.
45 MODE mode;
46 IDENT *idf = impl_decl (curlex, &mode);
47 rc = scan ("=");
48 rc = scan (EXPECT_NONE);
49 EXPR reg;
50 express (®, mode.type, mode.len);
51 if (reg.variant == EXPR_CONST) {
52 idf->parm = f_stralloc (reg.str);
53 if (idf->mode.type == NOTYPE) {
54 idf->mode = reg.mode;
55 }
56 // Write constant in the listing file.
57 RECORD fold;
58 RECCLR (fold);
59 snprintf (fold, RECLN, "// %s = %s", C_NAME(idf), idf->parm);
60 code (nprocs, PARAMETERS, fold);
61 } else {
62 EXPECT (2403, "constant");
63 }
64 rc = scan (EXPECT_NONE);
65 if (TOKEN (",")) {
66 continue;
67 } else if (TOKEN (")")) {
68 go_on = FALSE;
69 } else {
70 EXPECT (2404, ", or )");
71 go_on = FALSE;
72 }
73 }
74 (void) rc;
75 }
© 2002-2025 J.M. van der Veer (jmvdveer@xs4all.nl)
|