DragonFly On-Line Manual Pages

Search: Section:  


RATFOR77(1)            DragonFly General Commands Manual           RATFOR77(1)

NAME

ratfor77 - ratfor preprocessor for fortran77

SYNOPSIS

ratfor77 [-C] [-l n] [-o output] [input]

DESCRIPTION

Ratfor77 reads the ratfor source code in the file input (or standard input if input is not given) and converts it Fortran77 source code. The following options are available: -C If the -C options is specified, ratfor77 will keep the comments from the ratfor source in the Fortran77 output (useful for compiler directives). -l n The user sets the starting label to n. -o output Specify output file, otherwise it is the standard output. Ratfor has the following syntax: prog: stat prog stat stat: if (...) stat if (...) stat else stat while (...) stat repeat stat repeat stat until (...) for (...;...;...) stat do ... stat switch (intexpr) { case val[,val]: stmt ... default: stmt } break n next n return (...) digits stat { prog } or [ prog ] or $( prog $) anything unrecognizable where stat is any Fortran or Ratfor statement, and intexpr is an expression that resolves into an integer value. A statement is terminated by an end-of-line or a semicolon. The following translations are also performed. <.lt.<=.le. ==.eq. !=.ne.^=.ne. ~=.ne. >=.ge.>.gt. |.or.&.and. !.not.^.not. ~.not. Integer constants in bases other that decimal may be specified as n%dddd... where n is a decimal number indicating the base and dddd... are digits in that base. For bases > 10, letters are used for digits above 9. Examples: 8%77, 16%2ff, 2%0010011. The number is converted the equivalent decimal value using multiplication; this may cause sign problems if the number has too many digits. String literals ("..." or '...') can be continued across line boundaries by ending the line to be continued with an underline. The underline is not included as part of the literal. Leading blanks and tabs on the next line are ignored; this facilitates consistent indentation. include file will include the named file in the input. define (name,value) or define name value defines name as a symbolic parameter with the indicated value. Names of symbolic parameters may contain letters, digits, periods, and underline character but must begin with a letter (e.g. B.FLAG). Upper case is not equivalent to lower case in parameter names. string name "character string" or string name(size) "character string" defines name to be an integer array long enough to accomodate the ascii codes for the given character string, one per word. The last word of name is initialized to the symbolic parameter EOS, and indicates the end of string.

HISTORY

This is a C version of ratfor, derived from a UofA ratfor in ratfor. It was originally released to the net sometime ago, and It is re-released for the benefit of those sites who only get mod->comp.sources. It now includes minor changes to produce F77 code as well. This code *is* PD. You (public) have all the rights to the code. [But this also means you (singular) do not have any *extra* rights to the code, hence it is impossible for you to restrict the use and distribution of this code in any way.] I would, as usual, appreciate hearing about bug fixes and improvements. oz Usenet: [decvax|ihnp4]!utzoo!yetti!oz || ...seismo!mnetor!yetti!oz Bitnet: oz@[yusol|yuyetti].BITNET Phonet: [416] 736-5257 x 3976

BUGS

This is not a bug but a design error in both AT&T ratfor and this public domain ratfor: The problem is with the switch statment. It switches on an integer valued expression. It should switch on an integer variable. The reason is that "implicit undefined" "implicit null" is unusable because the switch is done on a new variable that is not declared or declarable by the programmer who cannot guess its name. Please let me know if you fix this. jon@sep.stanford.edu.us DragonFly 6.5-DEVELOPMENT August 26, 2000 DragonFly 6.5-DEVELOPMENT

Search: Section: