Review Request: CPP: build switch context, give "case <cursor>" special completion
David Nolden
david.nolden.kde at art-master.de
Sun Jun 26 12:19:24 UTC 2011
> On June 18, 2011, 11:30 a.m., David Nolden wrote:
> > languages/cpp/codecompletion/context.cpp, line 1372
> > <http://git.reviewboard.kde.org/r/101671/diff/1/?file=24688#file24688line1372>
> >
> > This will cause deadlocks (see the comment at the top of foregroundlock.h), because the duchain-lock is held.
> >
> > Qt-4.8 won't help too, as it will cause the same deadlock.
> >
> > You can use the ForegroundLock to get the required information, but you have to move the code out of the context where the duchain-lock is held. You have to make sure that the duchain-objects stay valid for the time you unlock the duchain-lock, you can use IndexedDeclaration or IndexedDUContext or similar for that.
> >
> > As you have to access the foreground synchronously anyway, you don't need to change DocumentAccess. You can simply do "PersistentMovingRange r = context->createMovingRange(); unlock duchain; ForegroundLock lock; text = r->text();" to get the text
>
> Olivier Jean de Gaalon wrote:
> Ok, I'll rewrite that part accordingly.
> BTW, I was referring to this: http://bugreports.qt.nokia.com/browse/QTBUG-10440
> Which means that it should be doing the same thing as the DocumentAccess's replaceCurrentAccess function, using a BlockingQueuedConnection.
>
> Olivier Jean de Gaalon wrote:
> Hrm, I don't see how one can get the text from a PersistentMovingRange (no text() function, at least).
> Also I get an assert "KDevelop::ForegroundLock::isLockedForThread()" if I attempt to create a PersistentMovingRange without holding the ForegroundLock.
>
>
> David Nolden wrote:
> I added the function yesterday
>
> Olivier Jean de Gaalon wrote:
> This is a little problematic.
> If I try to createRangeMoving() with the DUChain lock and without the Foreground lock, I run into the assert at duchainbase.cpp:173.
> If I try to createRangeMoving() with the Foreground lock and without the DUChain lock, I run into the assert at parsingenvironment.cpp:364
>
> Milian Wolff wrote:
> David, any input for Olivier?
Well, it might become a bit unpretty, but should be possible: You can lock the duchain when holding the foreground-lock, so here's the order:
IndexedDeclaration mydecl = decl;
unlock duchain;
lock foreground;
lock duchain;
if(mydecl.data())
{
text = mydecl.data()->createMovingRange()->text();
Do whatever you want;
}
- David
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
http://git.reviewboard.kde.org/r/101671/#review3994
-----------------------------------------------------------
On June 18, 2011, 4:58 a.m., Olivier Jean de Gaalon wrote:
>
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> http://git.reviewboard.kde.org/r/101671/
> -----------------------------------------------------------
>
> (Updated June 18, 2011, 4:58 a.m.)
>
>
> Review request for KDevelop.
>
>
> Summary
> -------
>
> Build a context for the switch AST.
> Add a new "case" parent context for cpp code completion to match the type of the switch's expression.
> Add test.
>
>
> This addresses bug 184185.
> http://bugs.kde.org/show_bug.cgi?id=184185
>
>
> Diffs
> -----
>
> languages/cpp/codecompletion/context.h 08049b8
> languages/cpp/codecompletion/context.cpp c0d6841
> languages/cpp/cppduchain/contextbuilder.h 3ab9cdd
> languages/cpp/cppduchain/contextbuilder.cpp b00c9c8
> languages/cpp/cpputils.h b0b633e
> languages/cpp/cpputils.cpp 6ac9414
> languages/cpp/tests/test_cppcodecompletion.h 7546f7e
> languages/cpp/tests/test_cppcodecompletion.cpp 6eb4257
>
> Diff: http://git.reviewboard.kde.org/r/101671/diff
>
>
> Testing
> -------
>
> Usage, new test.
>
>
> Thanks,
>
> Olivier Jean de
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kdevelop-devel/attachments/20110626/5d13caff/attachment.html>
More information about the KDevelop-devel
mailing list