diff options
| -rw-r--r-- | src/rebuild.cc | 5 | ||||
| -rw-r--r-- | src/task.cc | 5 | ||||
| -rw-r--r-- | src/task_fn.cc | 2 | 
3 files changed, 8 insertions, 4 deletions
| diff --git a/src/rebuild.cc b/src/rebuild.cc index 1db5e83..4ca1809 100644 --- a/src/rebuild.cc +++ b/src/rebuild.cc @@ -186,7 +186,10 @@ bool recompileCheck(const ctor::settings& global_settings, int argc, char* argv[  	ctor::settings settings{global_settings};  	settings.verbose = -1; // Make check completely silent. -	settings.builddir += "/ctor"; // override builddir to use ctor subdir + +	// override builddir to use ctor subdir +	auto ctor_builddir = std::filesystem::path(settings.builddir) / "ctor"; +	settings.builddir = ctor_builddir.string();  	{  		std::filesystem::path buildfile  = settings.builddir; diff --git a/src/task.cc b/src/task.cc index a9c0fee..cd03fce 100644 --- a/src/task.cc +++ b/src/task.cc @@ -3,7 +3,6 @@  // See accompanying file LICENSE for details.  #include "task.h" -#include <unistd.h>  #include <iostream>  #include <algorithm>  #include <utility> @@ -46,10 +45,12 @@ int Task::registerDepTasks(const std::vector<std::shared_ptr<Task>>& tasks)  bool Task::operator==(const std::string& depStr)  { +	std::filesystem::path generated_output = sourceDir; +	generated_output /= target();  	return  		name() == depStr ||  		target() == depStr || -		sourceDir + "/" + target() == depStr || +		generated_output  == depStr ||  		targetFile().string() == depStr  		;  } diff --git a/src/task_fn.cc b/src/task_fn.cc index 873dc44..1ff72f9 100644 --- a/src/task_fn.cc +++ b/src/task_fn.cc @@ -98,7 +98,7 @@ std::vector<std::string> TaskFn::depends() const  std::string TaskFn::target() const  { -	return _targetFile; +	return _targetFile.string();  }  std::filesystem::path TaskFn::targetFile() const | 
