Skip to content
  1. Mar 27, 2013
  2. Mar 26, 2013
  3. Mar 25, 2013
  4. Mar 20, 2013
  5. Mar 19, 2013
    • Edwin Vane's avatar
      Don't replace macro usage if macro body has NULL · c383960b
      Edwin Vane authored
      In case of macro body expansion, check to see if the macro is named NULL and
      don't replace inside the macro body. This fixes the case when NULL appears
      inside the macro body and the transform replaces the usage of the macro with
      nullptr. This is an easy fix for the problem for now and we should analyze the
      macro body to see if it expands to only NullToPointer in the future for a more
      robust solution that takes care of user defined macros that behaves like NULL.
      
      Other changes:
      - Moved complex macro tests to macros.cpp
      - Added new test cases.
      - Added checks to make sure that the macro bodies are not modified by the tool.
      
      Fixes: PR15396
      
      Author: Tareq A Siraj <tareq.a.siraj@intel.com>
      llvm-svn: 177422
      c383960b
  6. Mar 15, 2013
    • Edwin Vane's avatar
      Don't include outer-most explicit cast in nullptr replacement · 2032fb97
      Edwin Vane authored
      The outer-most explicit cast is now left alone by the Use-Nullptr transform to
      maintain the type of the expression and avoid introducing ambiguities.
      
      Fixes PR15395.
      
      Author: Ariel J Bernal <ariel.j.bernal@intel.com>
      llvm-svn: 177179
      2032fb97
    • Edwin Vane's avatar
      Prevent nullptr_t-typed exprs from being replaced · 52c326ec
      Edwin Vane authored
      The Use-Nullptr transform was replacing nullptr_t-typed expressions because in
      the AST such expressions have an implicit NullToPointer cast around them. Now
      the transform ignores these expressions.
      
      Fixes PR15414.
      
      llvm-svn: 177168
      52c326ec
  7. Mar 14, 2013
  8. Mar 12, 2013
  9. Mar 09, 2013
  10. Mar 08, 2013
  11. Mar 07, 2013
    • Edwin Vane's avatar
      Have LoopConvert use 'auto &&' where necessary · 4f05d714
      Edwin Vane authored
      For iterators where the dereference operator returns by value, LoopConvert
      should use 'auto &&' in the range-based for loop expression.
      
      If the dereference operator returns an rvalue reference, this is deemed too
      strange and the for loop is not converted.
      
      Moved test case from iterator_failing.cpp to iterator.cpp and added extra
      tests.
      
      Fixes PR15437.
      
      Reviewer: gribozavr
      llvm-svn: 176631
      4f05d714
    • Chandler Carruth's avatar
      Switch from autogenerating tests to using the preprocessor. · 074a3568
      Chandler Carruth authored
      NOTE: You may need to run 'make clean' or 'ninja -t clean' etc!!! This
            is due to really nasty bug/interactions between
            CMake/configure/make/Ninja/LIT...
      
      This commit tries to back out the support for generating test cases as
      part of the build system due to the issues I brought up in post-commit
      review:
      
      1) It adds a *lot* of complexity and fragility to the build system. See
         the number of commits required to try to get all the bots happy.
      2) It isn't really necessary -- we can already run scripts to generate
         things with the RUN lines of a test.
      3) It makes the tests somewhat harder to debug as they cross between
         more domains.
      4) In almost all cases it isn't really needed or it can be done directly
         using the preprocessor.
      
      I should have been more proactive reviewing this, and I'm really sorry
      about the churn here. =/ To help keep track of what commits are going
      where, this backs out most of the non-test-changes from these revisions:
        r176397
        r176373
        r176293
        r176184
        r175744
        r175624
        r175545
        r175544
      
      There were several trivial or cleanup changes to the lit files or other
      files. Some of these looked ok, but I didn't try to tease them apart...
      Edwin, if you know what to look for, please carry on with the cleanups
      there, and sorry for hosing stuff here but I'm not much of a Python
      person, and so I was erring on the side of cautiously backing out the
      change.
      
      I've tried to preserve the test changes everywhere I could, but review
      is appreciated here in case I missed some.
      
      I then re-wrote the tests to use the preprocessor rather than python to
      expand to the various bits of code. The nicest part of this is that now
      all the files are just C++ code. They edit and behave like C++ code,
      etc. RUN lines with different -D flags are used to run the same test
      over multiple different configurations, and includes bracketed in
      special defines are used to flesh out a collection of standard interface
      stubs to test interactions between pieces. These probably aren't perfect
      yet, but I think its an improvement (at least in terms of build system
      complexity) and will hopefully be a useful demonstration of the
      technique I prefer for these types of tests.
      
      llvm-svn: 176627
      074a3568
  12. Mar 06, 2013
    • Stefanus Du Toit's avatar
      Test case for PR-15414 - nullptr_t functions · 49fe6388
      Stefanus Du Toit authored
         
      The use-null-ptr transform will transform calls to functions that return a
      nullptr_t. Even if the function were to only return a null pointer and do
      nothing else, this replacement would still be undesired as the behavior and
      signature of the function could change in the future.
      
      This adds an XFAILed test case to demonstrate the issue.
      
      Reviewed by: Edwin Vane, Tareq Siraj
      
      llvm-svn: 176553
      49fe6388
    • Edwin Vane's avatar
      Fixed Use-Nullptr when replacing return(0) · 105963d1
      Edwin Vane authored
      Before fix, the paren expression was being replaced resulting in returnnullptr.
      ParenExpr and implicit casts now ignored so we get return(nullptr) instead.
      
      Added new test cases.
      
      Fixes PR15398
      
      Author: Ariel Bernal <ariel.j.bernal@intel.com>
      llvm-svn: 176551
      105963d1
  13. Mar 05, 2013
  14. Mar 04, 2013
  15. Mar 03, 2013
    • Sean Silva's avatar
      .gitignore: ignore docs/_build · 206bc114
      Sean Silva authored
      That is where the documentation gets built to.
      
      I'm pretty much clueless about SVN; I would appreciate if someone more
      knowledgeable about SVN made the equivalent change.
      
      llvm-svn: 176417
      206bc114
  16. Mar 02, 2013
  17. Mar 01, 2013
    • Edwin Vane's avatar
      Avoid parallelism problems generating lit.site.cfgs · a98217a2
      Edwin Vane authored
      extra/test/cpp11-migrate/Makefile was using the same tmp file for generating
      lit.site.cfg for two different directories. Parallelism caused conflicts so now
      using differently named temp files.
      
      llvm-svn: 176379
      a98217a2
Loading