[cfe-commits] r148887 - in /cfe/trunk: include/clang/Driver/CC1Options.td include/clang/Frontend/CompilerInvocation.h include/clang/Frontend/MigratorOptions.h lib/ARCMigrate/ARCMT.cpp lib/ARCMigrate/Internals.h lib/ARCMigrate/TransGCCalls.cpp lib/ARCMigrate/TransformActions.cpp lib/Frontend/CompilerInvocation.cpp test/ARCMT/GC-check-warn-nsalloc.m
Jordan Rose
jordan_rose at apple.com
Mon May 19 13:11:32 PDT 2014
> On May 19, 2014, at 12:30, Aaron Ballman <aaron at aaronballman.com> wrote:
>
> I did a little bit more digging into the issue, and the problem is in
> ARCMT.cpp:318, whic has the code:
>
> Diags->setDiagnosticMapping(diag::err_arcmt_nsalloc_realloc,
> NoNSAllocReallocError ? diag::MAP_WARNING
> : diag::MAP_ERROR,
> SourceLocation());
>
> You cannot map an error diagnostic to be a warning.
> DiagnosticsEngine::setDiagnosticMapping has this assert, which is
> triggered by that code:
>
> assert((Diags->isBuiltinWarningOrExtension(Diag) ||
> (Map == diag::MAP_FATAL || Map == diag::MAP_ERROR)) &&
> "Cannot map errors into warnings!");
>
> I'm not familiar enough with ARCMT to understand what is required for
> the correct fix.
If the current behavior is correct, the right way to declare the diagnostic in the .td file is "Warning<...>, DefaultError".
Jordan
More information about the cfe-commits
mailing list