2018-05-01 12:50:34 -07:00
|
|
|
<!--
|
2019-02-08 10:39:10 -08:00
|
|
|
Copyright (c) 2018-2019, NVIDIA CORPORATION. All rights reserved.
|
2018-05-01 12:50:34 -07:00
|
|
|
-->
|
|
|
|
|
2018-07-17 16:58:21 -07:00
|
|
|
As a general principle, this compiler will accept by default and
|
|
|
|
without complaint many legacy features, extensions to the standard
|
|
|
|
language, and features that have been deleted from the standard,
|
|
|
|
so long as the recognition of those features would not cause a
|
|
|
|
standard-conforming program to be rejected or misinterpreted.
|
2018-03-20 10:59:07 -07:00
|
|
|
|
2018-07-17 16:58:21 -07:00
|
|
|
Other non-standard features, which do conflict with the current
|
|
|
|
standard specification of the Fortran programming language, are
|
|
|
|
accepted if enabled by command-line options.
|
|
|
|
|
2019-07-08 10:44:14 -07:00
|
|
|
Intentional violations of the standard
|
|
|
|
======================================
|
|
|
|
* The default `INTEGER` type is required by the standard to occupy
|
|
|
|
the same amount of storage as the default `REAL` type. Default
|
|
|
|
`REAL` is of course 32-bit IEEE-754 floating-point today. This legacy
|
|
|
|
rule imposes an artificially small constraint in some cases
|
|
|
|
where Fortran mandates that something have the default `INTEGER`
|
2019-07-17 12:51:52 -07:00
|
|
|
type: specifically, the results of references to the intrinsic functions
|
|
|
|
`LEN`, `SIZE`, `LBOUND`, `UBOUND`, and `SHAPE`. We return
|
|
|
|
`INTEGER(KIND=8)` in these cases.
|
2019-07-08 10:44:14 -07:00
|
|
|
|
2018-07-17 16:58:21 -07:00
|
|
|
Extensions, deletions, and legacy features supported by default
|
|
|
|
===============================================================
|
2018-03-20 10:59:07 -07:00
|
|
|
* Tabs in source
|
|
|
|
* `<>` as synonym for `.NE.` and `/=`
|
|
|
|
* `$` and `@` as legal characters in names
|
|
|
|
* Initialization in type declaration statements using `/values/`
|
|
|
|
* Kind specification with `*`, e.g. `REAL*4`
|
|
|
|
* `DOUBLE COMPLEX`
|
|
|
|
* Signed complex literal constants
|
2018-07-17 16:58:21 -07:00
|
|
|
* DEC `STRUCTURE`, `RECORD`, `UNION`, and `MAP`
|
2018-03-20 10:59:07 -07:00
|
|
|
* Structure field access with `.field`
|
|
|
|
* `BYTE` as synonym for `INTEGER(KIND=1)`
|
|
|
|
* Quad precision REAL literals with `Q`
|
|
|
|
* `X` prefix/suffix as synonym for `Z` on hexadecimal literals
|
|
|
|
* `B`, `O`, `Z`, and `X` accepted as suffixes as well as prefixes
|
|
|
|
* Triplets allowed in array constructors
|
2018-07-18 12:54:30 -07:00
|
|
|
* Old-style `PARAMETER pi=3.14` statement without parentheses
|
2018-03-20 10:59:07 -07:00
|
|
|
* `%LOC`, `%VAL`, and `%REF`
|
|
|
|
* Leading comma allowed before I/O item list
|
|
|
|
* Empty parentheses allowed in `PROGRAM P()`
|
|
|
|
* Missing parentheses allowed in `FUNCTION F`
|
2019-07-01 13:22:22 -07:00
|
|
|
* Cray based `POINTER(p,x)` and `LOC()` intrinsic (with `%LOC()` as
|
|
|
|
an alias)
|
2018-07-17 16:58:21 -07:00
|
|
|
* Arithmetic `IF`. (Which branch should NaN take? Fall through?)
|
2018-03-20 10:59:07 -07:00
|
|
|
* `ASSIGN` statement, assigned `GO TO`, and assigned format
|
|
|
|
* `PAUSE` statement
|
|
|
|
* Hollerith literals and edit descriptors
|
|
|
|
* `NAMELIST` allowed in the execution part
|
|
|
|
* Omitted colons on type declaration statements with attributes
|
|
|
|
* COMPLEX constructor expression, e.g. `(x+y,z)`
|
|
|
|
* `+` and `-` before all primary expressions, e.g. `x*-y`
|
|
|
|
* `.NOT. .NOT.` accepted
|
|
|
|
* `NAME=` as synonym for `FILE=`
|
|
|
|
* Data edit descriptors without width or other details
|
|
|
|
* `D` lines in fixed form as comments or debug code
|
2019-03-22 15:08:16 -07:00
|
|
|
* `CONVERT=` on the OPEN and INQUIRE statements
|
|
|
|
* `DISPOSE=` on the OPEN and INQUIRE statements
|
2018-07-12 15:32:31 -07:00
|
|
|
* Leading semicolons are ignored before any statement that
|
|
|
|
could have a label
|
2018-07-17 16:58:21 -07:00
|
|
|
* The character `&` in column 1 in fixed form source is a variant form
|
|
|
|
of continuation line.
|
2019-02-15 12:20:30 -08:00
|
|
|
* Character literals as elements of an array constructor without an explicit
|
|
|
|
type specifier need not have the same length; the longest literal determines
|
|
|
|
the length parameter of the implicit type, not the first.
|
2019-03-14 14:51:40 -07:00
|
|
|
* Outside a character literal, a comment after a continuation marker (&)
|
|
|
|
need not begin with a comment marker (!).
|
2019-03-15 15:19:27 -07:00
|
|
|
* Classic C-style /*comments*/ are skipped, so multi-language header
|
|
|
|
files are easier to write and use.
|
2019-03-22 14:27:18 -07:00
|
|
|
* $ and \ edit descriptors are supported in FORMAT to suppress newline
|
|
|
|
output on user prompts.
|
2019-06-04 15:14:34 -07:00
|
|
|
* REAL and DOUBLE PRECISION variable and bounds in DO loops
|
2019-05-30 13:31:11 -07:00
|
|
|
* Integer literals without explicit kind specifiers that are out of range
|
|
|
|
for the default kind of INTEGER are assumed to have the least larger kind
|
|
|
|
that can hold them, if one exists.
|
2019-06-03 10:51:51 -07:00
|
|
|
* BOZ literals can be used as INTEGER values in contexts where the type is
|
2019-07-09 11:53:11 -07:00
|
|
|
unambiguous: the right hand sides of assigments and initializations
|
|
|
|
of INTEGER entities, and as actual arguments to a few intrinsic functions
|
2019-07-17 12:51:52 -07:00
|
|
|
(ACHAR, BTEST, CHAR). But they cannot be used if the type would not
|
|
|
|
be known (e.g., `IAND(X'1',X'2')`).
|
2019-07-17 14:29:11 -07:00
|
|
|
* BOZ literals can also be used as REAL values in some contexts where the
|
|
|
|
type is unambiguous, such as initializations of REAL parameters.
|
2019-06-19 16:34:22 -07:00
|
|
|
* EQUIVALENCE of numeric and character sequences (a ubiquitous extension)
|
2019-06-21 14:07:39 -07:00
|
|
|
* Values for whole anonymous parent components in structure constructors
|
|
|
|
(e.g., `EXTENDEDTYPE(PARENTTYPE(1,2,3))` rather than `EXTENDEDTYPE(1,2,3)`
|
|
|
|
or `EXTENDEDTYPE(PARENTTYPE=PARENTTYPE(1,2,3))`).
|
2019-07-17 12:51:52 -07:00
|
|
|
* Some intrinsic functions are specified in the standard as requiring the
|
|
|
|
same type and kind for their arguments (viz., ATAN with two arguments,
|
|
|
|
ATAN2, DIM, HYPOT, MAX, MIN, MOD, and MODULO);
|
|
|
|
we allow distinct types to be used, promoting
|
|
|
|
the arguments as if they were operands to an intrinsic `+` operator,
|
|
|
|
and defining the result type accordingly.
|
2019-09-02 13:54:01 -07:00
|
|
|
* DOUBLE COMPLEX intrinsics DREAL, DCMPLX, DCONJG and DIMAG.
|
2019-08-26 14:58:10 -07:00
|
|
|
* INT_PTR_KIND intrinsic returns the kind of c_intptr_t.
|
2018-07-17 16:58:21 -07:00
|
|
|
|
|
|
|
Extensions supported when enabled by options
|
|
|
|
--------------------------------------------
|
|
|
|
* C-style backslash escape sequences in quoted CHARACTER literals
|
|
|
|
(but not Hollerith) [-fbackslash]
|
|
|
|
* Logical abbreviations `.T.`, `.F.`, `.N.`, `.A.`, `.O.`, and `.X.`
|
|
|
|
[-flogical-abbreviations]
|
|
|
|
* `.XOR.` as a synonym for `.NEQV.` [-fxor-operator]
|
2018-03-20 10:59:07 -07:00
|
|
|
|
|
|
|
Extensions and legacy features deliberately not supported
|
|
|
|
---------------------------------------------------------
|
|
|
|
* `.LG.` as synonym for `.NE.`
|
|
|
|
* `REDIMENSION`
|
|
|
|
* Allocatable `COMMON`
|
|
|
|
* Expressions in formats
|
|
|
|
* `ACCEPT` as synonym for `READ *`
|
2018-03-23 15:14:52 -07:00
|
|
|
* `TYPE` as synonym for `PRINT`
|
2018-03-20 10:59:07 -07:00
|
|
|
* `ARRAY` as synonym for `DIMENSION`
|
|
|
|
* `VIRTUAL` as synonym for `DIMENSION`
|
|
|
|
* `ENCODE` and `DECODE` as synonyms for internal I/O
|
|
|
|
* `IMPLICIT AUTOMATIC`, `IMPLICIT STATIC`
|
|
|
|
* Default exponent of zero, e.g. `3.14159E`
|
|
|
|
* Characters in defined operators that are neither letters nor digits
|
|
|
|
* `B` suffix on unquoted octal constants
|
2018-10-16 14:42:22 -07:00
|
|
|
* `Z` prefix on unquoted hexadecimal constants (dangerous)
|
2019-06-03 10:51:51 -07:00
|
|
|
* `T` and `F` as abbreviations for `.TRUE.` and `.FALSE.` in DATA (PGI/XLF)
|
2019-02-08 10:39:10 -08:00
|
|
|
* Use of host FORMAT labels in internal subprograms (PGI-only feature)
|
2019-05-30 12:08:06 -07:00
|
|
|
* ALLOCATE(TYPE(derived)::...) as variant of correct ALLOCATE(derived::...) (PGI only)
|
2019-06-24 10:25:37 -07:00
|
|
|
* Defining an explicit interface for a subprogram within itself (PGI only)
|
2019-06-04 14:51:56 -07:00
|
|
|
* USE association of a procedure interface within that same procedure's definition
|
2019-06-05 15:40:59 -07:00
|
|
|
* NULL() as a structure constructor expression for an ALLOCATABLE component (PGI).
|
|
|
|
* Conversion of LOGICAL to INTEGER.
|
|
|
|
* IF (integer expression) THEN ... END IF (PGI/Intel)
|
|
|
|
* Comparsion of LOGICAL with ==/.EQ. rather than .EQV. (also .NEQV.) (PGI/Intel)
|
|
|
|
* Procedure pointers in COMMON blocks (PGI/Intel)
|
2019-06-25 13:07:32 -07:00
|
|
|
* Underindexing multi-dimensional arrays (e.g., A(1) rather than A(1,1)) (PGI only)
|
2019-06-28 11:16:37 -07:00
|
|
|
* Legacy PGI `NCHARACTER` type and `NC` Kanji character literals
|
2019-07-09 11:53:11 -07:00
|
|
|
* Using non-integer expressions for array bounds (e.g., REAL A(3.14159)) (PGI/Intel)
|
|
|
|
* Mixing INTEGER types as operands to bit intrinsics (e.g., IAND); only two
|
|
|
|
compilers support it, and they disagree on sign extension.
|
2019-07-18 13:57:21 -07:00
|
|
|
* Module & program names that conflict with an object inside the unit (PGI only).
|
2019-07-18 15:26:17 -07:00
|
|
|
* When the same name is brought into scope via USE association from
|
|
|
|
multiple modules, the name must refer to a generic interface; PGI
|
|
|
|
allows a name to be a procedure from one module and a generic interface
|
|
|
|
from another.
|
2019-08-02 15:42:54 -07:00
|
|
|
* Type parameter declarations must come first in a derived type definition;
|
|
|
|
some compilers allow them to follow `PRIVATE`, or be intermixed with the
|
|
|
|
component declarations.
|
2019-07-10 15:03:02 -07:00
|
|
|
|
|
|
|
Preprocessing behavior
|
|
|
|
======================
|
|
|
|
* The preprocessor is always run, whatever the filename extension may be.
|
|
|
|
* We respect Fortran comments in macro actual arguments (like GNU, Intel, NAG;
|
|
|
|
unlike PGI and XLF) on the principle that macro calls should be treated
|
|
|
|
like function references. Fortran's line continuation methods also work.
|