Index: clang/lib/StaticAnalyzer/Core/BugReporterVisitors.cpp =================================================================== --- clang/lib/StaticAnalyzer/Core/BugReporterVisitors.cpp +++ clang/lib/StaticAnalyzer/Core/BugReporterVisitors.cpp @@ -2410,16 +2410,18 @@ Out << (shouldInvert ? LhsString : RhsString); const LocationContext *LCtx = N->getLocationContext(); - PathDiagnosticLocation Loc(Cond, BRC.getSourceManager(), LCtx); // Convert 'field ...' to 'Field ...' if it is a MemberExpr. std::string Message = Out.str(); Message[0] = toupper(Message[0]); - // If we know the value create a pop-up note. - if (!IsAssuming) + // If we know the value create a pop-up note to the left part of 'BExpr'. + if (!IsAssuming) { + PathDiagnosticLocation Loc(BExpr->getLHS(), BRC.getSourceManager(), LCtx); return std::make_shared(Loc, Message); + } + PathDiagnosticLocation Loc(Cond, BRC.getSourceManager(), LCtx); auto event = std::make_shared(Loc, Message); if (shouldPrune.hasValue()) event->setPrunable(shouldPrune.getValue()); @@ -2472,12 +2474,14 @@ return nullptr; const LocationContext *LCtx = N->getLocationContext(); - PathDiagnosticLocation Loc(Cond, BRC.getSourceManager(), LCtx); - // If we know the value create a pop-up note. - if (!IsAssuming) + // If we know the value create a pop-up note to the 'DRE'. + if (!IsAssuming) { + PathDiagnosticLocation Loc(DRE, BRC.getSourceManager(), LCtx); return std::make_shared(Loc, Out.str()); + } + PathDiagnosticLocation Loc(Cond, BRC.getSourceManager(), LCtx); auto event = std::make_shared(Loc, Out.str()); const ProgramState *state = N->getState().get(); if (const MemRegion *R = state->getLValue(VD, LCtx).getAsRegion()) { @@ -2505,7 +2509,7 @@ return nullptr; const LocationContext *LCtx = N->getLocationContext(); - PathDiagnosticLocation Loc(Cond, BRC.getSourceManager(), LCtx); + PathDiagnosticLocation Loc(ME, BRC.getSourceManager(), LCtx); if (!Loc.isValid() || !Loc.asLocation().isValid()) return nullptr; Index: clang/lib/StaticAnalyzer/Core/HTMLDiagnostics.cpp =================================================================== --- clang/lib/StaticAnalyzer/Core/HTMLDiagnostics.cpp +++ clang/lib/StaticAnalyzer/Core/HTMLDiagnostics.cpp @@ -612,7 +612,7 @@ for (const auto &Range : PopUpRanges) { html::HighlightRange(R, Range.getBegin(), Range.getEnd(), "", "", - /*IsTokenRange=*/false); + /*IsTokenRange=*/true); } } @@ -644,12 +644,11 @@ Out << "
"; html::HighlightRange(R, Range.getBegin(), Range.getEnd(), "", Buf.c_str(), - /*IsTokenRange=*/false); - - // Otherwise inject just the new row at the end of the range. + /*IsTokenRange=*/true); } else { + // Otherwise inject just the new row at the end of the range. html::HighlightRange(R, Range.getBegin(), Range.getEnd(), "", Buf.c_str(), - /*IsTokenRange=*/false); + /*IsTokenRange=*/true); } } Index: clang/test/Analysis/Inputs/expected-plists/cxx-for-range.cpp.plist =================================================================== --- clang/test/Analysis/Inputs/expected-plists/cxx-for-range.cpp.plist +++ clang/test/Analysis/Inputs/expected-plists/cxx-for-range.cpp.plist @@ -191,7 +191,7 @@ line11 - col14 + col9 file0 @@ -515,7 +515,7 @@ line11 - col14 + col9 file0 Index: clang/test/Analysis/Inputs/expected-plists/edges-new.mm.plist =================================================================== --- clang/test/Analysis/Inputs/expected-plists/edges-new.mm.plist +++ clang/test/Analysis/Inputs/expected-plists/edges-new.mm.plist @@ -2727,7 +2727,7 @@ line146 - col13 + col8 file0 @@ -2949,7 +2949,7 @@ line146 - col13 + col8 file0 @@ -3929,7 +3929,7 @@ line178 - col14 + col9 file0 @@ -4185,7 +4185,7 @@ line178 - col14 + col9 file0 @@ -4281,7 +4281,7 @@ line181 - col14 + col9 file0 @@ -8087,7 +8087,7 @@ location line267 - col18 + col19 file0 ranges @@ -8095,7 +8095,7 @@ line267 - col18 + col19 file0 @@ -8119,12 +8119,12 @@ line267 - col18 + col19 file0 line267 - col18 + col22 file0 @@ -11983,12 +11983,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -12000,7 +12000,7 @@ location line457 - col9 + col10 file0 ranges @@ -12008,7 +12008,7 @@ line457 - col9 + col10 file0 @@ -12032,12 +12032,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -12244,12 +12244,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -12261,7 +12261,7 @@ location line457 - col9 + col10 file0 ranges @@ -12269,7 +12269,7 @@ line457 - col9 + col10 file0 @@ -12293,12 +12293,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -12571,12 +12571,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -12588,7 +12588,7 @@ location line457 - col9 + col10 file0 ranges @@ -12596,7 +12596,7 @@ line457 - col9 + col10 file0 @@ -12620,12 +12620,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -13128,12 +13128,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -13145,7 +13145,7 @@ location line457 - col9 + col10 file0 ranges @@ -13153,7 +13153,7 @@ line457 - col9 + col10 file0 @@ -13177,12 +13177,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -13752,12 +13752,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -13769,7 +13769,7 @@ location line457 - col9 + col10 file0 ranges @@ -13777,7 +13777,7 @@ line457 - col9 + col10 file0 @@ -13801,12 +13801,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -15295,12 +15295,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -15312,7 +15312,7 @@ location line457 - col9 + col10 file0 ranges @@ -15320,7 +15320,7 @@ line457 - col9 + col10 file0 @@ -15344,12 +15344,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -16965,12 +16965,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -16982,7 +16982,7 @@ location line457 - col9 + col10 file0 ranges @@ -16990,7 +16990,7 @@ line457 - col9 + col10 file0 @@ -17014,12 +17014,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -18860,12 +18860,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -18877,7 +18877,7 @@ location line457 - col9 + col10 file0 ranges @@ -18885,7 +18885,7 @@ line457 - col9 + col10 file0 @@ -18909,12 +18909,12 @@ line457 - col9 + col10 file0 line457 - col9 + col14 file0 @@ -22261,7 +22261,7 @@ line587 - col16 + col11 file0 Index: clang/test/Analysis/Inputs/expected-plists/inline-plist.c.plist =================================================================== --- clang/test/Analysis/Inputs/expected-plists/inline-plist.c.plist +++ clang/test/Analysis/Inputs/expected-plists/inline-plist.c.plist @@ -548,7 +548,7 @@ line45 - col12 + col7 file0 Index: clang/test/Analysis/Inputs/expected-plists/objc-radar17039661.m.plist =================================================================== --- clang/test/Analysis/Inputs/expected-plists/objc-radar17039661.m.plist +++ clang/test/Analysis/Inputs/expected-plists/objc-radar17039661.m.plist @@ -836,7 +836,7 @@ line38 - col37 + col20 file0 Index: clang/test/Analysis/Inputs/expected-plists/plist-output.m.plist =================================================================== --- clang/test/Analysis/Inputs/expected-plists/plist-output.m.plist +++ clang/test/Analysis/Inputs/expected-plists/plist-output.m.plist @@ -2513,7 +2513,7 @@ line96 - col13 + col8 file0 @@ -2735,7 +2735,7 @@ line96 - col13 + col8 file0 @@ -3554,7 +3554,7 @@ line127 - col14 + col9 file0 @@ -3776,7 +3776,7 @@ line127 - col14 + col9 file0