FS::Path ObjectFile::generate_target_path(const Component &comp, const FS::Path &src)
{
const SourcePackage &pkg = comp.get_package();
- FS::Path temp_dir = pkg.get_temp_directory()/comp.get_name();
+ FS::Path temp_dir = pkg.get_temp_directory();
FS::Path rel_src;
if(FS::descendant_depth(src, temp_dir)>=0)
rel_src = FS::relative(src, temp_dir);
fn += *i;
}
const Architecture &arch = comp.get_package().get_builder().get_current_arch();
- return temp_dir/arch.create_filename<ObjectFile>(FS::basepart(fn));
+ return temp_dir/comp.get_name()/arch.create_filename<ObjectFile>(FS::basepart(fn));
}
void ObjectFile::set_used_in_shared_library(bool u)
TemplateFile &tmpl = dynamic_cast<TemplateFile &>(*sources.front());
const Component *comp = tmpl.get_component();
const SourcePackage *pkg = tmpl.get_package();
+ FS::Path subdir;
string base;
- if(processing_unit==ONE_FILE)
- base = FS::basepart(FS::basename(tmpl.get_path()));
- else if(processing_unit==DIRECTORY)
- base = FS::basename(FS::dirname(tmpl.get_path()));
- else
+ if(processing_unit==COMPONENT)
base = comp->get_name();
+ else
+ {
+ subdir = FS::dirname(FS::relative(tmpl.get_path(), pkg->get_source_directory()));
+ if(processing_unit==ONE_FILE)
+ base = FS::basepart(FS::basename(tmpl.get_path()));
+ else if(processing_unit==DIRECTORY)
+ {
+ base = FS::basename(subdir);
+ subdir = FS::dirname(subdir);
+ }
+ }
Target *primary = 0;
for(list<string>::const_iterator i=out_suffixes.begin(); i!=out_suffixes.end(); ++i)
Tool *tool = builder.get_toolchain().get_tool_for_suffix(*i, true);
if(tool)
{
- FS::Path fn = pkg->get_temp_directory()/comp->get_name()/(base+*i);
+ FS::Path fn = pkg->get_temp_directory()/"generated"/subdir/(base+*i);
Target *target = tool->create_source(*comp, fn);
target->set_tool(*this);
for(list<Target *>::const_iterator j=sources.begin(); j!=sources.end(); ++j)