Skip to content

Commit

Permalink
add a policy to disable module culling
Browse files Browse the repository at this point in the history
  • Loading branch information
Arthapz committed Jul 21, 2024
1 parent 2412ed9 commit e5ba7a1
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 5 deletions.
10 changes: 10 additions & 0 deletions tests/projects/c++/modules/culling/src/hello.mpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
module;
#include <cstdio>

export module hello;

export namespace hello {
void say(const char* str) {
printf("%s\n", str);
}
}
1 change: 1 addition & 0 deletions tests/projects/c++/modules/culling/test.lua
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
inherit(".test_base")
7 changes: 7 additions & 0 deletions tests/projects/c++/modules/culling/xmake.lua
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
add_rules("mode.release", "mode.debug")
set_languages("c++20")

target("culling")
set_kind("static")
add_files("src/*.mpp")
set_policy("build.c++.modules.culling", false)
2 changes: 2 additions & 0 deletions xmake/core/project/policy.lua
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,8 @@ function policy.policies()
["build.c++.modules"] = {description = "Enable C++ modules for C++ building.", type = "boolean"},
-- Enable std module
["build.c++.modules.std"] = {description = "Enable std modules.", default = true, type = "boolean"},
-- Enable unreferenced and non-public named module culling
["build.c++.modules.culling"] = {description = "Enable unrefereced and non-public named module culling.", default = true, type = "boolean"},
-- Try to reuse compiled module bmi file if targets flags permit it
["build.c++.modules.tryreuse"] = {description = "Try to reuse compiled module if possible.", default = true, type = "boolean"},
-- Enable module taking defines acbount for bmi reuse discrimination
Expand Down
14 changes: 9 additions & 5 deletions xmake/rules/c++/modules/modules_support/dependency_scanner.lua
Original file line number Diff line number Diff line change
Expand Up @@ -422,11 +422,15 @@ function sort_modules_by_dependencies(target, objectfiles, modules)
local objectfiles_sorted_set = hashset.from(objectfiles_sorted)
for _, objectfile in ipairs(objectfiles) do
if not objectfiles_sorted_set:has(objectfile) then
-- cull unreferenced non-public named module but add non-module files and implementation modules
local _, provide, cppfile = compiler_support.get_provided_module(modules[objectfile])
local fileconfig = target:fileconfig(cppfile)
local public = fileconfig and fileconfig.public
if not provide or public then
if target:policy("build.c++.modules.culling") then
-- cull unreferenced non-public named module but add non-module files and implementation modules
local _, provide, cppfile = compiler_support.get_provided_module(modules[objectfile])
local fileconfig = target:fileconfig(cppfile)
local public = fileconfig and fileconfig.public
if not provide or public then
table.insert(result, objectfile)
end
else
table.insert(result, objectfile)
end
end
Expand Down

0 comments on commit e5ba7a1

Please sign in to comment.