<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><div>On Sep 20, 2011, at 9:27 AM, Anna Zaks wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><span class="Apple-style-span" style="border-collapse: separate; font-family: Helvetica; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; font-size: medium; "><div>Thanks for catching this! LocationContext's constructor is protected so we cannot construct one from AnalysisContext directly (passing ParentMap would solve the issue, I forgot that it's constructed on demand). We could require either LocationContextManager or AnalysisManager to be passed in by the users that do not have LocationContext. AnalysisManager is probably better since that's what is passed to the checkers.</div></span><br class="Apple-interchange-newline"></blockquote></div><div><br></div><div>I don't think the managers should get involved here. How would PathDiagnosticLocation know which AnalysisContext to create? It also seems unnecessary since we already have an AnalysisContext object almost everywhere. From a design point, LocationContexts represent points of context-sensitivity, so it doesn't make sense to create them on-the-fly when they aren't being used for that purpose. Similarly, we create AnalysisContexts at key points when we start running an analysis to cache centralized data (e.g., CFGs, live variables information, etc.) used by one or more analyses. PathDiagnosticLocation shouldn't be just creating them on-the-fly.</div><div><br></div><div>From my perspective, I see two variants:</div><div><br></div><div>(1) PathDiagnosticLocations that utilize context-sensitivity.</div><div><br></div><div>(2) PathDiagnosticLocations that don't utilize context-sensitivity.</div><div><br></div><div>Only genRange() and genLocation() use the LocationContext*, and they could just use an AnalysisContext* instead. We don't utilize the context-sensitivty in any way yet in PathDiagnosticLocation, but that is something we may add later.</div><div><br></div><div>It seems like want to support (1) and (2) easily for both clients.</div><div><br></div><div>Here's a possibility. Take:</div><div><br></div><div><blockquote type="cite"><div><font class="Apple-style-span" color="#000000">PathDiagnosticLocation</font></div><div><font class="Apple-style-span" color="#000000"> PathDiagnosticLocation::createDeclBegin(const LocationContext *LC,</font></div><div><font class="Apple-style-span" color="#000000"> const SourceManager &SM) </font></div></blockquote></div><div><br></div><div>and make it:</div><div><br></div><div><blockquote type="cite"><div><font class="Apple-style-span" color="#000000">PathDiagnosticLocation</font></div><div><font class="Apple-style-span" color="#000000"> PathDiagnosticLocation::createDeclBegin(LocationOrAnalysisContext Ctx,</font></div><div><font class="Apple-style-span" color="#000000"> const SourceManager &SM) </font></div></blockquote></div><div><br></div><div>LocationOrAnalysisContext could be a typedef for a PointerUnion of LocationContext* and AnalysisContext*. Then genRange() and genLocation() can just take an AnalysisContext* (because we can get an AnalysisContext* from a LocationContext*) and all of the clients don't need to provide a LocationContext* if they don't care about context-sensitivity. When we decide to model context-sensitivty in PathDiagnosticLocation, we just query LocationOrAnalysisContext to see if it is a LocationContext*, and then do the right thing (whatever that ends up being).</div></body></html>