forked from OSchip/llvm-project
Driver: Add a Tool::hasGoodDiagnostics hook, and use it to simplify logic for
deciding when we need to emit an extra "command failed" diagnostic. - This also fixes the case where we were emitting that extra diagnostics, even when using clang w/ the integrated assembler, which has good diagnostics. llvm-svn: 100529
This commit is contained in:
parent
6285f754fa
commit
3d45e17d15
|
@ -48,6 +48,10 @@ public:
|
|||
virtual bool hasIntegratedAssembler() const { return false; }
|
||||
virtual bool hasIntegratedCPP() const = 0;
|
||||
|
||||
/// \brief Does this tool have "good" standardized diagnostics, or should the
|
||||
/// driver add an additional "command failed" diagnostic on failures.
|
||||
virtual bool hasGoodDiagnostics() const { return false; }
|
||||
|
||||
/// ConstructJob - Construct jobs to perform the action \arg JA,
|
||||
/// writing to \arg Output and with \arg Inputs.
|
||||
///
|
||||
|
|
|
@ -239,12 +239,8 @@ int Driver::ExecuteCompilation(const Compilation &C) const {
|
|||
// other tools are less common, and they generally have worse diagnostics,
|
||||
// so always print the diagnostic there.
|
||||
const Action &Source = FailingCommand->getSource();
|
||||
bool IsFriendlyTool = (isa<PreprocessJobAction>(Source) ||
|
||||
isa<PrecompileJobAction>(Source) ||
|
||||
isa<AnalyzeJobAction>(Source) ||
|
||||
isa<CompileJobAction>(Source));
|
||||
|
||||
if (!IsFriendlyTool || Res != 1) {
|
||||
if (!FailingCommand->getCreator().hasGoodDiagnostics() || Res != 1) {
|
||||
// FIXME: See FIXME above regarding result code interpretation.
|
||||
if (Res < 0)
|
||||
Diag(clang::diag::err_drv_command_signalled)
|
||||
|
|
|
@ -42,6 +42,7 @@ namespace tools {
|
|||
|
||||
virtual bool acceptsPipedInput() const { return true; }
|
||||
virtual bool canPipeOutput() const { return true; }
|
||||
virtual bool hasGoodDiagnostics() const { return true; }
|
||||
virtual bool hasIntegratedAssembler() const { return true; }
|
||||
virtual bool hasIntegratedCPP() const { return true; }
|
||||
|
||||
|
@ -79,6 +80,7 @@ namespace gcc {
|
|||
|
||||
virtual bool acceptsPipedInput() const { return true; }
|
||||
virtual bool canPipeOutput() const { return true; }
|
||||
virtual bool hasGoodDiagnostics() const { return true; }
|
||||
virtual bool hasIntegratedCPP() const { return false; }
|
||||
|
||||
virtual void RenderExtraToolArgs(const JobAction &JA,
|
||||
|
@ -91,6 +93,7 @@ namespace gcc {
|
|||
|
||||
virtual bool acceptsPipedInput() const { return true; }
|
||||
virtual bool canPipeOutput() const { return false; }
|
||||
virtual bool hasGoodDiagnostics() const { return true; }
|
||||
virtual bool hasIntegratedCPP() const { return true; }
|
||||
|
||||
virtual void RenderExtraToolArgs(const JobAction &JA,
|
||||
|
@ -103,6 +106,7 @@ namespace gcc {
|
|||
|
||||
virtual bool acceptsPipedInput() const { return true; }
|
||||
virtual bool canPipeOutput() const { return true; }
|
||||
virtual bool hasGoodDiagnostics() const { return true; }
|
||||
virtual bool hasIntegratedCPP() const { return true; }
|
||||
|
||||
virtual void RenderExtraToolArgs(const JobAction &JA,
|
||||
|
@ -176,6 +180,7 @@ namespace darwin {
|
|||
|
||||
virtual bool acceptsPipedInput() const { return true; }
|
||||
virtual bool canPipeOutput() const { return true; }
|
||||
virtual bool hasGoodDiagnostics() const { return true; }
|
||||
virtual bool hasIntegratedCPP() const { return true; }
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in New Issue