254 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			254 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* f2c.h  --  Standard Fortran to C header file */
 | 
						|
 | 
						|
/**  barf  [ba:rf]  2.  "He suggested using FORTRAN, and everybody barfed."
 | 
						|
 | 
						|
	- From The Shogakukan DICTIONARY OF NEW ENGLISH (Second edition) */
 | 
						|
 | 
						|
#ifndef F2C_INCLUDE
 | 
						|
#define F2C_INCLUDE
 | 
						|
 | 
						|
#include <assert.h>
 | 
						|
#include <math.h>
 | 
						|
#include <ctype.h>
 | 
						|
#include <stdlib.h>
 | 
						|
/* needed for Windows Mobile */
 | 
						|
#ifdef WINCE
 | 
						|
#undef complex; 
 | 
						|
#endif
 | 
						|
#include <string.h>
 | 
						|
#include <stdio.h>
 | 
						|
 | 
						|
#if __SSE2__ || defined _M_X64
 | 
						|
#include "emmintrin.h"
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
extern "C" {
 | 
						|
#endif
 | 
						|
 | 
						|
typedef int integer;
 | 
						|
typedef unsigned int uinteger;
 | 
						|
typedef char *address;
 | 
						|
typedef short int shortint;
 | 
						|
typedef float real;
 | 
						|
typedef double doublereal;
 | 
						|
typedef struct { real r, i; } complex;
 | 
						|
typedef struct { doublereal r, i; } doublecomplex;
 | 
						|
typedef int logical;
 | 
						|
typedef short int shortlogical;
 | 
						|
typedef char logical1;
 | 
						|
typedef char integer1;
 | 
						|
#ifdef INTEGER_STAR_8	/* Adjust for integer*8. */
 | 
						|
typedef long long longint;		/* system-dependent */
 | 
						|
typedef unsigned long long ulongint;	/* system-dependent */
 | 
						|
#define qbit_clear(a,b)	((a) & ~((ulongint)1 << (b)))
 | 
						|
#define qbit_set(a,b)	((a) |  ((ulongint)1 << (b)))
 | 
						|
#endif
 | 
						|
 | 
						|
#define TRUE_ (1)
 | 
						|
#define FALSE_ (0)
 | 
						|
 | 
						|
/* Extern is for use with -E */
 | 
						|
#ifndef Extern
 | 
						|
#define Extern extern
 | 
						|
#endif
 | 
						|
 | 
						|
/* I/O stuff */
 | 
						|
 | 
						|
#ifdef f2c_i2
 | 
						|
/* for -i2 */
 | 
						|
typedef short flag;
 | 
						|
typedef short ftnlen;
 | 
						|
typedef short ftnint;
 | 
						|
#else
 | 
						|
typedef int flag;
 | 
						|
typedef int ftnlen;
 | 
						|
typedef int ftnint;
 | 
						|
#endif
 | 
						|
 | 
						|
/*external read, write*/
 | 
						|
typedef struct
 | 
						|
{	flag cierr;
 | 
						|
	ftnint ciunit;
 | 
						|
	flag ciend;
 | 
						|
	char *cifmt;
 | 
						|
	ftnint cirec;
 | 
						|
} cilist;
 | 
						|
 | 
						|
/*internal read, write*/
 | 
						|
typedef struct
 | 
						|
{	flag icierr;
 | 
						|
	char *iciunit;
 | 
						|
	flag iciend;
 | 
						|
	char *icifmt;
 | 
						|
	ftnint icirlen;
 | 
						|
	ftnint icirnum;
 | 
						|
} icilist;
 | 
						|
 | 
						|
/*open*/
 | 
						|
typedef struct
 | 
						|
{	flag oerr;
 | 
						|
	ftnint ounit;
 | 
						|
	char *ofnm;
 | 
						|
	ftnlen ofnmlen;
 | 
						|
	char *osta;
 | 
						|
	char *oacc;
 | 
						|
	char *ofm;
 | 
						|
	ftnint orl;
 | 
						|
	char *oblnk;
 | 
						|
} olist;
 | 
						|
 | 
						|
/*close*/
 | 
						|
typedef struct
 | 
						|
{	flag cerr;
 | 
						|
	ftnint cunit;
 | 
						|
	char *csta;
 | 
						|
} cllist;
 | 
						|
 | 
						|
/*rewind, backspace, endfile*/
 | 
						|
typedef struct
 | 
						|
{	flag aerr;
 | 
						|
	ftnint aunit;
 | 
						|
} alist;
 | 
						|
 | 
						|
/* inquire */
 | 
						|
typedef struct
 | 
						|
{	flag inerr;
 | 
						|
	ftnint inunit;
 | 
						|
	char *infile;
 | 
						|
	ftnlen infilen;
 | 
						|
	ftnint	*inex;	/*parameters in standard's order*/
 | 
						|
	ftnint	*inopen;
 | 
						|
	ftnint	*innum;
 | 
						|
	ftnint	*innamed;
 | 
						|
	char	*inname;
 | 
						|
	ftnlen	innamlen;
 | 
						|
	char	*inacc;
 | 
						|
	ftnlen	inacclen;
 | 
						|
	char	*inseq;
 | 
						|
	ftnlen	inseqlen;
 | 
						|
	char 	*indir;
 | 
						|
	ftnlen	indirlen;
 | 
						|
	char	*infmt;
 | 
						|
	ftnlen	infmtlen;
 | 
						|
	char	*inform;
 | 
						|
	ftnint	informlen;
 | 
						|
	char	*inunf;
 | 
						|
	ftnlen	inunflen;
 | 
						|
	ftnint	*inrecl;
 | 
						|
	ftnint	*innrec;
 | 
						|
	char	*inblank;
 | 
						|
	ftnlen	inblanklen;
 | 
						|
} inlist;
 | 
						|
 | 
						|
#define VOID void
 | 
						|
 | 
						|
union Multitype {	/* for multiple entry points */
 | 
						|
	integer1 g;
 | 
						|
	shortint h;
 | 
						|
	integer i;
 | 
						|
	/* longint j; */
 | 
						|
	real r;
 | 
						|
	doublereal d;
 | 
						|
	complex c;
 | 
						|
	doublecomplex z;
 | 
						|
	};
 | 
						|
 | 
						|
typedef union Multitype Multitype;
 | 
						|
 | 
						|
/*typedef long int Long;*/	/* No longer used; formerly in Namelist */
 | 
						|
 | 
						|
struct Vardesc {	/* for Namelist */
 | 
						|
	char *name;
 | 
						|
	char *addr;
 | 
						|
	ftnlen *dims;
 | 
						|
	int  type;
 | 
						|
	};
 | 
						|
typedef struct Vardesc Vardesc;
 | 
						|
 | 
						|
struct Namelist {
 | 
						|
	char *name;
 | 
						|
	Vardesc **vars;
 | 
						|
	int nvars;
 | 
						|
	};
 | 
						|
typedef struct Namelist Namelist;
 | 
						|
 | 
						|
#ifndef abs
 | 
						|
#define abs(x) ((x) >= 0 ? (x) : -(x))
 | 
						|
#endif
 | 
						|
#define dabs(x) (doublereal)abs(x)
 | 
						|
#ifndef min
 | 
						|
#define min(a,b) ((a) <= (b) ? (a) : (b))
 | 
						|
#endif
 | 
						|
#ifndef max
 | 
						|
#define max(a,b) ((a) >= (b) ? (a) : (b))
 | 
						|
#endif
 | 
						|
#define dmin(a,b) (doublereal)min(a,b)
 | 
						|
#define dmax(a,b) (doublereal)max(a,b)
 | 
						|
#define bit_test(a,b)	((a) >> (b) & 1)
 | 
						|
#define bit_clear(a,b)	((a) & ~((uinteger)1 << (b)))
 | 
						|
#define bit_set(a,b)	((a) |  ((uinteger)1 << (b)))
 | 
						|
 | 
						|
/* procedure parameter types for -A and -C++ */
 | 
						|
 | 
						|
#define F2C_proc_par_types 1
 | 
						|
#ifdef __cplusplus
 | 
						|
typedef int /* Unknown procedure type */ (*U_fp)(...);
 | 
						|
typedef shortint (*J_fp)(...);
 | 
						|
typedef integer (*I_fp)(...);
 | 
						|
typedef real (*R_fp)(...);
 | 
						|
typedef doublereal (*D_fp)(...), (*E_fp)(...);
 | 
						|
typedef /* Complex */ VOID (*C_fp)(...);
 | 
						|
typedef /* Double Complex */ VOID (*Z_fp)(...);
 | 
						|
typedef logical (*L_fp)(...);
 | 
						|
typedef shortlogical (*K_fp)(...);
 | 
						|
typedef /* Character */ VOID (*H_fp)(...);
 | 
						|
typedef /* Subroutine */ int (*S_fp)(...);
 | 
						|
#else
 | 
						|
typedef int /* Unknown procedure type */ (*U_fp)();
 | 
						|
typedef shortint (*J_fp)();
 | 
						|
typedef integer (*I_fp)();
 | 
						|
typedef real (*R_fp)();
 | 
						|
typedef doublereal (*D_fp)(), (*E_fp)();
 | 
						|
typedef /* Complex */ VOID (*C_fp)();
 | 
						|
typedef /* Double Complex */ VOID (*Z_fp)();
 | 
						|
typedef logical (*L_fp)();
 | 
						|
typedef shortlogical (*K_fp)();
 | 
						|
typedef /* Character */ VOID (*H_fp)();
 | 
						|
typedef /* Subroutine */ int (*S_fp)();
 | 
						|
#endif
 | 
						|
/* E_fp is for real functions when -R is not specified */
 | 
						|
typedef VOID C_f;	/* complex function */
 | 
						|
typedef VOID H_f;	/* character function */
 | 
						|
typedef VOID Z_f;	/* double complex function */
 | 
						|
typedef doublereal E_f;	/* real function with -R not specified */
 | 
						|
 | 
						|
/* undef any lower-case symbols that your C compiler predefines, e.g.: */
 | 
						|
 | 
						|
#ifndef Skip_f2c_Undefs
 | 
						|
#undef cray
 | 
						|
#undef gcos
 | 
						|
#undef mc68010
 | 
						|
#undef mc68020
 | 
						|
#undef mips
 | 
						|
#undef pdp11
 | 
						|
#undef sgi
 | 
						|
#undef sparc
 | 
						|
#undef sun
 | 
						|
#undef sun2
 | 
						|
#undef sun3
 | 
						|
#undef sun4
 | 
						|
#undef u370
 | 
						|
#undef u3b
 | 
						|
#undef u3b2
 | 
						|
#undef u3b5
 | 
						|
#undef unix
 | 
						|
#undef vax
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
}
 | 
						|
#endif
 | 
						|
 | 
						|
#endif
 |