This is the Minuit2 fitter standalone extractor, from the ROOT toolkit. It uses CMake 3.1+ to build. See README.md for information about building Minuit2.
To extract, run the following commands from the math/minuit2/build directory:
This will fill in the math/minuit2 directory with all the files needed for Minuit2, copied from the corresponding ROOT files, as part of the configure step. At this point, you could continue to build (using make). Note that the CMake option minuit2_inroot will automatically be set to ON if you are inside the ROOT source tree. Setting minuit2_standalone requires that this be inside the ROOT source tree. As always, any manual setting of a cached variable in CMake will be remembered as long as the CMakeCache.txt file is not removed.
Remember that after building a tarball or a binary package you should remove the copied files using:
Otherwise git shows the file as untracked, unless you explicitly remove their tracking yourself with a .gitignore file
Minuit2 standalone also has support for CPack to make installers for different platforms. To build a source package:
This will create a source file in several formats that you can distribute. Reminder: You must have used -Dminuit2_standalone=ON when you configured CMake, or many of the files will be missing.
To build a binary package (add other generators with -G): 
If new files are needed by Minuit2 due to additions to ROOT, they should be added to the source files lists in src/Math/CMakeLists.txt and src/Minuit2/CMakeLists.txt (depending on if it's a new Math or Minuit2 requirement).
For testing, the main test/CMakeLists.txt is used by ROOT, and the test/*/CMakeLists.txt files are used by the standalone build.
Extracting from the ROOT sources is made possible through a few careful design features:
minuit2_inroot lets the build system know we are inside ROOT (it looks for ../../build/version_info)copy_standalone, and that handles selecting the correct locationcopy_standalone copies the files into the minuit2 source directory if minuit2_standalone is ONAfter this happens, all the standard CMake machinery can produce the source distribution. And, CMake correctly builds and installs in either mode, since all source and header files are explicitly listed.