#include "builder.h"
#include "component.h"
#include "executable.h"
+#include "file.h"
#include "header.h"
#include "install.h"
#include "objectfile.h"
#include "sharedlibrary.h"
#include "sourcepackage.h"
#include "staticlibrary.h"
+#include "tarball.h"
#include "target.h"
using namespace std;
PathList files=collect_source_files();
- bool build_exe=(type!=HEADERS);
-
- list<ObjectFile *> objs;
- list<FileTarget *> inst_tgts;
- for(PathList::const_iterator i=files.begin(); i!=files.end(); ++i)
+ if(type==TARBALL)
{
- string ext=FS::extpart(FS::basename(*i));
- if((ext==".cpp" || ext==".c") && build_exe)
+ string tarname=name;
+ if(name=="@src")
+ tarname=pkg.get_name()+"-"+pkg.get_version();
+ TarBall *result=new TarBall(builder, pkg, tarname);
+
+ if(name=="@src")
{
- SourceFile *src=new SourceFile(builder, this, i->str());
+ const TargetMap &targets=builder.get_targets();
+ for(TargetMap::const_iterator i=targets.begin(); i!=targets.end(); ++i)
+ if(i->second->get_package()==&pkg && !i->second->get_buildable())
+ result->add_depend(i->second);
+ files.push_back(pkg.get_source()/"Build");
+ }
- // Compile sources
- ObjectFile *obj=new ObjectFile(builder, *this, *src);
- objs.push_back(obj);
+ for(PathList::const_iterator i=files.begin(); i!=files.end(); ++i)
+ {
+ FileTarget *ft;
+ if(Target *tgt=builder.get_target(i->str()))
+ ft=dynamic_cast<FileTarget *>(tgt);
+ else
+ ft=new File(builder, *i);
+ result->add_depend(ft);
}
- else if(ext==".h")
+
+ Target *tarbls_tgt=builder.get_target("tarballs");
+ tarbls_tgt->add_depend(result);
+
+ return;
+ }
+
+ list<FileTarget *> inst_list;
+ for(PathList::const_iterator i=files.begin(); i!=files.end(); ++i)
+ {
+ string ext=FS::extpart(FS::basename(*i));
+ if(ext==".h")
{
FileTarget *hdr=dynamic_cast<FileTarget *>(builder.get_target(i->str()));
if(!hdr)
// Install headers if requested
if(type==HEADERS && install)
- inst_tgts.push_back(hdr);
+ inst_list.push_back(hdr);
}
}
- if(build_exe)
+ if(type==PROGRAM || type==LIBRARY || type==MODULE)
{
- Binary *bin=0;
- StaticLibrary *slib=0;
- if(type==LIBRARY)
+ list<ObjectFile *> objs;
+ for(PathList::const_iterator i=files.begin(); i!=files.end(); ++i)
{
- bin=new SharedLibrary(builder, *this, objs);
- slib=new StaticLibrary(builder, *this, objs);
+ string ext=FS::extpart(FS::basename(*i));
+ if((ext==".cpp" || ext==".cc" || ext==".c"))
+ {
+ SourceFile *src=new SourceFile(builder, this, i->str());
+ ObjectFile *obj=new ObjectFile(builder, *this, *src);
+ objs.push_back(obj);
+ }
}
- else
- bin=new Executable(builder, *this, objs);
- if(&pkg==builder.get_main_package() && deflt)
+ list<FileTarget *> results;
+ if(type==LIBRARY)
{
- def_tgt->add_depend(bin);
- if(slib) def_tgt->add_depend(slib);
+ results.push_back(new SharedLibrary(builder, *this, objs));
+ results.push_back(new StaticLibrary(builder, *this, objs));
}
else
- {
- world->add_depend(bin);
- if(slib) world->add_depend(slib);
- }
+ results.push_back(new Executable(builder, *this, objs));
- if(install)
+ for(list<FileTarget *>::const_iterator i=results.begin(); i!=results.end(); ++i)
{
- inst_tgts.push_back(bin);
- if(slib)
- inst_tgts.push_back(slib);
+ if(&pkg==builder.get_main_package() && deflt)
+ def_tgt->add_depend(*i);
+ else
+ world->add_depend(*i);
+ if(install)
+ inst_list.push_back(*i);
}
}
Target *inst_tgt=builder.get_target("install");
- for(list<FileTarget *>::const_iterator i=inst_tgts.begin(); i!=inst_tgts.end(); ++i)
+ for(list<FileTarget *>::const_iterator i=inst_list.begin(); i!=inst_list.end(); ++i)
inst_tgt->add_depend(new Install(builder, pkg, **i));
}