2021-12-15 06:16:22 -08:00
#+TITLE : lang/fortran
#+DATE : October 22, 2021
#+SINCE : v3.0.0 (#5676)
#+STARTUP : inlineimages nofold
* Table of Contents :TOC_3:noexport:
- [[#description ][Description ]]
- [[#maintainers ][Maintainers ]]
- [[#module-flags ][Module Flags ]]
- [[#plugins ][Plugins ]]
- [[#prerequisites ][Prerequisites ]]
2022-04-13 08:29:37 -07:00
- [[#general ][General ]]
- [[#arch-linux ][Arch Linux ]]
- [[#installing-intel-fortran ][Installing Intel Fortran ]]
2021-12-15 06:16:22 -08:00
- [[#features ][Features ]]
- [[#configuration ][Configuration ]]
- [[#troubleshooting ][Troubleshooting ]]
* Description
This module enables a complete, modern development environment for the [[https://fortran-lang.org/ ][Fortran ]]
language. Initially released in 1956 (a year before Lisp 1.0), Fortran is the
original high-performance computation language and is still widely used in
science and academia. Popular versions of the language include Fortran 77 and
Fortran 90, with further extensions in the 1995 and 2008 varieties. Today,
Fortran has joined the modern age with its own [[https://github.com/fortran-lang/fpm ][package manager ]], [[https://fortran-lang.org/packages/ ][package
registry]], and [[https://fortran-lang.discourse.group/ ][Discourse community ]].
In particular, this module features:
+ Support for all major Fortran varieties.
+ Auto-formatting via =fprettier= .
+ Integration with the =fpm= package manager.
2022-03-04 00:52:55 -08:00
+ LSP support via [[https://github.com/gnikit/fortls ][fortls ]].
2022-04-13 08:29:37 -07:00
+ Optional Intel Fortran support via the =+intel= flag.
2021-12-15 06:16:22 -08:00
#+begin_quote
After a career of writing Fortran on Mainframes and Windows machines, my
now-retired Dad is switching to Linux. Imagine my surprise when I learned that
off-the-shelf setups for Fortran on Linux basically don't exist! Well, until
now... Cheers Dad, hope this helps.
#+end_quote
** Maintainers
+ [[https://github.com/fosskers ][@fosskers ]] (Author)
** Module Flags
2022-03-04 00:52:55 -08:00
+ =+lsp= Activate =fortls= for Fortran projects.
2022-04-13 08:29:37 -07:00
+ =+intel= Use the =ifort= compiler by default.
2021-12-15 06:16:22 -08:00
** Plugins
* Prerequisites
2022-04-13 08:29:37 -07:00
** General
2021-12-15 06:16:22 -08:00
For minimum functionality, this module requires =gfortran= . For most project
management tasks you will also need [[https://github.com/fortran-lang/fpm ][fpm ]], the Fortran Package Manager.
2022-04-13 08:29:37 -07:00
*** Arch Linux
2021-12-15 06:16:22 -08:00
=gfortran= is available from the official repositories:
#+begin_example
sudo pacman -S gcc-fortran
#+end_example
2022-03-04 00:52:55 -08:00
Whereas =fpm= and =fortls= are available from the AUR and thus must be installed
with an AUR-compatible tool like [[https://github.com/fosskers/aura ][Aura ]]:
2021-12-15 06:16:22 -08:00
#+begin_example
2022-03-04 00:52:55 -08:00
sudo aura -A fortran-fpm fortls
2021-12-15 06:16:22 -08:00
#+end_example
2022-04-13 08:29:37 -07:00
** Installing Intel Fortran
Activating the =+intel= flag won't automatically install Intel Fortan for you.
Here's how to do it on *nix systems.
You can of course install the entire High-performance Computing kit from Intel,
which includes Fortran, but the installation footprint is quite large. Instead,
you're able to install just Fortran and its core facilities on their own as a
[[https://www.intel.com/content/www/us/en/developer/articles/tool/oneapi-standalone-components.html#fortran ][standalone component ]]. Download this script, and make it executable via:
#+begin_example
chmod +x l_fortran-compiler_p_2022.0.3.83_offline.sh
#+end_example
The filepath will of course change with time, so alter the above command
accordingly. Now run the script _as a normal user_ (non-sudo) and follow the
instructions of the installer. This will install =ifort= , etc., in a local
filepath of your choosing.
To actually use =ifort= and have it link to its libraries properly, we must run a
script provided by Intel to set certain environment variables:
#+begin_example
. ~/intel/oneapi/setvars.sh
#+end_example
(Modify according to where you installed Intel Fortran.) Now =ifort= should be
runnable in your terminal as you'd expect. _To persist this, add that line to
your Bash Profile, etc., and log out and in again._ Now Doom will be able to use
=ifort= too.
Good luck and happy computing!
2021-12-15 06:16:22 -08:00
* Features
# An in-depth list of features, how to use them, and their dependencies.
* Configuration
# How to configure this module, including common problems and how to address them.
* Troubleshooting
# Common issues and their solution, or places to look for help.