X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fvirtualtarget.cpp;h=85bdbc0779fd26c0855d8a053338106be48d91a0;hb=8d7926359d2477a9928d7367678314bcbc1f6e81;hp=3f0081ce0dd7b4a0dd45d3329345f150d1c1191f;hpb=4d0d003b022943d8a0e39ba19078bab8d32d8857;p=builder.git diff --git a/source/virtualtarget.cpp b/source/virtualtarget.cpp index 3f0081c..85bdbc0 100644 --- a/source/virtualtarget.cpp +++ b/source/virtualtarget.cpp @@ -1,29 +1,28 @@ /* $Id$ This file is part of builder -Copyright © 2006-2007 Mikko Rasa, Mikkosoft Productions +Copyright © 2006-2009 Mikko Rasa, Mikkosoft Productions Distributed under the LGPL */ -#include +#include +#include +#include "builder.h" #include "virtualtarget.h" using namespace std; +using namespace Msp; -/** -Virtual targets are only rebuilt if their dependencies need rebuilding. -*/ -void VirtualTarget::check_rebuild() +VirtualTarget::VirtualTarget(Builder &b, const string &n): + Target(b, 0, n) { - for(TargetList::iterator i=depends.begin(); (i!=depends.end() && !rebuild); ++i) - if((*i)->get_rebuild()) - mark_rebuild(Msp::basename((*i)->get_name())+" needs rebuilding"); + builder.add_target(this); } -/** -Don't count virtual targets since "building" them causes no action. -*/ -unsigned VirtualTarget::count_rebuild() +void VirtualTarget::check_rebuild() { - return Target::count_rebuild()-rebuild; + // Virtual targets are only rebuilt if their dependencies need rebuilding. + for(TargetList::iterator i=depends.begin(); (i!=depends.end() && !rebuild); ++i) + if((*i)->get_rebuild()) + mark_rebuild((*i)->get_name()+" needs rebuilding"); }