<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">Wonderful work, I look forward to it landing in SVN.<div><br></div><div>Only one concern: the choice to select the personality during compilation seems to create problems:</div><div><br></div><div> * We won't have an easy way to check that changes that add / change diagnostics correctly update all the personalities</div><div> * Distributions would presumably pick one personality for their users, restricting user choice<br></div><div> * The unit tests hard-code expected diagnostic output for a particular personality, so would fail on other personalities.</div></div><div class="gmail_quote"><br></div><div class="gmail_quote"><div>I think the solution should be completely clear: please also update the build system to always build the compiler five times, one for each personality, and likewise make four additional copies of the test suite, one for each new personality. This will increase build time and developer overhead, but it's obviously worthwhile.</div></div><div class="gmail_quote"><br></div><div class="gmail_quote">On Fri, Apr 1, 2016 at 12:32 PM, Chris Bieneman via cfe-commits <span dir="ltr"><<a href="mailto:cfe-commits@lists.llvm.org" target="_blank">cfe-commits@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">Hello Clang Community!<br>
<br>
I’m writing as a representative of the self-termed "Clang Diagnostic Innovation” (CDI) working group to share with you all our newest feature.<br>
<br>
Clang has long been known for its excellent diagnostic messages, and for providing meaningful and actionable errors and warnings even in the most extreme cases. We set for ourselves the difficult challenge of trying to figure out how to get Clang’s diagnostic messages to have a stronger impact on our users and to help them grow as engineers.<br>
<br>
We spent months researching and laboring over how to truly influence our users and found there really isn’t a silver bullet. Each individual engineer is motivated and inspired by something different. In short, there is no one-size-fits-all solution here. To maximize our reach, we have come up with a new and imaginative solution that we call Clang Diagnostic Personalities.<br>
<br>
Clang Diagnostic Personalities are special modes enabled at configuration time that translate Clang diagnostic strings into more engaging messages that will reverberate with our users, we hope, inspiring them to write better code. Because each person is inspired by different influences we’ve provided a variety of personalities as part of our initial implementation, and we want to encourage members of the Clang community to contribute their own unique personalities.<br>
<br>
These diagnostic personalities allow us to reach our users on a much more personal and visceral level.<br>
<br>
With our new Snark personality we ensure that our users feel each failure with a very personal twinge. It seeks to prod our engineers by not sparing the stick or holding back at all.<br>
<br>
Our new Mr. T personality ensures that “The jibba jabba stops here!” and uses subtle intimidation to motivate engineers to learn from their mistakes and become better people as well as better engineers.<br>
<br>
The new Star Trek personality inspires us all to imagine a Gene Roddenberry future utopia, and it helps us get there by making us feel like we already are.<br>
<br>
Lastly da Chicago personality keeps da wiseguys in line and speaks da language of da people. Da Bulls!<br>
<br>
I’ve attached patches for the basic clang support as well as for the various personalities for review and consideration by the wider community.<br>
<br>
Thank you,<br>
<br>
-Chris<br>
<br>
CDI Working Group Members:<br>
Chris Bieneman<br>
Justin Bogner<br>
Pete Cooper<br>
Dallas De Atley<br>
Kevin Enderby<br>
Louis Gerbarg<br>
Jim Grosbach<br>
Lang Hames<br>
Michael Ilseman<br>
Nick Kledzik<br>
Alex Rosenberg<br>
Marc Schifer<br>
<br>
<br>_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@lists.llvm.org">cfe-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits</a><br>
<br></blockquote></div><br></div></div>