summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorViktor Mukha <viktor.m@l4b-software.com>2018-05-16 08:04:04 (GMT)
committerBrad King <brad.king@kitware.com>2018-05-16 16:48:20 (GMT)
commitb6c49713b35cf1ab9c0bff30cb7a6e20a8f3b481 (patch)
tree00a8a77dbb01551e32927b39ccc8977e28998d02
parentc698dbd45d0f51b5b13d728a2216308c6a11478e (diff)
downloadCMake-b6c49713b35cf1ab9c0bff30cb7a6e20a8f3b481.zip
CMake-b6c49713b35cf1ab9c0bff30cb7a6e20a8f3b481.tar.gz
CMake-b6c49713b35cf1ab9c0bff30cb7a6e20a8f3b481.tar.bz2
Makefile: Fix command line limits for static libs
I have been hitting the Windows command-line limit when cross-compiling static library (POCO) and having more than 8000 characters in the call to "ar". Calculating exact limits here are tricky, since this particular limit will only take into account object file strings, which is correct for response files, but not for the archive rules (link.txt files), since they also contain the call to "ar" and its arguments. Also, there can be other additional arguments if "ar" tool is wrapped into something else, so it is a good idea to leave more space than trying to exactly fit the limit. Since response files use half of the limit as a heuristic, we reproduce it here for consistency.
-rw-r--r--Source/cmMakefileLibraryTargetGenerator.cxx13
1 files changed, 9 insertions, 4 deletions
diff --git a/Source/cmMakefileLibraryTargetGenerator.cxx b/Source/cmMakefileLibraryTargetGenerator.cxx
index 27fae04..c538992 100644
--- a/Source/cmMakefileLibraryTargetGenerator.cxx
+++ b/Source/cmMakefileLibraryTargetGenerator.cxx
@@ -5,6 +5,7 @@
#include <algorithm>
#include <memory> // IWYU pragma: keep
#include <sstream>
+#include <stddef.h>
#include <vector>
#include "cmGeneratedFileStream.h"
@@ -732,10 +733,14 @@ void cmMakefileLibraryTargetGenerator::WriteLibraryRules(
// Archiving rules never use a response file.
useResponseFileForObjects = false;
- // Limit the length of individual object lists to less than the
- // 32K command line length limit on Windows. We could make this a
- // platform file variable but this should work everywhere.
- archiveCommandLimit = 30000;
+ // Limit the length of individual object lists to less than half of
+ // the command line length limit (leaving half for other flags).
+ // This may result in several calls to the archiver.
+ if (size_t limit = cmSystemTools::CalculateCommandLineLengthLimit()) {
+ archiveCommandLimit = limit / 2;
+ } else {
+ archiveCommandLimit = 8000;
+ }
}
// Expand the rule variables.