Files
create/cMake/FreeCAD_Helpers
Jacob Oursland c56ae33493 CMake: use job pools to restrict number of concurrent compilers and linkers.
When using Ninja build system, CMake can specify job pools for number of concurrent compilers
and concurrent linkers.  This PR employes the heuristic of max number of compilers as available
physical ram / 1 GiB and a single linker instance to prevent using excessive RAM.  Modern
linkers are multithreaded and should not be run concurrently due to risk of resource exhaustion.
2025-04-15 13:04:22 +02:00
..
2019-09-26 18:54:45 +02:00
2025-03-24 21:09:48 -05:00
2025-03-31 10:49:16 -05:00

This folder will contain an individual cmake file for each FreeCAD "helper".

A "helper" should be a macro or function that tries (as much as possible) to adhere to the UNIX philosophy - in other words, it should strive to do one thing and do it well.

The idea here is to break up the cmake build system into smaller, more manageable chunks. This should make maintenance easier, and should also make troubleshooting a bit less painful. Finally, it should also clean up our top-level CMakeLists.txt file a bit, making it bit easier for new developers to jump in and see what's what.

NOTE: CMake has a very distinct difference between its macros and its functions. Namely, a function creates its own SCOPE, whereas a macro essentially executes in the calling scope. There are also some specifics of how arguments are managed.

In general:

  1. If you use a macro, be careful modifying arguments - you may get surprises.
  2. If you use a function, make sure to use set(.... PARENT_SCOPE) for variables that should be available outside of the function.