|  | @@ -435,6 +435,7 @@ cmGlobalUnixMakefileGenerator3
 | 
	
		
			
				|  |  |         (l->second.GetType() == cmTarget::SHARED_LIBRARY) ||
 | 
	
		
			
				|  |  |         (l->second.GetType() == cmTarget::MODULE_LIBRARY) ||
 | 
	
		
			
				|  |  |         (l->second.GetType() == cmTarget::OBJECT_LIBRARY) ||
 | 
	
		
			
				|  |  | +       (l->second.GetType() == cmTarget::INTERFACE_LIBRARY) ||
 | 
	
		
			
				|  |  |         (l->second.GetType() == cmTarget::UTILITY))
 | 
	
		
			
				|  |  |        {
 | 
	
		
			
				|  |  |        // Add this to the list of depends rules in this directory.
 | 
	
	
		
			
				|  | @@ -612,6 +613,7 @@ cmGlobalUnixMakefileGenerator3
 | 
	
		
			
				|  |  |            (t->second.GetType() == cmTarget::SHARED_LIBRARY) ||
 | 
	
		
			
				|  |  |            (t->second.GetType() == cmTarget::MODULE_LIBRARY) ||
 | 
	
		
			
				|  |  |            (t->second.GetType() == cmTarget::OBJECT_LIBRARY) ||
 | 
	
		
			
				|  |  | +          (t->second.GetType() == cmTarget::INTERFACE_LIBRARY) ||
 | 
	
		
			
				|  |  |            (t->second.GetType() == cmTarget::UTILITY)))
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  |          // Add a rule to build the target by name.
 | 
	
	
		
			
				|  | @@ -633,6 +635,10 @@ cmGlobalUnixMakefileGenerator3
 | 
	
		
			
				|  |  |                            t->second.GetName(), depends, commands,
 | 
	
		
			
				|  |  |                            true);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +        if (t->second.GetType() == cmTarget::INTERFACE_LIBRARY)
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +          continue;
 | 
	
		
			
				|  |  | +          }
 | 
	
		
			
				|  |  |          // Add a fast rule to build the target
 | 
	
		
			
				|  |  |          std::string localName = lg->GetRelativeTargetDirectory(t->second);
 | 
	
		
			
				|  |  |          std::string makefileName;
 | 
	
	
		
			
				|  | @@ -699,6 +705,7 @@ cmGlobalUnixMakefileGenerator3
 | 
	
		
			
				|  |  |          || (t->second.GetType() == cmTarget::SHARED_LIBRARY)
 | 
	
		
			
				|  |  |          || (t->second.GetType() == cmTarget::MODULE_LIBRARY)
 | 
	
		
			
				|  |  |          || (t->second.GetType() == cmTarget::OBJECT_LIBRARY)
 | 
	
		
			
				|  |  | +        || (t->second.GetType() == cmTarget::INTERFACE_LIBRARY)
 | 
	
		
			
				|  |  |          || (t->second.GetType() == cmTarget::UTILITY)))
 | 
	
		
			
				|  |  |        {
 | 
	
		
			
				|  |  |        std::string makefileName;
 | 
	
	
		
			
				|  | @@ -715,53 +722,64 @@ cmGlobalUnixMakefileGenerator3
 | 
	
		
			
				|  |  |          << localName << "\n\n";
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        commands.clear();
 | 
	
		
			
				|  |  | -      makeTargetName = localName;
 | 
	
		
			
				|  |  | -      makeTargetName += "/depend";
 | 
	
		
			
				|  |  | -      commands.push_back(lg->GetRecursiveMakeCall
 | 
	
		
			
				|  |  | -                         (makefileName.c_str(),makeTargetName.c_str()));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -      // add requires if we need it for this generator
 | 
	
		
			
				|  |  | -      if (needRequiresStep)
 | 
	
		
			
				|  |  | +      if(t->second.GetType() != cmTarget::INTERFACE_LIBRARY)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  |          makeTargetName = localName;
 | 
	
		
			
				|  |  | -        makeTargetName += "/requires";
 | 
	
		
			
				|  |  | +        makeTargetName += "/depend";
 | 
	
		
			
				|  |  |          commands.push_back(lg->GetRecursiveMakeCall
 | 
	
		
			
				|  |  | -                           (makefileName.c_str(),makeTargetName.c_str()));
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -      makeTargetName = localName;
 | 
	
		
			
				|  |  | -      makeTargetName += "/build";
 | 
	
		
			
				|  |  | -      commands.push_back(lg->GetRecursiveMakeCall
 | 
	
		
			
				|  |  |                            (makefileName.c_str(),makeTargetName.c_str()));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -      // Write the rule.
 | 
	
		
			
				|  |  | -      localName += "/all";
 | 
	
		
			
				|  |  | -      depends.clear();
 | 
	
		
			
				|  |  | +        // add requires if we need it for this generator
 | 
	
		
			
				|  |  | +        if (needRequiresStep)
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +          makeTargetName = localName;
 | 
	
		
			
				|  |  | +          makeTargetName += "/requires";
 | 
	
		
			
				|  |  | +          commands.push_back(lg->GetRecursiveMakeCall
 | 
	
		
			
				|  |  | +                            (makefileName.c_str(),makeTargetName.c_str()));
 | 
	
		
			
				|  |  | +          }
 | 
	
		
			
				|  |  | +        makeTargetName = localName;
 | 
	
		
			
				|  |  | +        makeTargetName += "/build";
 | 
	
		
			
				|  |  | +        commands.push_back(lg->GetRecursiveMakeCall
 | 
	
		
			
				|  |  | +                            (makefileName.c_str(),makeTargetName.c_str()));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -      std::string progressDir =
 | 
	
		
			
				|  |  | -        lg->GetMakefile()->GetHomeOutputDirectory();
 | 
	
		
			
				|  |  | -      progressDir += cmake::GetCMakeFilesDirectory();
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -        cmOStringStream progCmd;
 | 
	
		
			
				|  |  | -        progCmd << "$(CMAKE_COMMAND) -E cmake_progress_report ";
 | 
	
		
			
				|  |  | -        // all target counts
 | 
	
		
			
				|  |  | -        progCmd << lg->Convert(progressDir.c_str(),
 | 
	
		
			
				|  |  | -                                cmLocalGenerator::FULL,
 | 
	
		
			
				|  |  | -                                cmLocalGenerator::SHELL);
 | 
	
		
			
				|  |  | -        progCmd << " ";
 | 
	
		
			
				|  |  | -        std::vector<unsigned long>& progFiles =
 | 
	
		
			
				|  |  | -          this->ProgressMap[&t->second].Marks;
 | 
	
		
			
				|  |  | -        for (std::vector<unsigned long>::iterator i = progFiles.begin();
 | 
	
		
			
				|  |  | -              i != progFiles.end(); ++i)
 | 
	
		
			
				|  |  | +        // Write the rule.
 | 
	
		
			
				|  |  | +        localName += "/all";
 | 
	
		
			
				|  |  | +        depends.clear();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        std::string progressDir =
 | 
	
		
			
				|  |  | +          lg->GetMakefile()->GetHomeOutputDirectory();
 | 
	
		
			
				|  |  | +        progressDir += cmake::GetCMakeFilesDirectory();
 | 
	
		
			
				|  |  |            {
 | 
	
		
			
				|  |  | -          progCmd << " " << *i;
 | 
	
		
			
				|  |  | +          cmOStringStream progCmd;
 | 
	
		
			
				|  |  | +          progCmd << "$(CMAKE_COMMAND) -E cmake_progress_report ";
 | 
	
		
			
				|  |  | +          // all target counts
 | 
	
		
			
				|  |  | +          progCmd << lg->Convert(progressDir.c_str(),
 | 
	
		
			
				|  |  | +                                  cmLocalGenerator::FULL,
 | 
	
		
			
				|  |  | +                                  cmLocalGenerator::SHELL);
 | 
	
		
			
				|  |  | +          progCmd << " ";
 | 
	
		
			
				|  |  | +          std::vector<unsigned long>& progFiles =
 | 
	
		
			
				|  |  | +            this->ProgressMap[&t->second].Marks;
 | 
	
		
			
				|  |  | +          for (std::vector<unsigned long>::iterator i = progFiles.begin();
 | 
	
		
			
				|  |  | +                i != progFiles.end(); ++i)
 | 
	
		
			
				|  |  | +            {
 | 
	
		
			
				|  |  | +            progCmd << " " << *i;
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +          commands.push_back(progCmd.str());
 | 
	
		
			
				|  |  |            }
 | 
	
		
			
				|  |  | -        commands.push_back(progCmd.str());
 | 
	
		
			
				|  |  | +        progressDir = "Built target ";
 | 
	
		
			
				|  |  | +        progressDir += t->first;
 | 
	
		
			
				|  |  | +        lg->AppendEcho(commands,progressDir.c_str());
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +      else
 | 
	
		
			
				|  |  | +        {
 | 
	
		
			
				|  |  | +        depends.clear();
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -      progressDir = "Built target ";
 | 
	
		
			
				|  |  | -      progressDir += t->first;
 | 
	
		
			
				|  |  | -      lg->AppendEcho(commands,progressDir.c_str());
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |        this->AppendGlobalTargetDepends(depends,t->second);
 | 
	
		
			
				|  |  | +      if(depends.empty() && this->EmptyRuleHackDepends != "")
 | 
	
		
			
				|  |  | +        {
 | 
	
		
			
				|  |  | +        depends.push_back(this->EmptyRuleHackDepends);
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  |        lg->WriteMakeRule(ruleFileStream, "All Build rule for target.",
 | 
	
		
			
				|  |  |                          localName.c_str(), depends, commands, true);
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -777,7 +795,7 @@ cmGlobalUnixMakefileGenerator3
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        // Write the rule.
 | 
	
		
			
				|  |  |        commands.clear();
 | 
	
		
			
				|  |  | -      progressDir = lg->GetMakefile()->GetHomeOutputDirectory();
 | 
	
		
			
				|  |  | +      std::string progressDir = lg->GetMakefile()->GetHomeOutputDirectory();
 | 
	
		
			
				|  |  |        progressDir += cmake::GetCMakeFilesDirectory();
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        {
 |