⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 libgfortran.h

📁 gcc-fortran,linux使用fortran的编译软件。很好用的。
💻 H
📖 第 1 页 / 共 2 页
字号:
/* Common declarations for all of libgfortran.   Copyright (C) 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc.   Contributed by Paul Brook <paul@nowt.org>, and   Andy Vaught <andy@xena.eas.asu.edu>This file is part of the GNU Fortran 95 runtime library (libgfortran).Libgfortran is free software; you can redistribute it and/ormodify it under the terms of the GNU Lesser General PublicLicense as published by the Free Software Foundation; eitherversion 2.1 of the License, or (at your option) any later version.Libgfortran 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 Lesser General Public License for more details.You should have received a copy of the GNU Lesser General PublicLicense along with libgfor; see the file COPYING.LIB.  If not,write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,Boston, MA 02110-1301, USA.  *//* As a special exception, if you link this library with other files,   some of which are compiled with GCC, to produce an executable,   this library does not by itself cause the resulting executable   to be covered by the GNU General Public License.   This exception does not however invalidate any other reasons why   the executable file might be covered by the GNU General Public License.  */#ifndef LIBGFOR_H#define LIBGFOR_H#include <math.h>#include <stddef.h>#ifndef M_PI#define M_PI 3.14159265358979323846264338327#endif#if HAVE_COMPLEX_H# include <complex.h>#else#define complex __complex__#endif#include "config.h"#include "c99_protos.h"#if HAVE_IEEEFP_H#include <ieeefp.h>#endif#include "gstdint.h"#if HAVE_SYS_TYPES_H#include <sys/types.h>#endiftypedef off_t gfc_offset;#ifndef NULL#define NULL (void *) 0#endif#ifndef __GNUC__#define __attribute__(x)#endif/* For a library, a standard prefix is a requirement in order to partition   the namespace.  IPREFIX is for symbols intended to be internal to the   library.  */#define PREFIX(x)	_gfortran_ ## x#define IPREFIX(x)	_gfortrani_ ## x/* Magic to rename a symbol at the compiler level.  You continue to refer   to the symbol as OLD in the source, but it'll be named NEW in the asm.  */#define sym_rename(old, new) sym_rename1(old, __USER_LABEL_PREFIX__, new)#define sym_rename1(old, ulp, new) sym_rename2(old, ulp, new)#define sym_rename2(old, ulp, new) extern __typeof(old) old __asm__(#ulp #new)/* There are several classifications of routines:     (1) Symbols used only within the library,     (2) Symbols to be exported from the library,     (3) Symbols to be exported from the library, but	 also used inside the library.   By telling the compiler about these different classifications we can   tightly control the interface seen by the user, and get better code   from the compiler at the same time.   One of the following should be used immediately after the declaration   of each symbol:     internal_proto	Marks a symbol used only within the library,			and adds IPREFIX to the assembly-level symbol			name.  The later is important for maintaining			the namespace partition for the static library.     export_proto	Marks a symbol to be exported, and adds PREFIX			to the assembly-level symbol name.     export_proto_np	Marks a symbol to be exported without adding PREFIX.     iexport_proto	Marks a function to be exported, but with the 			understanding that it can be used inside as well.     iexport_data_proto	Similarly, marks a data symbol to be exported.			Unfortunately, some systems can't play the hidden			symbol renaming trick on data symbols, thanks to			the horribleness of COPY relocations.   If iexport_proto or iexport_data_proto is used, you must also use   iexport or iexport_data after the *definition* of the symbol.  */#if defined(HAVE_ATTRIBUTE_VISIBILITY)# define internal_proto(x) \	sym_rename(x, IPREFIX (x)) __attribute__((__visibility__("hidden")))#else# define internal_proto(x)	sym_rename(x, IPREFIX(x))#endif#if defined(HAVE_ATTRIBUTE_VISIBILITY) && defined(HAVE_ATTRIBUTE_ALIAS)# define export_proto(x)	sym_rename(x, PREFIX(x))# define export_proto_np(x)	extern char swallow_semicolon# define iexport_proto(x)	internal_proto(x)# define iexport(x)		iexport1(x, __USER_LABEL_PREFIX__, IPREFIX(x))# define iexport1(x,p,y)	iexport2(x,p,y)# define iexport2(x,p,y) \	extern __typeof(x) PREFIX(x) __attribute__((__alias__(#p #y)))/* ??? We're not currently building a dll, and it's wrong to add dllexport   to objects going into a static library archive.  */#elif 0 && defined(HAVE_ATTRIBUTE_DLLEXPORT)# define export_proto_np(x)	extern __typeof(x) x __attribute__((dllexport))# define export_proto(x)    sym_rename(x, PREFIX(x)) __attribute__((dllexport))# define iexport_proto(x)	export_proto(x)# define iexport(x)		extern char swallow_semicolon#else# define export_proto(x)	sym_rename(x, PREFIX(x))# define export_proto_np(x)	extern char swallow_semicolon# define iexport_proto(x)	export_proto(x)# define iexport(x)		extern char swallow_semicolon#endif/* TODO: detect the case when we *can* hide the symbol.  */#define iexport_data_proto(x)	export_proto(x)#define iexport_data(x)		extern char swallow_semicolon/* The only reliable way to get the offset of a field in a struct   in a system independent way is via this macro.  */#ifndef offsetof#define offsetof(TYPE, MEMBER)  ((size_t) &((TYPE *) 0)->MEMBER)#endif/* The isfinite macro is only available with C99, but some non-C99   systems still provide fpclassify, and there is a `finite' function   in BSD.   Also, isfinite is broken on Cygwin.   When isfinite is not available, try to use one of the   alternatives, or bail out.  */#if defined(HAVE_BROKEN_ISFINITE) || defined(__CYGWIN__)#undef isfinite#endif#if defined(HAVE_BROKEN_ISNAN)#undef isnan#endif#if defined(HAVE_BROKEN_FPCLASSIFY)#undef fpclassify#endif#if !defined(isfinite)#if !defined(fpclassify)#define isfinite(x) ((x) - (x) == 0)#else#define isfinite(x) (fpclassify(x) != FP_NAN && fpclassify(x) != FP_INFINITE)#endif /* !defined(fpclassify) */#endif /* !defined(isfinite)  */#if !defined(isnan)#if !defined(fpclassify)#define isnan(x) ((x) != (x))#else#define isnan(x) (fpclassify(x) == FP_NAN)#endif /* !defined(fpclassify) */#endif /* !defined(isfinite)  *//* TODO: find the C99 version of these an move into above ifdef.  */#define REALPART(z) (__real__(z))#define IMAGPART(z) (__imag__(z))#define COMPLEX_ASSIGN(z_, r_, i_) {__real__(z_) = (r_); __imag__(z_) = (i_);}#include "kinds.h"/* The following two definitions must be consistent with the types used   by the compiler.  *//* The type used of array indices, amongst other things.  */typedef ssize_t index_type;/* The type used for the lengths of character variables.  */typedef GFC_INTEGER_4 gfc_charlen_type;/* This will be 0 on little-endian machines and one on big-endian machines.  */extern int l8_to_l4_offset;internal_proto(l8_to_l4_offset);#define GFOR_POINTER_L8_TO_L4(p8) \  (l8_to_l4_offset + (GFC_LOGICAL_4 *)(p8))#define GFC_INTEGER_4_HUGE \  (GFC_INTEGER_4)((((GFC_UINTEGER_4)1) << 31) - 1)#define GFC_INTEGER_8_HUGE \  (GFC_INTEGER_8)((((GFC_UINTEGER_8)1) << 63) - 1)#ifdef HAVE_GFC_INTEGER_16#define GFC_INTEGER_16_HUGE \  (GFC_INTEGER_16)((((GFC_UINTEGER_16)1) << 127) - 1)#endif#define GFC_REAL_4_HUGE FLT_MAX#define GFC_REAL_8_HUGE DBL_MAX#ifdef HAVE_GFC_REAL_10#define GFC_REAL_10_HUGE LDBL_MAX#endif#ifdef HAVE_GFC_REAL_16#define GFC_REAL_16_HUGE LDBL_MAX#endif#ifndef GFC_MAX_DIMENSIONS#define GFC_MAX_DIMENSIONS 7#endiftypedef struct descriptor_dimension{  index_type stride;  index_type lbound;  index_type ubound;}descriptor_dimension;#define GFC_ARRAY_DESCRIPTOR(r, type) \struct {\  type *data;\  size_t offset;\  index_type dtype;\  descriptor_dimension dim[r];\}/* Commonly used array descriptor types.  */typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, void) gfc_array_void;typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, char) gfc_array_char;typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_INTEGER_4) gfc_array_i4;typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_INTEGER_8) gfc_array_i8;#ifdef HAVE_GFC_INTEGER_16typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_INTEGER_16) gfc_array_i16;#endiftypedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_REAL_4) gfc_array_r4;typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_REAL_8) gfc_array_r8;#ifdef HAVE_GFC_REAL_10typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_REAL_10) gfc_array_r10;#endif#ifdef HAVE_GFC_REAL_16typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_REAL_16) gfc_array_r16;#endiftypedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_COMPLEX_4) gfc_array_c4;typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_COMPLEX_8) gfc_array_c8;#ifdef HAVE_GFC_COMPLEX_10typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_COMPLEX_10) gfc_array_c10;#endif#ifdef HAVE_GFC_COMPLEX_16typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_COMPLEX_16) gfc_array_c16;#endiftypedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_LOGICAL_4) gfc_array_l4;typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_LOGICAL_8) gfc_array_l8;#ifdef HAVE_GFC_LOGICAL_16typedef GFC_ARRAY_DESCRIPTOR (GFC_MAX_DIMENSIONS, GFC_LOGICAL_16) gfc_array_l16;#endif#define GFC_DTYPE_RANK_MASK 0x07#define GFC_DTYPE_TYPE_SHIFT 3#define GFC_DTYPE_TYPE_MASK 0x38#define GFC_DTYPE_SIZE_SHIFT 6enum{  GFC_DTYPE_UNKNOWN = 0,  GFC_DTYPE_INTEGER,  /* TODO: recognize logical types.  */  GFC_DTYPE_LOGICAL,  GFC_DTYPE_REAL,  GFC_DTYPE_COMPLEX,  GFC_DTYPE_DERIVED,  GFC_DTYPE_CHARACTER};#define GFC_DESCRIPTOR_RANK(desc) ((desc)->dtype & GFC_DTYPE_RANK_MASK)#define GFC_DESCRIPTOR_TYPE(desc) (((desc)->dtype & GFC_DTYPE_TYPE_MASK) \                                   >> GFC_DTYPE_TYPE_SHIFT)#define GFC_DESCRIPTOR_SIZE(desc) ((desc)->dtype >> GFC_DTYPE_SIZE_SHIFT)#define GFC_DESCRIPTOR_DATA(desc) ((desc)->data)#define GFC_DESCRIPTOR_DTYPE(desc) ((desc)->dtype)/* Runtime library include.  */#define stringize(x) expand_macro(x)#define expand_macro(x) # x/* Runtime options structure.  */typedef struct{  int stdin_unit, stdout_unit, stderr_unit, optional_plus;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -