Review Request 126526: [hg]Fixed memory leak
Tomasz Bojczuk
seelook at gmail.com
Sun Dec 27 20:07:10 GMT 2015
> On Dec. 27, 2015, 3:46 p.m., Mark Gaiser wrote:
> > This is exactly the reason (a forgotten delete) why i prefer to use smart pointers instead of naked pointers.
> > Could you put m_config in a std::unique_ptr<...> object? Or if you really want to use Qt smart pointers then put it in a QScopedPointer<...>.
>
> Tomasz Bojczuk wrote:
> But it doesn't match a type when KConfigGroup() is created with m_config as a first parameter. (Either for std::unique_ptr or QScopedPointer).
> IMO, using destructor is much clearer and quite sufficient for this purpose.
>
> Mark Gaiser wrote:
> I don't see what you mean..
> This should work (QScopedPointer):
>
> QScopedPointer<KConfig> scoped(new KConfig(QLatin1String("dolphin-hg"), KConfig::SimpleConfig, QStandardPaths::GenericConfigLocation));
>
> Od std::unique_ptr version:
> std::unique_ptr<KConfig> scoped(new KConfig(QLatin1String("dolphin-hg"), KConfig::SimpleConfig, QStandardPaths::GenericConfigLocation));
>
> Be sure to include <memory> for std::unique_ptr and <QScopedPointer> for QScopedPointer.
>
> Anyway, what you did (in the diff as it is right now) looks fine to me. Don't read my comment as "you must change it", it's fine imho. I simply prefer samrt pointers. You don't have to follow my preference :)
I meant, when m_config is used to create KConfigGroup(m_config, "some_name") - a few places in patched file, KConfigGroup constructor may take either pointer to KGlobalConfig (KConfig inherits from it) or KSharedConfigPtr. So probably neither std::unique_ptr nor QScopedPointer won't compile because they are not compatible.
I will stay with destructor, but in someway You uncovered std::unique_ptr for me. So thanks.
May I ship it then?
- Tomasz
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/126526/#review90147
-----------------------------------------------------------
On Dec. 26, 2015, 1:52 p.m., Tomasz Bojczuk wrote:
>
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://git.reviewboard.kde.org/r/126526/
> -----------------------------------------------------------
>
> (Updated Dec. 26, 2015, 1:52 p.m.)
>
>
> Review request for Dolphin.
>
>
> Repository: dolphin-plugins
>
>
> Description
> -------
>
> There is KConfig instance
> KConfig *m_config;
> It is created in constructor but never deleted (no destructor).
> Added destructor then.
> In occasion, when m_config is created - wrapped file name text by QLatin1String
>
>
> Diffs
> -----
>
> hg/config-widgets/pluginsettings.h 42d3cec
> hg/config-widgets/pluginsettings.cpp 2267a3a
>
> Diff: https://git.reviewboard.kde.org/r/126526/diff/
>
>
> Testing
> -------
>
>
> Thanks,
>
> Tomasz Bojczuk
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mail.kde.org/mailman/private/kfm-devel/attachments/20151227/11cf4dae/attachment.htm>
More information about the kfm-devel
mailing list