[Scons-users] SCons 4.10.0 released

Bill Deegan bill at baddogconsulting.com
Thu Oct 2 13:54:42 EDT 2025


A new SCons release, 4.9.10, is now available on the SCons download page:

    https://scons.org/pages/download.html

Here is a summary of the changes since 4.9.1:


CHANGED/ENHANCED EXISTING FUNCTIONALITY
---------------------------------------

- Nodes are now treated as PathLike objects.

- Replace use of old conditional expression idioms with the official
  one from PEP 308 introduced in Python 2.5 (2006). The idiom being
  replaced (using and/or) is regarded as error prone.

- MSVC: The following shell environment variables are now included in
  the environment used by SCons to initialize MSVC when defined:
  VCPKG_DISABLE_METRICS, VCPKG_ROOT, POWERSHELL_TELEMETRY_OPTOUT,
  PSDisableModuleAnalysisCacheCleanup, and PSModuleAnalysisCachePath.
  A subset of the shell environment PSModulePath is included in the
  environment used by SCons to initialize MSVC when defined.  None of
  these variables and values are propagated to the user's SCons
  environment after running the MSVC batch files.

- TEMPFILE: A UserError exception is raised when encoding
  the contents of the tempfile fails due to a limited set of expected
  exceptions (e.g., UnicodeError).

FIXES
-----

- Fixed SCons.Variables.PackageVariable to correctly test the default
  setting against both enable & disable strings. (Fixes #4702)

- MSVC: Fixed a significant delay experienced in the Github Actions
  windows 2022 and 2025 runners due to the environment used by SCons
  to initialize MSVC when the Visual Studio vcpkg component is
  installed. The Github Actions windows 2019 runner was not affected.

- Fix the variant dir component being missing from generated source file
  paths with CompilationDatabase() builder (Fixes #4003).

- Ninja tool generate_command() fixed to call subst() with correct
  arguments in ListAction case. Unit tests added for generate_command.

- Fix the SCons.Scanner.LaTeX to mimic LaTeX's search method.

- Ninja tool now quotes targets (if necessary) when calling back to
  SCons - both in the POST request constructed to contact the
  daemon, and in the command eventually issued from the deamon.

- Ninja tool is adjusted to recognize and emit the right rule in
  the case of special actions that the tool recognizes, like Copy.
  This was working in the case of single commands, but not when part
  of a list of actions. Recognition only happens if the special
  action is first in the list.

- Fix a test problem on Windows where UNC tests failed due to incorrect path
  munging if a non-default %TEMP% was defined (as in moving to a Dev Drive).

- Fix Issue #4746. The TEMPFILE is written in utf-8 encoding by default.
  If the tempfile contents cannot be decoded by the command the
  tempfile is passed to, (new) TEMPPFILEENCODING can be used to speficy a
  different encoding to use. On Windows, the username may be a cause of
this,
  as the default path for temporary files includes the username. Setting
  (existing) TEMPFILEDIR may also help in this case.

- Tweak runtest.py and test framework to more reliably get the requested
  Python binary (for odd Windows setups + Python launcher)

- Fix the tempfile encoding test regex strings to remove warnings in
  python 3.12 and 3.13.

- Incremental builds in Interactive mode could fail on platforms that
  support batch mode (currently: Windows).  Change the way the changed
  and unchanged target and source lists are accounted for to resolve.
  Fixes #3029.

IMPROVEMENTS
------------

- Virtualenv support module modernized: previously looked first for an
  unofficial approach from before venv support was made part of Python
  in 3.3; now looks for the official approach first. This in an internal
  detail, the API is unchanged.

- Add internal routines to manipulate publicly visible argument and
  target lists. These interfaces are not part of the public API.

- Improve the error message when an environment method is called which
  does not exist in that environment. Mostly this is intended to be a
  bit more helpful in the case of a builder which did not instantiate.

PACKAGING
---------

- The generated roff (.1) manpages are now included in the
  scons-doc tarball built at part of the release process,
  in addition to the html and txt versions. For distribution
  packaging, the manpages can be extracted from here (downloadable
  from https://scons.org/doc/ using a a version-specific URL,
  e.g. https://scons.org/doc/4.9.1/scons-doc-4.9.1.tar.gz).

DOCUMENTATION
-------------

- Clarify how pre/post actions on an alias work.

- Improve the description of PackageVariable.

- The "API Docs" build (Sphinx) configuration is improved, and
  SConsDoc and SConsExample are now included - their API is
  interesting to developers working on SCons (needed to write docs),
  even if not part of "The SCons API" itself.

- Missing documentation for the Virtualenv() function is added.
  Note that the User Guide previously described a negative outcome
  as returning None.  It is now explicit that the path is returned if
  running in a virtualenv, and an empty (falsy) string if not.

- Improve the wording of Configure methods.

- Improve the wording of AppendENVPath and PrependENVPath in manpage.

- Improve documentation of builder methods and builder objects.

- All the User Guide sections now have textual anchors, meaning there
  no longer be build-generated numeric tags like
  https://scons.org/doc/production/HTML/scons-user.html#id1514

DEVELOPMENT
-----------

- runtest.py once again finds "external" tests, such as the tests for
  tools in scons-contrib. An earlier rework had broken this.  Fixes #4699.

- Clean up C and C++ FLAGS tests. Tests which use a real compiler
  are now more clearly distinguished (-live.py suffix and docstring).

- Fix a couple of unit tests to not fail with Python 3.14. These involve
  expectations for bytecode strings and error message contents; there was
  no problem with SCons itself using 3.14.

- Move the GitHub workflow test runner files from the SCons root to
  the ci subdirectory of the testing directory.

- GitHub: Enable the interactive tests on windows.

- GitHub: Enable the packaging tar xz test on windows.

- GitHub: Exclude two ninja tests that consistently fail on MacOS in
  the experimental tests workflow.

- GitHub: Add a workflow file to test MSVC with optional environment
  variables.

- GitHub: Populate the MSVC cache before running the test suite for
  select windows workflow files.

- GitHub: Upload the failed_tests.log artifact on failure in select
  workflow files.

- GitHub: Change the runtest workflow to allow the python version to
  be specified with the OS version.

- Testing: Increase the default timeout from 20 seconds to 60 seconds
  in the testing framework wait_for method. The timeout was increased
  during isolated experiments of the interactive tests on windows.

- Testing: Update the packaging tar bz2 and xz tests on on Windows.
  The packaging tar bz2 and xz tests should be skipped on Windows 10
  and GitHub windows-2022. The packaging tar bz2 and xz tests should
  be run on Windows 11 and GitHub windows-2025.

- Ninja: Increase the number of generated source files in the
  iterative speedup test from 200 to 250.  Increasing the workload
  should reduce the likelihood that the ninja tests are slower.

- Add more unit tests to internal AppendPath, PrependPath functions.

Thanks to the following contributors listed below for their contributions
to this release.
==========================================================================================
.. code-block:: text


    git shortlog --no-merges -ns 4.9.1..HEAD
        61  Mats Wichmann
        46  Joseph Brill
        25  William Deegan
         6  Keith F. Prussing
         1  Bill Prendergast
         1  Edward Peek
         1  Thaddeus Crews
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://pairlist4.pair.net/pipermail/scons-users/attachments/20251002/ace7ed97/attachment.htm>


More information about the Scons-users mailing list