| Chandler Carruth | c00c0c3 | 2011-11-28 07:16:19 +0000 | [diff] [blame] | 1 | <html> | 
|  | 2 | <head> | 
|  | 3 | <title>Clang 3.0 Release Notes</title> | 
|  | 4 | <link type="text/css" rel="stylesheet" href="../menu.css" /> | 
|  | 5 | <link type="text/css" rel="stylesheet" href="../content.css" /> | 
|  | 6 | <style type="text/css"> | 
|  | 7 | td { | 
|  | 8 | vertical-align: top; | 
|  | 9 | } | 
|  | 10 | </style> | 
|  | 11 | </head> | 
|  | 12 | <body> | 
|  | 13 |  | 
|  | 14 | <!--#include virtual="../menu.html.incl"--> | 
|  | 15 |  | 
|  | 16 | <div id="content"> | 
|  | 17 |  | 
|  | 18 | <h1>Clang 3.0 Release Notes</h1> | 
|  | 19 |  | 
|  | 20 | <img align=right src="http://llvm.org/img/DragonSmall.png" | 
|  | 21 | width="136" height="136" alt="LLVM Dragon Logo"> | 
|  | 22 |  | 
|  | 23 | <ul> | 
|  | 24 | <li><a href="#intro">Introduction</a></li> | 
|  | 25 | <li><a href="#whatsnew">What's New in Clang 3.0?</a> | 
|  | 26 | <ul> | 
|  | 27 | <li><a href="#majorfeatures">Major New Features</a></li> | 
|  | 28 | <li><a href="#cchanges">C Language Changes</a></li> | 
|  | 29 | <li><a href="#cxxhanges">C++ Language Changes</a></li> | 
|  | 30 | <li><a href="#objchanges">Objective-C Language Changes</a></li> | 
|  | 31 | <li><a href="#apichanges">Internal API Changes</a></li> | 
|  | 32 | </li> | 
|  | 33 | <li><a href="#knownproblems">Known Problems</a></li> | 
|  | 34 | <li><a href="#additionalinfo">Additional Information</a></li> | 
|  | 35 | </ul> | 
|  | 36 |  | 
|  | 37 | <div class="doc_author"> | 
|  | 38 | <p>Written by the <a href="http://llvm.org/">LLVM Team</a></p> | 
|  | 39 | </div> | 
|  | 40 |  | 
|  | 41 | <!-- | 
|  | 42 | <h1 style="color:red">These are in-progress notes for the upcoming LLVM 3.0 | 
|  | 43 | release.<br> | 
|  | 44 | You may prefer the | 
|  | 45 | <a href="http://llvm.org/releases/2.9/docs/ReleaseNotes.html">LLVM 2.9 | 
|  | 46 | Release Notes</a>.</h1> | 
|  | 47 | --> | 
|  | 48 |  | 
|  | 49 | <!-- ======================================================================= --> | 
|  | 50 | <h2 id="intro">Introduction</h2> | 
|  | 51 | <!-- ======================================================================= --> | 
|  | 52 |  | 
|  | 53 | <p>This document contains the release notes for the Clang C/C++/Objective-C | 
|  | 54 | frontend, part of the LLVM Compiler Infrastructure, release 3.0.  Here we | 
|  | 55 | describe the status of Clang in some detail, including major improvements from | 
|  | 56 | the previous release and new feature work. For the general LLVM release notes, | 
|  | 57 | see <a href ="http;//llvm.org/docs/ReleaseNotes.html">the LLVM | 
|  | 58 | documentation</a>. All LLVM releases may be downloaded from the | 
|  | 59 | <a href="http://llvm.org/releases/">LLVM releases web site</a>.</p> | 
|  | 60 |  | 
|  | 61 | <p>For more information about Clang or LLVM, including information about the | 
|  | 62 | latest release, please check out the main please see the | 
|  | 63 | <a href="http://clang.llvm.org">Clang Web Site</a> or the | 
|  | 64 | <a href="http://llvm.org">LLVM Web Site</a>. | 
|  | 65 |  | 
|  | 66 | <p>Note that if you are reading this file from a Subversion checkout or the main | 
|  | 67 | Clang web page, this document applies to the <i>next</i> release, not the | 
|  | 68 | current one.  To see the release notes for a specific release, please see the | 
|  | 69 | <a href="http://llvm.org/releases/">releases page</a>.</p> | 
|  | 70 |  | 
|  | 71 | <!-- ======================================================================= --> | 
|  | 72 | <h2 id="whatsnew">What's New in Clang 3.0?</h2> | 
|  | 73 | <!-- ======================================================================= --> | 
|  | 74 |  | 
|  | 75 | <p>Some of the major new features and improvements to Clang are listed here. | 
|  | 76 | Generic improvements to Clang as a whole or two its underlying infrastructure | 
|  | 77 | are described first, followed by language-specific sections with improvements to | 
|  | 78 | Clang's support for those languages.</p> | 
|  | 79 |  | 
|  | 80 | <!-- = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = --> | 
|  | 81 | <h3 id="majorfeatures">Major New Features</h3> | 
|  | 82 | <!-- = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = --> | 
|  | 83 |  | 
| Chandler Carruth | a3950cc | 2011-11-28 08:41:06 +0000 | [diff] [blame] | 84 | <h4 id="notes">Unorganized Notes</h4> | 
|  | 85 | <p>These are completely random notes as I'm organizing my thoughts and reviewing | 
|  | 86 | the history. Anything still here needs to be distilled and turned into proper | 
|  | 87 | prose in a section of its own. When doing that, delete the notes.</p> | 
|  | 88 | <ul> | 
|  | 89 | <li>Make analyzer (especially as used w/ warnings in Clang) much faster</li> | 
|  | 90 | <li>OpenCL support -- need details from Tanya and Peter -- separate language | 
|  | 91 | section?</li> | 
|  | 92 | <li>Building Clang on windows -- mingw, 32 and 64 bit, native windows builds, | 
|  | 93 | cygwin. get chapuni to flesh out details.</li> | 
| Chandler Carruth | 1af4022 | 2011-11-28 09:43:30 +0000 | [diff] [blame] | 94 | <li>Compiling C/C++ w/ MinGW (32/64) and Cygwin on Windows -- chapuni</li> | 
|  | 95 | <li>C++ -- Parsing and AST support for Windows Structured Exception | 
|  | 96 | Handling.</li> | 
| Chandler Carruth | a3950cc | 2011-11-28 08:41:06 +0000 | [diff] [blame] | 97 | <li>C++11 -- noexcept (Sebastian Redl)</li> | 
|  | 98 | <li>Uninitialized values Clang warning rewrite -- more accurate, faster, able | 
|  | 99 | to differentiate between the possibility of an uninitialized use and the | 
|  | 100 | certainty of an uninitialized use.</li> | 
|  | 101 | <li>Enhancements to PPCallbacks | 
|  | 102 | <ul> | 
| Chandler Carruth | 7717ce4 | 2011-11-28 12:24:23 +0000 | [diff] [blame] | 103 | <li>exact include paths</li> | 
|  | 104 | <li>source range for macro expansions</li> | 
| Chandler Carruth | a3950cc | 2011-11-28 08:41:06 +0000 | [diff] [blame] | 105 | </ul> | 
|  | 106 | </li> | 
|  | 107 | <li>Support for language specific address spaces</li> | 
| Chandler Carruth | 1af4022 | 2011-11-28 09:43:30 +0000 | [diff] [blame] | 108 | <li>Support for compiling on NetBSD systems -- Joerg Sonnenberger to fill | 
|  | 109 | out</li> | 
| Chandler Carruth | a3950cc | 2011-11-28 08:41:06 +0000 | [diff] [blame] | 110 | <li>Support for '--sysroot' based cross-compilation</li> | 
|  | 111 | <li>Crash recovery handling for libclang clients -- Ted</li> | 
|  | 112 | <li>Driver support for automatic preparation of reproduction steps for | 
|  | 113 | compiler crashes -- Chad</li> | 
|  | 114 | <li>OS Availability attribute -- r128127</li> | 
|  | 115 | <li>GNU ObjectiveC Runtime support -- David Chisnall</li> | 
|  | 116 | <li>C++11 -- override</li> | 
|  | 117 | <li>Diagnostic improvements bucket? | 
|  | 118 | <ul> | 
|  | 119 | <li>Emitting fewer include stacks</li> | 
| Chandler Carruth | 1af4022 | 2011-11-28 09:43:30 +0000 | [diff] [blame] | 120 | <li>Significantly better recovery when encountering misspelled type names | 
|  | 121 | in a declaration context. r130082</li> | 
| Chandler Carruth | b6a1d9d | 2011-11-28 11:27:33 +0000 | [diff] [blame] | 122 | <li>Expanded typo correction, most especially namespace-aware typo | 
|  | 123 | correction in C++</li> | 
| Chandler Carruth | 5d46a50 | 2011-11-28 12:24:21 +0000 | [diff] [blame] | 124 | <li>Significantly more rich diagnostics w.r.t. macro expansion backtraces, | 
|  | 125 | especially when macro arguments are involved.</li> | 
| Chandler Carruth | a3950cc | 2011-11-28 08:41:06 +0000 | [diff] [blame] | 126 | </ul> | 
|  | 127 | </li> | 
| Douglas Gregor | 7c304c4 | 2011-11-28 17:50:36 +0000 | [diff] [blame] | 128 | <li>libclang improvements bucket | 
| Chandler Carruth | 7717ce4 | 2011-11-28 12:24:23 +0000 | [diff] [blame] | 129 | <ul> | 
|  | 130 | <li>Better Python Bindings</li> | 
|  | 131 | <li>More AST coverage</li> | 
|  | 132 | <li>Improved cursor support within macros, especially function-style macro | 
|  | 133 | arguments.</li> | 
|  | 134 | <li>Improved code completion surrounding macros, macro arguments, and | 
|  | 135 | token pasting.</li> | 
| Douglas Gregor | 7c304c4 | 2011-11-28 17:50:36 +0000 | [diff] [blame] | 136 | <li>Improved code completion for in-class member functions.</li> | 
| Chandler Carruth | 7717ce4 | 2011-11-28 12:24:23 +0000 | [diff] [blame] | 137 | </ul> | 
|  | 138 | </li> | 
| Chandler Carruth | a3950cc | 2011-11-28 08:41:06 +0000 | [diff] [blame] | 139 | <li>C++ -- supported in the static analyzer: methods, new, constructors, | 
|  | 140 | destructors, etc.</li> | 
| Chandler Carruth | 1af4022 | 2011-11-28 09:43:30 +0000 | [diff] [blame] | 141 | <li>Improved AST support for partially constructed nodes and incomplete | 
|  | 142 | information for LLDB and other clients which dynamically build AST nodes.</li> | 
|  | 143 | <li>Largely complete MSVC-compatible parsing mode -- fpichet</li> | 
|  | 144 | <li>C1X -- static asserts and generic selections</li> | 
|  | 145 | <li>C++11 -- alias declarations -- zygoloid</li> | 
|  | 146 | <li>C++11 -- range-based-for loops -- zygoloid</li> | 
| Chandler Carruth | bba72a8 | 2011-11-28 10:57:14 +0000 | [diff] [blame] | 147 | <li>C++11 -- nullptr -- zygoloid</li> | 
| Chandler Carruth | b6a1d9d | 2011-11-28 11:27:33 +0000 | [diff] [blame] | 148 | <li>C++11 -- in-class init -- zygoloid</li> | 
| Chandler Carruth | 7717ce4 | 2011-11-28 12:24:23 +0000 | [diff] [blame] | 149 | <li>C++11 -- raw string literals -- zygoloid</li> | 
| Douglas Gregor | 7c304c4 | 2011-11-28 17:50:36 +0000 | [diff] [blame] | 150 | <li>C++11 -- delegating ctors -- zygoloid/scshunt</li> | 
| Chandler Carruth | 1af4022 | 2011-11-28 09:43:30 +0000 | [diff] [blame] | 151 | <li>Memory reduction -- initializers, macro expansions, source locations, | 
|  | 152 | etc.</li> | 
|  | 153 | <li>Full set of type traits, sufficient to support C++11 standard libraries; | 
|  | 154 | also expression traits.</li> | 
| Chandler Carruth | bba72a8 | 2011-11-28 10:57:14 +0000 | [diff] [blame] | 155 | <li>CFI-based debug info -- nlewycky/espindola details</li> | 
| Chandler Carruth | b6a1d9d | 2011-11-28 11:27:33 +0000 | [diff] [blame] | 156 | <li>ObjC ARC -- get a blurb from rjmccall</li> | 
| Douglas Gregor | a1e3e8c | 2011-11-28 17:51:39 +0000 | [diff] [blame] | 157 | <li>ObjC related result type/instancetype</li> | 
| Chandler Carruth | 7717ce4 | 2011-11-28 12:24:23 +0000 | [diff] [blame] | 158 | <li>Thread Safety attributes and correctness analysis added to Clang.</li> | 
| Chandler Carruth | 7a1f148 | 2011-11-28 13:02:29 +0000 | [diff] [blame] | 159 | <li>API -- Many opaque typedefs in Sema around AST nodes are gone.</li> | 
|  | 160 | <li>NRVO for blocks.</li> | 
|  | 161 | <li>Major improvements to the interactions between serializing and | 
|  | 162 | deserializing the AST and the preprocessor -- argiris</li> | 
| Chandler Carruth | 7a1f148 | 2011-11-28 13:02:29 +0000 | [diff] [blame] | 163 | <li>Major driver and system compatibility changes: | 
|  | 164 | <ul> | 
|  | 165 | <li>Correct support for many more hardware architecture pre-defined macros | 
|  | 166 | (e.g., __i686__).</li> | 
|  | 167 | <li>Much more robust detection of library and header search paths on Linux | 
|  | 168 | distributions.</li> | 
|  | 169 | <li>Partial support for sysroot based cross compiling on Linux (like) | 
|  | 170 | systems.</li> | 
|  | 171 | <li>Improved support for locating and using libcxx, especially on | 
|  | 172 | Darwin.</li> | 
|  | 173 | </ul> | 
|  | 174 | </li> | 
|  | 175 | <li>Initial steps of CUDA support -- Peter</li> | 
|  | 176 | <li>Atomic builtins and C1X specifiers using the new LLVM atomic instructions | 
|  | 177 | and memory model -- efriedma, jyasskin</li> | 
| Chandler Carruth | a3950cc | 2011-11-28 08:41:06 +0000 | [diff] [blame] | 178 | </ul> | 
|  | 179 |  | 
| Chandler Carruth | c00c0c3 | 2011-11-28 07:16:19 +0000 | [diff] [blame] | 180 | <!-- = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = --> | 
|  | 181 | <h3 id="cchanges">C Language Changes in Clang</h3> | 
|  | 182 | <!-- = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = --> | 
|  | 183 |  | 
|  | 184 | <!-- = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = --> | 
|  | 185 | <h3 id="cxxchanges">C++ Language Changes in Clang</h3> | 
|  | 186 | <!-- = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = --> | 
|  | 187 |  | 
|  | 188 | <!-- = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = --> | 
|  | 189 | <h3 id="objcchanges">Objective-C Language Changes in Clang</h3> | 
|  | 190 | <!-- = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = --> | 
|  | 191 |  | 
|  | 192 | <!-- = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = --> | 
|  | 193 | <h3 id="apichanges">Internal API Changes</h3> | 
|  | 194 | <!-- = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = --> | 
|  | 195 |  | 
| Chandler Carruth | c4dbffa | 2011-11-28 18:55:47 +0000 | [diff] [blame] | 196 | These are major API changes that have happened since the 2.9 release of Clang. | 
|  | 197 | If upgrading an external codebase that uses Clang as a library, this section | 
|  | 198 | should help get you past the largest hurdles of upgrading. | 
|  | 199 |  | 
| Chandler Carruth | 7d727b7 | 2011-11-28 19:06:34 +0000 | [diff] [blame^] | 200 | <h4 id="macroexpansion">Switched terminology from "instantiation" to "expansion" | 
|  | 201 | for macros</h4> | 
|  | 202 | A great deal of comments and code changes fell out of this, but also every API | 
|  | 203 | relating to macros with the word "instantiation" (or some variant thereof) was | 
|  | 204 | renamed. An incomplete list of the most note-worthy ones is here: | 
|  | 205 | <ul> | 
|  | 206 | <li><code>MacroInstantiation</code> became <code>MacroExpansion</code></li> | 
|  | 207 | <li><code>SourceManager::getInstantiationLoc</code> became | 
|  | 208 | <code>SourceManager::getExpansionLoc</code></li> | 
|  | 209 | <li><code>SourceManager::getInstantiationRange</code> became | 
|  | 210 | <code>SourceManager::getExpansionRange</code></li> | 
|  | 211 | <li><code>SourceManager::getImmediateInstantiationRange</code> became | 
|  | 212 | <code>SourceManager::getImmediateExpansionRange</code></li> | 
|  | 213 | <li><code>SourceManager::getDecomposedInstantiationLoc</code> became | 
|  | 214 | <code>SourceManager::getDecomposedExpansionLoc</code></li> | 
|  | 215 | <li><code>SourceManager::getInstantiationColumnNumber</code> became | 
|  | 216 | <code>SourceManager::getExpansionColumnNumber</code></li> | 
|  | 217 | <li><code>SourceManager::getInstantiationLineNumber</code> became | 
|  | 218 | <code>SourceManager::getExpansionLineNumber</code></li> | 
|  | 219 | <!-- TODO: Make this more complete! --> | 
|  | 220 | </ul> | 
|  | 221 |  | 
| Chandler Carruth | c4dbffa | 2011-11-28 18:55:47 +0000 | [diff] [blame] | 222 | <h4 id="diagnosticrename">Diagnostic class names were shuffled</h4> | 
|  | 223 | <ul> | 
|  | 224 | <li><code>Diagnostic</code> became <code>DiagnosticEngine</code></li> | 
|  | 225 | <li><code>DiagnosticClient</code> became <code>DiagnosticConsumer</code></li> | 
|  | 226 | <li><code>DiagnosticInfo</code> became <code>Diagnostic</code></li> | 
|  | 227 | </ul> | 
|  | 228 | Subclasses of <code>DiagnosticConsumer</code> were also then renamed to end with | 
|  | 229 | <code>Consumer</code>. | 
|  | 230 |  | 
| Chandler Carruth | c00c0c3 | 2011-11-28 07:16:19 +0000 | [diff] [blame] | 231 | <!-- ======================================================================= --> | 
|  | 232 | <h2 id="knownproblems">Significant Known Problems</h2> | 
|  | 233 | <!-- ======================================================================= --> | 
|  | 234 |  | 
|  | 235 | <!-- ======================================================================= --> | 
|  | 236 | <h2 id="additionalinfo">Additional Information</h2> | 
|  | 237 | <!-- ======================================================================= --> | 
|  | 238 |  | 
|  | 239 | <p>A wide variety of additional information is available on the | 
|  | 240 | <a href="http://clang.llvm.org/">Clang web page</a>.  The web page contains | 
|  | 241 | versions of the API documentation which are up-to-date with the Subversion | 
|  | 242 | version of the source code.  You can access versions of these documents specific | 
|  | 243 | to this release by going into the "<tt>clang/doc/</tt>" directory in the Clang | 
|  | 244 | tree.</p> | 
|  | 245 |  | 
|  | 246 | <p>If you have any questions or comments about Clang, please feel free to | 
|  | 247 | contact us via the <a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev"> | 
|  | 248 | mailing list</a>.</p> | 
|  | 249 |  | 
|  | 250 | </body> | 
|  | 251 | </html> |