Skip to content
  1. Mar 02, 2012
  2. Dec 15, 2011
    • Richard Trieu's avatar
      Modify how the -verify flag works. Currently, the verification string and · 553b2b2e
      Richard Trieu authored
      diagnostic message are compared.  If either is a substring of the other, then
      no error is given.  This gives rise to an unexpected case:
      
        // expect-error{{candidate function has different number of parameters}}
      
      will match the following error messages from Clang:
      
        candidate function has different number of parameters (expected 1 but has 2)
        candidate function has different number of parameters
      
      It will also match these other error messages:
      
        candidate function
        function has different number of parameters
        number of parameters
      
      This patch will change so that the verification string must be a substring of
      the diagnostic message before accepting.  Also, all the failing tests from this
      change have been corrected.  Some stats from this cleanup:
      
      87 - removed extra spaces around verification strings
      70 - wording updates to diagnostics
      40 - extra leading or trailing characters (typos, unmatched parens or quotes)
      35 - diagnostic level was included (error:, warning:, or note:)
      18 - flag name put in the warning (-Wprotocol)
      
      llvm-svn: 146619
      553b2b2e
  3. Dec 09, 2011
    • Richard Smith's avatar
      Replace the implementation of __builtin_constant_p (which was based on the GCC · 10c7c909
      Richard Smith authored
      documentation) with one based on what GCC's __builtin_constant_p is actually
      intended to do (discovered by asking a friendly GCC developer).
      
      In particular, an expression which folds to a pointer is now only considered to
      be a "constant" by this builtin if it refers to the first character in a string
      literal.
      
      This fixes a rather subtle wrong-code issue when building with glibc. Given:
      
      const char cs[4] = "abcd";
      int f(const char *p) { return strncmp(p, cs, 4); }
      
      ... the macro magic for strncmp produces a (potentially crashing) call to
      strlen(cs), because it expands to an expression starting with:
      
        __builtin_constant_p(cs) && strlen(cs) < 4 ? /* ... */
      
      Under the secret true meaning of __builtin_constant_p, this is guaranteed to be
      safe!
      
      llvm-svn: 146236
      10c7c909
  4. Dec 06, 2011
  5. Mar 15, 2011
  6. Oct 15, 2010
  7. Oct 12, 2010
  8. Sep 07, 2010
  9. Aug 25, 2010
  10. Jul 28, 2010
  11. Jul 27, 2010
  12. Jul 18, 2010
    • Chandler Carruth's avatar
      Improve the representation of the atomic builtins in a few ways. First, we make · bc8cab16
      Chandler Carruth authored
      their call expressions synthetically have the "deduced" types based on their
      first argument. We only insert conversions in the AST for arguments whose
      values require conversion to match the value type expected. This keeps PR7600
      closed by maintaining the return type, but avoids assertions due to unexpected
      implicit casts making the type unsigned (test case added from Daniel).
      
      The magic is moved into the codegen for the atomic builtin which inserts the
      casts as needed at the IR level to raise the type to an integer suitable for
      the LLVM intrinsic. This shouldn't cause any real change in functionality, but
      now we can make the builtin be more truly polymorphic.
      
      llvm-svn: 108638
      bc8cab16
  13. Jul 09, 2010
  14. Apr 19, 2010
  15. Apr 17, 2010
  16. Dec 30, 2009
  17. Dec 15, 2009
  18. Sep 28, 2009
  19. Sep 26, 2009
  20. Sep 23, 2009
  21. Sep 21, 2009
  22. Jul 22, 2009
  23. Jun 06, 2009
  24. May 08, 2009
  25. Apr 28, 2009
    • Eli Friedman's avatar
      Simplify the scheme used for keywords, and change the classification · 2b680b43
      Eli Friedman authored
      scheme to be more useful.
      
      The new scheme introduces a set of categories that should be more 
      readable, and also reflects what we want to consider as an extension 
      more accurately.  Specifically, it makes the "what is a keyword" 
      determination accurately reflect whether the keyword is a GNU or 
      Microsoft extension.
      
      I also introduced separate flags for keyword aliases; this is useful 
      because the classification of the aliases is mostly unrelated to the 
      classification of the original keyword.
      
      This patch treats anything that's in the implementation 
      namespace (prefixed with "__", or "_X" where "X" is any upper-case 
      letter) as a keyword without marking it as an extension.  This is 
      consistent with the standards in that an implementation is allowed to define 
      arbitrary extensions in the implementation namespace without violating 
      the standard. This gets rid of all the nasty "extension used" warnings 
      for stuff like __attribute__ in -pedantic mode.  We still warn for 
      extensions outside of the the implementation namespace, like typeof.
      If someone wants to implement -Wextensions or something like that, we 
      could add additional information to the keyword table.
      
      This also removes processing for the unused "Boolean" language option; 
      such an extension isn't supported on any other C implementation, so I 
      don't see any point to adding it.
      
      The changes to test/CodeGen/inline.c are required because previously, we 
      weren't actually disabling the "inline" keyword in -std=c89 mode.
      
      I'll remove Boolean and NoExtensions from LangOptions in a follow-up 
      commit.
      
      llvm-svn: 70281
      2b680b43
  26. Apr 02, 2009
  27. Mar 24, 2009
  28. Nov 21, 2008
  29. May 25, 2008
  30. May 06, 2008
  31. Jan 04, 2008
  32. Dec 20, 2007
Loading