\section{Quick Installation of \Dumux} \label{quick-install} This only provides one quick way of installing \Dumux. You should have a recent working Linux environment, no \Dune core modules should be installed. If you need more information, have \Dune already installed, please have a look at the detailed installation instructions in Section \ref{install}. \subsection{Obtaining the code with the script \texttt{checkout-dumux}} The shell-script \texttt{checkout-dumux} facilitates setting up a {\Dune}/{\Dumux} directory tree (currently for the trunk version). It is contained in the download section of the \Dumux web page \cite{DUMUX-HP}. For example the second line below will check out the required \Dune modules and \texttt{dumux}, \texttt{dumux-devel} and the \texttt{external} folder, which contains some useful external software and libraries. Again, \texttt{joeuser} needs to be replaced by the actual user name. \begin{lstlisting}[style=Bash] $ checkout-dumux -h # show help, $ checkout-dumux -gme -u joeuser -p password -d DUMUX \end{lstlisting} \subsection{Build of \Dune and \Dumux} \label{buildIt} Building of \Dune and \Dumux is done by the command-line script \texttt{dunecontrol} as described in \Dune Installation Notes \cite{DUNE-INST} and in much more comprehensive form in the \Dune Buildsystem Howto \cite{DUNE-BS}. If something fails during the execution of \texttt{dunecontrol} feel free to report it to the \Dune or \Dumux developer mailing list, but also try to include error details.\\ It is possible to compile \Dumux with nearly no explicit options to the build system. %, but experience showed that the code quality through all parts of \Dune is not yet high enough to give the compiler full %freedom for allowing certain kinds of optimizations. However, for the successful compilation of \Dune and \Dumux, it is currently necessary to pass the %As options, switches for the optimization can be set in parts %build system for code by default, it is safer to pass the option \texttt{-fno-strict-aliasing} to the C++-compiler \cite{WIKIPED-ALIASING}, which is done here via a command-line argument to \texttt{dunecontrol}: \begin{lstlisting}[style=Bash] $ # make sure you are in the directory DUNE-Root $ ./dune-common/bin/dunecontrol --configure-opts="CXXFLAGS=-fno-strict-aliasing" all \end{lstlisting} Too many options can make life hard. That's why usually option-files are being used together with dunecontrol and its sub-tools. Larger sets of options are kept in them. If you are going to compile with options suited for debugging the code, the following can be a starting point: %Below in command-line make sure to insert the right name of dumux' root directory, which is in the case of installation from tar-files \texttt{dumux-2.0} or in the case of installation from subversion just \texttt{dumux}. For a developer it is also possible to take the options file from \texttt{dumux-devel}. \begin{lstlisting}[style=Bash] $ # make sure you are in the directory DUNE-Root $ cp dumux/debug.opts my-debug.opts # create a personal version $ gedit my-debug.opts # optional editing the options file $ ./dune-common/bin/dunecontrol --opts=my-debug.opts all \end{lstlisting} More optimized code, which is typically not usable for standard debugging tasks, can be produced by \begin{lstlisting}[style=Bash] $ cp dumux/optim.opts my-optim.opts $ ./dune-common/bin/dunecontrol --opts=my-optim.opts all \end{lstlisting} Sometimes it is necessary to have additional options which are specific to a package set of an operating system or sometimes you have your own preferences. Feel free to work with your own set of options, which may evolve over time. The option files above are to be understood more as a starting point for setting up an own customization than as something which is fixed. The use of external libraries can make it necessary to add quite many options in an option-file. It can be helpful to give your customized option file its own name, as done above. One avoids confusing it with the option files which came out of the distribution and which can be possibly updated by subversion later on.