Ingen beskrivning

Brad King d9195ab081 Tests: Teach run_ctest to handle removal of CTestConfig.cmake 7 år sedan
.github 7983e068e1 Add GitHub PR template to point contributors at CONTRIBUTING.rst 8 år sedan
Auxiliary a4e9391953 ExternalProject: add LOG_PATCH option to log the patch command 7 år sedan
Help 3125c47d27 ctest_build: Do not require unnecessary [CTEST_]PROJECT_NAME value 7 år sedan
Licenses 9ad10c8feb cmake-gui: Reference LGPLv3 when redistributing Qt 9 år sedan
Modules 1ca53f5ef1 Remove unnecessary CTEST_PROJECT_NAME variables 7 år sedan
Packaging 94420a7b61 QtIFW: Improved packaging as part of the QtSDK 8 år sedan
Source 15ac4aae0e Remove warning when no CTestConfig.cmake file exists 7 år sedan
Templates cb694f8cd6 VS: Properly quote arguments in nasm.xml 7 år sedan
Tests d9195ab081 Tests: Teach run_ctest to handle removal of CTestConfig.cmake 7 år sedan
Utilities 9bb203ed0f Merge topic 'FindBoost-1.69' 7 år sedan
.clang-format 523c443d13 clang-format.bash: update to clang-format-6.0 7 år sedan
.clang-tidy 3c8187f687 clang-tidy: restore 'misc-noexcept-move-constructor' 7 år sedan
.gitattributes 523c443d13 clang-format.bash: update to clang-format-6.0 7 år sedan
.gitignore 9c01704e9f gitignore: Ignore a .vscode directory in the source tree 7 år sedan
.hooks-config 3288ab0c78 Convert local hook configuration to a Git config file format 8 år sedan
CMakeCPack.cmake fa23f66ad5 CMakeCPack: Exclude version-control-specific files from source package 8 år sedan
CMakeCPackOptions.cmake.in fa23f66ad5 CMakeCPack: Exclude version-control-specific files from source package 8 år sedan
CMakeGraphVizOptions.cmake 77543bde41 Convert CMake-language commands to lower case 13 år sedan
CMakeLists.txt 786dddc0fd Add option to build CMake itself with IPO/LTO 7 år sedan
CMakeLogo.gif bde7f6c023 ENH: fancier logo 18 år sedan
CONTRIBUTING.rst 670324bea2 Help: Update maintainer edit checkbox label 7 år sedan
CTestConfig.cmake 86578eccf2 Simplify CMake per-source license notices 9 år sedan
CTestCustom.cmake.in ce3cd1a89b Solaris: Silence warning when using system libform. 7 år sedan
CompileFlags.cmake a1dee224b8 CMake: Enable /MP for MSVC toolchain 7 år sedan
Copyright.txt 84e7920b3a FindFontconfig: Add module to find Fontconfig 7 år sedan
DartConfig.cmake 86578eccf2 Simplify CMake per-source license notices 9 år sedan
README.rst 33632898e9 README: Suggest "sudo" for "make install" 7 år sedan
bootstrap fc8955e889 add_subdirectory: Run subdirectory install rules in correct order 7 år sedan
cmake_uninstall.cmake.in 5bd48ac534 Replace string(REGEX REPLACE) with string(REPLACE) where possible 11 år sedan
configure 28531d1707 Simplify bootstrap script source dir detection 16 år sedan
doxygen.config 7bbaa4283d Remove trailing whitespace from most CMake and C/C++ code 13 år sedan

README.rst

CMake
*****

Introduction
============

CMake is a cross-platform, open-source build system generator.
For full documentation visit the `CMake Home Page`_ and the
`CMake Documentation Page`_. The `CMake Community Wiki`_ also
references useful guides and recipes.

.. _`CMake Home Page`: https://cmake.org
.. _`CMake Documentation Page`: https://cmake.org/cmake/help/documentation.html
.. _`CMake Community Wiki`: https://gitlab.kitware.com/cmake/community/wikis/home

CMake is maintained and supported by `Kitware`_ and developed in
collaboration with a productive community of contributors.

.. _`Kitware`: http://www.kitware.com/cmake

License
=======

CMake is distributed under the OSI-approved BSD 3-clause License.
See `Copyright.txt`_ for details.

.. _`Copyright.txt`: Copyright.txt

Building CMake
==============

Supported Platforms
-------------------

* Microsoft Windows
* Apple macOS
* Linux
* FreeBSD
* OpenBSD
* Solaris
* AIX

Other UNIX-like operating systems may work too out of the box, if not
it should not be a major problem to port CMake to this platform.
Subscribe and post to the `CMake Users List`_ to ask if others have
had experience with the platform.

.. _`CMake Users List`: https://cmake.org/mailman/listinfo/cmake

Building CMake from Scratch
---------------------------

UNIX/Mac OSX/MinGW/MSYS/Cygwin
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

You need to have a C++ compiler (supporting C++11) and a ``make`` installed.
Run the ``bootstrap`` script you find in the source directory of CMake.
You can use the ``--help`` option to see the supported options.
You may use the ``--prefix=`` option to specify a custom
installation directory for CMake. You can run the ``bootstrap`` script from
within the CMake source directory or any other build directory of your
choice. Once this has finished successfully, run ``make`` and
``make install``. In summary::

$ ./bootstrap && make && sudo make install

Windows
^^^^^^^

You need to download and install a binary release of CMake in order to build
CMake. You can get these releases from the `CMake Download Page`_. Then
proceed with the instructions below.

.. _`CMake Download Page`: https://cmake.org/cmake/resources/software.html

Building CMake with CMake
-------------------------

You can build CMake as any other project with a CMake-based build system:
run the installed CMake on the sources of this CMake with your preferred
options and generators. Then build it and install it.
For instructions how to do this, see documentation on `Running CMake`_.

.. _`Running CMake`: https://cmake.org/cmake/help/runningcmake.html

To build the documentation, install `Sphinx`_ and configure CMake with
``-DSPHINX_HTML=ON`` and/or ``-DSPHINX_MAN=ON`` to enable the "html" or
"man" builder. Add ``-DSPHINX_EXECUTABLE=/path/to/sphinx-build`` if the
tool is not found automatically.

.. _`Sphinx`: http://sphinx-doc.org

Reporting Bugs
==============

If you have found a bug:

1. If you have a patch, please read the `CONTRIBUTING.rst`_ document.

2. Otherwise, please join the `CMake Users List`_ and ask about
the expected and observed behaviors to determine if it is really
a bug.

3. Finally, if the issue is not resolved by the above steps, open
an entry in the `CMake Issue Tracker`_.

.. _`CMake Issue Tracker`: https://gitlab.kitware.com/cmake/cmake/issues

Contributing
============

See `CONTRIBUTING.rst`_ for instructions to contribute.

.. _`CONTRIBUTING.rst`: CONTRIBUTING.rst