ratfor man page on DragonFly

Man page or keyword search:  
man Server   44335 pages
apropos Keyword Search (all sections)
Output format
DragonFly logo
[printable version]

RATFOR77(1)		  BSD 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 com‐
	     piler 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 expres‐
     sion that resolves into an integer value.	A statement is terminated by
     an end-of-line or a semicolon.  The following translations are also per‐
     formed.

     <.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 sym‐
bolic 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 ini‐
tialized 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 val‐
     ued 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

BSD				August 26, 2000				   BSD
[top]

List of man pages available for DragonFly

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net