Review Request 122232: KConfig: fix using KSharedConfig in global object destructor.
David Faure
faure at kde.org
Sat Apr 4 11:47:20 UTC 2015
> On Feb. 21, 2015, 8:19 p.m., Matthew Dawson wrote:
> > Everything looked good, but when I tried to rerun the tests to make sure everything is ok the kconfig_in_global_object test I'm getting an abort with the same error message. Backtrace:
> > ```
> > #5 0x00007ffff791b630 in qAppName () at kernel/qcoreapplication.cpp:541
> > #6 0x00007ffff78a9c76 in QLockFilePrivate::tryLock_sys (this=this at entry=0x608ec0) at io/qlockfile_unix.cpp:140
> > #7 0x00007ffff783c1ec in QLockFile::tryLock (this=<optimized out>, timeout=-1) at io/qlockfile.cpp:208
> > #8 0x00007ffff7ba17db in KConfigIniBackend::lock (this=0x608fe0) at /home/matthew/kde/kconfig/src/core/kconfigini.cpp:634
> > #9 0x00007ffff7b84ce0 in KConfigPrivate::lockLocal (this=0x608b40) at /home/matthew/kde/kconfig/src/core/kconfig.cpp:104
> > #10 0x00007ffff7b86aa9 in KConfig::sync (this=0x606ae0) at /home/matthew/kde/kconfig/src/core/kconfig.cpp:415
> > #11 0x00007ffff7b85c28 in KConfig::~KConfig (this=0x606ae0, __in_chrg=<optimized out>) at /home/matthew/kde/kconfig/src/core/kconfig.cpp:267
> > #12 0x00007ffff7b85c82 in KConfig::~KConfig (this=0x606ae0, __in_chrg=<optimized out>) at /home/matthew/kde/kconfig/src/core/kconfig.cpp:270
> > #13 0x0000000000401844 in Tester::~Tester (this=0x6030e8 <(anonymous namespace)::Q_QGS_globalTestObject::innerFunction()::holder>, __in_chrg=<optimized out>)
> > at /home/matthew/kde/kconfig/autotests/kconfig_in_global_object.cpp:56
> > ```
> > Which seems to be second issue we found. I'm not sure how to solve this issue yet, but I'd be happy to just document the issue and strike this test.
> >
> > I only get this when the configuration file does not exist before the program executes, which may be why we missed it from the earlier patches.
>
> David Faure wrote:
> Indeed. Good catch.
>
> Fixed in Qt. https://codereview.qt-project.org/106953.
>
> David Faure wrote:
> Ah, and https://codereview.qt-project.org/106954
>
> Matthew Dawson wrote:
> Ok, sounds good :). I think it would be good to fix as much of the issue this RR covers while we wait for that patch to ship in a released Qt version (since I assume its Qt 5.5 or 5.6 territory).
>
> So, I think the ksharedconfig_in_global_object test and and the changes in the src/ folder should be committed now, so that KSharedConfig creation is safe. After the Qt patch lands, this RR (or a new one) can be updated to test everything, given a recent enough copy of Qt (basically kconfig_in_global object). Thoughts? If you are happy with this plan, the first part has a ship it from me.
OK, done, thanks for the input.
- David
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/122232/#review76407
-----------------------------------------------------------
On April 4, 2015, 11:45 a.m., David Faure wrote:
>
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://git.reviewboard.kde.org/r/122232/
> -----------------------------------------------------------
>
> (Updated April 4, 2015, 11:45 a.m.)
>
>
> Review request for KDE Frameworks and Matthew Dawson.
>
>
> Repository: kconfig
>
>
> Description
> -------
>
> kconfig_in_global_object.cpp comes from kdelibs4support
> (after porting to Q_GLOBAL_STATIC)
>
> ksharedconfig_in_global_object.cpp is now in kdelibs4 too
> (where it works) and reproduces Albert's KgDifficulty testcase.
>
>
> Diffs
> -----
>
> autotests/CMakeLists.txt b91f754b705fc87bb8b729bea72fbb5f7d427ace
> autotests/kconfig_in_global_object.cpp PRE-CREATION
> autotests/ksharedconfig_in_global_object.cpp PRE-CREATION
> src/core/kconfig.cpp 1da816faea5548d2f529755d6538a142a2193720
> src/core/ksharedconfig.h d0791e461804d421010bc5f82873371a4d3bc992
>
> Diff: https://git.reviewboard.kde.org/r/122232/diff/
>
>
> Testing
> -------
>
> Both tests pass and the QCoreApplication::arguments warning (because called after qApp is destroyed) is gone.
>
>
> Thanks,
>
> David Faure
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-frameworks-devel/attachments/20150404/d196aaa4/attachment.html>
More information about the Kde-frameworks-devel
mailing list