04d87103d4
* sta.c (ffesta_ffebad_1sp, ffesta_ffebad_1st, ffesta_ffebad_2st): Const-ify a char*. * sta.h (ffesta_ffebad_1sp, ffesta_ffebad_1st, ffesta_ffebad_2st): Likewise. * stb.c (ffestb_local_u_): Likewise. (ffestb_do, ffestb_dowhile, ffestb_else, ffestb_elsexyz, ffestb_else3_, ffestb_endxyz, ffestb_goto, ffestb_let, ffestb_type, ffestb_type1_, ffestb_varlist, ffestb_R423B, ffestb_R522, ffestb_R528, ffestb_R542, ffestb_R834, ffestb_R835, ffestb_R838, ffestb_R841, ffestb_R1102, ffestb_blockdata, ffestb_R1212, ffestb_R1228, ffestb_V009, ffestb_module, ffestb_R809, ffestb_R810, ffestb_R10014_, ffestb_R10015_, ffestb_R10018_, ffestb_R1107, ffestb_R1202, ffestb_R12026_, ffestb_S3P4, ffestb_V012, ffestb_V014, ffestb_V025, ffestb_V0255_, ffestb_V020, ffestb_dimlist, ffestb_dummy, ffestb_R524, ffestb_R547, ffestb_decl_chartype, ffestb_decl_dbltype, ffestb_decl_gentype, ffestb_decl_recursive, ffestb_decl_entsp_2_, ffestb_decl_func_, ffestb_V003, ffestb_V016, ffestb_V027, ffestb_decl_R539): Likewise. * stb.h (_ffestb_args_): Likewise. * stc.c (ffestc_subr_binsrch_, ffestc_subr_is_present_, ffestc_subr_speccmp_, ffestc_R904, ffestc_R907): Likewise. * std.c (ffestd_R1001dump_1005_1_, ffestd_R1001dump_1005_2_, ffestd_R1001dump_1005_3_, ffestd_R1001dump_1005_4_, ffestd_R1001dump_1005_5_, ffestd_R1001dump_1010_1_, ffestd_R1001dump_1010_2_, ffestd_R1001dump_1010_3_, ffestd_R1001dump_1010_4_, ffestd_R1001dump_1010_5_): Likewise. * ste.c (ffeste_begin_iterdo_, ffeste_subr_file_): Likewise. * sts.c (ffests_printf_1D, ffests_printf_1U, ffests_printf_1s, ffests_printf_2Us, ffests_puts, ffests_puttext): Likewise. * sts.h (ffests_printf_1D, ffests_printf_1U, ffests_printf_1s, ffests_printf_2Us, ffests_puts, ffests_puttext): Likewise. * stt.c (ffestt_exprlist_drive, ffestt_implist_drive, ffestt_tokenlist_drive): Add prototype arguments. * stt.h (ffestt_exprlist_drive, ffestt_implist_drive, ffestt_tokenlist_drive): Likewise. * stu.c (ffestu_dummies_transition_): Likewise. (ffestu_sym_end_transition): Const-ify a char*. * stw.c (ffestw_display_state, ffestw_new, ffestw_pop): Add prototype arguments. * stw.h (ffestw_display_state, ffestw_new, ffestw_pop): Likewise. * version.c (ffe_version_string): Const-ify a char*. * version.h (ffe_version_string): Likewise. From-SVN: r26064
231 lines
6.7 KiB
C
231 lines
6.7 KiB
C
/* stt.h -- Private #include File (module.h template V1.0)
|
|
Copyright (C) 1995 Free Software Foundation, Inc.
|
|
Contributed by James Craig Burley.
|
|
|
|
This file is part of GNU Fortran.
|
|
|
|
GNU Fortran is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2, or (at your option)
|
|
any later version.
|
|
|
|
GNU Fortran is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GNU Fortran; see the file COPYING. If not, write to
|
|
the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
|
|
02111-1307, USA.
|
|
|
|
Owning Modules:
|
|
stt.c
|
|
|
|
Modifications:
|
|
*/
|
|
|
|
/* Allow multiple inclusion to work. */
|
|
|
|
#ifndef _H_f_stt
|
|
#define _H_f_stt
|
|
|
|
/* Simple definitions and enumerations. */
|
|
|
|
|
|
/* Typedefs. */
|
|
|
|
typedef struct _ffest_case_list_ *ffesttCaseList;
|
|
typedef struct _ffest_dim_list_ *ffesttDimList;
|
|
typedef struct _ffest_expr_list_ *ffesttExprList;
|
|
typedef struct _ffest_format_value_ ffesttFormatValue;
|
|
typedef struct _ffest_format_list_ *ffesttFormatList;
|
|
typedef struct _ffest_imp_list_ *ffesttImpList;
|
|
typedef struct _ffest_token_item_ *ffesttTokenItem;
|
|
typedef struct _ffest_token_list_ *ffesttTokenList;
|
|
|
|
/* Include files needed by this one. */
|
|
|
|
#include "top.h"
|
|
#include "bld.h"
|
|
#include "info.h"
|
|
#include "lex.h"
|
|
#include "stp.h"
|
|
|
|
/* Structure definitions. */
|
|
|
|
struct _ffest_case_list_
|
|
{
|
|
ffesttCaseList next;
|
|
ffesttCaseList previous;
|
|
ffelexToken t;
|
|
ffebld expr1;
|
|
ffebld expr2;
|
|
bool range; /* TRUE if "[expr1]:[expr2]", FALSE if
|
|
"expr1". */
|
|
};
|
|
|
|
struct _ffest_dim_list_
|
|
{
|
|
ffesttDimList next;
|
|
ffesttDimList previous;
|
|
ffelexToken t;
|
|
ffebld lower;
|
|
ffebld upper;
|
|
};
|
|
|
|
struct _ffest_expr_list_
|
|
{
|
|
ffesttExprList next;
|
|
ffesttExprList previous;
|
|
ffelexToken t;
|
|
ffebld expr;
|
|
};
|
|
|
|
struct _ffest_token_item_
|
|
{
|
|
ffesttTokenItem next;
|
|
ffesttTokenItem previous;
|
|
ffelexToken t;
|
|
};
|
|
|
|
struct _ffest_token_list_
|
|
{
|
|
ffesttTokenItem first;
|
|
ffesttTokenItem last;
|
|
int count; /* Number of tokens in list. */
|
|
};
|
|
|
|
struct _ffest_format_value_
|
|
{
|
|
bool present; /* TRUE if value supplied (needed for
|
|
optional values only). */
|
|
bool rtexpr; /* FALSE if constant value here, TRUE if
|
|
run-time expr (VXT). */
|
|
ffelexToken t; /* The first token, or perhaps just prior if
|
|
can't get it. */
|
|
union
|
|
{
|
|
ffeUnionLongPtr unused; /* Make sure all the info gets copied. */
|
|
long signed_val; /* for R1011. */
|
|
unsigned long unsigned_val; /* For other constant values. */
|
|
ffebld expr; /* For run-time expression (VXT). */
|
|
}
|
|
u;
|
|
};
|
|
|
|
struct _ffest_format_list_
|
|
{
|
|
ffesttFormatList next;
|
|
ffesttFormatList previous;
|
|
ffelexToken t; /* The NAME, CHARACTER, or HOLLERITH token. */
|
|
ffestpFormatType type;
|
|
union ffest_format_
|
|
{
|
|
struct
|
|
{
|
|
ffesttFormatValue R1004; /* r, the repeat count. */
|
|
ffesttFormatValue R1006; /* w, the field width. */
|
|
ffesttFormatValue R1007_or_R1008; /* m, the minimum number of
|
|
digits; d, the number of
|
|
decimal digits. */
|
|
ffesttFormatValue R1009; /* e, the number of exponent digits. */
|
|
}
|
|
R1005; /* data-edit-desc. */
|
|
struct
|
|
{
|
|
ffesttFormatValue val; /* r, the repeat count; k, the
|
|
precision magnitude adjustment; n,
|
|
the column number (abs or rel). */
|
|
}
|
|
R1010; /* control-edit-desc. */
|
|
struct
|
|
{
|
|
ffesttFormatValue R1004; /* r, the repeat count. */
|
|
ffesttFormatList format; /* the parenthesized
|
|
format-item-list. */
|
|
}
|
|
R1003D; /* format-item of for [r](format-item-list). */
|
|
struct
|
|
{
|
|
ffesttFormatList parent; /* NULL if outer list, else parent
|
|
item. */
|
|
}
|
|
root; /* FFESTP_formattypeNone case. */
|
|
}
|
|
u;
|
|
};
|
|
|
|
/* Global objects accessed by users of this module. */
|
|
|
|
|
|
/* Declare functions with prototypes. */
|
|
|
|
void ffestt_caselist_append (ffesttCaseList list, bool range, ffebld case1,
|
|
ffebld case2, ffelexToken t);
|
|
ffesttCaseList ffestt_caselist_create (void);
|
|
#if FFECOM_targetCURRENT == FFECOM_targetFFE
|
|
void ffestt_caselist_dump (ffesttCaseList list);
|
|
#endif
|
|
void ffestt_caselist_kill (ffesttCaseList list);
|
|
void ffestt_dimlist_append (ffesttDimList list, ffebld lower, ffebld upper,
|
|
ffelexToken t);
|
|
ffebld ffestt_dimlist_as_expr (ffesttDimList list, ffeinfoRank *rank,
|
|
ffebld *array_size, ffebld *extents,
|
|
bool is_ugly_assumed);
|
|
ffesttDimList ffestt_dimlist_create (void);
|
|
#if FFECOM_targetCURRENT == FFECOM_targetFFE
|
|
void ffestt_dimlist_dump (ffesttDimList list);
|
|
#endif
|
|
void ffestt_dimlist_kill (ffesttDimList list);
|
|
ffestpDimtype ffestt_dimlist_type (ffesttDimList dims, bool is_ugly_assumed);
|
|
void ffestt_exprlist_append (ffesttExprList list, ffebld expr, ffelexToken t);
|
|
ffesttExprList ffestt_exprlist_create (void);
|
|
void ffestt_exprlist_drive (ffesttExprList list, void (*fn) (ffebld, ffelexToken));
|
|
#if FFECOM_targetCURRENT == FFECOM_targetFFE
|
|
void ffestt_exprlist_dump (ffesttExprList list);
|
|
#endif
|
|
void ffestt_exprlist_kill (ffesttExprList list);
|
|
ffesttFormatList ffestt_formatlist_append (ffesttFormatList list);
|
|
ffesttFormatList ffestt_formatlist_create (ffesttFormatList parent,
|
|
ffelexToken t);
|
|
#if FFECOM_targetCURRENT == FFECOM_targetFFE
|
|
void ffestt_formatlist_dump (ffesttFormatList list);
|
|
#endif
|
|
void ffestt_formatlist_kill (ffesttFormatList list);
|
|
void ffestt_implist_append (ffesttImpList list, ffelexToken first,
|
|
ffelexToken last);
|
|
ffesttImpList ffestt_implist_create (void);
|
|
void ffestt_implist_drive (ffesttImpList list, void (*fn) (ffelexToken, ffelexToken));
|
|
#if FFECOM_targetCURRENT == FFECOM_targetFFE
|
|
void ffestt_implist_dump (ffesttImpList list);
|
|
#endif
|
|
void ffestt_implist_kill (ffesttImpList list);
|
|
void ffestt_tokenlist_append (ffesttTokenList list, ffelexToken t);
|
|
ffesttTokenList ffestt_tokenlist_create (void);
|
|
void ffestt_tokenlist_drive (ffesttTokenList list, void (*fn) (ffelexToken));
|
|
#if FFECOM_targetCURRENT == FFECOM_targetFFE
|
|
void ffestt_tokenlist_dump (ffesttTokenList list);
|
|
#endif
|
|
ffelexHandler ffestt_tokenlist_handle (ffesttTokenList list,
|
|
ffelexHandler handler);
|
|
void ffestt_tokenlist_kill (ffesttTokenList list);
|
|
|
|
/* Define macros. */
|
|
|
|
#define ffestt_init_0()
|
|
#define ffestt_init_1()
|
|
#define ffestt_init_2()
|
|
#define ffestt_init_3()
|
|
#define ffestt_init_4()
|
|
#define ffestt_terminate_0()
|
|
#define ffestt_terminate_1()
|
|
#define ffestt_terminate_2()
|
|
#define ffestt_terminate_3()
|
|
#define ffestt_terminate_4()
|
|
#define ffestt_tokenlist_count(tl) ((tl)->count)
|
|
|
|
/* End of #include file. */
|
|
|
|
#endif
|