- struct stat st;
- if(!stat(name, st))
- mtime=Time::TimeStamp::from_unixtime(st.st_mtime);
-}
-
-void Target::mark_rebuild(const std::string &reason)
-{
- rebuild=true;
- rebuild_reason=reason;
-}
-
-/**
-Checks if this target needs to be rebuilt and why.
-*/
-void Target::check_rebuild()
-{
- if(!buildable)
- return;
-
- if(builder.get_build_all())
- mark_rebuild("Rebuilding everything");
- else if(!mtime)
- mark_rebuild("Does not exist");
- else
- {
- for(TargetList::iterator i=depends.begin(); (i!=depends.end() && !rebuild); ++i)
- {
- if((*i)->get_mtime()>mtime)
- mark_rebuild(basename((*i)->get_name())+" has changed");
- else if((*i)->get_rebuild())
- mark_rebuild(basename((*i)->get_name())+" needs rebuilding");
- }
- }
+ builder.get_logger().log("rebuild", format("Rebuilding %s: %s", name, reason));