summaryrefslogtreecommitdiffstats
path: root/Help/prop_tgt/UNITY_BUILD_MODE.rst
diff options
context:
space:
mode:
authorRobert Maynard <robert.maynard@kitware.com>2020-05-06 19:45:42 (GMT)
committerRobert Maynard <robert.maynard@kitware.com>2020-05-07 15:13:34 (GMT)
commit9f4eb352fe1383f740876e3924205be1d4bf897c (patch)
tree6911d23d9c5f950860a9ba1d0048b4d7f1417f1c /Help/prop_tgt/UNITY_BUILD_MODE.rst
parentb00585adcc11afcf4d02d9d9927a929f33b19546 (diff)
downloadCMake-9f4eb352fe1383f740876e3924205be1d4bf897c.zip
CMake-9f4eb352fe1383f740876e3924205be1d4bf897c.tar.gz
CMake-9f4eb352fe1383f740876e3924205be1d4bf897c.tar.bz2
Unity Builds: Support explicit specification of sources to groups
Instead of having CMake determine which files should go into each unity file, the user can now use explicitly state the mapping.
Diffstat (limited to 'Help/prop_tgt/UNITY_BUILD_MODE.rst')
-rw-r--r--Help/prop_tgt/UNITY_BUILD_MODE.rst22
1 files changed, 22 insertions, 0 deletions
diff --git a/Help/prop_tgt/UNITY_BUILD_MODE.rst b/Help/prop_tgt/UNITY_BUILD_MODE.rst
new file mode 100644
index 0000000..cbc4989
--- /dev/null
+++ b/Help/prop_tgt/UNITY_BUILD_MODE.rst
@@ -0,0 +1,22 @@
+UNITY_BUILD_MODE
+----------------
+
+CMake provides different algorithms for selecting which sources are grouped
+together into a *bucket*. Selection is decided by this property,
+which has the following acceptable values:
+
+* ``BATCH``
+ When in this mode CMake determines which files are grouped together.
+ The :prop_tgt:`UNITY_BUILD_BATCH_SIZE` property controls the upper limit on
+ how many sources can be combined per unity source file.
+
+* ``GROUP``
+ When in this mode each target explicitly specifies how to group
+ source files. Each source file that has the same
+ :prop_sf:`UNITY_GROUP` value will be grouped together. Any sources
+ that don't have this property will be compiled individually. The
+ :prop_tgt:`UNITY_BUILD_BATCH_SIZE` property is ignored when using
+ this mode.
+
+If no explicit :prop_tgt:`UNITY_BUILD_MODE` has been specified, CMake will
+default to ``BATCH``.