]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
[3.11] gh-108494: Document how to add a project in PCbuild/readme.txt (#110077) ...
authorVictor Stinner <vstinner@python.org>
Mon, 2 Oct 2023 19:43:05 +0000 (21:43 +0200)
committerGitHub <noreply@github.com>
Mon, 2 Oct 2023 19:43:05 +0000 (19:43 +0000)
gh-108494: Document how to add a project in PCbuild/readme.txt (#110077)

(cherry picked from commit 6387b5313c60c1403785b2245db33372476ac304)

PCbuild/readme.txt

index 092b2cc8c1a7f711c1b9a3d3c9200602ed1d2451..d6149a3cedeaa35522f4ab90bc32c0516d742ed6 100644 (file)
@@ -291,3 +291,31 @@ project, with some projects overriding certain specific values. The GUI
 doesn't always reflect the correct settings and may confuse the user
 with false information, especially for settings that automatically adapt
 for different configurations.
+
+Add a new project
+-----------------
+
+For example, add a new _testclinic_limited project to build a new
+_testclinic_limited extension, the file Modules/_testclinic_limited.c:
+
+* In PCbuild/, copy _testclinic.vcxproj to _testclinic_limited.vcxproj,
+  replace RootNamespace value with `_testclinic_limited`, replace
+  `_asyncio.c` with `_testclinic_limited.c`.
+* Open Visual Studio, open PCbuild\pcbuild.sln solution, add the
+  PCbuild\_testclinic_limited.vcxproj project to the solution ("add existing
+  project).
+* Add a dependency on the python project to the new _testclinic_limited
+  project.
+* Save and exit Visual Studio.
+* Add `;_testclinic_limited` to `<TestModules Include="...">` in
+  PCbuild\pcbuild.proj.
+* Update "exts" in Tools\msi\lib\lib_files.wxs file or in
+  Tools\msi\test\test_files.wxs file (for tests).
+* PC\layout\main.py needs updating if you add a test-only extension whose name
+  doesn't start with "_test".
+* Add the extension to PCbuild\readme.txt (this file).
+* Build Python from scratch (clean the solution) to check that the new project
+  is built successfully.
+* Ensure the new .vcxproj and .vcxproj.filters files are added to your commit,
+  as well as the changes to pcbuild.sln, pcbuild.proj and any other modified
+  files.