If building with :ref:`external_amrex`, specify the path to AMReX with
The options **ENABLE\_PARTICLES=yes**, **ENABLE\_AMRDATA=yes**, and **ENABLE\_EB=yes** are required by MFiX-Exa. ``[other amrex options]`` in the snippet above refers to any other AMReX configuration option in addition to the required ones. Please refer to the `AMReX user guide <https://amrex-codes.github.io/amrex/docs_html/BuildingAMReX.html#building-with-cmake>`_ for more details on building AMReX with CMake.
``-DAMREX_ROOT``:
.. highlight:: console
::
Building MFiX-Exa
~~~~~~~~~~~~~~~~~
> cmake -S . -B builddir \
Clone and build MFiX-Exa:
-DAMREX_ROOT=/absolute/path/to/amrex/installdir
Passing ``-DAMREX_ROOT=/absolute/path/to/amrex/installdir`` instructs CMake to
.. code:: shell
search ``/absolute/path/to/amrex/installdir``, and then search system paths, for
an available AMReX installation.
Alternatively, set the ``AMREX_ROOT`` environmental variable instead of passing
If no AMReX installation is found on the system, or if one is found but does not meet MFiX-Exa requirements, MFiX-Exa CMake falls back to **SUPERBUILD** mode.
When building in **SUPERBUILD** mode, the AMReX git repo is checked out via a git submodule before AMReX CMake build system is included into MFiX-Exa CMake infrastructure. Consequently, MFiX-Exa CMake inherents AMReX's CMake targets and configuration options, that is, MFiX-Exa and AMReX are configured and built as a single entity.
Assuming no valid AMReX installation is present on the target system, and ``AMReX_ROOT`` is not set in the environment, the following code will build MFiX-Exa in **SUPERBUILD** mode:
.. note::
.. code:: shell
MFiX-Exa needs to be built with the same CMake options used to build the
``[amrex options]`` is a list of any of the AMReX configuration options listed in the `AMReX user guide <https://amrex-codes.github.io/amrex/docs_html/BuildingAMReX.html#building-with-cmake>`_
.. _Building:
Building
Few more notes on building MFiX-Exa
--------
-----------------------------------
To build MFiX-Exa:
The system defaults compilers can be overwritten as follows: