X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsourcearchivecomponent.cpp;fp=source%2Fsourcearchivecomponent.cpp;h=6dc5fe6caa2a6dd96d88736d45a1f1a430aa9839;hb=11b4732f81396aa3d8b0fc8928b8e1981032e743;hp=0000000000000000000000000000000000000000;hpb=35f2979869bff43706f3163ec0979c7084aaa3c4;p=builder.git diff --git a/source/sourcearchivecomponent.cpp b/source/sourcearchivecomponent.cpp new file mode 100644 index 0000000..6dc5fe6 --- /dev/null +++ b/source/sourcearchivecomponent.cpp @@ -0,0 +1,41 @@ +#include +#include "builder.h" +#include "file.h" +#include "sourcearchivecomponent.h" +#include "sourcepackage.h" +#include "tool.h" + +using namespace std; + +SourceArchiveComponent::SourceArchiveComponent(SourcePackage &p): + Component(p, p.get_name()+"-source") +{ } + +void SourceArchiveComponent::create_targets() const +{ + Builder &builder = package.get_builder(); + + list files; + files.insert(files.begin(), &package.get_build_file()); + + SourceList source_filenames = collect_source_files(); + for(SourceList::const_iterator i=source_filenames.begin(); i!=source_filenames.end(); ++i) + { + FileTarget *file = builder.get_vfs().get_target(*i); + if(!file) + file = new File(builder, package, *i); + files.push_back(file); + } + + BuildGraph &build_graph = builder.get_build_graph(); + const BuildGraph::TargetMap &targets = build_graph.get_targets(); + for(BuildGraph::TargetMap::const_iterator i=targets.begin(); i!=targets.end(); ++i) + if(i->second->get_package()==&package && !i->second->is_buildable()) + if(find(files.begin(), files.end(), i->second)==files.end()) + files.push_back(i->second); + + const Toolchain &toolchain = builder.get_toolchain(); + string archive_name = package.get_name()+"-"+package.get_version()+"-source"; + Target *result = toolchain.get_tool("TAR").create_target(files, archive_name); + build_graph.get_target("archives")->add_dependency(*result); +}