<html><head><meta http-equiv="Content-Type" content="text/html charset=windows-1252"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">Hi Tobias,<div><br><div><div>On Jul 26, 2013, at 4:19 PM, Tobias Grosser <<a href="mailto:tobias@grosser.es">tobias@grosser.es</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">On 07/25/2013 05:09 PM, Quentin Colombet wrote:<br><blockquote type="cite">Hi,<br><br>I think we have a consensus on how we should report diagnostics now.<br>For broader uses, the discussion is still open.<br><br>To move forward on the diagnostic part, here is the plan:<br>- Extend the current handler with a prototype like:<br>void report(enum Kind, enum Classification, const char* msg)<br>where<br>- Kind is the kind of report: InlineAsm, StackSize, Other.<br>- Classification is Error, Warning.<br>- msg contains the fall back message to print in case the front-end do not know what to do with the report.<br></blockquote><br>Hello Quentin,<br><br>could you explain how plugins would use your infrastructure?</div></blockquote><div>I am not familiar with how plug-ins work with LLVM, but let me try to sketch something.</div><div><br></div><div>With the proposed infrastructure, LLVMContext will supply a callback to report events of special interest to the LLVM clients (clang, etc.).</div><div>As long as the plugin has access to the LLVMContext, I do not see why it should not be able to report its own events.</div><div>See the example below.</div><div><br></div><div>Note that the proposed prototype changed recently to (see Chris’ email):</div><div>void report(enum Kind, StringRef StringData, enum Classification, StringRef msg)</div><br><blockquote type="cite"><div style="font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">Would it be possible for a plugin to provide (limited) warnings/diagnostics without requiring clang/LLVM to be adapted?<br></div></blockquote><div>I think so.</div><div>Typically, to report a warning, I would do from the plug-in:</div><div><get the LLVMContext>.report(Other, “Whatever”, Warning, “Weird stuff during plug-in analysis.”);</div><div> </div><div>For the explanation I quote Chris:</div><div><blockquote type="cite">The idea is that "StringData+Kind" can be used to format something nice in clang, but that "msg" fully covers it for clients that don't know the Kind enum.</blockquote></div><div><br></div><div>Hope this helps!</div><div><br></div><div>Cheers,</div><div>-Quentin</div></div><br></div></body></html>