From 19fcec84d8d7d21e796c7624e521b60d28ee21ed Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 20:45:59 +0200 Subject: Adding upstream version 16.2.11+ds. Signed-off-by: Daniel Baumann --- src/boost/tools/build/test/pch.py | 58 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 src/boost/tools/build/test/pch.py (limited to 'src/boost/tools/build/test/pch.py') diff --git a/src/boost/tools/build/test/pch.py b/src/boost/tools/build/test/pch.py new file mode 100644 index 000000000..58cf894a9 --- /dev/null +++ b/src/boost/tools/build/test/pch.py @@ -0,0 +1,58 @@ +#!/usr/bin/python + +# Copyright 2006 Vladimir Prus. +# Distributed under the Boost Software License, Version 1.0. (See +# accompanying file LICENSE_1_0.txt or copy at +# http://www.boost.org/LICENSE_1_0.txt) + +import BoostBuild +from time import sleep + + +t = BoostBuild.Tester() + +t.write("jamroot.jam", """ +import pch ; +cpp-pch pch : pch.hpp : msvc:pch.cpp . ; +exe hello : hello.cpp pch : . ; +""") + +t.write("pch.hpp.bad", """ +THIS WILL NOT COMPILE +""") + +# Note that pch.hpp is written after pch.hpp.bad, so its timestamp will not be +# less than timestamp of pch.hpp.bad. +sleep(1) +t.write("pch.hpp", """ +class TestClass +{ +public: + TestClass( int, int ) {} +}; +""") + +t.write("pch.cpp", """#include +""") + +t.write("hello.cpp", """#include +int main() { TestClass c(1, 2); } +""") + +t.run_build_system() +t.expect_addition("bin/$toolset/debug*/hello.exe") + + +# Now make the header unusable, without changing timestamp. If everything is OK, +# B2 will not recreate PCH, and compiler will happily use pre-compiled +# header, not noticing that the real header is bad. + +t.copy_preserving_timestamp("pch.hpp.bad", "pch.hpp") + +t.rm("bin/$toolset/debug/hello.obj") +t.rm("bin/$toolset/debug/*/hello.obj") + +t.run_build_system() +t.expect_addition("bin/$toolset/debug*/hello.obj") + +t.cleanup() -- cgit v1.2.3