Skip to content
Chris MacMackin edited this page Aug 11, 2015 · 44 revisions

##Version 4.1.0 New features:

  • adds support for submodules (a Fortran 2008 feature)
  • improved display of abstract derived types (previously there was no indication that they were abstract) and their deferred type-bound procedures (will show the required interface, if one is specified) (Issue 68)
  • can now handle multiple entities of the same type with the same name
  • a --debug command-line flag which will cause FORD to produce a backtrace if it encounters an error when parsing a file.

Bug fixes:

  • now recognizes module procedures inside generic interfaces even if the word "module" is not used (Issue 69)
  • fixed broken links to overloaded operators (Issue 67)
  • fixed a regression which caused procedure arguments to be listed in an order different from that found in the source code (Issue 64)

##Version 4.0.1 Fixed a bug which caused FORD to try to interpret the class default statement in a select type construct as a variable declaration. ##Version 4.0.0 Non-backwards compatible changes:

  • Removed -v/--verbose and --no-warn from CLI, as they were unnecessary
  • Changed the default predocmark_alt from # to |
  • Meta-data no longer displayed in procedure, interface, and derived type summaries if those entities have their own page

New features:

  • Can now change sort order
  • Option to force FORD to read all non-string and non-comment source code as [lower case] (https://github.com/cmacmackin/ford/wiki/Project-File-Options#lower)
  • Support for coarrays
  • Option to turn off search feature, either in project file or at command line (useful for large projects, as generating the search database can take a long time)
  • Recognition of intrinsic and common third-party modules, with links to external documentation (iso_fortran_env, iso_c_binding, ieee_arithmetic, ieee_exceptions, ieee_features, omp_lib, mpi, mpi_f08, openacc)
  • Ability to add recognition of third-party modules and links to their documentation

Bug fixes:

  • Fixed extraneous text resulting from using the markdown.extras.abbrv plugin with abbreviations in the project summary (Issue 61)
  • Fixed links to functions in modules (Issue 60)
  • Fixed a warning which was sometimes raised by Beautiful Soup (Issue 59)

##Version 3.1.0 Fixed bugs causing certain files (e.g. CSS and JavaScript) to appear to never be updated. This can be problematic with certain build systems. Also fixed an error which caused the pages feature to be unable to copy sub-directories. Finally, fixed an issue which could have potentially broken the command-line -w/--warn option.

Added a -q/--quiet option to the CLI (as well as a quiet setting for project file metadata) which suppresses all output from FORD.

##Version 3.0.2 Fixed bug in link to a single source file in the main menu, if the file name contained an uppercase letter.

##Version 3.0.1 Fixed errors when documentation followed alternative documentation. Also added checks to ensure that none of the docmarks are the same. This was supposed to be in the previous release, but was overlooked.

##Version 3.0.0

  • Added option to exclude contents of directories
  • Fixed a bug in creating output files in Windows
  • Now preprocesses code from files whose extensions indicate that this is necessary, prior to extracting documentation. This can be deactivated. The user can also specify which macros should be provided to the preprocessor.
  • Change the meta-data settings "deprecated" and "warn" so that their value now needs to be "true" in order to have any effect.
  • predocmark, docmark_alt, and predocmark_alt now have the default values of >, *, and #, respectively.
  • Improved support for parsing type-bound procedures.

##Version 2.1.0

  • Added support for linking to other parts of the documentation.
  • Introduced option to include a procedure's, derived type's, or programs's syntax-highlighted source code at the bottom of its documentation page. Can be specified globally and overridden for specific items.
  • Added option to change what will be displayed for a particular portion of a project. Also added a 'none' option to display settings, causing all contents of an item to be hidden.
  • Created new way of specifying documentation. This allows a special docmark to be designated which indicates that all comments in the following block should be counted as documentation. This can apply for comments before or after whatever item is to be documented.

##Version 2.0.0

  • Altered the CLI so that the Python argparse help message is more accurate
  • Added support for extra variable types (useful when software uses certain libraries)
  • Fixed handling of abstract interfaces, so that they are now treated as distinct from normal interfaces
  • Added ability to produces links to abstract interfaces when being used to declare a procedure pointer
  • Reworked internal treatment of interfaces in general
  • Added support for multiple directories containing source files
  • Improved checking if project_dir within output_dir
  • Added |url| and |media| macros
  • Added ability to produce a page hierarchy, not linked to any particular source code
  • Added ability to recognize implicitly declared arguments
  • Added F90, F95, F03, F08 to list of default extensions to scan

##Version 1.1.0

  • Added support for Python3 (thanks to Jacob Williams for implementing this)
  • Added a -V/--version option to the command line interface, so that you can check which version of FORD is installed.
  • Fixed a regression where FORD was looking for any included markdown files relative to where it was being run, rather than relative to the project file.

##Version 1.0.1

  • Fixed a bug which was causing FORD to crash in some circumstances when handling abstract interfaces. This bug would likely have also been present for the handling of interfaces to non-module procedures.

##Version 1.0.0

  • Formal adoption of semantic versioning. The API, as described here, should now be considered stable.
  • Ability to specify documentation preceding the code which it is documenting (thanks to mrestelli for contributing that improvement).
  • Small bug fixes.

##Version 0.5

  • Fixed a problem in reader.py which caused it to split lines even if semi-colons were within strings.
  • Fixed conflicts between including Markdown files in documentation and any other syntax (particularly that found in code fragments). However, this required breaking the API, as the syntax for including a file is now {! filename !}.
  • Fixed a bug whereby if documentation lacks meta-data but has a colon in the first line it would cause an error (as Markdown would try to interpret that as meta-data).
Clone this wiki locally