X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fobjectfile.cpp;h=f3d6183afa6b01161b1039af0bb6f838d571e5d8;hb=af2dac0d09df4782060dd131f2a761e8a46a8d55;hp=3f4ba2019f32a835449d72ce336f0f08076573d7;hpb=57bdb055acb0453c75b22cb64f35cc0e817a2827;p=builder.git diff --git a/source/objectfile.cpp b/source/objectfile.cpp index 3f4ba20..f3d6183 100644 --- a/source/objectfile.cpp +++ b/source/objectfile.cpp @@ -1,89 +1,82 @@ -#include -#include +/* $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 "package.h" #include "sourcefile.h" +#include "sourcepackage.h" using namespace std; using namespace Msp; -ObjectFile::ObjectFile(Builder &b, const Component &c, SourceFile &src): - Target(b, &c.get_package(), generate_target_name(c, src.get_name())), - comp(c) +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(&src); + buildable = true; + add_depend(&source); } -/** -Processes as many new dependences as possible. Some may be left unprocessed -if their own dependencies are not ready, requiring another call to this -function. Use the get_deps_ready() function to determine whether this is the -case. -*/ void ObjectFile::find_depends() { for(TargetList::iterator i=new_deps.begin(); i!=new_deps.end();) { - Target *tgt=*i; + Target *tgt = *i; if(tgt->get_depends_ready()) { - i=new_deps.erase(i); + i = new_deps.erase(i); find_depends(tgt); } else ++i; } - deps_ready=new_deps.empty(); + deps_ready = new_deps.empty(); } -Action *ObjectFile::build() -{ - return Target::build(new Compile(builder, *this)); -} -/** -Recursively looks for header targets and adds them as dependencies. -*/ void ObjectFile::find_depends(Target *tgt) { - const string &tname=tgt->get_name(); - string path=tname.substr(0, tname.rfind('/')); - - SourceFile *src=dynamic_cast(tgt); - if(!src) - { - Install *inst=dynamic_cast(tgt); - if(inst) - src=dynamic_cast(inst->get_depends().front()); - } - if(!src) + SourceFile *src = dynamic_cast(tgt->get_real_target()); + FileTarget *file = dynamic_cast(tgt); + if(!src || !file) return; - const list &includes=src->get_includes(); + 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 *hdr2=builder.get_header(*i, path, comp.get_build_info().incpath); - if(hdr2 && !contains(depends, hdr2)) - add_depend(hdr2); + Target *hdr = builder.get_header(*i, spath, incpath); + if(hdr && find(depends.begin(), depends.end(), hdr)==depends.end()) + add_depend(hdr); } } -/** -Adds a target to the dependency list as well as the new dependencies list. -*/ void ObjectFile::add_depend(Target *tgt) { Target::add_depend(tgt); new_deps.push_back(tgt); } -string ObjectFile::generate_target_name(const Component &comp, const string &src) +Action *ObjectFile::create_action() +{ + return new Compile(builder, *this); +} + +FS::Path ObjectFile::generate_target_path(const Component &comp, const string &src) { - return (comp.get_package().get_temp_dir()/comp.get_name()/(Path::splitext(src.substr(src.rfind('/')+1)).base+".o")).str(); + const SourcePackage &pkg = comp.get_package(); + return pkg.get_temp_dir()/comp.get_name()/(FS::basepart(src)+".o"); }