summaryrefslogtreecommitdiffstats
path: root/src/engine/SCons
Commit message (Collapse)AuthorAgeFilesLines
* Remove deprecated BuildDir, build_dirMats Wichmann2019-12-155-56/+8
| | | | | | | | | Updates docs and code; moves tests to test/Removed/BuildDir/Old. New tests verify that these can no longer be used. Along the way a small cleanup in SConscript.py Signed-off-by: Mats Wichmann <mats@linux.com>
* Merge pull request #3495 from mwichmann/depr-CopyWilliam Deegan2019-12-153-23/+0
|\ | | | | Remove deprecated env.Copy()
| * Remove deprecated env.Copy()Mats Wichmann2019-12-143-23/+0
| | | | | | | | | | | | | | | | | | Method removed. Test moved to test/Removed/Copy-Method/Old, and new test added to ensure it takes an AttributeError. Deprecation warning no longer useful for this one, so removed. Signed-off-by: Mats Wichmann <mats@linux.com>
* | Merge branch 'master' into entry-microoptimizationWilliam Deegan2019-12-132-7/+15
|\ \ | |/
| * Merge pull request #3493 from mwichmann/defenv-2477William Deegan2019-12-131-5/+11
| |\ | | | | | | Tweak DefaultEnvironment descriptions
| | * [PR #3493] fix review comment [ci skip]Mats Wichmann2019-12-131-1/+1
| | | | | | | | | | | | Signed-off-by: Mats Wichmann <mats@linux.com>
| | * Tweak DefaultEnvironment descriptions (ci skip)Mats Wichmann2019-12-131-5/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Doc-only change to be more explicit about when the default construction environment is used, and what it means to call DefaultEnvironment() - only the first call instantiates it, later calls return the object. Fixes #2477 Signed-off-by: Mats Wichmann <mats@linux.com>
| * | Improve DAG walk performance by preventing unnecessary list manipulationMathew Robinson2019-12-111-2/+4
| |/
* | Optimize for most common case in Entry.disambiguate()Mathew Robinson2019-12-121-5/+5
|/ | | | This removes many unnecessary os.stat and related FS IO calls.
* Merge branch 'master' into py3-doctasksWilliam Deegan2019-12-109-65/+143
|\
| * Merge pull request #3473 from kulikjak/masterWilliam Deegan2019-12-102-5/+8
| |\ | | | | | | Fix incorrect testing assumptions for Solaris
| | * Fix incorrect testing assumptions for SolarisJakub Kulik2019-11-012-5/+8
| | |
| * | Merge pull request #3475 from mwichmann/addopt-docsWilliam Deegan2019-12-101-4/+33
| |\ \ | | | | | | | | Document that AddOption has limitations
| | * | [PR 3475] further wording tweaks on AddOption [ci skip]Mats Wichmann2019-11-211-6/+20
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Reword some parts. Add note to manpage that AddOption does not support matching "abbreviations" for long option names. Add note to manpage and user guide that you can't SetOption on options added via AddOption. (as noted in issue #2105) Signed-off-by: Mats Wichmann <mats@linux.com>
| | * | [PR 3475] update docs/generated [ci skip]Mats Wichmann2019-11-161-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There's debated about whether the generated should be checked in at all; without an answer to that, they've fallen far enough out of sync that it becomes harder to use "git diff" as a spot-check that nothing strange is happening due to any given doc change. This should resync them to current. Signed-off-by: Mats Wichmann <mats@linux.com>
| | * | Document that AddOpt has limitations [ci skip]Mats Wichmann2019-11-131-0/+15
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Manpage describes that using spaces between AddOption'd option and its argument is undefined. Use Guide goes into more detail, including workarounds. :: these are not a solution, but do at least reduce the surprise factor. (multiple github issues) Fix tag mismatch in depends.xml introduced by a previous deletion. Signed-off-by: Mats Wichmann <mats@linux.com>
| * | | Merge pull request #3487 from mwichmann/update-action-timestampWilliam Deegan2019-12-092-5/+4
| |\ \ \ | | | | | | | | | | Align debug action timestamps to existing conventions
| | * | | Update debug=action-timestampsMats Wichmann2019-12-072-5/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | + Rename to action-timestamps (from action_timestamps) for consistency with other compound word options. + Put manpage entry in alphabetical order. + Describe what option does and shorten it (refers to debug=time instead of duplicating it) + Change prints a bit (and tests to match) + Show scons version where added. + Slight adjustment to manpage introduction to debug options. Along the way, fixes a lingering tag mismatch from an earlier documentation PR. Updates PR#3456 Signed-off-by: Mats Wichmann <mats@linux.com>
| * | | | Convert our file replacement to be a classAdam Gross2019-12-091-3/+6
| | | | | | | | | | | | | | | | | | | | This hopefully will fix one unit test that validates that it's a class.
| * | | | Merge branch 'master' into topic/grossag/winmultifixAdam Gross2019-12-082-12/+51
| |\ \ \ \
| | * | | | Address GaryO's feedback on PR 3129. Also reformatted Command() PEP8William Deegan2019-12-081-18/+34
| | | | | |
| | * | | | Merge pull request #3129 from dragon512/update-commandWilliam Deegan2019-12-062-6/+29
| | |\ \ \ \ | | | |/ / / | | |/| | | Allow Command to take more builder options
| | | * | | Allow Command to take more builder optionsJason Kenny2019-12-042-6/+29
| | | |/ / | | | | | | | | | | | | | | | | | | | | add to change log add documentation update test
| * | | | Fix SConsTests.py to actually clear out the file/open overridesAdam Gross2019-12-081-16/+12
| | | | | | | | | | | | | | | | | | | | | | | | | This was breaking the tests because it was not clearing the overrides in a manner consistent with the new logic.
| * | | | Fix multithreaded Windows builds when a thread has a file open for writeAdam Gross2019-12-061-25/+34
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | Python 2 enables handle inheritance by default for child processes. It wasn't until Python 3.4 that it was disabled. This causes problems because if a Python action is writing to a file and a child process is spawned at that exact moment, builds fail because of sharing issues.
* | | | Improve building of docs using Py3 [ci skip]Mats Wichmann2019-12-05110-115/+115
|/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * context managers on file r/w + use shutil.copy where it makes sense. * lxml wants (demands?) that xml files be processed as bytes * for the phase where we gen the entity files, read as text anyway * Need to solve a problem where the generated xml is putting the \n in literally, not evaluating it. * Fix some examples broken for py3 * Fix more octal constant instances * Cleanups suggested by PyCharm: staticmethods, two blanks before class definition, others. This addresses issues called out in #3300, but is not a complete solution because the actual doc build step still fails with the epydoc failures (which aren't directly because of Py3; epydoc build doesn't work any better on my system with Py3, even with the forked version with patches). Signed-off-by: Mats Wichmann <mats@linux.com>
* | | fix more Python escape complaintsMats Wichmann2019-12-022-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | Write as raw strings: Two are docstrings that contain a backslash; the third is an odd expression parenthesized for no good reason and containing backslashes. Signed-off-by: Mats Wichmann <mats@linux.com>
* | | try a different approach that should work on python 3.5.Rob Boehne2019-11-261-2/+2
| | |
* | | Fix a problem under Solaris when using Python 3, while maintaining support ↵Rob Boehne2019-11-261-13/+28
| | | | | | | | | | | | for Python 2.7. subproces.Popen() produces bytes without the encoding argument in 3, which is not recognized by 2.7, and doesn't need to be decoded.
* | | Merge branch 'master' into patch-1William Deegan2019-11-183-12/+9
|\ \ \
| * | | Fix simple typo: whos -> whoseTim Gates2019-11-161-1/+1
| |/ /
| * | Merge pull request #3472 from maiphi/latex_latin1William Deegan2019-11-081-2/+2
| |\ \ | | | | | | | | Fix crash when Latin-1 encoded Latex log file is read with Python 3
| | * | Tex builder: avoid error when reading non-utf-8 log filesmaiphi2019-11-011-2/+2
| | |/ | | | | | | | | | | | | | | | | | | Python 3 throws a UnicodeDecodeError when reading a non-utf-8 file in text mode with default (utf-8) encoding. This happens when T1 fontenc is used in Latex and a warning in the log file contains e.g. umlauts. Invalid characters are now replaced.
| * | Remove deprecated Builder keywordsMats Wichmann2019-10-221-9/+6
| |/ | | | | | | | | | | overrides= and scanner= have been deprecated for over a decade. Signed-off-by: Mats Wichmann <mats@linux.com>
* | Added support for "-imacros" to ParseFlagsIvan Kravets2019-11-063-28/+31
| |
* | Parse GCC -imacros optionIvan Kravets2019-11-011-1/+4
|/ | | https://gcc.gnu.org/onlinedocs/gcc/Preprocessor-Options.html
* Remove deprecated {Source,Target}SignaturesMats Wichmann2019-10-205-403/+7
| | | | | | | | | | These two have been deprecated since 2010 (about SCons 2.0), commit 935e6985. Methods are removed, setoption for setting them removed, doc is removed, tests are migrated to test/Removed/*/Old with a sconstest.skip file so they don't run, and two new tests are added to confirm that using the functions and setoptions generate exceptions. Signed-off-by: Mats Wichmann <mats@linux.com>
* Merge pull request #3462 from mwichmann/msvc_env_cacheWilliam Deegan2019-10-124-70/+140
|\ | | | | enable experimental persistent caching of vcvars on win32
| * [PR 3462] update doc/comments for msvc-env-cacheMats Wichmann2019-10-122-8/+15
| | | | | | | | Signed-off-by: Mats Wichmann <mats@linux.com>
| * [PR 3462] convert json cache better way for py2Mats Wichmann2019-10-112-18/+19
| | | | | | | | | | | | | | | | | | | | | | | | there was still a path through without fully converted data, where env['ENV'] could contain unicode, so convert the cache hit instead. This is a little slower but only for Py2 which is going away anyway. added the vs2019 exec test (vs-14.2-exec) which is just a copy of 14.0, 14.1 with the required version changed - this had never been added. Signed-off-by: Mats Wichmann <mats@linux.com>
| * [PR 3462] python two handle the jsonMats Wichmann2019-10-111-1/+13
| | | | | | | | | | | | | | | | | | reading the cache from the json file got us unicode when running python2, and this broke certain tests when calling subprocess.Popen: TypeError, because all the environment wasn't strings, some was unicode. Signed-off-by: Mats Wichmann <mats@linux.com>
| * [PR 3462] env-var-cache: fix exception to be 2.7 compatibleMats Wichmann2019-10-101-20/+25
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | msvc env-var cache-read function use 'except IOError' since 'FileNotFoundError' did not exist on Py2.7/win32. try to handle error if caceh write fails. add SCONS_CACHE_MSVC_CONFIG to manpage. SCONS_CACHE_MSVC_CONFIG can take a pathname to specify the cache file to use, or it can use the default. slightly simplified logging setup - logging is stdlib since py2.3, no need for try block on import. Signed-off-by: Mats Wichmann <mats@linux.com>
| * [WIP] enable persistent caching of vcvars on win32Mats Wichmann2019-10-104-57/+102
| | | | | | | | | | | | | | | | | | | | | | Setting env var SCONS_CACHE_MSVC_CONFIG enables a filesystem cache of vcvars results, making them persistent across scons runs. On test runs (notably our CI system) this helps a lot; in normal usage where you run one scons invocation at a time instead of many hundreds in a test run it will make things a little more responsive (esp on vs2019) but the impact will be much smaller. Signed-off-by: Mats Wichmann <mats@linux.com>
* | Merge remote-tracking branch 'origin/master'Edoardo Bezzeccheri2019-10-094-8/+32
|\ \ | | | | | | | | | | | | # Conflicts: # src/CHANGES.txt
| * \ Merge branch 'master' into CmdStringHolderWilliam Deegan2019-10-086-67/+156
| |\ \
| | * \ Merge pull request #3457 from mwichmann/emitter-docWilliam Deegan2019-10-081-5/+25
| | |\ \ | | | |/ | | |/| Add doc for *EMITTER consvars
| | | * Add doc for *EMITTER consvars [ci skip]Mats Wichmann2019-10-011-5/+25
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Three *EMITTER construction variables had documentation of "TODO". A fourth, LDMODULEEMITTER, was not mentioned at all. Signed-off-by: Mats Wichmann <mats@linux.com>
| | * | Merge branch 'master' into patch-1William Deegan2019-10-061-2/+2
| | |\ \
| | | * | Fix bytes not being decoded in suncxx.pyJakub Kulík2019-09-271-2/+2
| | | |/
| | * | fix CheckFunc detection code for MSVCjw0k2019-10-041-0/+4
| | |/