📄 info.c
字号:
/* info.c -- Implementation File (module.c 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 modifyit under the terms of the GNU General Public License as published bythe 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 ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with GNU Fortran; see the file COPYING. If not, write tothe Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA02111-1307, USA. Related Modules: None Description: An abstraction for information maintained on a per-operator and per- operand basis in expression trees. Modifications: 30-Aug-90 JCB 2.0 Extensive rewrite for new cleaner approach.*//* Include files. */#include "proj.h"#include "info.h"#include "target.h"#include "type.h"/* Externals defined here. *//* Simple definitions and enumerations. *//* Internal typedefs. *//* Private include files. *//* Internal structure definitions. *//* Static objects accessed by functions in this module. */static const char *ffeinfo_basictype_string_[]={#define FFEINFO_BASICTYPE(KWD,LNAM,SNAM) SNAM,#include "info-b.def"#undef FFEINFO_BASICTYPE};static const char *ffeinfo_kind_message_[]={#define FFEINFO_KIND(KWD,LNAM,SNAM) LNAM,#include "info-k.def"#undef FFEINFO_KIND};static const char *ffeinfo_kind_string_[]={#define FFEINFO_KIND(KWD,LNAM,SNAM) SNAM,#include "info-k.def"#undef FFEINFO_KIND};static ffeinfoBasictype ffeinfo_combine_[FFEINFO_basictype][FFEINFO_basictype];static const char *ffeinfo_kindtype_string_[]={ "", "1", "2", "3", "4", "5", "6", "7", "8", "*",};static const char *ffeinfo_where_string_[]={#define FFEINFO_WHERE(KWD,LNAM,SNAM) SNAM,#include "info-w.def"#undef FFEINFO_WHERE};static ffetype ffeinfo_types_[FFEINFO_basictype][FFEINFO_kindtype] = { { NULL } };/* Static functions (internal). *//* Internal macros. *//* ffeinfo_basictype_combine -- Combine two basictypes into highest rank type ffeinfoBasictype i, j, k; k = ffeinfo_basictype_combine(i,j); Returns a type based on "standard" operation between two given types. */ffeinfoBasictypeffeinfo_basictype_combine (ffeinfoBasictype l, ffeinfoBasictype r){ assert (l < FFEINFO_basictype); assert (r < FFEINFO_basictype); return ffeinfo_combine_[l][r];}/* ffeinfo_basictype_string -- Return tiny string showing the basictype ffeinfoBasictype i; printf("%s",ffeinfo_basictype_string(dt)); Returns the string based on the basic type. */const char *ffeinfo_basictype_string (ffeinfoBasictype basictype){ if (basictype >= ARRAY_SIZE (ffeinfo_basictype_string_)) return "?\?\?"; return ffeinfo_basictype_string_[basictype];}/* ffeinfo_init_0 -- Initialize ffeinfo_init_0(); */voidffeinfo_init_0 (){ ffeinfoBasictype i; ffeinfoBasictype j; assert (FFEINFO_basictype == ARRAY_SIZE (ffeinfo_basictype_string_)); assert (FFEINFO_kind == ARRAY_SIZE (ffeinfo_kind_message_)); assert (FFEINFO_kind == ARRAY_SIZE (ffeinfo_kind_string_)); assert (FFEINFO_kindtype == ARRAY_SIZE (ffeinfo_kindtype_string_)); assert (FFEINFO_where == ARRAY_SIZE (ffeinfo_where_string_)); /* Make array that, given two basic types, produces resulting basic type. */ for (i = 0; i < FFEINFO_basictype; ++i) for (j = 0; j < FFEINFO_basictype; ++j) if ((i == FFEINFO_basictypeANY) || (j == FFEINFO_basictypeANY)) ffeinfo_combine_[i][j] = FFEINFO_basictypeANY; else ffeinfo_combine_[i][j] = FFEINFO_basictypeNONE;#define same(bt) ffeinfo_combine_[bt][bt] = bt#define use2(bt1,bt2) ffeinfo_combine_[bt1][bt2] \ = ffeinfo_combine_[bt2][bt1] = bt2 same (FFEINFO_basictypeINTEGER); same (FFEINFO_basictypeLOGICAL); same (FFEINFO_basictypeREAL); same (FFEINFO_basictypeCOMPLEX); same (FFEINFO_basictypeCHARACTER); use2 (FFEINFO_basictypeINTEGER, FFEINFO_basictypeREAL); use2 (FFEINFO_basictypeINTEGER, FFEINFO_basictypeCOMPLEX); use2 (FFEINFO_basictypeREAL, FFEINFO_basictypeCOMPLEX);#undef same#undef use2}/* ffeinfo_kind_message -- Return helpful string showing the kind ffeinfoKind kind; printf("%s",ffeinfo_kind_message(kind)); Returns the string based on the kind. */const char *ffeinfo_kind_message (ffeinfoKind kind){ if (kind >= ARRAY_SIZE (ffeinfo_kind_message_)) return "?\?\?"; return ffeinfo_kind_message_[kind];}/* ffeinfo_kind_string -- Return tiny string showing the kind ffeinfoKind kind; printf("%s",ffeinfo_kind_string(kind)); Returns the string based on the kind. */const char *ffeinfo_kind_string (ffeinfoKind kind){ if (kind >= ARRAY_SIZE (ffeinfo_kind_string_)) return "?\?\?"; return ffeinfo_kind_string_[kind];}ffeinfoKindtypeffeinfo_kindtype_max(ffeinfoBasictype bt, ffeinfoKindtype k1, ffeinfoKindtype k2){ if ((bt == FFEINFO_basictypeANY) || (k1 == FFEINFO_kindtypeANY) || (k2 == FFEINFO_kindtypeANY)) return FFEINFO_kindtypeANY; if (ffetype_size (ffeinfo_types_[bt][k1]) > ffetype_size (ffeinfo_types_[bt][k2])) return k1; return k2;}/* ffeinfo_kindtype_string -- Return tiny string showing the kind type ffeinfoKindtype kind_type; printf("%s",ffeinfo_kindtype_string(kind)); Returns the string based on the kind type. */const char *ffeinfo_kindtype_string (ffeinfoKindtype kind_type){ if (kind_type >= ARRAY_SIZE (ffeinfo_kindtype_string_)) return "?\?\?"; return ffeinfo_kindtype_string_[kind_type];}voidffeinfo_set_type (ffeinfoBasictype basictype, ffeinfoKindtype kindtype, ffetype type){ assert (basictype < FFEINFO_basictype); assert (kindtype < FFEINFO_kindtype); assert (ffeinfo_types_[basictype][kindtype] == NULL); ffeinfo_types_[basictype][kindtype] = type;}ffetypeffeinfo_type (ffeinfoBasictype basictype, ffeinfoKindtype kindtype){ assert (basictype < FFEINFO_basictype); assert (kindtype < FFEINFO_kindtype); return ffeinfo_types_[basictype][kindtype];}/* ffeinfo_where_string -- Return tiny string showing the where ffeinfoWhere where; printf("%s",ffeinfo_where_string(where)); Returns the string based on the where. */const char *ffeinfo_where_string (ffeinfoWhere where){ if (where >= ARRAY_SIZE (ffeinfo_where_string_)) return "?\?\?"; return ffeinfo_where_string_[where];}/* ffeinfo_new -- Return object representing datatype, kind, and where info ffeinfo i; i = ffeinfo_new(FFEINFO_datatypeINTEGER,FFEINFO_kindSCALAR, FFEINFO_whereLOCAL); Returns the string based on the data type. */#ifndef __GNUC__ffeinfoffeinfo_new (ffeinfoBasictype basictype, ffeinfoKindtype kindtype, ffeinfoRank rank, ffeinfoKind kind, ffeinfoWhere where, ffetargetCharacterSize size){ ffeinfo i; i.basictype = basictype; i.kindtype = kindtype; i.rank = rank; i.size = size; i.kind = kind; i.where = where; i.size = size; return i;}#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -