diff options
author | Stephan Bergmann <sbergman@redhat.com> | 2021-10-15 10:33:07 +0200 |
---|---|---|
committer | Stephan Bergmann <sbergman@redhat.com> | 2021-10-15 13:20:21 +0200 |
commit | af908d9f18fbb83a5c393f856026cebefd821f18 (patch) | |
tree | 8febcffa229c560089fe6e443d97575893531056 | |
parent | 99adfcad3517de6530c9a2f025c528001f543ae2 (diff) |
Avoid usage of incomplete types in member functions defined in-class
...that started to fail now at least with clang-cl (where the MSVC rules when to
emit inline member function definitions are more aggressive than for other ABIs)
with --with-latest-c++ and --with-visual-studio=2022 (where usage of incomplete
types in std::vector now triggered
> In file included from C:/lo-clang/core/slideshow/source/engine/opengl/TransitionerImpl.cxx:31:
> In file included from C:/PROGRA~1/MIB055~1/2022/Preview/VC/Tools/MSVC/1430~1.305/Include\memory:11:
> In file included from C:/PROGRA~1/MIB055~1/2022/Preview/VC/Tools/MSVC/1430~1.305/Include\exception:12:
> C:/PROGRA~1/MIB055~1/2022/Preview/VC/Tools/MSVC/1430~1.305/Include\type_traits(744,50): error: incomplete type 'Primitive' used in type trait expression
> struct is_trivially_destructible : bool_constant<__is_trivially_destructible(_Ty)> {
> ^
> C:/PROGRA~1/MIB055~1/2022/Preview/VC/Tools/MSVC/1430~1.305/Include\type_traits(59,53): note: in instantiation of template class 'std::is_trivially_destructible<Primitive>' requested here
> struct conjunction<_First, _Rest...> : _Conjunction<_First::value, _First, _Rest...>::type {
> ^
> C:/PROGRA~1/MIB055~1/2022/Preview/VC/Tools/MSVC/1430~1.305/Include\type_traits(64,44): note: in instantiation of template class 'std::conjunction<std::is_trivially_destructible<Primitive>, std::disjunction<std::_Is_default_allocator<std::allocator<Primitive>>, std::_Has_no_alloc_destroy<std::allocator<Primitive>, Primitive *>>>' requested here
> _INLINE_VAR constexpr bool conjunction_v = conjunction<_Traits...>::value;
> ^
> C:/PROGRA~1/MIB055~1/2022/Preview/VC/Tools/MSVC/1430~1.305/Include\xmemory(934,20): note: in instantiation of variable template specialization 'std::conjunction_v<std::is_trivially_destructible<Primitive>, std::disjunction<std::_Is_default_allocator<std::allocator<Primitive>>, std::_Has_no_alloc_destroy<std::allocator<Primitive>, Primitive *>>>' requested here
> if constexpr (!conjunction_v<is_trivially_destructible<_Ty>, _Uses_default_destroy<_Alloc, _Ty*>>) {
> ^
> C:/PROGRA~1/MIB055~1/2022/Preview/VC/Tools/MSVC/1430~1.305/Include\vector(1632,13): note: in instantiation of function template specialization 'std::_Destroy_range<std::allocator<Primitive>>' requested here
> _Destroy_range(_Myfirst, _Mylast, _Al);
> ^
> C:/PROGRA~1/MIB055~1/2022/Preview/VC/Tools/MSVC/1430~1.305/Include\vector(583,9): note: in instantiation of member function 'std::vector<Primitive>::_Tidy' requested here
> _Tidy();
> ^
> C:/lo-clang/core/slideshow/source/engine/opengl/TransitionImpl.hxx(74,5): note: in instantiation of member function 'std::vector<Primitive>::~vector' requested here
> TransitionScene(
> ^
> C:/lo-clang/core/slideshow/source/engine/opengl/TransitionImpl.hxx(42,7): note: forward declaration of 'Primitive'
> class Primitive;
> ^
etc.).
Which in turn required tweaking of loplugin:unnecessaryoverride to avoid false
> In file included from C:/lo-clang/core/slideshow/source/engine/opengl/TransitionerImpl.cxx:67:
> C:/lo-clang/core/slideshow/source/engine/opengl/TransitionImpl.hxx(389,18): error: unnecessary user-declared destructor [loplugin:unnecessaryoverride]
> TransitionScene::~TransitionScene() = default;
> ~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~
> C:/lo-clang/core/slideshow/source/engine/opengl/TransitionImpl.hxx(81,12): note: declared here [loplugin:unnecessaryoverride]
> inline ~TransitionScene();
> ~~~~~~~^~~~~~~~~~~~~~~~~~
Change-Id: Ia72fb44e6e92ff47376d7b7159c0df7cbf883b69
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/123648
Tested-by: Jenkins
Reviewed-by: Stephan Bergmann <sbergman@redhat.com>
-rw-r--r-- | compilerplugins/clang/test/unnecessaryoverride-dtor.cxx | 4 | ||||
-rw-r--r-- | compilerplugins/clang/unnecessaryoverride.cxx | 6 | ||||
-rw-r--r-- | slideshow/source/engine/opengl/TransitionImpl.hxx | 27 | ||||
-rw-r--r-- | sw/inc/swcrsr.hxx | 8 | ||||
-rw-r--r-- | sw/source/core/layout/layhelp.hxx | 12 | ||||
-rw-r--r-- | writerfilter/source/dmapper/DomainMapper_Impl.hxx | 14 |
6 files changed, 49 insertions, 22 deletions
diff --git a/compilerplugins/clang/test/unnecessaryoverride-dtor.cxx b/compilerplugins/clang/test/unnecessaryoverride-dtor.cxx index b54957be2d7a..8ed472749105 100644 --- a/compilerplugins/clang/test/unnecessaryoverride-dtor.cxx +++ b/compilerplugins/clang/test/unnecessaryoverride-dtor.cxx @@ -78,10 +78,10 @@ struct DefaultDerived1: VirtualBase { }; struct DefaultDerived2: VirtualBase { - ~DefaultDerived2() override; // expected-note {{declared here [loplugin:unnecessaryoverride]}} + ~DefaultDerived2() override; }; -DefaultDerived2::~DefaultDerived2() = default; // expected-error {{unnecessary user-declared destructor [loplugin:unnecessaryoverride]}} +DefaultDerived2::~DefaultDerived2() = default; struct EmptyDerived1: VirtualBase { ~EmptyDerived1() override {}; // expected-error {{unnecessary user-declared destructor [loplugin:unnecessaryoverride]}} diff --git a/compilerplugins/clang/unnecessaryoverride.cxx b/compilerplugins/clang/unnecessaryoverride.cxx index 6523170105a2..0641339d4e6f 100644 --- a/compilerplugins/clang/unnecessaryoverride.cxx +++ b/compilerplugins/clang/unnecessaryoverride.cxx @@ -200,7 +200,11 @@ bool UnnecessaryOverride::VisitCXXMethodDecl(const CXXMethodDecl* methodDecl) { return true; } - if (!methodDecl->isExplicitlyDefaulted()) { + if (methodDecl->isExplicitlyDefaulted()) { + if (methodDecl->getPreviousDecl() != nullptr) { + return true; + } + } else { if (!methodDecl->doesThisDeclarationHaveABody() || methodDecl->isLateTemplateParsed()) { diff --git a/slideshow/source/engine/opengl/TransitionImpl.hxx b/slideshow/source/engine/opengl/TransitionImpl.hxx index 9a869203cb56..9ca35c1e8f6d 100644 --- a/slideshow/source/engine/opengl/TransitionImpl.hxx +++ b/slideshow/source/engine/opengl/TransitionImpl.hxx @@ -71,18 +71,14 @@ typedef std::vector<std::shared_ptr<Operation> > Operations_t; class TransitionScene { public: - TransitionScene( + inline TransitionScene( Primitives_t&& rLeavingSlidePrimitives, Primitives_t&& rEnteringSlidePrimitives, Operations_t&& rOverallOperations = Operations_t(), SceneObjects_t&& rSceneObjects = SceneObjects_t() - ) - : maLeavingSlidePrimitives(std::move(rLeavingSlidePrimitives)) - , maEnteringSlidePrimitives(std::move(rEnteringSlidePrimitives)) - , maOverallOperations(std::move(rOverallOperations)) - , maSceneObjects(std::move(rSceneObjects)) - { - } + ); + + inline ~TransitionScene(); TransitionScene(TransitionScene const& rOther); TransitionScene& operator=(const TransitionScene& rOther); @@ -377,6 +373,21 @@ private: std::vector<Vertex> Vertices; }; +TransitionScene::TransitionScene( + Primitives_t&& rLeavingSlidePrimitives, + Primitives_t&& rEnteringSlidePrimitives, + Operations_t&& rOverallOperations, + SceneObjects_t&& rSceneObjects +) + : maLeavingSlidePrimitives(std::move(rLeavingSlidePrimitives)) + , maEnteringSlidePrimitives(std::move(rEnteringSlidePrimitives)) + , maOverallOperations(std::move(rOverallOperations)) + , maSceneObjects(std::move(rSceneObjects)) +{ +} + +TransitionScene::~TransitionScene() = default; + #endif // INCLUDED_SLIDESHOW_TRANSITION_HXX_ /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sw/inc/swcrsr.hxx b/sw/inc/swcrsr.hxx index e8fa059ee5ff..cd2b4ac74ed7 100644 --- a/sw/inc/swcrsr.hxx +++ b/sw/inc/swcrsr.hxx @@ -84,7 +84,7 @@ protected: void SaveState(); void RestoreState(); - const SwCursor_SavePos* GetSavePos() const { return m_vSavePos.empty() ? nullptr : &m_vSavePos.back(); } + inline const SwCursor_SavePos* GetSavePos() const; virtual const SwContentFrame* DoSetBidiLevelLeftRight( bool & io_rbLeft, bool bVisualAllowed, bool bInsertCursor); @@ -96,7 +96,7 @@ public: SwCursor( const SwPosition &rPos, SwPaM* pRing ); virtual ~SwCursor() override; - SwCursor & operator =(SwCursor const &) = default; + inline SwCursor & operator =(SwCursor const &); /// this takes a second parameter, which indicates the Ring that /// the new cursor should be part of (may be null) @@ -310,6 +310,10 @@ public: const SwTableCursor* GetPrev() const { return dynamic_cast<SwTableCursor const *>(GetPrevInRing()); } }; +const SwCursor_SavePos* SwCursor::GetSavePos() const { return m_vSavePos.empty() ? nullptr : &m_vSavePos.back(); } + +SwCursor & SwCursor::operator =(SwCursor const &) = default; + #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sw/source/core/layout/layhelp.hxx b/sw/source/core/layout/layhelp.hxx index fef26842d9cc..106fe4428013 100644 --- a/sw/source/core/layout/layhelp.hxx +++ b/sw/source/core/layout/layhelp.hxx @@ -63,7 +63,7 @@ class SwLayCacheImpl void Insert( sal_uInt16 nType, sal_uLong nIndex, sal_Int32 nOffset ); public: - SwLayCacheImpl() : m_bUseFlyCache(false) {} + inline SwLayCacheImpl(); size_t size() const { return mIndices.size(); } @@ -73,8 +73,8 @@ public: sal_Int32 GetBreakOfst( size_t nIdx ) const { return m_aOffset[ nIdx ]; } sal_uInt16 GetBreakType( size_t nIdx ) const { return m_aType[ nIdx ]; } - size_t GetFlyCount() const { return m_FlyCache.size(); } - SwFlyCache& GetFlyCache( size_t nIdx ) { return m_FlyCache[ nIdx ]; } + inline size_t GetFlyCount() const; + inline SwFlyCache& GetFlyCache( size_t nIdx ); bool IsUseFlyCache() const { return m_bUseFlyCache; } }; @@ -212,6 +212,12 @@ public: SwRect( nXL, nYL, nWL, nHL ), nOrdNum( nO ), nPageNum( nP ){} }; +SwLayCacheImpl::SwLayCacheImpl() : m_bUseFlyCache(false) {} + +size_t SwLayCacheImpl::GetFlyCount() const { return m_FlyCache.size(); } + +SwFlyCache& SwLayCacheImpl::GetFlyCache( size_t nIdx ) { return m_FlyCache[ nIdx ]; } + #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/writerfilter/source/dmapper/DomainMapper_Impl.hxx b/writerfilter/source/dmapper/DomainMapper_Impl.hxx index b23a0b42416d..7d58fe653716 100644 --- a/writerfilter/source/dmapper/DomainMapper_Impl.hxx +++ b/writerfilter/source/dmapper/DomainMapper_Impl.hxx @@ -253,12 +253,7 @@ struct TextAppendContext */ std::vector<AnchoredObjectInfo> m_aAnchoredObjects; - TextAppendContext(const css::uno::Reference<css::text::XTextAppend>& xAppend, const css::uno::Reference<css::text::XTextCursor>& xCur) - : xTextAppend(xAppend) - { - xCursor.set(xCur, css::uno::UNO_QUERY); - xInsertPosition = xCursor; - } + inline TextAppendContext(const css::uno::Reference<css::text::XTextAppend>& xAppend, const css::uno::Reference<css::text::XTextCursor>& xCur); }; struct AnchoredContext @@ -1172,6 +1167,13 @@ private: std::unordered_map<OUString, CommentProperties> m_aCommentProps; }; +TextAppendContext::TextAppendContext(const css::uno::Reference<css::text::XTextAppend>& xAppend, const css::uno::Reference<css::text::XTextCursor>& xCur) + : xTextAppend(xAppend) +{ + xCursor.set(xCur, css::uno::UNO_QUERY); + xInsertPosition = xCursor; +} + } //namespace writerfilter::dmapper /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |