OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-stable/] [gcc-4.5.1/] [gcc/] [fortran/] [gfc-internals.texi] - Diff between revs 816 and 826

Only display areas with differences | Details | Blame | View Log

Rev 816 Rev 826
\input texinfo  @c -*-texinfo-*-
\input texinfo  @c -*-texinfo-*-
@c %**start of header
@c %**start of header
@setfilename gfc-internals.info
@setfilename gfc-internals.info
@set copyrights-gfortran 2007, 2008, 2009
@set copyrights-gfortran 2007, 2008, 2009
 
 
@include gcc-common.texi
@include gcc-common.texi
 
 
@synindex tp cp
@synindex tp cp
 
 
@settitle GNU Fortran Compiler Internals
@settitle GNU Fortran Compiler Internals
 
 
@c %**end of header
@c %**end of header
 
 
@c Use with @@smallbook.
@c Use with @@smallbook.
 
 
@c %** start of document
@c %** start of document
 
 
@c Cause even numbered pages to be printed on the left hand side of
@c Cause even numbered pages to be printed on the left hand side of
@c the page and odd numbered pages to be printed on the right hand
@c the page and odd numbered pages to be printed on the right hand
@c side of the page.  Using this, you can print on both sides of a
@c side of the page.  Using this, you can print on both sides of a
@c sheet of paper and have the text on the same part of the sheet.
@c sheet of paper and have the text on the same part of the sheet.
 
 
@c The text on right hand pages is pushed towards the right hand
@c The text on right hand pages is pushed towards the right hand
@c margin and the text on left hand pages is pushed toward the left
@c margin and the text on left hand pages is pushed toward the left
@c hand margin.
@c hand margin.
@c (To provide the reverse effect, set bindingoffset to -0.75in.)
@c (To provide the reverse effect, set bindingoffset to -0.75in.)
 
 
@c @tex
@c @tex
@c \global\bindingoffset=0.75in
@c \global\bindingoffset=0.75in
@c \global\normaloffset =0.75in
@c \global\normaloffset =0.75in
@c @end tex
@c @end tex
 
 
@copying
@copying
Copyright @copyright{} @value{copyrights-gfortran} Free Software Foundation,
Copyright @copyright{} @value{copyrights-gfortran} Free Software Foundation,
Inc.
Inc.
 
 
Permission is granted to copy, distribute and/or modify this document
Permission is granted to copy, distribute and/or modify this document
under the terms of the GNU Free Documentation License, Version 1.2 or
under the terms of the GNU Free Documentation License, Version 1.2 or
any later version published by the Free Software Foundation; with the
any later version published by the Free Software Foundation; with the
Invariant Sections being ``Funding Free Software'', the Front-Cover
Invariant Sections being ``Funding Free Software'', the Front-Cover
Texts being (a) (see below), and with the Back-Cover Texts being (b)
Texts being (a) (see below), and with the Back-Cover Texts being (b)
(see below).  A copy of the license is included in the section entitled
(see below).  A copy of the license is included in the section entitled
``GNU Free Documentation License''.
``GNU Free Documentation License''.
 
 
(a) The FSF's Front-Cover Text is:
(a) The FSF's Front-Cover Text is:
 
 
     A GNU Manual
     A GNU Manual
 
 
(b) The FSF's Back-Cover Text is:
(b) The FSF's Back-Cover Text is:
 
 
     You have freedom to copy and modify this GNU Manual, like GNU
     You have freedom to copy and modify this GNU Manual, like GNU
     software.  Copies published by the Free Software Foundation raise
     software.  Copies published by the Free Software Foundation raise
     funds for GNU development.
     funds for GNU development.
@end copying
@end copying
 
 
@ifinfo
@ifinfo
@dircategory Software development
@dircategory Software development
@direntry
@direntry
* gfortran: (gfortran).                  The GNU Fortran Compiler.
* gfortran: (gfortran).                  The GNU Fortran Compiler.
@end direntry
@end direntry
This file documents the internals of the GNU Fortran
This file documents the internals of the GNU Fortran
compiler, (@command{gfortran}).
compiler, (@command{gfortran}).
 
 
Published by the Free Software Foundation
Published by the Free Software Foundation
51 Franklin Street, Fifth Floor
51 Franklin Street, Fifth Floor
Boston, MA 02110-1301 USA
Boston, MA 02110-1301 USA
 
 
@insertcopying
@insertcopying
@end ifinfo
@end ifinfo
 
 
 
 
@setchapternewpage odd
@setchapternewpage odd
@titlepage
@titlepage
@title GNU Fortran Internals
@title GNU Fortran Internals
@versionsubtitle
@versionsubtitle
@author The @t{gfortran} team
@author The @t{gfortran} team
@page
@page
@vskip 0pt plus 1filll
@vskip 0pt plus 1filll
Published by the Free Software Foundation@*
Published by the Free Software Foundation@*
51 Franklin Street, Fifth Floor@*
51 Franklin Street, Fifth Floor@*
Boston, MA 02110-1301, USA@*
Boston, MA 02110-1301, USA@*
@c Last printed ??ber, 19??.@*
@c Last printed ??ber, 19??.@*
@c Printed copies are available for $? each.@*
@c Printed copies are available for $? each.@*
@c ISBN ???
@c ISBN ???
@sp 1
@sp 1
@insertcopying
@insertcopying
@end titlepage
@end titlepage
 
 
@summarycontents
@summarycontents
@contents
@contents
 
 
@page
@page
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c TexInfo table of contents.
@c TexInfo table of contents.
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@ifnottex
@ifnottex
@node Top
@node Top
@top Introduction
@top Introduction
@cindex Introduction
@cindex Introduction
 
 
This manual documents the internals of @command{gfortran},
This manual documents the internals of @command{gfortran},
the GNU Fortran compiler.
the GNU Fortran compiler.
 
 
@ifset DEVELOPMENT
@ifset DEVELOPMENT
@emph{Warning:} This document, and the compiler it describes, are still
@emph{Warning:} This document, and the compiler it describes, are still
under development.  While efforts are made to keep it up-to-date, it might
under development.  While efforts are made to keep it up-to-date, it might
not accurately reflect the status of the most recent GNU Fortran compiler.
not accurately reflect the status of the most recent GNU Fortran compiler.
@end ifset
@end ifset
 
 
@comment
@comment
@comment  When you add a new menu item, please keep the right hand
@comment  When you add a new menu item, please keep the right hand
@comment  aligned to the same column.  Do not use tabs.  This provides
@comment  aligned to the same column.  Do not use tabs.  This provides
@comment  better formatting.
@comment  better formatting.
@comment
@comment
@menu
@menu
* Introduction::           About this manual.
* Introduction::           About this manual.
* User Interface::         Code that Interacts with the User.
* User Interface::         Code that Interacts with the User.
* Frontend Data Structures::
* Frontend Data Structures::
                           Data structures used by the frontend
                           Data structures used by the frontend
* Object Orientation::     Internals of Fortran 2003 OOP features.
* Object Orientation::     Internals of Fortran 2003 OOP features.
* LibGFortran::            The LibGFortran Runtime Library.
* LibGFortran::            The LibGFortran Runtime Library.
* GNU Free Documentation License::
* GNU Free Documentation License::
                           How you can copy and share this manual.
                           How you can copy and share this manual.
* Index::                  Index of this documentation.
* Index::                  Index of this documentation.
@end menu
@end menu
@end ifnottex
@end ifnottex
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c Introduction
@c Introduction
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@node Introduction
@node Introduction
@chapter Introduction
@chapter Introduction
 
 
@c The following duplicates the text on the TexInfo table of contents.
@c The following duplicates the text on the TexInfo table of contents.
@iftex
@iftex
This manual documents the internals of @command{gfortran}, the GNU Fortran
This manual documents the internals of @command{gfortran}, the GNU Fortran
compiler.
compiler.
 
 
@ifset DEVELOPMENT
@ifset DEVELOPMENT
@emph{Warning:} This document, and the compiler it describes, are still
@emph{Warning:} This document, and the compiler it describes, are still
under development.  While efforts are made to keep it up-to-date, it
under development.  While efforts are made to keep it up-to-date, it
might not accurately reflect the status of the most recent GNU Fortran
might not accurately reflect the status of the most recent GNU Fortran
compiler.
compiler.
@end ifset
@end ifset
@end iftex
@end iftex
 
 
At present, this manual is very much a work in progress, containing
At present, this manual is very much a work in progress, containing
miscellaneous notes about the internals of the compiler.  It is hoped
miscellaneous notes about the internals of the compiler.  It is hoped
that at some point in the future it will become a reasonably complete
that at some point in the future it will become a reasonably complete
guide; in the interim, GNU Fortran developers are strongly encouraged to
guide; in the interim, GNU Fortran developers are strongly encouraged to
contribute to it as a way of keeping notes while working on the
contribute to it as a way of keeping notes while working on the
compiler.
compiler.
 
 
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c Code that Interacts with the User
@c Code that Interacts with the User
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@node User Interface
@node User Interface
@chapter Code that Interacts with the User
@chapter Code that Interacts with the User
 
 
@menu
@menu
* Command-Line Options::    Command-Line Options.
* Command-Line Options::    Command-Line Options.
* Error Handling::          Error Handling.
* Error Handling::          Error Handling.
@end menu
@end menu
 
 
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c Command-Line Options
@c Command-Line Options
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@node Command-Line Options
@node Command-Line Options
@section Command-Line Options
@section Command-Line Options
 
 
Command-line options for @command{gfortran} involve four interrelated
Command-line options for @command{gfortran} involve four interrelated
pieces within the Fortran compiler code.
pieces within the Fortran compiler code.
 
 
The relevant command-line flag is defined in @file{lang.opt}, according
The relevant command-line flag is defined in @file{lang.opt}, according
to the documentation in @ref{Options,, Options, gccint, GNU Compiler
to the documentation in @ref{Options,, Options, gccint, GNU Compiler
Collection Internals}.  This is then processed by the overall GCC
Collection Internals}.  This is then processed by the overall GCC
machinery to create the code that enables @command{gfortran} and
machinery to create the code that enables @command{gfortran} and
@command{gcc} to recognize the option in the command-line arguments and
@command{gcc} to recognize the option in the command-line arguments and
call the relevant handler function.
call the relevant handler function.
 
 
This generated code calls the @code{gfc_handle_option} code in
This generated code calls the @code{gfc_handle_option} code in
@file{options.c} with an enumerator variable indicating which option is
@file{options.c} with an enumerator variable indicating which option is
to be processed, and the relevant integer or string values associated
to be processed, and the relevant integer or string values associated
with that option flag.  Typically, @code{gfc_handle_option} uses these
with that option flag.  Typically, @code{gfc_handle_option} uses these
arguments to set global flags which record the option states.
arguments to set global flags which record the option states.
 
 
The global flags that record the option states are stored in the
The global flags that record the option states are stored in the
@code{gfc_option_t} struct, which is defined in @file{gfortran.h}.
@code{gfc_option_t} struct, which is defined in @file{gfortran.h}.
Before the options are processed, initial values for these flags are set
Before the options are processed, initial values for these flags are set
in @code{gfc_init_option} in @file{options.c}; these become the default
in @code{gfc_init_option} in @file{options.c}; these become the default
values for the options.
values for the options.
 
 
 
 
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c Error Handling
@c Error Handling
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@node Error Handling
@node Error Handling
@section Error Handling
@section Error Handling
 
 
The GNU Fortran compiler's parser operates by testing each piece of
The GNU Fortran compiler's parser operates by testing each piece of
source code against a variety of matchers.  In some cases, if these
source code against a variety of matchers.  In some cases, if these
matchers do not match the source code, they will store an error message
matchers do not match the source code, they will store an error message
in a buffer.  If the parser later finds a matcher that does correctly
in a buffer.  If the parser later finds a matcher that does correctly
match the source code, then the buffered error is discarded.  However,
match the source code, then the buffered error is discarded.  However,
if the parser cannot find a match, then the buffered error message is
if the parser cannot find a match, then the buffered error message is
reported to the user.  This enables the compiler to provide more
reported to the user.  This enables the compiler to provide more
meaningful error messages even in the many cases where (erroneous)
meaningful error messages even in the many cases where (erroneous)
Fortran syntax is ambiguous due to things like the absence of reserved
Fortran syntax is ambiguous due to things like the absence of reserved
keywords.
keywords.
 
 
As an example of how this works, consider the following line:
As an example of how this works, consider the following line:
@smallexample
@smallexample
IF = 3
IF = 3
@end smallexample
@end smallexample
Hypothetically, this may get passed to the matcher for an @code{IF}
Hypothetically, this may get passed to the matcher for an @code{IF}
statement.  Since this could plausibly be an erroneous @code{IF}
statement.  Since this could plausibly be an erroneous @code{IF}
statement, the matcher will buffer an error message reporting the
statement, the matcher will buffer an error message reporting the
absence of an expected @samp{(} following an @code{IF}.  Since no
absence of an expected @samp{(} following an @code{IF}.  Since no
matchers reported an error-free match, however, the parser will also try
matchers reported an error-free match, however, the parser will also try
matching this against a variable assignment.  When @code{IF} is a valid
matching this against a variable assignment.  When @code{IF} is a valid
variable, this will be parsed as an assignment statement, and the error
variable, this will be parsed as an assignment statement, and the error
discarded.  However, when @code{IF} is not a valid variable, this
discarded.  However, when @code{IF} is not a valid variable, this
buffered error message will be reported to the user.
buffered error message will be reported to the user.
 
 
The error handling code is implemented in @file{error.c}.  Errors are
The error handling code is implemented in @file{error.c}.  Errors are
normally entered into the buffer with the @code{gfc_error} function.
normally entered into the buffer with the @code{gfc_error} function.
Warnings go through a similar buffering process, and are entered into
Warnings go through a similar buffering process, and are entered into
the buffer with @code{gfc_warning}.  There is also a special-purpose
the buffer with @code{gfc_warning}.  There is also a special-purpose
function, @code{gfc_notify_std}, for things which have an error/warning
function, @code{gfc_notify_std}, for things which have an error/warning
status that depends on the currently-selected language standard.
status that depends on the currently-selected language standard.
 
 
The @code{gfc_error_check} function checks the buffer for errors,
The @code{gfc_error_check} function checks the buffer for errors,
reports the error message to the user if one exists, clears the buffer,
reports the error message to the user if one exists, clears the buffer,
and returns a flag to the user indicating whether or not an error
and returns a flag to the user indicating whether or not an error
existed.  To check the state of the buffer without changing its state or
existed.  To check the state of the buffer without changing its state or
reporting the errors, the @code{gfc_error_flag_test} function can be
reporting the errors, the @code{gfc_error_flag_test} function can be
used.  The @code{gfc_clear_error} function will clear out any errors in
used.  The @code{gfc_clear_error} function will clear out any errors in
the buffer, without reporting them.  The @code{gfc_warning_check} and
the buffer, without reporting them.  The @code{gfc_warning_check} and
@code{gfc_clear_warning} functions provide equivalent functionality for
@code{gfc_clear_warning} functions provide equivalent functionality for
the warning buffer.
the warning buffer.
 
 
Only one error and one warning can be in the buffers at a time, and
Only one error and one warning can be in the buffers at a time, and
buffering another will overwrite the existing one.  In cases where one
buffering another will overwrite the existing one.  In cases where one
may wish to work on a smaller piece of source code without disturbing an
may wish to work on a smaller piece of source code without disturbing an
existing error state, the @code{gfc_push_error}, @code{gfc_pop_error},
existing error state, the @code{gfc_push_error}, @code{gfc_pop_error},
and @code{gfc_free_error} mechanism exists to implement a stack for the
and @code{gfc_free_error} mechanism exists to implement a stack for the
error buffer.
error buffer.
 
 
For cases where an error or warning should be reported immediately
For cases where an error or warning should be reported immediately
rather than buffered, the @code{gfc_error_now} and
rather than buffered, the @code{gfc_error_now} and
@code{gfc_warning_now} functions can be used.  Normally, the compiler
@code{gfc_warning_now} functions can be used.  Normally, the compiler
will continue attempting to parse the program after an error has
will continue attempting to parse the program after an error has
occurred, but if this is not appropriate, the @code{gfc_fatal_error}
occurred, but if this is not appropriate, the @code{gfc_fatal_error}
function should be used instead.  For errors that are always the result
function should be used instead.  For errors that are always the result
of a bug somewhere in the compiler, the @code{gfc_internal_error}
of a bug somewhere in the compiler, the @code{gfc_internal_error}
function should be used.
function should be used.
 
 
The syntax for the strings used to produce the error/warning message in
The syntax for the strings used to produce the error/warning message in
the various error and warning functions is similar to the @code{printf}
the various error and warning functions is similar to the @code{printf}
syntax, with @samp{%}-escapes to insert variable values.  The details,
syntax, with @samp{%}-escapes to insert variable values.  The details,
and the allowable codes, are documented in the @code{error_print}
and the allowable codes, are documented in the @code{error_print}
function in @file{error.c}.
function in @file{error.c}.
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c Frontend Data Structures
@c Frontend Data Structures
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@node Frontend Data Structures
@node Frontend Data Structures
@chapter Frontend Data Structures
@chapter Frontend Data Structures
@cindex data structures
@cindex data structures
 
 
This chapter should describe the details necessary to understand how
This chapter should describe the details necessary to understand how
the various @code{gfc_*} data are used and interact.  In general it is
the various @code{gfc_*} data are used and interact.  In general it is
advisable to read the code in @file{dump-parse-tree.c} as its routines
advisable to read the code in @file{dump-parse-tree.c} as its routines
should exhaust all possible valid combinations of content for these
should exhaust all possible valid combinations of content for these
structures.
structures.
 
 
@menu
@menu
* gfc_code:: Representation of Executable Statements.
* gfc_code:: Representation of Executable Statements.
* gfc_expr:: Representation of Values and Expressions.
* gfc_expr:: Representation of Values and Expressions.
@end menu
@end menu
 
 
 
 
@c gfc_code
@c gfc_code
@c --------
@c --------
 
 
@node gfc_code
@node gfc_code
@section @code{gfc_code}
@section @code{gfc_code}
@cindex statement chaining
@cindex statement chaining
@tindex @code{gfc_code}
@tindex @code{gfc_code}
@tindex @code{struct gfc_code}
@tindex @code{struct gfc_code}
 
 
The executable statements in a program unit are represented by a
The executable statements in a program unit are represented by a
nested chain of @code{gfc_code} structures.  The type of statement is
nested chain of @code{gfc_code} structures.  The type of statement is
identified by the @code{op} member of the structure, the different
identified by the @code{op} member of the structure, the different
possible values are enumerated in @code{gfc_exec_op}.  A special
possible values are enumerated in @code{gfc_exec_op}.  A special
member of this @code{enum} is @code{EXEC_NOP} which is used to
member of this @code{enum} is @code{EXEC_NOP} which is used to
represent the various @code{END} statements if they carry a label.
represent the various @code{END} statements if they carry a label.
Depending on the type of statement some of the other fields will be
Depending on the type of statement some of the other fields will be
filled in.  Fields that are generally applicable are the @code{next}
filled in.  Fields that are generally applicable are the @code{next}
and @code{here} fields.  The former points to the next statement in
and @code{here} fields.  The former points to the next statement in
the current block or is @code{NULL} if the current statement is the
the current block or is @code{NULL} if the current statement is the
last in a block, @code{here} points to the statement label of the
last in a block, @code{here} points to the statement label of the
current statement.
current statement.
 
 
If the current statement is one of @code{IF}, @code{DO}, @code{SELECT}
If the current statement is one of @code{IF}, @code{DO}, @code{SELECT}
it starts a block, i.e.@: a nested level in the program.  In order to
it starts a block, i.e.@: a nested level in the program.  In order to
represent this, the @code{block} member is set to point to a
represent this, the @code{block} member is set to point to a
@code{gfc_code} structure whose @code{next} member starts the chain of
@code{gfc_code} structure whose @code{next} member starts the chain of
statements inside the block; this structure's @code{op} member should be set to
statements inside the block; this structure's @code{op} member should be set to
the same value as the parent structure's @code{op} member.  The @code{SELECT}
the same value as the parent structure's @code{op} member.  The @code{SELECT}
and @code{IF} statements may contain various blocks (the chain of @code{ELSE IF}
and @code{IF} statements may contain various blocks (the chain of @code{ELSE IF}
and @code{ELSE} blocks or the various @code{CASE}s, respectively).  These chains
and @code{ELSE} blocks or the various @code{CASE}s, respectively).  These chains
are linked-lists formed by the @code{block} members.
are linked-lists formed by the @code{block} members.
 
 
Consider the following example code:
Consider the following example code:
 
 
@example
@example
IF (foo < 20) THEN
IF (foo < 20) THEN
  PRINT *, "Too small"
  PRINT *, "Too small"
  foo = 20
  foo = 20
ELSEIF (foo > 50) THEN
ELSEIF (foo > 50) THEN
  PRINT *, "Too large"
  PRINT *, "Too large"
  foo = 50
  foo = 50
ELSE
ELSE
  PRINT *, "Good"
  PRINT *, "Good"
END IF
END IF
@end example
@end example
 
 
This statement-block will be represented in the internal gfortran tree as
This statement-block will be represented in the internal gfortran tree as
follows, were the horizontal link-chains are those induced by the @code{next}
follows, were the horizontal link-chains are those induced by the @code{next}
members and vertical links down are those of @code{block}. @samp{==|} and
members and vertical links down are those of @code{block}. @samp{==|} and
@samp{--|} mean @code{NULL} pointers to mark the end of a chain:
@samp{--|} mean @code{NULL} pointers to mark the end of a chain:
 
 
@example
@example
... ==> IF ==> ...
... ==> IF ==> ...
        |
        |
        +--> IF foo < 20 ==> PRINT *, "Too small" ==> foo = 20 ==|
        +--> IF foo < 20 ==> PRINT *, "Too small" ==> foo = 20 ==|
             |
             |
             +--> IF foo > 50 ==> PRINT *, "Too large" ==> foo = 50 ==|
             +--> IF foo > 50 ==> PRINT *, "Too large" ==> foo = 50 ==|
                  |
                  |
                  +--> ELSE ==> PRINT *, "Good" ==|
                  +--> ELSE ==> PRINT *, "Good" ==|
                       |
                       |
                       +--|
                       +--|
@end example
@end example
 
 
 
 
@subsection IF Blocks
@subsection IF Blocks
 
 
Conditionals are represented by @code{gfc_code} structures with their
Conditionals are represented by @code{gfc_code} structures with their
@code{op} member set to @code{EXEC_IF}.  This structure's @code{block}
@code{op} member set to @code{EXEC_IF}.  This structure's @code{block}
member must point to another @code{gfc_code} node that is the header of the
member must point to another @code{gfc_code} node that is the header of the
if-block.  This header's @code{op} member must be set to @code{EXEC_IF}, too,
if-block.  This header's @code{op} member must be set to @code{EXEC_IF}, too,
its @code{expr} member holds the condition to check for, and its @code{next}
its @code{expr} member holds the condition to check for, and its @code{next}
should point to the code-chain of the statements to execute if the condition is
should point to the code-chain of the statements to execute if the condition is
true.
true.
 
 
If in addition an @code{ELSEIF} or @code{ELSE} block is present, the
If in addition an @code{ELSEIF} or @code{ELSE} block is present, the
@code{block} member of the if-block-header node points to yet another
@code{block} member of the if-block-header node points to yet another
@code{gfc_code} structure that is the header of the elseif- or else-block.  Its
@code{gfc_code} structure that is the header of the elseif- or else-block.  Its
structure is identical to that of the if-block-header, except that in case of an
structure is identical to that of the if-block-header, except that in case of an
@code{ELSE} block without a new condition the @code{expr} member should be
@code{ELSE} block without a new condition the @code{expr} member should be
@code{NULL}.  This block can itself have its @code{block} member point to the
@code{NULL}.  This block can itself have its @code{block} member point to the
next @code{ELSEIF} or @code{ELSE} block if there's a chain of them.
next @code{ELSEIF} or @code{ELSE} block if there's a chain of them.
 
 
 
 
@subsection Loops
@subsection Loops
 
 
@code{DO} loops are stored in the tree as @code{gfc_code} nodes with their
@code{DO} loops are stored in the tree as @code{gfc_code} nodes with their
@code{op} set to @code{EXEC_DO} for a @code{DO} loop with iterator variable and
@code{op} set to @code{EXEC_DO} for a @code{DO} loop with iterator variable and
to @code{EXEC_DO_WHILE} for infinite @code{DO}s and @code{DO WHILE} blocks.
to @code{EXEC_DO_WHILE} for infinite @code{DO}s and @code{DO WHILE} blocks.
Their @code{block} member should point to a @code{gfc_code} structure heading
Their @code{block} member should point to a @code{gfc_code} structure heading
the code-chain of the loop body; its @code{op} member should be set to
the code-chain of the loop body; its @code{op} member should be set to
@code{EXEC_DO} or @code{EXEC_DO_WHILE}, too, respectively.
@code{EXEC_DO} or @code{EXEC_DO_WHILE}, too, respectively.
 
 
For @code{DO WHILE} loops, the loop condition is stored on the top
For @code{DO WHILE} loops, the loop condition is stored on the top
@code{gfc_code} structure's @code{expr} member; @code{DO} forever loops are
@code{gfc_code} structure's @code{expr} member; @code{DO} forever loops are
simply @code{DO WHILE} loops with a constant @code{.TRUE.} loop condition in
simply @code{DO WHILE} loops with a constant @code{.TRUE.} loop condition in
the internal representation.
the internal representation.
 
 
Similarly, @code{DO} loops with an iterator have instead of the condition their
Similarly, @code{DO} loops with an iterator have instead of the condition their
@code{ext.iterator} member set to the correct values for the loop iterator
@code{ext.iterator} member set to the correct values for the loop iterator
variable and its range.
variable and its range.
 
 
 
 
@subsection @code{SELECT} Statements
@subsection @code{SELECT} Statements
 
 
A @code{SELECT} block is introduced by a @code{gfc_code} structure with an
A @code{SELECT} block is introduced by a @code{gfc_code} structure with an
@code{op} member of @code{EXEC_SELECT} and @code{expr} containing the expression
@code{op} member of @code{EXEC_SELECT} and @code{expr} containing the expression
to evaluate and test.  Its @code{block} member starts a list of @code{gfc_code}
to evaluate and test.  Its @code{block} member starts a list of @code{gfc_code}
structures linked together by their @code{block} members that stores the various
structures linked together by their @code{block} members that stores the various
@code{CASE} parts.
@code{CASE} parts.
 
 
Each @code{CASE} node has its @code{op} member set to @code{EXEC_SELECT}, too,
Each @code{CASE} node has its @code{op} member set to @code{EXEC_SELECT}, too,
its @code{next} member points to the code-chain to be executed in the current
its @code{next} member points to the code-chain to be executed in the current
case-block, and @code{extx.case_list} contains the case-values this block
case-block, and @code{extx.case_list} contains the case-values this block
corresponds to.  The @code{block} member links to the next case in the list.
corresponds to.  The @code{block} member links to the next case in the list.
 
 
 
 
@c gfc_expr
@c gfc_expr
@c --------
@c --------
 
 
@node gfc_expr
@node gfc_expr
@section @code{gfc_expr}
@section @code{gfc_expr}
@tindex @code{gfc_expr}
@tindex @code{gfc_expr}
@tindex @code{struct gfc_expr}
@tindex @code{struct gfc_expr}
 
 
Expressions and ``values'', including constants, variable-, array- and
Expressions and ``values'', including constants, variable-, array- and
component-references as well as complex expressions consisting of operators and
component-references as well as complex expressions consisting of operators and
function calls are internally represented as one or a whole tree of
function calls are internally represented as one or a whole tree of
@code{gfc_expr} objects.  The member @code{expr_type} specifies the overall
@code{gfc_expr} objects.  The member @code{expr_type} specifies the overall
type of an expression (for instance, @code{EXPR_CONSTANT} for constants or
type of an expression (for instance, @code{EXPR_CONSTANT} for constants or
@code{EXPR_VARIABLE} for variable references).  The members @code{ts} and
@code{EXPR_VARIABLE} for variable references).  The members @code{ts} and
@code{rank} as well as @code{shape}, which can be @code{NULL}, specify
@code{rank} as well as @code{shape}, which can be @code{NULL}, specify
the type, rank and, if applicable, shape of the whole expression or expression
the type, rank and, if applicable, shape of the whole expression or expression
tree of which the current structure is the root.  @code{where} is the locus of
tree of which the current structure is the root.  @code{where} is the locus of
this expression in the source code.
this expression in the source code.
 
 
Depending on the flavor of the expression being described by the object
Depending on the flavor of the expression being described by the object
(that is, the value of its @code{expr_type} member), the corresponding structure
(that is, the value of its @code{expr_type} member), the corresponding structure
in the @code{value} union will usually contain additional data describing the
in the @code{value} union will usually contain additional data describing the
expression's value in a type-specific manner.  The @code{ref} member is used to
expression's value in a type-specific manner.  The @code{ref} member is used to
build chains of (array-, component- and substring-) references if the expression
build chains of (array-, component- and substring-) references if the expression
in question contains such references, see below for details.
in question contains such references, see below for details.
 
 
 
 
@subsection Constants
@subsection Constants
 
 
Scalar constants are represented by @code{gfc_expr} nodes with their
Scalar constants are represented by @code{gfc_expr} nodes with their
@code{expr_type} set to @code{EXPR_CONSTANT}.  The constant's value shall
@code{expr_type} set to @code{EXPR_CONSTANT}.  The constant's value shall
already be known at compile-time and is stored in the @code{logical},
already be known at compile-time and is stored in the @code{logical},
@code{integer}, @code{real}, @code{complex} or @code{character} struct inside
@code{integer}, @code{real}, @code{complex} or @code{character} struct inside
@code{value}, depending on the constant's type specification.
@code{value}, depending on the constant's type specification.
 
 
 
 
@subsection Operators
@subsection Operators
 
 
Operator-expressions are expressions that are the result of the execution of
Operator-expressions are expressions that are the result of the execution of
some operator on one or two operands.  The expressions have an @code{expr_type}
some operator on one or two operands.  The expressions have an @code{expr_type}
of @code{EXPR_OP}.  Their @code{value.op} structure contains additional data.
of @code{EXPR_OP}.  Their @code{value.op} structure contains additional data.
 
 
@code{op1} and optionally @code{op2} if the operator is binary point to the
@code{op1} and optionally @code{op2} if the operator is binary point to the
two operands, and @code{operator} or @code{uop} describe the operator that
two operands, and @code{operator} or @code{uop} describe the operator that
should be evaluated on these operands, where @code{uop} describes a user-defined
should be evaluated on these operands, where @code{uop} describes a user-defined
operator.
operator.
 
 
 
 
@subsection Function Calls
@subsection Function Calls
 
 
If the expression is the return value of a function-call, its @code{expr_type}
If the expression is the return value of a function-call, its @code{expr_type}
is set to @code{EXPR_FUNCTION}, and @code{symtree} must point to the symtree
is set to @code{EXPR_FUNCTION}, and @code{symtree} must point to the symtree
identifying the function to be called.  @code{value.function.actual} holds the
identifying the function to be called.  @code{value.function.actual} holds the
actual arguments given to the function as a linked list of
actual arguments given to the function as a linked list of
@code{gfc_actual_arglist} nodes.
@code{gfc_actual_arglist} nodes.
 
 
The other members of @code{value.function} describe the function being called
The other members of @code{value.function} describe the function being called
in more detail, containing a link to the intrinsic symbol or user-defined
in more detail, containing a link to the intrinsic symbol or user-defined
function symbol if the call is to an intrinsic or external function,
function symbol if the call is to an intrinsic or external function,
respectively.  These values are determined during resolution-phase from the
respectively.  These values are determined during resolution-phase from the
structure's @code{symtree} member.
structure's @code{symtree} member.
 
 
A special case of function calls are ``component calls'' to type-bound
A special case of function calls are ``component calls'' to type-bound
procedures; those have the @code{expr_type} @code{EXPR_COMPCALL} with
procedures; those have the @code{expr_type} @code{EXPR_COMPCALL} with
@code{value.compcall} containing the argument list and the procedure called,
@code{value.compcall} containing the argument list and the procedure called,
while @code{symtree} and @code{ref} describe the object on which the procedure
while @code{symtree} and @code{ref} describe the object on which the procedure
was called in the same way as a @code{EXPR_VARIABLE} expression would.
was called in the same way as a @code{EXPR_VARIABLE} expression would.
@xref{Type-bound Procedures}.
@xref{Type-bound Procedures}.
 
 
 
 
@subsection Array- and Structure-Constructors
@subsection Array- and Structure-Constructors
 
 
Array- and structure-constructors (one could probably call them ``array-'' and
Array- and structure-constructors (one could probably call them ``array-'' and
``derived-type constants'') are @code{gfc_expr} structures with their
``derived-type constants'') are @code{gfc_expr} structures with their
@code{expr_type} member set to @code{EXPR_ARRAY} or @code{EXPR_STRUCTURE},
@code{expr_type} member set to @code{EXPR_ARRAY} or @code{EXPR_STRUCTURE},
respectively.  For structure constructors, @code{symtree} points to the
respectively.  For structure constructors, @code{symtree} points to the
derived-type symbol for the type being constructed.
derived-type symbol for the type being constructed.
 
 
The values for initializing each array element or structure component are
The values for initializing each array element or structure component are
stored as linked-list of @code{gfc_constructor} nodes in the
stored as linked-list of @code{gfc_constructor} nodes in the
@code{value.constructor} member.
@code{value.constructor} member.
 
 
 
 
@subsection Null
@subsection Null
 
 
@code{NULL} is a special value for pointers; it can be of different base types.
@code{NULL} is a special value for pointers; it can be of different base types.
Such a @code{NULL} value is represented in the internal tree by a
Such a @code{NULL} value is represented in the internal tree by a
@code{gfc_expr} node with @code{expr_type} @code{EXPR_NULL}.  If the base type
@code{gfc_expr} node with @code{expr_type} @code{EXPR_NULL}.  If the base type
of the @code{NULL} expression is known, it is stored in @code{ts} (that's for
of the @code{NULL} expression is known, it is stored in @code{ts} (that's for
instance the case for default-initializers of @code{ALLOCATABLE} components),
instance the case for default-initializers of @code{ALLOCATABLE} components),
but this member can also be set to @code{BT_UNKNOWN} if the information is not
but this member can also be set to @code{BT_UNKNOWN} if the information is not
available (for instance, when the expression is a pointer-initializer
available (for instance, when the expression is a pointer-initializer
@code{NULL()}).
@code{NULL()}).
 
 
 
 
@subsection Variables and Reference Expressions
@subsection Variables and Reference Expressions
 
 
Variable references are @code{gfc_expr} structures with their @code{expr_type}
Variable references are @code{gfc_expr} structures with their @code{expr_type}
set to @code{EXPR_VARIABLE}; their @code{symtree} should point to the variable
set to @code{EXPR_VARIABLE}; their @code{symtree} should point to the variable
that is referenced.
that is referenced.
 
 
For this type of expression, it's also possible to chain array-, component-
For this type of expression, it's also possible to chain array-, component-
or substring-references to the original expression to get something like
or substring-references to the original expression to get something like
@samp{struct%component(2:5)}, where @code{component} is either an array or
@samp{struct%component(2:5)}, where @code{component} is either an array or
a @code{CHARACTER} member of @code{struct} that is of some derived-type.  Such a
a @code{CHARACTER} member of @code{struct} that is of some derived-type.  Such a
chain of references is achieved by a linked list headed by @code{ref} of the
chain of references is achieved by a linked list headed by @code{ref} of the
@code{gfc_expr} node.  For the example above it would be (@samp{==|} is the
@code{gfc_expr} node.  For the example above it would be (@samp{==|} is the
last @code{NULL} pointer):
last @code{NULL} pointer):
 
 
@smallexample
@smallexample
EXPR_VARIABLE(struct) ==> REF_COMPONENT(component) ==> REF_ARRAY(2:5) ==|
EXPR_VARIABLE(struct) ==> REF_COMPONENT(component) ==> REF_ARRAY(2:5) ==|
@end smallexample
@end smallexample
 
 
If @code{component} is a string rather than an array, the last element would be
If @code{component} is a string rather than an array, the last element would be
a @code{REF_SUBSTRING} reference, of course.  If the variable itself or some
a @code{REF_SUBSTRING} reference, of course.  If the variable itself or some
component referenced is an array and the expression should reference the whole
component referenced is an array and the expression should reference the whole
array rather than being followed by an array-element or -section reference, a
array rather than being followed by an array-element or -section reference, a
@code{REF_ARRAY} reference must be built as the last element in the chain with
@code{REF_ARRAY} reference must be built as the last element in the chain with
an array-reference type of @code{AR_FULL}. Consider this example code:
an array-reference type of @code{AR_FULL}. Consider this example code:
 
 
@smallexample
@smallexample
TYPE :: mytype
TYPE :: mytype
  INTEGER :: array(42)
  INTEGER :: array(42)
END TYPE mytype
END TYPE mytype
 
 
TYPE(mytype) :: variable
TYPE(mytype) :: variable
INTEGER :: local_array(5)
INTEGER :: local_array(5)
 
 
CALL do_something (variable%array, local_array)
CALL do_something (variable%array, local_array)
@end smallexample
@end smallexample
 
 
The @code{gfc_expr} nodes representing the arguments to the @samp{do_something}
The @code{gfc_expr} nodes representing the arguments to the @samp{do_something}
call will have a reference-chain like this:
call will have a reference-chain like this:
 
 
@smallexample
@smallexample
EXPR_VARIABLE(variable) ==> REF_COMPONENT(array) ==> REF_ARRAY(FULL) ==|
EXPR_VARIABLE(variable) ==> REF_COMPONENT(array) ==> REF_ARRAY(FULL) ==|
EXPR_VARIABLE(local_array) ==> REF_ARRAY(FULL) ==|
EXPR_VARIABLE(local_array) ==> REF_ARRAY(FULL) ==|
@end smallexample
@end smallexample
 
 
 
 
@subsection Constant Substring References
@subsection Constant Substring References
 
 
@code{EXPR_SUBSTRING} is a special type of expression that encodes a substring
@code{EXPR_SUBSTRING} is a special type of expression that encodes a substring
reference of a constant string, as in the following code snippet:
reference of a constant string, as in the following code snippet:
 
 
@smallexample
@smallexample
x = "abcde"(1:2)
x = "abcde"(1:2)
@end smallexample
@end smallexample
 
 
In this case, @code{value.character} contains the full string's data as if it
In this case, @code{value.character} contains the full string's data as if it
was a string constant, but the @code{ref} member is also set and points to a
was a string constant, but the @code{ref} member is also set and points to a
substring reference as described in the subsection above.
substring reference as described in the subsection above.
 
 
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c F2003 OOP
@c F2003 OOP
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@node Object Orientation
@node Object Orientation
@chapter Internals of Fortran 2003 OOP Features
@chapter Internals of Fortran 2003 OOP Features
 
 
@menu
@menu
* Type-bound Procedures:: Type-bound procedures.
* Type-bound Procedures:: Type-bound procedures.
* Type-bound Operators::  Type-bound operators.
* Type-bound Operators::  Type-bound operators.
@end menu
@end menu
 
 
 
 
@c Type-bound procedures
@c Type-bound procedures
@c ---------------------
@c ---------------------
 
 
@node Type-bound Procedures
@node Type-bound Procedures
@section Type-bound Procedures
@section Type-bound Procedures
 
 
Type-bound procedures are stored in the @code{tb_sym_root} of the namespace
Type-bound procedures are stored in the @code{tb_sym_root} of the namespace
@code{f2k_derived} associated with the derived-type symbol as @code{gfc_symtree}
@code{f2k_derived} associated with the derived-type symbol as @code{gfc_symtree}
nodes.  The name and symbol of these symtrees corresponds to the binding-name
nodes.  The name and symbol of these symtrees corresponds to the binding-name
of the procedure, i.e. the name that is used to call it from the context of an
of the procedure, i.e. the name that is used to call it from the context of an
object of the derived-type.
object of the derived-type.
 
 
In addition, this type of symtrees stores in @code{n.tb} a struct of type
In addition, this type of symtrees stores in @code{n.tb} a struct of type
@code{gfc_typebound_proc} containing the additional data needed:  The
@code{gfc_typebound_proc} containing the additional data needed:  The
binding attributes (like @code{PASS} and @code{NOPASS}, @code{NON_OVERRIDABLE}
binding attributes (like @code{PASS} and @code{NOPASS}, @code{NON_OVERRIDABLE}
or the access-specifier), the binding's target(s) and, if the current binding
or the access-specifier), the binding's target(s) and, if the current binding
overrides or extends an inherited binding of the same name, @code{overridden}
overrides or extends an inherited binding of the same name, @code{overridden}
points to this binding's @code{gfc_typebound_proc} structure.
points to this binding's @code{gfc_typebound_proc} structure.
 
 
 
 
@subsection Specific Bindings
@subsection Specific Bindings
@c --------------------------
@c --------------------------
 
 
For specific bindings (declared with @code{PROCEDURE}), if they have a
For specific bindings (declared with @code{PROCEDURE}), if they have a
passed-object argument, the passed-object dummy argument is first saved by its
passed-object argument, the passed-object dummy argument is first saved by its
name, and later during resolution phase the corresponding argument is looked for
name, and later during resolution phase the corresponding argument is looked for
and its position remembered as @code{pass_arg_num} in @code{gfc_typebound_proc}.
and its position remembered as @code{pass_arg_num} in @code{gfc_typebound_proc}.
The binding's target procedure is pointed-to by @code{u.specific}.
The binding's target procedure is pointed-to by @code{u.specific}.
 
 
@code{DEFERRED} bindings are just like ordinary specific bindings, except
@code{DEFERRED} bindings are just like ordinary specific bindings, except
that their @code{deferred} flag is set of course and that @code{u.specific}
that their @code{deferred} flag is set of course and that @code{u.specific}
points to their ``interface'' defining symbol (might be an abstract interface)
points to their ``interface'' defining symbol (might be an abstract interface)
instead of the target procedure.
instead of the target procedure.
 
 
At the moment, all type-bound procedure calls are statically dispatched and
At the moment, all type-bound procedure calls are statically dispatched and
transformed into ordinary procedure calls at resolution time; their actual
transformed into ordinary procedure calls at resolution time; their actual
argument list is updated to include at the right position the passed-object
argument list is updated to include at the right position the passed-object
argument, if applicable, and then a simple procedure call to the binding's
argument, if applicable, and then a simple procedure call to the binding's
target procedure is built.  To handle dynamic dispatch in the future, this will
target procedure is built.  To handle dynamic dispatch in the future, this will
be extended to allow special code generation during the trans-phase to dispatch
be extended to allow special code generation during the trans-phase to dispatch
based on the object's dynamic type.
based on the object's dynamic type.
 
 
 
 
@subsection Generic Bindings
@subsection Generic Bindings
@c -------------------------
@c -------------------------
 
 
Bindings declared as @code{GENERIC} store the specific bindings they target as
Bindings declared as @code{GENERIC} store the specific bindings they target as
a linked list using nodes of type @code{gfc_tbp_generic} in @code{u.generic}.
a linked list using nodes of type @code{gfc_tbp_generic} in @code{u.generic}.
For each specific target, the parser records its symtree and during resolution
For each specific target, the parser records its symtree and during resolution
this symtree is bound to the corresponding @code{gfc_typebound_proc} structure
this symtree is bound to the corresponding @code{gfc_typebound_proc} structure
of the specific target.
of the specific target.
 
 
Calls to generic bindings are handled entirely in the resolution-phase, where
Calls to generic bindings are handled entirely in the resolution-phase, where
for the actual argument list present the matching specific binding is found
for the actual argument list present the matching specific binding is found
and the call's target procedure (@code{value.compcall.tbp}) is re-pointed to
and the call's target procedure (@code{value.compcall.tbp}) is re-pointed to
the found specific binding and this call is subsequently handled by the logic
the found specific binding and this call is subsequently handled by the logic
for specific binding calls.
for specific binding calls.
 
 
 
 
@subsection Calls to Type-bound Procedures
@subsection Calls to Type-bound Procedures
@c ---------------------------------------
@c ---------------------------------------
 
 
Calls to type-bound procedures are stored in the parse-tree as @code{gfc_expr}
Calls to type-bound procedures are stored in the parse-tree as @code{gfc_expr}
nodes of type @code{EXPR_COMPCALL}.  Their @code{value.compcall.actual} saves
nodes of type @code{EXPR_COMPCALL}.  Their @code{value.compcall.actual} saves
the actual argument list of the call and @code{value.compcall.tbp} points to the
the actual argument list of the call and @code{value.compcall.tbp} points to the
@code{gfc_typebound_proc} structure of the binding to be called.  The object
@code{gfc_typebound_proc} structure of the binding to be called.  The object
in whose context the procedure was called is saved by combination of
in whose context the procedure was called is saved by combination of
@code{symtree} and @code{ref}, as if the expression was of type
@code{symtree} and @code{ref}, as if the expression was of type
@code{EXPR_VARIABLE}.
@code{EXPR_VARIABLE}.
 
 
For code like this:
For code like this:
@smallexample
@smallexample
CALL myobj%procedure (arg1, arg2)
CALL myobj%procedure (arg1, arg2)
@end smallexample
@end smallexample
@noindent
@noindent
the @code{CALL} is represented in the parse-tree as a @code{gfc_code} node of
the @code{CALL} is represented in the parse-tree as a @code{gfc_code} node of
type @code{EXEC_COMPCALL}.  The @code{expr} member of this node holds an
type @code{EXEC_COMPCALL}.  The @code{expr} member of this node holds an
expression of type @code{EXPR_COMPCALL} of the same structure as mentioned above
expression of type @code{EXPR_COMPCALL} of the same structure as mentioned above
except that its target procedure is of course a @code{SUBROUTINE} and not a
except that its target procedure is of course a @code{SUBROUTINE} and not a
@code{FUNCTION}.
@code{FUNCTION}.
 
 
Expressions that are generated internally (as expansion of a type-bound
Expressions that are generated internally (as expansion of a type-bound
operator call) may also use additional flags and members.
operator call) may also use additional flags and members.
@code{value.compcall.ignore_pass} signals that even though a @code{PASS}
@code{value.compcall.ignore_pass} signals that even though a @code{PASS}
attribute may be present the actual argument list should not be updated because
attribute may be present the actual argument list should not be updated because
it already contains the passed-object.
it already contains the passed-object.
@code{value.compcall.base_object} overrides, if it is set, the base-object
@code{value.compcall.base_object} overrides, if it is set, the base-object
(that is normally stored in @code{symtree} and @code{ref} as mentioned above);
(that is normally stored in @code{symtree} and @code{ref} as mentioned above);
this is needed because type-bound operators can be called on a base-object that
this is needed because type-bound operators can be called on a base-object that
need not be of type @code{EXPR_VARIABLE} and thus representable in this way.
need not be of type @code{EXPR_VARIABLE} and thus representable in this way.
Finally, if @code{value.compcall.assign} is set, the call was produced in
Finally, if @code{value.compcall.assign} is set, the call was produced in
expansion of a type-bound assignment; this means that proper dependency-checking
expansion of a type-bound assignment; this means that proper dependency-checking
needs to be done when relevant.
needs to be done when relevant.
 
 
 
 
@c Type-bound operators
@c Type-bound operators
@c --------------------
@c --------------------
 
 
@node Type-bound Operators
@node Type-bound Operators
@section Type-bound Operators
@section Type-bound Operators
 
 
Type-bound operators are in fact basically just @code{GENERIC} procedure
Type-bound operators are in fact basically just @code{GENERIC} procedure
bindings and are represented much in the same way as those (see
bindings and are represented much in the same way as those (see
@ref{Type-bound Procedures}).
@ref{Type-bound Procedures}).
 
 
They come in two flavours:
They come in two flavours:
User-defined operators (like @code{.MYOPERATOR.})
User-defined operators (like @code{.MYOPERATOR.})
are stored in the @code{f2k_derived} namespace's @code{tb_uop_root}
are stored in the @code{f2k_derived} namespace's @code{tb_uop_root}
symtree exactly like ordinary type-bound procedures are stored in
symtree exactly like ordinary type-bound procedures are stored in
@code{tb_sym_root}; their symtrees' names are the operator-names (e.g.
@code{tb_sym_root}; their symtrees' names are the operator-names (e.g.
@samp{myoperator} in the example).
@samp{myoperator} in the example).
Intrinsic operators on the other hand are stored in the namespace's
Intrinsic operators on the other hand are stored in the namespace's
array member @code{tb_op} indexed by the intrinsic operator's enum
array member @code{tb_op} indexed by the intrinsic operator's enum
value.  Those need not be packed into @code{gfc_symtree} structures and are
value.  Those need not be packed into @code{gfc_symtree} structures and are
only @code{gfc_typebound_proc} instances.
only @code{gfc_typebound_proc} instances.
 
 
When an operator call or assignment is found that can not be handled in
When an operator call or assignment is found that can not be handled in
another way (i.e. neither matches an intrinsic nor interface operator
another way (i.e. neither matches an intrinsic nor interface operator
definition) but that contains a derived-type expression, all type-bound
definition) but that contains a derived-type expression, all type-bound
operators defined on that derived-type are checked for a match with
operators defined on that derived-type are checked for a match with
the operator call.  If there's indeed a relevant definition, the
the operator call.  If there's indeed a relevant definition, the
operator call is replaced with an internally generated @code{GENERIC}
operator call is replaced with an internally generated @code{GENERIC}
type-bound procedure call to the respective definition and that call is
type-bound procedure call to the respective definition and that call is
further processed.
further processed.
 
 
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c LibGFortran
@c LibGFortran
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@node LibGFortran
@node LibGFortran
@chapter The LibGFortran Runtime Library
@chapter The LibGFortran Runtime Library
 
 
@menu
@menu
* Symbol Versioning::    Symbol Versioning.
* Symbol Versioning::    Symbol Versioning.
@end menu
@end menu
 
 
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c Symbol Versioning
@c Symbol Versioning
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@node Symbol Versioning
@node Symbol Versioning
@section Symbol Versioning
@section Symbol Versioning
@comment Based on http://gcc.gnu.org/wiki/SymbolVersioning,
@comment Based on http://gcc.gnu.org/wiki/SymbolVersioning,
@comment as of 2006-11-05, written by Janne Blomqvist.
@comment as of 2006-11-05, written by Janne Blomqvist.
 
 
In general, this capability exists only on a few platforms, thus there
In general, this capability exists only on a few platforms, thus there
is a need for configure magic so that it is used only on those targets
is a need for configure magic so that it is used only on those targets
where it is supported.
where it is supported.
 
 
The central concept in symbol versioning is the so-called map file,
The central concept in symbol versioning is the so-called map file,
which specifies the version node(s) exported symbols are labeled with.
which specifies the version node(s) exported symbols are labeled with.
Also, the map file is used to hide local symbols.
Also, the map file is used to hide local symbols.
 
 
Some relevant references:
Some relevant references:
@itemize @bullet
@itemize @bullet
@item
@item
@uref{http://www.gnu.org/software/binutils/manual/ld-2.9.1/html_node/ld_25.html,
@uref{http://www.gnu.org/software/binutils/manual/ld-2.9.1/html_node/ld_25.html,
GNU @command{ld} manual}
GNU @command{ld} manual}
 
 
@item
@item
@uref{http://people.redhat.com/drepper/symbol-versioning, ELF Symbol
@uref{http://people.redhat.com/drepper/symbol-versioning, ELF Symbol
Versioning - Ulrich Depper}
Versioning - Ulrich Depper}
 
 
@item
@item
@uref{http://people.redhat.com/drepper/dsohowto.pdf, How to Write Shared
@uref{http://people.redhat.com/drepper/dsohowto.pdf, How to Write Shared
Libraries - Ulrich Drepper (see Chapter 3)}
Libraries - Ulrich Drepper (see Chapter 3)}
 
 
@end itemize
@end itemize
 
 
If one adds a new symbol to a library that should be exported, the new
If one adds a new symbol to a library that should be exported, the new
symbol should be mentioned in the map file and a new version node
symbol should be mentioned in the map file and a new version node
defined, e.g., if one adds a new symbols @code{foo} and @code{bar} to
defined, e.g., if one adds a new symbols @code{foo} and @code{bar} to
libgfortran for the next GCC release, the following should be added to
libgfortran for the next GCC release, the following should be added to
the map file:
the map file:
@smallexample
@smallexample
GFORTRAN_1.1 @{
GFORTRAN_1.1 @{
    global:
    global:
        foo;
        foo;
        bar;
        bar;
@} GFORTRAN_1.0;
@} GFORTRAN_1.0;
@end smallexample
@end smallexample
@noindent
@noindent
where @code{GFORTRAN_1.0} is the version node of the current release,
where @code{GFORTRAN_1.0} is the version node of the current release,
and @code{GFORTRAN_1.1} is the version node of the next release where
and @code{GFORTRAN_1.1} is the version node of the next release where
foo and bar are made available.
foo and bar are made available.
 
 
If one wants to change an existing interface, it is possible by using
If one wants to change an existing interface, it is possible by using
some asm trickery (from the @command{ld} manual referenced above):
some asm trickery (from the @command{ld} manual referenced above):
 
 
@smallexample
@smallexample
__asm__(".symver original_foo,foo@@");
__asm__(".symver original_foo,foo@@");
__asm__(".symver old_foo,foo@@VERS_1.1");
__asm__(".symver old_foo,foo@@VERS_1.1");
__asm__(".symver old_foo1,foo@@VERS_1.2");
__asm__(".symver old_foo1,foo@@VERS_1.2");
__asm__(".symver new_foo,foo@@VERS_2.0");
__asm__(".symver new_foo,foo@@VERS_2.0");
@end smallexample
@end smallexample
 
 
In this example, @code{foo@@} represents the symbol @code{foo} bound to
In this example, @code{foo@@} represents the symbol @code{foo} bound to
the unspecified base version of the symbol. The source file that
the unspecified base version of the symbol. The source file that
contains this example would define 4 C functions: @code{original_foo},
contains this example would define 4 C functions: @code{original_foo},
@code{old_foo}, @code{old_foo1}, and @code{new_foo}.
@code{old_foo}, @code{old_foo1}, and @code{new_foo}.
 
 
In this case the map file must contain @code{foo} in @code{VERS_1.1}
In this case the map file must contain @code{foo} in @code{VERS_1.1}
and @code{VERS_1.2} as well as in @code{VERS_2.0}.
and @code{VERS_1.2} as well as in @code{VERS_2.0}.
 
 
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c GNU Free Documentation License
@c GNU Free Documentation License
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@include fdl.texi
@include fdl.texi
 
 
 
 
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
@c Index
@c Index
@c ---------------------------------------------------------------------
@c ---------------------------------------------------------------------
 
 
@node Index
@node Index
@unnumbered Index
@unnumbered Index
 
 
@printindex cp
@printindex cp
 
 
@bye
@bye
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.