/forpedo

A Fortran 90/95 preprocessor for generics and polymorphism.

Primary LanguagePythonBSD 3-Clause "New" or "Revised" LicenseBSD-3-Clause

Forpedo (v0.1) -- a Fortran preprocessor for generics
-----------------------------------------------------
Author:        Drew McCormack
Created:       26 Nov 2004
Last Modified: 26 Nov 2004

'Forpedo' is a preprocessor for Fortran 90 code, written in python. 
(The name is inspired by the flipper feet himself.) It can handle
some typical preprocessing tasks, like including code from one file in
another, but it is mostly designed to provide C++ like generics (templates).

The output of Forpedo is pure Fortran code, which should work with any
standard compiler.

To use Forpedo, you will need access to a recent version of Python (2.3 or later).
Python is commonly available these days, on almost all platforms (see http://www.python.org)

Forpedo is very new software, and may contain bugs. Please report them
to drewmccormack@mac.com. The Forpedo web site is http://www.maniacalextent.com/forpedo

New functionality should be added to Forpedo in good time. Suggestions and offers
of support are always welcome.


Using forpedo
-------------

To run forpedo, simply pipe your source code into forpedo.py. Generated code will
be written to standard output. 
Eg.

forpedo.py < myFile.f90t > myFile.f90
f90 myFile.f90


Directives Reference
--------------------

import
------
Include the source of one file in another (like C's include directive).

Example:
#import "OtherFile.fh"


definetype
----------
Used to define generic types, and type definitions (like C's typedef's).  

Example of simple type definition:
#definetype  RealParamType   none   real(8), parameter

Example of using this defined type:
@RealParamType :: r = 10
print *, r


Example of generic type definition:
#definetype T   Int   integer
#definetype T   Real  real

Example of using this generic type:
@T var<T>
var<T> = 10
print *, var<T>

A definetype directive has a type name, a tag, and a concrete fortran type.
The typename should be used, after an @ symbol, anywhere in the code that  
the type is required. 

The tag can be accessed in the code by putting the 
type name between triangular parentheses (ie <typename>). The tag is often 
required to avoid name clashes, particularly for variables with global scope.
So, for example, you would generally need to use the tag for a module name,
otherwise multiple modules may get the same name.

Eg.
module MyModule<T>

this will be replaced with

module MyModuleInt
and
module MyModuleReal

When you are using definetype for a type definition, rather than generic
types, the tag is not really needed, and you can simply set it to some
string like 'none'.