X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fobjectfile.cpp;h=0536755bb26788354d5e147e021f38fe64d0af36;hb=HEAD;hp=f3d6183afa6b01161b1039af0bb6f838d571e5d8;hpb=05a2b9dabd01414e9e9a91f9d69babaca4ccb32d;p=builder.git diff --git a/source/objectfile.cpp b/source/objectfile.cpp deleted file mode 100644 index f3d6183..0000000 --- a/source/objectfile.cpp +++ /dev/null @@ -1,82 +0,0 @@ -/* $Id$ - -This file is part of builder -Copyright © 2006-2010 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - -#include -#include -#include "builder.h" -#include "compile.h" -#include "component.h" -#include "install.h" -#include "objectfile.h" -#include "sourcefile.h" -#include "sourcepackage.h" - -using namespace std; -using namespace Msp; - -ObjectFile::ObjectFile(Builder &b, const Component &c, SourceFile &s): - FileTarget(b, &c.get_package(), generate_target_path(c, FS::basename(s.get_path()))), - comp(c), - source(s) -{ - buildable = true; - add_depend(&source); -} - -void ObjectFile::find_depends() -{ - for(TargetList::iterator i=new_deps.begin(); i!=new_deps.end();) - { - Target *tgt = *i; - if(tgt->get_depends_ready()) - { - i = new_deps.erase(i); - find_depends(tgt); - } - else - ++i; - } - - deps_ready = new_deps.empty(); -} - - -void ObjectFile::find_depends(Target *tgt) -{ - SourceFile *src = dynamic_cast(tgt->get_real_target()); - FileTarget *file = dynamic_cast(tgt); - if(!src || !file) - return; - - FS::Path spath = FS::dirname(file->get_path()); - const StringList &incpath = comp.get_build_info().incpath; - - const list &includes = src->get_includes(); - for(list::const_iterator i=includes.begin(); i!=includes.end(); ++i) - { - Target *hdr = builder.get_header(*i, spath, incpath); - if(hdr && find(depends.begin(), depends.end(), hdr)==depends.end()) - add_depend(hdr); - } -} - -void ObjectFile::add_depend(Target *tgt) -{ - Target::add_depend(tgt); - new_deps.push_back(tgt); -} - -Action *ObjectFile::create_action() -{ - return new Compile(builder, *this); -} - -FS::Path ObjectFile::generate_target_path(const Component &comp, const string &src) -{ - const SourcePackage &pkg = comp.get_package(); - return pkg.get_temp_dir()/comp.get_name()/(FS::basepart(src)+".o"); -}