📄 readme.netlib
字号:
If your compiler does not recognize ANSI C headers,compile with KR_headers defined: either add -DKR_headersto the definition of CFLAGS in the makefile, or insert#define KR_headersat the top of f2c.h and fmtlib.c .If you have a really ancient K&R C compiler that does not understandvoid, add -Dvoid=int to the definition of CFLAGS in the makefile.If you use a C++ compiler, first create a local f2c.h by appendingf2ch.add to the usual f2c.h, e.g., by issuing the command make f2c.hwhich assumes f2c.h is installed in /usr/include .If your system lacks /usr/include/fcntl.h , then youshould simply create an empty fcntl.h in this directory.If your compiler then complains about creat and open nothaving a prototype, compile with OPEN_DECL defined.On many systems, open and creat are declared in fcntl.h .If your system has /usr/include/fcntl.h, you may need to add-D_POSIX_SOURCE to the makefile's definition of CFLAGS.If your system's sprintf does not work the way ANSI Cspecifies -- specifically, if it does not return thenumber of characters transmitted -- then insert the line#define USE_STRLENat the end of fmt.h . This is necessary withat least some versions of Sun and DEC software.In particular, if you get a warning about an improperpointer/integer combination in compiling wref.c, thenyou need to compile with -DUSE_STRLEN .If your system's fopen does not like the ANSI binaryreading and writing modes "rb" and "wb", then you shouldcompile open.c with NON_ANSI_RW_MODES #defined.If you get error messages about references to cf->_ptrand cf->_base when compiling wrtfmt.c and wsfe.c or tostderr->_flag when compiling err.c, then insert the line#define NON_UNIX_STDIOat the beginning of fio.h, and recompile everything (orat least those modules that contain NON_UNIX_STDIO).Unformatted sequential records consist of a length of recordcontents, the record contents themselves, and the length ofrecord contents again (for backspace). Prior to 17 Oct. 1991,the length was of type int; now it is of type long, but youcan change it back to int by inserting#define UIOLEN_intat the beginning of fio.h. This affects only sue.c and uio.c .On VAX, Cray, or Research Tenth-Edition Unix systems, you mayneed to add -DVAX, -DCRAY, or -DV10 (respectively) to CFLAGSto make fp.h work correctly. Alternatively, you may need toedit fp.h to suit your machine.You may need to supply the following non-ANSI routines: fstat(int fileds, struct stat *buf) is similarto stat(char *name, struct stat *buf), except thatthe first argument, fileds, is the file descriptorreturned by open rather than the name of the file.fstat is used in the system-dependent routinecanseek (in the libI77 source file err.c), whichis supposed to return 1 if it's possible to issueseeks on the file in question, 0 if it's not; you mayneed to suitably modify err.c . On non-UNIX systems,you can avoid references to fstat and stat by compilingwith NON_UNIX_STDIO defined; in that case, you may needto supply access(char *Name,0), which is supposed toreturn 0 if file Name exists, nonzero otherwise. char * mktemp(char *buf) is supposed to replace the6 trailing X's in buf with a unique number and thenreturn buf. The idea is to get a unique name fora temporary file.On non-UNIX systems, you may need to change a few other,e.g.: the form of name computed by mktemp() in endfile.c andopen.c; the use of the open(), close(), and creat() systemcalls in endfile.c, err.c, open.c; and the modes in calls onfopen() and fdopen() (and perhaps the use of fdopen() itself-- it's supposed to return a FILE* corresponding to a givenan integer file descriptor) in err.c and open.c (component ufmtof struct unit is 1 for formatted I/O -- text mode on some systems-- and 0 for unformatted I/O -- binary mode on some systems).Compiling with -DNON_UNIX_STDIO omits all references to creat()and almost all references to open() and close(), the exceptionbeing in the function f__isdev() (in open.c).For MS-DOS, compile all of libI77 with -DMSDOS (which implies-DNON_UNIX_STDIO). You may need to make other compiler-dependentadjustments; for example, for Turbo C++ you need to adjust the mktempinvocations and to #undef ungetc in lread.c and rsne.c .If you want to be able to load against libI77 but not libF77,then you will need to add sig_die.o (from libF77) to libI77.If you wish to use translated Fortran that has funny notionsof record length for direct unformatted I/O (i.e., that assumesRECL= values in OPEN statements are not bytes but rather countsof some other units -- e.g., 4-character words for VMS), then youshould insert an appropriate #define for url_Adjust at thebeginning of open.c . For VMS Fortran, for example,#define url_Adjust(x) x *= 4would suffice.To check for transmission errors, issue the command make checkThis assumes you have the xsum program whose source, xsum.c,is distributed as part of "all from f2c/src". If you do nothave xsum, you can obtain xsum.c by sending the following E-mailmessage to netlib@netlib.bell-labs.com send xsum.c from f2c/srcThe makefile assumes you have installed f2c.h in a standardplace (and does not cause recompilation when f2c.h is changed);f2c.h comes with "all from f2c" (the source for f2c) and isavailable separately ("f2c.h from f2c").By default, Fortran I/O units 5, 6, and 0 are pre-connected tostdin, stdout, and stderr, respectively. You can change thisbehavior by changing f_init() in err.c to suit your needs.Note that f2c assumes READ(*... means READ(5... and WRITE(*...means WRITE(6... . Moreover, an OPEN(n,... statement that doesnot specify a file name (and does not specify STATUS='SCRATCH')assumes FILE='fort.n' . You can change this by editing open.cand endfile.c suitably.Unless you adjust the "#define MXUNIT" line in fio.h, Fortran units0, 1, ..., 99 are available, i.e., the highest allowed unit numberis MXUNIT - 1.Lines protected from compilation by #ifdef Allow_TYQUADare for a possible extension to 64-bit integers in whichinteger = int = 32 bits and longint = long = 64 bits.Extensions (Feb. 1993) to NAMELIST processing: 1. Reading a ? instead of &name (the start of a namelist) causesthe namelist being sought to be written to stdout (unit 6);to omit this feature, compile rsne.c with -DNo_Namelist_Questions. 2. Reading the wrong namelist name now leads to an error messageand an attempt to skip input until the right namelist name is found;to omit this feature, compile rsne.c with -DNo_Bad_Namelist_Skip. 3. Namelist writes now insert newlines before each variable; to omitthis feature, compile xwsne.c with -DNo_Extra_Namelist_Newlines. 4. (Sept. 1995) When looking for the &name that starts namelistinput, lines whose first non-blank character is something otherthan &, $, or ? are treated as comment lines and ignored, unlessrsne.c is compiled with -DNo_Namelist_Comments.Nonstandard extension (Feb. 1993) to open: for sequential files,ACCESS='APPEND' (or access='anything else starting with "A" or "a"')causes the file to be positioned at end-of-file, so a write willappend to the file.Some buggy Fortran programs use unformatted direct I/O to writean incomplete record and later read more from that record thanthey have written. For records other than the last, the unwrittenportion of the record reads as binary zeros. The last record isa special case: attempting to read more from it than was writtengives end-of-file -- which may help one find a bug. Some otherFortran I/O libraries treat the last record no differently thanothers and thus give no help in finding the bug of reading morethan was written. If you wish to have this behavior, compileuio.c with -DPad_UDread .If you want to be able to catch write failures (e.g., due to adisk being full) with an ERR= specifier, compile dfe.c, due.c,sfe.c, sue.c, and wsle.c with -DALWAYS_FLUSH. This will lead toslower execution and more I/O, but should make ERR= work asexpected, provided fflush returns an error return when itsphysical write fails.Carriage controls are meant to be interpreted by the UNIX colprogram (or a similar program). Sometimes it's convenient to useonly ' ' as the carriage control character (normal single spacing).If you compile lwrite.c and wsfe.c with -DOMIT_BLANK_CC, formattedexternal output lines will have an initial ' ' quietly omitted,making use of the col program unnecessary with output that onlyhas ' ' for carriage control.The Fortran 77 Standard leaves it up to the implementation whetherformatted writes of floating-point numbers of absolute value < 1 havea zero before the decimal point. By default, libI77 omits suchsuperfluous zeros, but you can cause them to appear by compilinglwrite.c, wref.c, and wrtfmt.c with -DWANT_LEAD_0 .If your system lacks a ranlib command, you don't need it.Either comment out the makefile's ranlib invocation, or installa harmless "ranlib" command somewhere in your PATH, such as theone-line shell script exit 0or (on some systems) exec /usr/bin/ar lts $1 >/dev/nullMost of the routines in libI77 are support routines for FortranI/O. There are a few exceptions, summarized below -- I/O relatedfunctions and subroutines that appear to your program as ordinaryexternal Fortran routines.1. CALL FLUSH flushes all buffers.2. FTELL(i) is an INTEGER function that returns the current offset of Fortran unit i (or -1 if unit i is not open).3. CALL FSEEK(i, offset, whence, *errlab) attemps to move Fortran unit i to the specified offset: absolute offset if whence = 0; relative to the current offset if whence = 1; relative to the end of the file if whence = 2. It branches to label errlab if unit i is not open or if the call otherwise fails.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -