<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><div>On Nov 10, 2011, at 10:32 AM, Argyrios Kyrtzidis 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 style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><blockquote type="cite"><div>+void CXLoadedDiagnostic::decodeLocation(CXSourceLocation location,<br>+ CXFile *file,<br>+ unsigned int *line,<br>+ unsigned int *column,<br>+ unsigned int *offset) {<br>+ <br>+ <br>+ // CXSourceLocation consists of the following fields:<br>+ //<br>+ // void *ptr_data[2];<br>+ // unsigned int_data;<br>+ //<br>+ // The lowest bit of ptr_data[0] is always set to 1 to indicate this<br>+ // is a persistent diagnostic.<br>+ //<br>+ // For now, do the unoptimized approach and store the data in a side<br>+ // data structure. We can optimize this case later.<br>+ <br>+ uintptr_t V = (uintptr_t) location.ptr_data[0];<br>+ assert((V & 0x1) == 1);<br>+ V &= ~(uintptr_t)1;<br>+ <br>+ const Location &Loc = *((Location*)V);<br>+ <br>+ if (file)<br>+ *file = Loc.file; <br>+ if (line)<br>+ *line = Loc.line;<br>+ if (column)<br>+ *column = Loc.column;<br>+ if (offset)<br>+ *offset = Loc.offset;<br>+}<br></div></blockquote><div><br></div><div>Is this modification to CXSourceLocation so that the diagnostic location becomes independent of a SourceManager ?</div></div></div></span></blockquote><div><br></div><div>Yes. The idea is that deserialized diagnostics don't have a source location. They don't actually need one since all this locations are raw physical locations anyway.</div><br><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 style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><div><br></div><div>Why not introduce a new kind of location (like CXFileLocation or something) instead ?</div></div></div></span></blockquote><div><br></div><div>I couldn't disagree with you more. Requiring clients to use a different set of mostly duplicate APIs for source locations which are just different under the hood seems like extremely poor API design to me. It makes the API verbose for no reason at all. Why should the client be concerned at all about how the CXSourceLocation is implemented under the hood as long as it provides the same functionality?</div><div><br></div><div>Keep in mind this would also require duplicating a bunch of the CXDiagnostics API to distinguish between diagnostics that have CXFileLocations and those that have CXSourceLocations.</div><br><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 style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><div> If you remove the SourceManager you "disable" the functionality of CXSourceLocation anyway, e.g. while previously you could go through the expansion stack, get presumed location, etc., you can't do that with this new kind of location.</div></div></div></span></blockquote><div><br></div><div>Sorry, but I think that statement is not true. The prime use of CXSourceLocations is to query file, line, and column information. That is still supported.</div><div><br></div><div>We aren't disabling any functionality. Yes, we are losing the macro expansion trace and the inclusion stack, but the locations are actual locations. They are just the spelling locations. In the absence of macro expansions, these are the same exact locations that a client would see in the non-deserialized diagnostics case. One way to think of it is that the locations have been "pre-lowered" for consumption by a client that just wants to issue warnings at actual lines/columns in code. We can still include all the macro expansion goop, but pre-lower those as parts of the diagnostic instead of encoding them into the CXSourceLocations.</div><br><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 style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><div> Seems better to be clear in the API.</div></div></div></span></blockquote><br></div><div>I think duplicating most (all) of the same CXSourceLocation APIs just to expose a detail that clients should not be thinking about anyway adds no clarity to the API.</div></body></html>