1
0
mirror of https://github.com/ohwgiles/laminar.git synced 2024-10-27 20:34:20 +00:00

implement .init script to populate workspace

This commit is contained in:
Oliver Giles 2017-08-07 08:15:35 +03:00
parent 4fc2310ed9
commit f42325b472

View File

@ -434,14 +434,6 @@ std::shared_ptr<Run> Laminar::queueJob(std::string name, ParamMap params) {
return nullptr; return nullptr;
} }
// attempt to create a workspace for this job if it doesn't exist
if(!fs::exists(fs::path(homeDir)/"run"/name/"workspace")) {
if(!fs::create_directories(fs::path(homeDir)/"run"/name/"workspace")) {
LLOG(ERROR, "Could not create job workspace", name);
return nullptr;
}
}
std::shared_ptr<Run> run = std::make_shared<Run>(); std::shared_ptr<Run> run = std::make_shared<Run>();
run->name = name; run->name = name;
run->queuedAt = time(0); run->queuedAt = time(0);
@ -555,15 +547,29 @@ void Laminar::assignNewJobs() {
Node& node = sn.second; Node& node = sn.second;
std::shared_ptr<Run> run = *it; std::shared_ptr<Run> run = *it;
if(nodeCanQueue(node, *run)) { if(nodeCanQueue(node, *run)) {
fs::path cfgDir = fs::path(homeDir)/"cfg";
// create a workspace for this job if it doesn't exist
fs::path ws = fs::path(homeDir)/"run"/run->name/"workspace";
if(!fs::exists(ws)) {
if(!fs::create_directories(ws)) {
LLOG(ERROR, "Could not create job workspace", run->name);
break;
}
// prepend the workspace init script
if(fs::exists(cfgDir/"jobs"/run->name+".init"))
run->addScript((cfgDir/"jobs"/run->name+".init").string(), ws.string());
}
int buildNum = buildNums[run->name] + 1; int buildNum = buildNums[run->name] + 1;
// create the run directory (different to a workspace!) // create the run directory
fs::path rd = fs::path(homeDir)/"run"/run->name/std::to_string(buildNum); fs::path rd = fs::path(homeDir)/"run"/run->name/std::to_string(buildNum);
if(!fs::create_directory(rd)) { if(!fs::create_directory(rd)) {
LLOG(ERROR, "Could not create working directory", rd.string()); LLOG(ERROR, "Could not create working directory", rd.string());
break; break;
} }
run->runDir = rd.string(); run->runDir = rd.string();
// create an archive directory // create an archive directory
fs::path archive = fs::path(homeDir)/"archive"/run->name/std::to_string(buildNum); fs::path archive = fs::path(homeDir)/"archive"/run->name/std::to_string(buildNum);
if(fs::is_directory(archive)) { if(fs::is_directory(archive)) {
@ -574,7 +580,6 @@ void Laminar::assignNewJobs() {
} }
// add scripts // add scripts
fs::path cfgDir = fs::path(homeDir)/"cfg";
// global before-run script // global before-run script
if(fs::exists(cfgDir/"before")) if(fs::exists(cfgDir/"before"))
run->addScript((cfgDir/"before").string()); run->addScript((cfgDir/"before").string());