threaded exception handling
Some checks failed
demo.yaml / threaded exception handling (push) Failing after 0s
Some checks failed
demo.yaml / threaded exception handling (push) Failing after 0s
This commit is contained in:
parent
598c666e91
commit
c2bb9023d4
14 changed files with 237 additions and 127 deletions
|
|
@ -1,7 +1,7 @@
|
||||||
on: [push]
|
# on: [push]
|
||||||
jobs:
|
# jobs:
|
||||||
test:
|
# test:
|
||||||
runs-on: arch
|
# runs-on: arch
|
||||||
steps:
|
# steps:
|
||||||
- run: curl google.com
|
# - run: curl google.com
|
||||||
|
|
||||||
|
|
|
||||||
4
build.sh
4
build.sh
|
|
@ -11,6 +11,7 @@ if [ ! -f "$STD_HEADER" ]; then
|
||||||
fi
|
fi
|
||||||
cp "$STD_HEADER" ./build/std.cppm
|
cp "$STD_HEADER" ./build/std.cppm
|
||||||
clang++ -std=c++26 -Wno-reserved-identifier -Wno-reserved-module-identifier --precompile ./build/std.cppm -o ./build/std.pcm
|
clang++ -std=c++26 -Wno-reserved-identifier -Wno-reserved-module-identifier --precompile ./build/std.cppm -o ./build/std.pcm
|
||||||
|
clang++ -std=c++26 --precompile -fprebuilt-module-path=./build interfaces/Crafter.Build-CompileStatus.cppm -o ./build/Crafter.Build-CompileStatus.pcm
|
||||||
clang++ -std=c++26 --precompile -fprebuilt-module-path=./build interfaces/Crafter.Build-Command.cppm -o ./build/Crafter.Build-Command.pcm
|
clang++ -std=c++26 --precompile -fprebuilt-module-path=./build interfaces/Crafter.Build-Command.cppm -o ./build/Crafter.Build-Command.pcm
|
||||||
clang++ -std=c++26 --precompile -fprebuilt-module-path=./build interfaces/Crafter.Build-Shader.cppm -o ./build/Crafter.Build-Shader.pcm
|
clang++ -std=c++26 --precompile -fprebuilt-module-path=./build interfaces/Crafter.Build-Shader.cppm -o ./build/Crafter.Build-Shader.pcm
|
||||||
clang++ -std=c++26 --precompile -fprebuilt-module-path=./build interfaces/Crafter.Build-Module.cppm -o ./build/Crafter.Build-Module.pcm
|
clang++ -std=c++26 --precompile -fprebuilt-module-path=./build interfaces/Crafter.Build-Module.cppm -o ./build/Crafter.Build-Module.pcm
|
||||||
|
|
@ -27,6 +28,7 @@ clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./build/Crafter.Build-I
|
||||||
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./build/Crafter.Build-Configuration.pcm -o ./build/Crafter.Build-Configuration.o
|
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./build/Crafter.Build-Configuration.pcm -o ./build/Crafter.Build-Configuration.o
|
||||||
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./build/Crafter.Build-Project.pcm -o ./build/Crafter.Build-Project.o
|
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./build/Crafter.Build-Project.pcm -o ./build/Crafter.Build-Project.o
|
||||||
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./build/Crafter.Build-Test.pcm -o ./build/Crafter.Build-Test.o
|
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./build/Crafter.Build-Test.pcm -o ./build/Crafter.Build-Test.o
|
||||||
|
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./build/Crafter.Build-CompileStatus.pcm -o ./build/Crafter.Build-CompileStatus.o
|
||||||
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./build/Crafter.Build.pcm -o ./build/Crafter.Build.o
|
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./build/Crafter.Build.pcm -o ./build/Crafter.Build.o
|
||||||
|
|
||||||
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./implementations/Crafter.Build-Command.cpp -o ./build/Crafter.Build-Command_impl.o
|
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./implementations/Crafter.Build-Command.cpp -o ./build/Crafter.Build-Command_impl.o
|
||||||
|
|
@ -38,7 +40,7 @@ clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./implementations/Craft
|
||||||
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./implementations/Crafter.Build-Project.cpp -o ./build/Crafter.Build-Project_impl.o
|
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./implementations/Crafter.Build-Project.cpp -o ./build/Crafter.Build-Project_impl.o
|
||||||
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./implementations/main.cpp -o ./build/main.o
|
clang++ -std=c++26 -O3 -fprebuilt-module-path=./build -c ./implementations/main.cpp -o ./build/main.o
|
||||||
|
|
||||||
clang++ -std=c++26 -O3 -L/usr/local/lib -L/usr/lib/ -lvulkan -lMachineIndependent -lOSDependent -lGenericCodeGen -lglslang -lglslang-default-resource-limits -lSPIRV -ltbb -fuse-ld=lld ./build/Crafter.Build-Command.o ./build/Crafter.Build-Shader.o ./build/Crafter.Build-Module.o ./build/Crafter.Build-Configuration.o ./build/Crafter.Build-Project.o ./build/Crafter.Build.o ./build/Crafter.Build-Command_impl.o ./build/Crafter.Build-Shader_impl.o ./build/Crafter.Build-Module_impl.o ./build/Crafter.Build-Configuration_impl.o ./build/Crafter.Build-Project_impl.o ./build/Crafter.Build-Implementation.o ./build/Crafter.Build-Implementation_impl.o ./build/Crafter.Build-Test_impl.o ./build/Crafter.Build-Test.o ./build/main.o -o ./bin/executable/crafter-build
|
clang++ -std=c++26 -O3 -L/usr/local/lib -L/usr/lib/ -lvulkan -lMachineIndependent -lOSDependent -lGenericCodeGen -lglslang -lglslang-default-resource-limits -lSPIRV -ltbb -fuse-ld=lld ./build/Crafter.Build-Command.o ./build/Crafter.Build-CompileStatus.o ./build/Crafter.Build-Shader.o ./build/Crafter.Build-Module.o ./build/Crafter.Build-Configuration.o ./build/Crafter.Build-Project.o ./build/Crafter.Build.o ./build/Crafter.Build-Command_impl.o ./build/Crafter.Build-Shader_impl.o ./build/Crafter.Build-Module_impl.o ./build/Crafter.Build-Configuration_impl.o ./build/Crafter.Build-Project_impl.o ./build/Crafter.Build-Implementation.o ./build/Crafter.Build-Implementation_impl.o ./build/Crafter.Build-Test_impl.o ./build/Crafter.Build-Test.o ./build/main.o -o ./bin/executable/crafter-build
|
||||||
|
|
||||||
cp -r binlib/* bin/
|
cp -r binlib/* bin/
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -51,40 +51,40 @@ namespace Crafter {
|
||||||
pclose(pipe);
|
pclose(pipe);
|
||||||
}
|
}
|
||||||
|
|
||||||
CompileException::CompileException(std::vector<CompileError>&& errors) : errors(std::move(errors)) {
|
// CompileException::CompileException(std::vector<CompileError>&& errors) : errors(std::move(errors)) {
|
||||||
for(CompileError error : errors) {
|
// for(CompileError error : errors) {
|
||||||
message += std::format("File: {}:{}\nMessage: {}\nCode: {}", error.filename, error.line, error.message, error.code);
|
// message += std::format("File: {}:{}\nMessage: {}\nCode: {}", error.filename, error.line, error.message, error.code);
|
||||||
}
|
// }
|
||||||
};
|
// };
|
||||||
const char* CompileException::what() const noexcept {
|
// const char* CompileException::what() const noexcept {
|
||||||
return message.c_str();
|
// return message.c_str();
|
||||||
}
|
// }
|
||||||
|
|
||||||
void RunClang(const std::string_view cmd) {
|
std::string RunClang(const std::string_view cmd) {
|
||||||
std::cout << cmd << std::endl;
|
// std::string result = RunCommand(cmd);
|
||||||
std::string result = RunCommand(cmd);
|
// // std::vector<CompileError> errors;
|
||||||
std::cout << result << std::endl;
|
|
||||||
// std::vector<CompileError> errors;
|
|
||||||
|
|
||||||
// std::regex error_regex(R"((/[^:]+\.cpp):(\d+):\d+: error: (.*)\n\s*[0-9| ]*\s*(.*))");
|
// // std::regex error_regex(R"((/[^:]+\.cpp):(\d+):\d+: error: (.*)\n\s*[0-9| ]*\s*(.*))");
|
||||||
// std::smatch match;
|
// // std::smatch match;
|
||||||
|
|
||||||
// while (std::regex_search(result, match, error_regex)) {
|
// // while (std::regex_search(result, match, error_regex)) {
|
||||||
// CompileError error;
|
// // CompileError error;
|
||||||
// error.filename = match[1].str();
|
// // error.filename = match[1].str();
|
||||||
// error.line = std::stoi(match[2].str());
|
// // error.line = std::stoi(match[2].str());
|
||||||
// error.message = match[3].str();
|
// // error.message = match[3].str();
|
||||||
// error.code = match[4].str();
|
// // error.code = match[4].str();
|
||||||
// errors.push_back(error);
|
// // errors.push_back(error);
|
||||||
// result = match.suffix().str();
|
// // result = match.suffix().str();
|
||||||
|
// // }
|
||||||
|
|
||||||
|
// if(result != "") {
|
||||||
|
// // if(errors.size() != 0) {
|
||||||
|
// // throw CompileException(std::move(errors));
|
||||||
|
// // } else {
|
||||||
|
// throw std::runtime_error(result);
|
||||||
|
// //}
|
||||||
// }
|
// }
|
||||||
|
std::cout << cmd << std::endl;
|
||||||
if(result != "") {
|
return RunCommand(cmd);
|
||||||
// if(errors.size() != 0) {
|
|
||||||
// throw CompileException(std::move(errors));
|
|
||||||
// } else {
|
|
||||||
throw std::runtime_error(result);
|
|
||||||
//}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -45,17 +45,23 @@ namespace Crafter {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void Implementation::Compile(const std::string_view clang, const fs::path& buildDir) const {
|
void Implementation::Compile(const std::string_view clang, const fs::path& buildDir, std::string& result) const {
|
||||||
for(ModulePartition* dependency : partitionDependencies) {
|
for(ModulePartition* dependency : partitionDependencies) {
|
||||||
if(!dependency->compiled.load()) {
|
if(!dependency->compiled.load()) {
|
||||||
dependency->compiled.wait(false);
|
dependency->compiled.wait(CRAFTER_COMPILE_STATUS_WAITING);
|
||||||
|
if(dependency->compiled.load() == CRAFTER_COMPILE_STATUS_ERROR) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for(Module* dependency : moduleDependencies) {
|
for(Module* dependency : moduleDependencies) {
|
||||||
if(!dependency->compiled.load()) {
|
if(!dependency->compiled.load()) {
|
||||||
dependency->compiled.wait(false);
|
dependency->compiled.wait(CRAFTER_COMPILE_STATUS_WAITING);
|
||||||
|
if(dependency->compiled.load() == CRAFTER_COMPILE_STATUS_ERROR) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
RunClang(std::format("{} {}.cpp -c -o {}_impl.o", clang, path.string(), (buildDir/path.filename()).string()));
|
return RunClang(std::format("{} {}.cpp -c -o {}_impl.o", clang, path.string(), (buildDir/path.filename()).string()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -24,7 +24,7 @@ import :Command;
|
||||||
namespace fs = std::filesystem;
|
namespace fs = std::filesystem;
|
||||||
|
|
||||||
namespace Crafter {
|
namespace Crafter {
|
||||||
ModulePartition::ModulePartition(std::string&& name, fs::path&& path) : name(std::move(name)), path(std::move(path)), compiled(false), checked(false) {}
|
ModulePartition::ModulePartition(std::string&& name, fs::path&& path) : name(std::move(name)), path(std::move(path)), compiled(CRAFTER_COMPILE_STATUS_WAITING), checked(false) {}
|
||||||
|
|
||||||
bool ModulePartition::Check(const fs::path& pcmDir) {
|
bool ModulePartition::Check(const fs::path& pcmDir) {
|
||||||
if(!checked) {
|
if(!checked) {
|
||||||
|
|
@ -43,7 +43,7 @@ namespace Crafter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
needsRecompiling = false;
|
needsRecompiling = false;
|
||||||
compiled.store(true);
|
compiled.store(CRAFTER_COMPILE_STATUS_COMPLETED);
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
needsRecompiling = true;
|
needsRecompiling = true;
|
||||||
|
|
@ -54,24 +54,34 @@ namespace Crafter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ModulePartition::Compile(const std::string_view clang, const fs::path& pcmDir, const fs::path& buildDir) {
|
void ModulePartition::Compile(const std::string_view clang, const fs::path& pcmDir, const fs::path& buildDir, std::string& result) {
|
||||||
for(ModulePartition* dependency : partitionDependencies) {
|
for(ModulePartition* dependency : partitionDependencies) {
|
||||||
if(!dependency->compiled.load()) {
|
if(!dependency->compiled.load()) {
|
||||||
//std::cout << std::format("{} is waiting on {} {}", name, dependency->name, dependency->needsRecompiling) << std::endl;
|
//std::cout << std::format("{} is waiting on {} {}", name, dependency->name, dependency->needsRecompiling) << std::endl;
|
||||||
dependency->compiled.wait(false);
|
dependency->compiled.wait(CRAFTER_COMPILE_STATUS_WAITING);
|
||||||
|
if(dependency->compiled.load() == CRAFTER_COMPILE_STATUS_ERROR) {
|
||||||
|
compiled.store(CRAFTER_COMPILE_STATUS_ERROR);
|
||||||
|
compiled.notify_all();
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
RunClang(std::format("{} {}.cppm --precompile -o {}.pcm", clang, path.string(), (pcmDir/path.filename()).string()));
|
result += RunClang(std::format("{} {}.cppm --precompile -o {}.pcm", clang, path.string(), (pcmDir/path.filename()).string()));
|
||||||
RunClang(std::format("{} {}.pcm -c -o {}.o", clang, (pcmDir/path.filename()).string(), (buildDir/path.filename()).string()));
|
result += RunClang(std::format("{} {}.pcm -c -o {}.o", clang, (pcmDir/path.filename()).string(), (buildDir/path.filename()).string()));
|
||||||
compiled.store(true);
|
if(result.empty()) {
|
||||||
compiled.notify_all();
|
compiled.store(CRAFTER_COMPILE_STATUS_COMPLETED);
|
||||||
|
compiled.notify_all();
|
||||||
|
} else {
|
||||||
|
compiled.store(CRAFTER_COMPILE_STATUS_ERROR);
|
||||||
|
compiled.notify_all();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Module::Module(std::string&& name, fs::path&& path, std::vector<std::unique_ptr<ModulePartition>>&& partitions) : name(std::move(name)), path(std::move(path)), partitions(std::move(partitions)), compiled(false), checked(false) {}
|
Module::Module(std::string&& name, fs::path&& path, std::vector<std::unique_ptr<ModulePartition>>&& partitions) : name(std::move(name)), path(std::move(path)), partitions(std::move(partitions)), compiled(CRAFTER_COMPILE_STATUS_WAITING), checked(false) {}
|
||||||
|
|
||||||
Module::Module(std::string&& name, fs::path&& path) : name(std::move(name)), path(std::move(path)), compiled(false), checked(false) {}
|
Module::Module(std::string&& name, fs::path&& path) : name(std::move(name)), path(std::move(path)), compiled(CRAFTER_COMPILE_STATUS_WAITING), checked(false) {}
|
||||||
|
|
||||||
Module::Module(fs::path&& path) : path(std::move(path)), compiled(false), checked(false) {
|
Module::Module(fs::path&& path) : path(std::move(path)), compiled(CRAFTER_COMPILE_STATUS_WAITING), checked(false) {
|
||||||
std::ifstream t(this->path);
|
std::ifstream t(this->path);
|
||||||
std::stringstream buffer;
|
std::stringstream buffer;
|
||||||
buffer << t.rdbuf();
|
buffer << t.rdbuf();
|
||||||
|
|
@ -101,7 +111,7 @@ namespace Crafter {
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
needsRecompiling = false;
|
needsRecompiling = false;
|
||||||
compiled.store(true);
|
compiled.store(CRAFTER_COMPILE_STATUS_COMPLETED);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -115,14 +125,13 @@ namespace Crafter {
|
||||||
return needsRecompiling;
|
return needsRecompiling;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Module::Compile(const std::string_view clang, const fs::path& pcmDir, const fs::path& buildDir) {
|
void Module::Compile(const std::string_view clang, const fs::path& pcmDir, const fs::path& buildDir, std::string& result) {
|
||||||
std::vector<std::thread> threads;
|
std::vector<std::thread> threads;
|
||||||
for(std::unique_ptr<ModulePartition>& partition : partitions) {
|
std::vector<std::string> results(partitions.size());
|
||||||
if(partition->needsRecompiling) {
|
for(std::uint_fast32_t i = 0; i < partitions.size(); i++) {
|
||||||
threads.emplace_back([&partition, clang, &pcmDir, &buildDir](){
|
if( partitions[i]->needsRecompiling) {
|
||||||
partition->Compile(clang, pcmDir, buildDir);
|
threads.emplace_back(&ModulePartition::Compile, partitions[i].get(), clang, pcmDir, buildDir, std::ref(results[i]));
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -130,10 +139,23 @@ namespace Crafter {
|
||||||
thread.join();
|
thread.join();
|
||||||
}
|
}
|
||||||
|
|
||||||
RunClang(std::format("{} {}.cppm --precompile -o {}.pcm", clang, path.string(), (pcmDir/path.filename()).string()));
|
for(const std::string& result2 : results) {
|
||||||
RunClang(std::format("{} {}.pcm -c -o {}.o", clang, (pcmDir/path.filename()).string(), (buildDir/path.filename()).string()));
|
result += result2;
|
||||||
|
}
|
||||||
|
|
||||||
compiled.store(true);
|
if(result.empty()) {
|
||||||
compiled.notify_all();
|
result += RunClang(std::format("{} {}.cppm --precompile -o {}.pcm", clang, path.string(), (pcmDir/path.filename()).string()));
|
||||||
|
result += RunClang(std::format("{} {}.pcm -c -o {}.o", clang, (pcmDir/path.filename()).string(), (buildDir/path.filename()).string()));
|
||||||
|
if(result.empty()) {
|
||||||
|
compiled.store(CRAFTER_COMPILE_STATUS_COMPLETED);
|
||||||
|
compiled.notify_all();
|
||||||
|
} else {
|
||||||
|
compiled.store(CRAFTER_COMPILE_STATUS_ERROR);
|
||||||
|
compiled.notify_all();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
compiled.store(CRAFTER_COMPILE_STATUS_ERROR);
|
||||||
|
compiled.notify_all();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -31,28 +31,28 @@ namespace Crafter {
|
||||||
Project::Project(std::string&& name, fs::path&& path, std::vector<Configuration>&& configurations) : name(std::move(name)), path(std::move(path)), configurations(std::move(configurations)) {}
|
Project::Project(std::string&& name, fs::path&& path, std::vector<Configuration>&& configurations) : name(std::move(name)), path(std::move(path)), configurations(std::move(configurations)) {}
|
||||||
Project::Project(std::string&& name, fs::path&& path, std::vector<Configuration>&& configurations, fs::path&& binDir, fs::path&& buildDir) : name(std::move(name)), path(std::move(path)), configurations(std::move(configurations)), binDir(std::move(binDir)), buildDir(std::move(buildDir)) {}
|
Project::Project(std::string&& name, fs::path&& path, std::vector<Configuration>&& configurations, fs::path&& binDir, fs::path&& buildDir) : name(std::move(name)), path(std::move(path)), configurations(std::move(configurations)), binDir(std::move(binDir)), buildDir(std::move(buildDir)) {}
|
||||||
|
|
||||||
Configuration& Project::Build(std::string_view configuration) {
|
|
||||||
|
std::tuple<Configuration&, BuildResult> Project::Build(std::string_view configuration) {
|
||||||
for(Configuration& config : configurations) {
|
for(Configuration& config : configurations) {
|
||||||
if(config.name == configuration){
|
if(config.name == configuration){
|
||||||
Build(config);
|
return {config, Build(config)};
|
||||||
return config;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
throw std::runtime_error(std::format("Configuration: {} not found.", configuration));
|
throw std::runtime_error(std::format("Configuration: {} not found.", configuration));
|
||||||
}
|
}
|
||||||
Configuration& Project::Build(std::string_view configuration, const fs::path& binDir, const fs::path& outputDir, const fs::path& buildDir, std::string outputName) {
|
std::tuple<Configuration&, BuildResult> Project::Build(std::string_view configuration, const fs::path& binDir, const fs::path& outputDir, const fs::path& buildDir, std::string outputName) {
|
||||||
for(Configuration& config : configurations) {
|
for(Configuration& config : configurations) {
|
||||||
if(config.name == configuration){
|
if(config.name == configuration){
|
||||||
Build(config, binDir, binDir, outputDir, outputName);
|
return {config, Build(config)};
|
||||||
return config;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
throw std::runtime_error(std::format("Configuration: {} not found.", configuration));
|
throw std::runtime_error(std::format("Configuration: {} not found.", configuration));
|
||||||
}
|
}
|
||||||
void Project::Build(Configuration& config) const {
|
BuildResult Project::Build(Configuration& config) const {
|
||||||
Build(config, binDir/config.name, binDir/config.name, buildDir/config.name, name);
|
return Build(config, binDir/config.name, binDir/config.name, buildDir/config.name, name);
|
||||||
}
|
}
|
||||||
void Project::Build(Configuration& config, const fs::path& binDir, const fs::path& outputDir, const fs::path& buildDir, std::string outputName) const {
|
BuildResult Project::Build(Configuration& config, const fs::path& binDir, const fs::path& outputDir, const fs::path& buildDir, std::string outputName) const {
|
||||||
|
BuildResult buildResult;
|
||||||
if (!fs::exists(binDir)) {
|
if (!fs::exists(binDir)) {
|
||||||
fs::create_directories(binDir);
|
fs::create_directories(binDir);
|
||||||
}
|
}
|
||||||
|
|
@ -75,7 +75,6 @@ namespace Crafter {
|
||||||
std::thread fileThread([&config, &outputDir](){
|
std::thread fileThread([&config, &outputDir](){
|
||||||
for (const fs::path& additionalFile : config.additionalFiles) {
|
for (const fs::path& additionalFile : config.additionalFiles) {
|
||||||
fs::path destination = outputDir / additionalFile.filename();
|
fs::path destination = outputDir / additionalFile.filename();
|
||||||
std::cout << destination << std::endl;
|
|
||||||
|
|
||||||
if (fs::is_directory(additionalFile)) {
|
if (fs::is_directory(additionalFile)) {
|
||||||
if (!fs::exists(destination)) {
|
if (!fs::exists(destination)) {
|
||||||
|
|
@ -190,9 +189,10 @@ namespace Crafter {
|
||||||
std::vector<std::thread> depThreads = std::vector<std::thread>(config.dependencies.size());
|
std::vector<std::thread> depThreads = std::vector<std::thread>(config.dependencies.size());
|
||||||
std::mutex libMutex;
|
std::mutex libMutex;
|
||||||
std::string libsString;
|
std::string libsString;
|
||||||
|
std::vector<std::string> resultsDep(config.dependencies.size());
|
||||||
|
|
||||||
for(std::uint_fast32_t i = 0; i < depThreads.size(); i++) {
|
for(std::uint_fast32_t i = 0; i < depThreads.size(); i++) {
|
||||||
depThreads[i] = std::thread([i, &config, &libMutex, &depLibSet, &buildDir, &pcmDir, &libsString, &binDir, this](){
|
depThreads[i] = std::thread([i, &config, &libMutex, &depLibSet, &buildDir, &pcmDir, &libsString, &binDir, this, &buildResult, &resultsDep](){
|
||||||
if(config.dependencies[i].path.ends_with(".git")) {
|
if(config.dependencies[i].path.ends_with(".git")) {
|
||||||
fs::path name = fs::path(config.dependencies[i].path).filename();
|
fs::path name = fs::path(config.dependencies[i].path).filename();
|
||||||
name.replace_extension();
|
name.replace_extension();
|
||||||
|
|
@ -216,8 +216,13 @@ namespace Crafter {
|
||||||
for(Configuration& depConfig : project.configurations) {
|
for(Configuration& depConfig : project.configurations) {
|
||||||
if(depConfig.name == config.dependencies[i].configuration){
|
if(depConfig.name == config.dependencies[i].configuration){
|
||||||
fs::path depBuildDir = fs::path(config.dependencies[i].path).parent_path()/project.buildDir/depConfig.name;
|
fs::path depBuildDir = fs::path(config.dependencies[i].path).parent_path()/project.buildDir/depConfig.name;
|
||||||
project.Build(depConfig, pcmDir, binDir, depBuildDir, project.name);
|
BuildResult depResult = project.Build(depConfig, pcmDir, binDir, depBuildDir, project.name);
|
||||||
libMutex.lock();
|
libMutex.lock();
|
||||||
|
if(depResult.repack) {
|
||||||
|
buildResult.repack = true;
|
||||||
|
}
|
||||||
|
resultsDep[i] = depResult.errors;
|
||||||
|
|
||||||
if (depLibSet.insert(project.name).second) {
|
if (depLibSet.insert(project.name).second) {
|
||||||
libsString+=std::format(" -l{}", project.name);
|
libsString+=std::format(" -l{}", project.name);
|
||||||
}
|
}
|
||||||
|
|
@ -231,6 +236,7 @@ namespace Crafter {
|
||||||
libsString+=std::format(" -l{}", project.name);
|
libsString+=std::format(" -l{}", project.name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
libMutex.unlock();
|
libMutex.unlock();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -243,31 +249,55 @@ namespace Crafter {
|
||||||
thread.join();
|
thread.join();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for(const std::string& result2 : resultsDep) {
|
||||||
|
buildResult.errors += result2;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!buildResult.errors.empty()) {
|
||||||
|
fileThread.join();
|
||||||
|
return buildResult;
|
||||||
|
}
|
||||||
|
|
||||||
std::string files;
|
std::string files;
|
||||||
bool repack = false;
|
std::vector<std::string> resultInterfaces(config.interfaces.size());
|
||||||
for(std::unique_ptr<Module>& modulee : config.interfaces) {
|
|
||||||
if(modulee->Check(pcmDir)) {
|
for(uint_fast32_t i = 0; i < config.interfaces.size(); i++) {
|
||||||
threads.emplace_back(&Module::Compile, modulee.get(), command, pcmDir, buildDir);
|
if(config.interfaces[i]->Check(pcmDir)) {
|
||||||
repack = true;
|
threads.emplace_back(&Module::Compile, config.interfaces[i].get(), command, pcmDir, buildDir, std::ref(resultInterfaces[i]));
|
||||||
|
buildResult.repack = true;
|
||||||
}
|
}
|
||||||
files += std::format(" {}/{}.o", buildDir.string(), modulee->path.filename().string());
|
files += std::format(" {}/{}.o", buildDir.string(), config.interfaces[i]->path.filename().string());
|
||||||
for(std::unique_ptr<ModulePartition>& part : modulee->partitions) {
|
for(std::unique_ptr<ModulePartition>& part : config.interfaces[i]->partitions) {
|
||||||
files += std::format(" {}/{}.o", buildDir.string(), part->path.filename().string());
|
files += std::format(" {}/{}.o", buildDir.string(), part->path.filename().string());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
std::vector<std::string> resultImplementations(config.implementations.size());
|
||||||
|
|
||||||
for(const Implementation& implementation : config.implementations) {
|
for(uint_fast32_t i = 0; i < config.implementations.size(); i++) {
|
||||||
if(implementation.Check(buildDir, pcmDir)) {
|
if(config.implementations[i].Check(buildDir, pcmDir)) {
|
||||||
repack = true;
|
buildResult.repack = true;
|
||||||
threads.emplace_back(&Implementation::Compile, &implementation, command, buildDir);
|
threads.emplace_back(&Implementation::Compile, &config.implementations[i], command, buildDir, std::ref(resultImplementations[i]));
|
||||||
}
|
}
|
||||||
files += std::format(" {}/{}_impl.o", buildDir.string(), implementation.path.filename().string());
|
files += std::format(" {}/{}_impl.o", buildDir.string(), config.implementations[i].path.filename().string());
|
||||||
}
|
}
|
||||||
|
|
||||||
for(std::thread& thread : threads) {
|
for(std::thread& thread : threads) {
|
||||||
thread.join();
|
thread.join();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for(const std::string& result2 : resultInterfaces) {
|
||||||
|
buildResult.errors += result2;
|
||||||
|
}
|
||||||
|
for(const std::string& result2 : resultImplementations) {
|
||||||
|
buildResult.errors += result2;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if(!buildResult.errors.empty()) {
|
||||||
|
fileThread.join();
|
||||||
|
return buildResult;
|
||||||
|
}
|
||||||
|
|
||||||
if(config.target != "wasm32-wasi") {
|
if(config.target != "wasm32-wasi") {
|
||||||
command += " -L/usr/local/lib";
|
command += " -L/usr/local/lib";
|
||||||
}
|
}
|
||||||
|
|
@ -285,19 +315,21 @@ namespace Crafter {
|
||||||
command += std::format(" -L{}", pcmDir.string());
|
command += std::format(" -L{}", pcmDir.string());
|
||||||
}
|
}
|
||||||
|
|
||||||
if(repack) {
|
if(buildResult.repack) {
|
||||||
if(config.type == CRAFTER_CONFIGURATION_TYPE_EXECUTABLE){
|
if(config.type == CRAFTER_CONFIGURATION_TYPE_EXECUTABLE){
|
||||||
if(config.target == "wasm32-wasi") {
|
if(config.target == "wasm32-wasi") {
|
||||||
outputName += ".wasm";
|
outputName += ".wasm";
|
||||||
}
|
}
|
||||||
RunClang(std::format("{}{} -o {} -fuse-ld=lld", command, files, (binDir/outputName).string()));
|
buildResult.errors = RunClang(std::format("{}{} -o {} -fuse-ld=lld", command, files, (binDir/outputName).string()));
|
||||||
} else if(config.type == CRAFTER_CONFIGURATION_TYPE_LIBRARY){
|
} else if(config.type == CRAFTER_CONFIGURATION_TYPE_LIBRARY){
|
||||||
std::cout << std::format("ar r {}.a {}", (binDir/fs::path(std::string("lib")+outputName)).string(), files) << std::endl;
|
|
||||||
RunCommandIgnore(std::format("ar r {}.a {}", (binDir/fs::path(std::string("lib")+outputName)).string(), files));
|
RunCommandIgnore(std::format("ar r {}.a {}", (binDir/fs::path(std::string("lib")+outputName)).string(), files));
|
||||||
} else {
|
} else {
|
||||||
RunClang(std::format("{}{} -shared -o {}.so -Wl,-rpath,'$ORIGIN' -fuse-ld=lld", command, files, (binDir/(std::string("lib")+outputName)).string()));
|
buildResult.errors = RunClang(std::format("{}{} -shared -o {}.so -Wl,-rpath,'$ORIGIN' -fuse-ld=lld", command, files, (binDir/(std::string("lib")+outputName)).string()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return buildResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
Project Project::LoadFromJSON(const fs::path& path) {
|
Project Project::LoadFromJSON(const fs::path& path) {
|
||||||
|
|
|
||||||
|
|
@ -69,18 +69,25 @@ int main(int argc, char* argv[]) {
|
||||||
Project project = Project::LoadFromJSON(projectPath);
|
Project project = Project::LoadFromJSON(projectPath);
|
||||||
|
|
||||||
if(command == "build") {
|
if(command == "build") {
|
||||||
Configuration& config = project.Build(argument);
|
std::tuple<Configuration&, BuildResult> config = project.Build(argument);
|
||||||
if(run){
|
std::cout << "amogus" << std::endl;
|
||||||
std::string binDir = std::format("{}/{}", project.binDir.string(), config.name);
|
if(std::get<1>(config).errors.empty()) {
|
||||||
if(config.debug) {
|
if(run){
|
||||||
system(std::format("cd {} && ./{}", (fs::path(projectPath).parent_path()/binDir).string(), project.name).c_str());
|
std::string binDir = std::format("{}/{}", project.binDir.string(), std::get<0>(config).name);
|
||||||
//system(std::format("cd {} && lldb -o run {}", (fs::path(projectPath).parent_path()/binDir).string(), project.name).c_str());
|
if(std::get<0>(config).debug) {
|
||||||
} else {
|
system(std::format("cd {} && ./{}", (fs::path(projectPath).parent_path()/binDir).string(), project.name).c_str());
|
||||||
system(std::format("cd {} && ./{}", (fs::path(projectPath).parent_path()/binDir).string(), project.name).c_str());
|
//system(std::format("cd {} && lldb -o run {}", (fs::path(projectPath).parent_path()/binDir).string(), project.name).c_str());
|
||||||
|
} else {
|
||||||
|
system(std::format("cd {} && ./{}", (fs::path(projectPath).parent_path()/binDir).string(), project.name).c_str());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
} else {
|
||||||
|
std::cout << std::get<1>(config).errors << std::endl;
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
} else if(command == "test") {
|
} else if(command == "test") {
|
||||||
|
bool anyFailed = false;
|
||||||
|
|
||||||
if(argument.empty()) {
|
if(argument.empty()) {
|
||||||
std::vector<TestResult> results = project.RunTests();
|
std::vector<TestResult> results = project.RunTests();
|
||||||
for(const TestResult& result : results) {
|
for(const TestResult& result : results) {
|
||||||
|
|
@ -88,6 +95,7 @@ int main(int argc, char* argv[]) {
|
||||||
std::cout << std::format("✅ {}", result.name) << std::endl;
|
std::cout << std::format("✅ {}", result.name) << std::endl;
|
||||||
} else {
|
} else {
|
||||||
std::cout << std::format("❌ {}\t{}", result.name, result.message) << std::endl;
|
std::cout << std::format("❌ {}\t{}", result.name, result.message) << std::endl;
|
||||||
|
anyFailed = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -96,8 +104,11 @@ int main(int argc, char* argv[]) {
|
||||||
std::cout << std::format("✅ {}", result.name) << std::endl;
|
std::cout << std::format("✅ {}", result.name) << std::endl;
|
||||||
} else {
|
} else {
|
||||||
std::cout << std::format("❌ {}\t{}", result.name, result.message) << std::endl;
|
std::cout << std::format("❌ {}\t{}", result.name, result.message) << std::endl;
|
||||||
|
anyFailed = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return anyFailed ? 1 : 0;
|
||||||
} else {
|
} else {
|
||||||
std::println("Unkown command: {}", command);
|
std::println("Unkown command: {}", command);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -21,22 +21,22 @@ export module Crafter.Build:Command;
|
||||||
import std;
|
import std;
|
||||||
|
|
||||||
namespace Crafter {
|
namespace Crafter {
|
||||||
export struct CompileError {
|
// export struct CompileError {
|
||||||
std::string filename;
|
// std::string filename;
|
||||||
std::uint_fast32_t line;
|
// std::uint_fast32_t line;
|
||||||
std::string message;
|
// std::string message;
|
||||||
std::string code;
|
// std::string code;
|
||||||
};
|
// };
|
||||||
|
|
||||||
export class CompileException : public std::exception {
|
// export class CompileException : public std::exception {
|
||||||
public:
|
// public:
|
||||||
std::string message;
|
// std::string message;
|
||||||
std::vector<CompileError> errors;
|
// std::vector<CompileError> errors;
|
||||||
CompileException(std::vector<CompileError>&& errors);
|
// CompileException(std::vector<CompileError>&& errors);
|
||||||
const char* what() const noexcept override;
|
// const char* what() const noexcept override;
|
||||||
};
|
// };
|
||||||
|
|
||||||
export std::string RunCommand(const std::string_view cmd);
|
export std::string RunCommand(const std::string_view cmd);
|
||||||
export void RunCommandIgnore(const std::string_view cmd);
|
export void RunCommandIgnore(const std::string_view cmd);
|
||||||
export void RunClang(const std::string_view cmd);
|
export std::string RunClang(const std::string_view cmd);
|
||||||
}
|
}
|
||||||
29
interfaces/Crafter.Build-CompileStatus.cppm
Normal file
29
interfaces/Crafter.Build-CompileStatus.cppm
Normal file
|
|
@ -0,0 +1,29 @@
|
||||||
|
/*
|
||||||
|
Crafter® Build
|
||||||
|
Copyright (C) 2025 Catcrafts®
|
||||||
|
Catcrafts.net
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License version 3.0 as published by the Free Software Foundation;
|
||||||
|
|
||||||
|
This library is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public
|
||||||
|
License along with this library; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
export module Crafter.Build:CompileStatus;
|
||||||
|
import std;
|
||||||
|
|
||||||
|
namespace Crafter {
|
||||||
|
export enum CompileStatus {
|
||||||
|
CRAFTER_COMPILE_STATUS_WAITING,
|
||||||
|
CRAFTER_COMPILE_STATUS_COMPLETED,
|
||||||
|
CRAFTER_COMPILE_STATUS_ERROR
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
@ -18,6 +18,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
export module Crafter.Build:Implementation;
|
export module Crafter.Build:Implementation;
|
||||||
|
import :CompileStatus;
|
||||||
import std;
|
import std;
|
||||||
namespace fs = std::filesystem;
|
namespace fs = std::filesystem;
|
||||||
|
|
||||||
|
|
@ -31,6 +32,6 @@ namespace Crafter {
|
||||||
fs::path path;
|
fs::path path;
|
||||||
Implementation(fs::path&& path);
|
Implementation(fs::path&& path);
|
||||||
bool Check(const fs::path& buildDir, const fs::path& pcmDir) const;
|
bool Check(const fs::path& buildDir, const fs::path& pcmDir) const;
|
||||||
void Compile(const std::string_view clang, const fs::path& buildDir) const;
|
void Compile(const std::string_view clang, const fs::path& buildDir, std::string& result) const;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -18,6 +18,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
export module Crafter.Build:Module;
|
export module Crafter.Build:Module;
|
||||||
|
import :CompileStatus;
|
||||||
import std;
|
import std;
|
||||||
namespace fs = std::filesystem;
|
namespace fs = std::filesystem;
|
||||||
|
|
||||||
|
|
@ -27,19 +28,19 @@ namespace Crafter {
|
||||||
public:
|
public:
|
||||||
std::vector<Module*> moduleDependencies;
|
std::vector<Module*> moduleDependencies;
|
||||||
std::vector<ModulePartition*> partitionDependencies;
|
std::vector<ModulePartition*> partitionDependencies;
|
||||||
std::atomic<bool> compiled;
|
std::atomic<CompileStatus> compiled;
|
||||||
bool needsRecompiling;
|
bool needsRecompiling;
|
||||||
bool checked = false;
|
bool checked = false;
|
||||||
std::string name;
|
std::string name;
|
||||||
fs::path path;
|
fs::path path;
|
||||||
ModulePartition(std::string&& name, fs::path&& path);
|
ModulePartition(std::string&& name, fs::path&& path);
|
||||||
bool Check(const fs::path& pcmDir);
|
bool Check(const fs::path& pcmDir);
|
||||||
void Compile(const std::string_view clang, const fs::path& pcmDir, const fs::path& buildDir);
|
void Compile(const std::string_view clang, const fs::path& pcmDir, const fs::path& buildDir, std::string& result);
|
||||||
};
|
};
|
||||||
|
|
||||||
export class Module {
|
export class Module {
|
||||||
public:
|
public:
|
||||||
std::atomic<bool> compiled;
|
std::atomic<CompileStatus> compiled;
|
||||||
bool needsRecompiling;
|
bool needsRecompiling;
|
||||||
bool checked = false;
|
bool checked = false;
|
||||||
std::vector<std::unique_ptr<ModulePartition>> partitions;
|
std::vector<std::unique_ptr<ModulePartition>> partitions;
|
||||||
|
|
@ -49,6 +50,6 @@ namespace Crafter {
|
||||||
Module(std::string&& name, fs::path&& path);
|
Module(std::string&& name, fs::path&& path);
|
||||||
Module(std::string&& name, fs::path&& path, std::vector<std::unique_ptr<ModulePartition>>&& partitions);
|
Module(std::string&& name, fs::path&& path, std::vector<std::unique_ptr<ModulePartition>>&& partitions);
|
||||||
bool Check(const fs::path& pcmDir);
|
bool Check(const fs::path& pcmDir);
|
||||||
void Compile(const std::string_view clang, const fs::path& pcmDir, const fs::path& buildDir);
|
void Compile(const std::string_view clang, const fs::path& pcmDir, const fs::path& buildDir, std::string& result);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -24,6 +24,11 @@ import :Test;
|
||||||
namespace fs = std::filesystem;
|
namespace fs = std::filesystem;
|
||||||
|
|
||||||
namespace Crafter {
|
namespace Crafter {
|
||||||
|
export struct BuildResult {
|
||||||
|
std::string errors;
|
||||||
|
bool repack;
|
||||||
|
};
|
||||||
|
|
||||||
export class Project {
|
export class Project {
|
||||||
public:
|
public:
|
||||||
std::string name;
|
std::string name;
|
||||||
|
|
@ -35,10 +40,10 @@ namespace Crafter {
|
||||||
Project(std::string&& name, fs::path&& path, std::vector<Configuration>&& configurations);
|
Project(std::string&& name, fs::path&& path, std::vector<Configuration>&& configurations);
|
||||||
Project(std::string&& name, fs::path&& path, std::vector<Configuration>&& configurations, fs::path&& buildDir, fs::path&& binDir);
|
Project(std::string&& name, fs::path&& path, std::vector<Configuration>&& configurations, fs::path&& buildDir, fs::path&& binDir);
|
||||||
static Project LoadFromJSON(const fs::path& path);
|
static Project LoadFromJSON(const fs::path& path);
|
||||||
Configuration& Build(std::string_view configuration);
|
std::tuple<Configuration&, BuildResult> Build(std::string_view configuration);
|
||||||
Configuration& Build(std::string_view configuration, const fs::path& binDir, const fs::path& outputDir, const fs::path& buildDir, std::string outputName);
|
std::tuple<Configuration&, BuildResult> Build(std::string_view configuration, const fs::path& binDir, const fs::path& outputDir, const fs::path& buildDir, std::string outputName);
|
||||||
void Build(Configuration& configuration) const;
|
BuildResult Build(Configuration& configuration) const;
|
||||||
void Build(Configuration& configuration, const fs::path& binDir, const fs::path& outputDir, const fs::path& buildDir, std::string outputName) const;
|
BuildResult Build(Configuration& configuration, const fs::path& binDir, const fs::path& outputDir, const fs::path& buildDir, std::string outputName) const;
|
||||||
TestResult RunTest(const std::string_view test);
|
TestResult RunTest(const std::string_view test);
|
||||||
TestResult RunTest(Test& test) const;
|
TestResult RunTest(Test& test) const;
|
||||||
std::vector<TestResult> RunTests();
|
std::vector<TestResult> RunTests();
|
||||||
|
|
|
||||||
|
|
@ -24,4 +24,5 @@ export import :Module;
|
||||||
export import :Configuration;
|
export import :Configuration;
|
||||||
export import :Shader;
|
export import :Shader;
|
||||||
export import :Implementation;
|
export import :Implementation;
|
||||||
export import :Test;
|
export import :Test;
|
||||||
|
export import :CompileStatus;
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
"configurations": [
|
"configurations": [
|
||||||
{
|
{
|
||||||
"name": "base",
|
"name": "base",
|
||||||
"interfaces": ["interfaces/Crafter.Build-Command", "interfaces/Crafter.Build-Configuration", "interfaces/Crafter.Build-Module", "interfaces/Crafter.Build-Project", "interfaces/Crafter.Build-Shader", "interfaces/Crafter.Build", "interfaces/Crafter.Build-Implementation", "interfaces/Crafter.Build-Test"],
|
"interfaces": ["interfaces/Crafter.Build-Command", "interfaces/Crafter.Build-Configuration", "interfaces/Crafter.Build-Module", "interfaces/Crafter.Build-Project", "interfaces/Crafter.Build-Shader", "interfaces/Crafter.Build", "interfaces/Crafter.Build-Implementation", "interfaces/Crafter.Build-Test", "interfaces/Crafter.Build-CompileStatus"],
|
||||||
"implementations": ["implementations/Crafter.Build-Command", "implementations/Crafter.Build-Configuration", "implementations/Crafter.Build-Module", "implementations/Crafter.Build-Project", "implementations/Crafter.Build-Shader", "implementations/Crafter.Build-Implementation", "implementations/Crafter.Build-Test"],
|
"implementations": ["implementations/Crafter.Build-Command", "implementations/Crafter.Build-Configuration", "implementations/Crafter.Build-Module", "implementations/Crafter.Build-Project", "implementations/Crafter.Build-Shader", "implementations/Crafter.Build-Implementation", "implementations/Crafter.Build-Test"],
|
||||||
"libs": ["vulkan", "MachineIndependent", "OSDependent", "GenericCodeGen", "glslang", "glslang-default-resource-limits", "SPIRV", "tbb"]
|
"libs": ["vulkan", "MachineIndependent", "OSDependent", "GenericCodeGen", "glslang", "glslang-default-resource-limits", "SPIRV", "tbb"]
|
||||||
},
|
},
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue