Supported Compilers
Selecting a compiler
Use the --compiler flag (case-insensitive, tab-completable):
fobis build --compiler gnu
fobis build --compiler intel
fobis build --compiler custom --fc g95 --modsw "-fmod="Or set it in the fobos file:
[default]
compiler = gnuBuilt-in compilers
| Identifier | Compiler |
|---|---|
gnu | GNU gfortran |
intel | Intel Fortran Compiler Classic (ifort) |
intel_nextgen | Intel Fortran Compiler (ifx) |
g95 | g95 |
opencoarrays-gnu | OpenCoarrays + gfortran |
pgi | PGI Fortran Compiler |
ibm | IBM XL Fortran |
nag | NAG Fortran Compiler |
nvfortran | NVIDIA HPC Fortran (nvfortran) |
amd | AMD Flang (amdflang) |
custom | User-defined — requires --fc and optionally --modsw |
Custom compiler
For any compiler not listed, use custom and specify the executable and module path switch:
fobis build --compiler custom --fc /opt/myfc/bin/myfc --modsw "-module "In a fobos file:
[default]
compiler = custom
fc = /opt/myfc/bin/myfc
modsw = -module
cflags = -c -O2Compiler variants
MPI
Enable the MPI-wrapped compiler variant:
fobis build --mpiThis switches to the MPI wrapper (e.g. mpif90 for GNU, mpiifort for Intel).
OpenMP
fobis build --openmpAdds the appropriate OpenMP flag for the selected compiler.
OpenMP offloading
fobis build --openmp-offloadCoarrays
fobis build --coarrayCoverage instrumentation
Instrument the build for gcov-compatible coverage analysis:
fobis build --coverageAfter running the program, analyze .gcov files with the intrinsic rule:
fobis rule --gcov-analyzer reports/ summaryProfiling
fobis build --profileCompiler-supplied intrinsic modules
The dependency scanner skips well-known intrinsic modules so they don't surface as "unreachable" warnings. Three tiers of filtering apply, in order:
1. Universal Fortran intrinsics — recognised by every compiler:
| Module |
|---|
iso_fortran_env, iso_c_binding |
ieee_exceptions, ieee_arithmetic, ieee_features |
openacc, omp_lib, mpi |
A use, intrinsic :: NAME declaration (any NAME) is also filtered, since the user has explicitly asked the compiler to take the intrinsic version.
2. Compiler-supplied modules — filtered only when the matching compiler is active. Switching to a compiler that doesn't ship these modules makes them resurface as unresolved dependencies, which is the right behaviour:
| Compiler | Recognised intrinsic modules |
|---|---|
nvfortran, pgi | cudafor, cudadeviceprop, cublas, cublas_v2, cusparse, cusolverdn, curand, curand_device, cufft, nccl, nvtx, thrust |
intel, intel_nextgen | ifport, ifcore, ifqwin, iflogm, dfport, mkl_service |
gnu, nag, ibm, amd, g95, opencoarrays-gnu | (universal set only) |
3. User-extensible per-mode list — for modules from external libraries (e.g. hdf5, hdf5_hl, mpi_f08, vendor HPC modules) declare them in the mode block:
[release]
compiler = nvfortran
intrinsic_modules = hdf5 hdf5_hl
target = src/main.F90Names are case-insensitive and apply only to the mode they are declared in. See the intrinsic_modules mode key documentation for details.
Compilation and linking flags
Override the default flags for the selected compiler:
fobis build --cflags " -c -O3 -march=native" --lflags " -O3"Or in fobos:
[default]
cflags = -c -O3 -march=native
lflags = -O3Flag prefixing
Prepend a space to flag strings to avoid the parser misinterpreting flags that start with -. See the Quick Start note.
Preprocessor flags
Pass flags to the compiler's built-in preprocessor (e.g. -D macros):
fobis build --preproc " -DDEBUG -DUSE_MPI"In fobos:
[default]
preproc = -DDEBUG -DUSE_MPI