Skip to content
  1. Jul 13, 2009
  2. Jul 11, 2009
    • Steve Naroff's avatar
      This patch includes a conceptually simple, but very intrusive/pervasive change. · 7cae42b0
      Steve Naroff authored
      The idea is to segregate Objective-C "object" pointers from general C pointers (utilizing the recently added ObjCObjectPointerType). The fun starts in Sema::GetTypeForDeclarator(), where "SomeInterface *" is now represented by a single AST node (rather than a PointerType whose Pointee is an ObjCInterfaceType). Since a significant amount of code assumed ObjC object pointers where based on C pointers/structs, this patch is very tedious. It should also explain why it is hard to accomplish this in smaller, self-contained patches.
      
      This patch does most of the "heavy lifting" related to moving from PointerType->ObjCObjectPointerType. It doesn't include all potential "cleanups". The good news is additional cleanups can be done later (some are noted in the code). This patch is so large that I didn't want to include any changes that are purely aesthetic.
      
      By making the ObjC types truly built-in, they are much easier to work with (and require fewer "hacks"). For example, there is no need for ASTContext::isObjCIdStructType() or ASTContext::isObjCClassStructType()! We believe this change (and the follow-up cleanups) will pay dividends over time. 
      
      Given the amount of code change, I do expect some fallout from this change (though it does pass all of the clang tests). If you notice any problems, please let us know asap! Thanks.
      
      llvm-svn: 75314
      7cae42b0
  3. Jul 10, 2009
  4. Jul 06, 2009
  5. Jun 30, 2009
    • Argyrios Kyrtzidis's avatar
      De-ASTContext-ify DeclContext. · cfbfe78e
      Argyrios Kyrtzidis authored
      Remove ASTContext parameter from DeclContext's methods. This change cascaded down to other Decl's methods and changes to call sites started "escalating".
      Timings using pre-tokenized "cocoa.h" showed only a ~1% increase in time run between and after this commit.
      
      llvm-svn: 74506
      cfbfe78e
    • Chris Lattner's avatar
      Key decisions about 'bool' vs '_Bool' to be based on a new flag in langoptions. · c61089a6
      Chris Lattner authored
      This is simple enough, but then I thought it would be nice to make PrintingPolicy
      get a LangOptions so that various things can key off "bool" and "C++" independently.
      This spiraled out of control.  There are many fixme's, but I think things are slightly
      better than they were before.
      
      One thing that can be improved: CFG should probably have an ASTContext pointer in it,
      which would simplify its clients.
      
      llvm-svn: 74493
      c61089a6
  6. Jun 26, 2009
  7. Jun 24, 2009
  8. Jun 18, 2009
    • Steve Naroff's avatar
      First step toward fixing <rdar://problem/6613046> refactor clang objc type representation. · fb4330f2
      Steve Naroff authored
      Add a type (ObjCObjectPointerType) and remove a type (ObjCQualifiedIdType).
      
      This large/tedious patch is just a first step. Next step is to remove ObjCQualifiedInterfaceType. After that, I will remove the magic TypedefType for 'id' (installed by Sema). This work will enable various simplifications throughout clang (when dealing with ObjC types). 
      
      No functionality change.
      
      llvm-svn: 73649
      fb4330f2
  9. Jun 16, 2009
  10. May 29, 2009
  11. May 26, 2009
  12. May 21, 2009
  13. May 18, 2009
  14. May 14, 2009
  15. May 05, 2009
  16. May 04, 2009
  17. May 02, 2009
  18. Apr 28, 2009
  19. Apr 26, 2009
  20. Apr 23, 2009
  21. Apr 22, 2009
  22. Apr 19, 2009
  23. Apr 17, 2009
  24. Apr 09, 2009
  25. Apr 08, 2009
    • Devang Patel's avatar
      Use presumed location to get line number info. · 2ac33a08
      Devang Patel authored
      llvm-svn: 68630
      2ac33a08
    • Daniel Dunbar's avatar
      Make debug info work when using -save-temps. · 3b358a3d
      Daniel Dunbar authored
       - This is pretty ugly, but the most obvious solution. Chime in if you
         have a nicer one.
      
       - The problem is that with -save-temps, clang-cc has no idea what the
         name of the original input file is. However, the user expects to be
         able to set breakpoints based on the input file name.
      
       - We support this by providing a new option -main-file-name (similar
         to -dumpbase used by gcc) which allows the driver to pass in the
         original file name.
      
       - <rdar://problem/6753383> building with clang using --save-temps
         gets the compile unit name from the .i file...
      
      llvm-svn: 68595
      3b358a3d
  26. Apr 01, 2009
  27. Mar 31, 2009
    • Douglas Gregor's avatar
      Improve the representation of template names in the AST. This · dc572a32
      Douglas Gregor authored
      representation handles the various ways in which one can name a
      template, including unqualified references ("vector"), qualified
      references ("std::vector"), and dependent template names
      ("MetaFun::template apply").
      
      One immediate effect of this change is that the representation of
      nested-name-specifiers in type names for class template
      specializations (e.g., std::vector<int>) is more accurate. Rather than
      representing std::vector<int> as
      
        std::(vector<int>)
      
      we represent it as
      
        (std::vector)<int>
      
      which more closely follows the C++ grammar. 
      
      Additionally, templates are no longer represented as declarations
      (DeclPtrTy) in Parse-Sema interactions. Instead, I've introduced a new
      OpaquePtr type (TemplateTy) that holds the representation of a
      TemplateName. This will simplify the handling of dependent
      template-names, once we get there.
      
      llvm-svn: 68074
      dc572a32
  28. Mar 28, 2009
Loading