Review Request 121757: Use target environment whenever available, and implement TU pinning (WIP)

Olivier Jean de Gaalon olivier.jg at gmail.com
Mon Jan 5 15:13:31 UTC 2015


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/121757/
-----------------------------------------------------------

(Updated Jan. 5, 2015, 3:13 p.m.)


Review request for KDevelop, Kevin Funk and Milian Wolff.


Changes
-------

More complete implementation.

Probably could be (very nicely) improved by rescheduling low-quality environments after higher quality ones.


Repository: kdev-clang


Description
-------

Note: This requires IBuildSystemManager::hasIncludesOrDefines, which should probably be renamed to isTranslationUnit()

The idea here is to use the AST of the buildsystem's translation units wherever possible, since that's the only file that's guaranteed to have correct defines and includes (and furthermore can handle strange cases such as '#include inside namespace' and picky include/define ordering).
This proposal essentially allows TU environments to override non-TU environments and then get "pinned" so that the non-TU will continue to use the TU AST to build its duchain.
This could eventually be exposed in the UI, allowing the user to pick different "views" of headers (overriding the pinned TU).
The pinning data needs to be fleshed out to handle expiry (header no longer included) and be serialized with an ItemRepository.

I'm looking for feedback on this idea... where does it break? Any better ideas?

This more or less works, we can flesh it out more if we want to take this route.


Diffs (updated)
-----

  tests/clang-parser.cpp 3f87d05 
  duchain/tuduchain.h dfcc439 
  duchain/tuduchain.cpp 33a0570 
  duchain/clangindex.cpp 02c93cf 
  duchain/clangparsingenvironment.h 7bb8111 
  duchain/clangparsingenvironment.cpp 1decc14 
  duchain/clangparsingenvironmentfile.h 953ee94 
  duchain/clangparsingenvironmentfile.cpp b3d0563 
  duchain/clangpch.cpp 1ce3457 
  duchain/debugvisitor.cpp be8debf 
  duchain/parsesession.h b688fb1 
  duchain/parsesession.cpp f41768a 
  tests/test_duchain.cpp 7db9fea 
  tests/test_problems.cpp 09018d1 
  clangparsejob.h 1cc8282 
  clangparsejob.cpp 297b836 
  codecompletion/completionhelper.cpp f5ed2b9 
  codecompletion/context.cpp 33c3391 
  codegen/clangsignatureassistant.cpp 9ea1f5b 
  duchain/clanghelpers.h 4216454 
  duchain/clanghelpers.cpp 5f29a2a 
  duchain/clangindex.h 991c7ca 

Diff: https://git.reviewboard.kde.org/r/121757/diff/


Testing
-------

Tests fail in the same manner as before


File Attachments
----------------

kdevelop patch
  https://git.reviewboard.kde.org/media/uploaded/files/2015/01/02/5c0314bf-f241-4ad0-93f6-9a0a48a79135__kdevelop-hasincordef.diff
platform patch
  https://git.reviewboard.kde.org/media/uploaded/files/2015/01/02/edc11881-06c6-4570-9afd-824a99687116__kdevplatform-hasincordef.diff


Thanks,

Olivier Jean de Gaalon

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kdevelop-devel/attachments/20150105/16535d6a/attachment-0001.html>


More information about the KDevelop-devel mailing list