[Libreoffice-commits] core.git: sot/source
Noel Grandin (via logerrit)
logerrit at kemper.freedesktop.org
Thu Jan 14 10:19:23 UTC 2021
sot/source/base/exchange.cxx | 55 +++++++++++++++++--------------------------
1 file changed, 23 insertions(+), 32 deletions(-)
New commits:
commit 52db69ed08a011c16673bc6d45834347e83a5bbf
Author: Noel Grandin <noel at peralex.com>
AuthorDate: Wed Jan 13 14:31:00 2021 +0200
Commit: Noel Grandin <noel.grandin at collabora.co.uk>
CommitDate: Thu Jan 14 11:18:42 2021 +0100
flatten formats data in SotStorage
there is no need for all this indirection.
Change-Id: Ie44723b54313b1103fe33a00ed014e2b28a59638
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/109225
Tested-by: Jenkins
Reviewed-by: Noel Grandin <noel.grandin at collabora.co.uk>
diff --git a/sot/source/base/exchange.cxx b/sot/source/base/exchange.cxx
index 4888a366ec71..ff7b8add31bd 100644
--- a/sot/source/base/exchange.cxx
+++ b/sot/source/base/exchange.cxx
@@ -213,22 +213,14 @@ struct DataFlavorRepresentation
const DataFlavorRepresentation, ImplFormatArray_Impl > {};
- typedef std::vector<std::unique_ptr<css::datatransfer::DataFlavor>> tDataFlavorList;
+ typedef std::vector<css::datatransfer::DataFlavor> tDataFlavorList;
- struct SotData_Impl
- {
- std::unique_ptr<tDataFlavorList> pDataFlavorList;
- };
-
- struct ImplData : public rtl::Static<SotData_Impl, ImplData> {};
+ struct ImplData : public rtl::Static<tDataFlavorList, ImplData> {};
}
static tDataFlavorList& InitFormats_Impl()
{
- SotData_Impl *pSotData = &ImplData::get();
- if( !pSotData->pDataFlavorList )
- pSotData->pDataFlavorList.reset(new tDataFlavorList);
- return *pSotData->pDataFlavorList;
+ return ImplData::get();
}
/*************************************************************************
@@ -258,17 +250,17 @@ SotClipboardFormatId SotExchange::RegisterFormatName( const OUString& rName )
tDataFlavorList& rL = InitFormats_Impl();
for( tDataFlavorList::size_type i = 0; i < rL.size(); i++ )
{
- auto const& pFlavor = rL[ i ];
- if( pFlavor && rName == pFlavor->HumanPresentableName )
+ auto const& rFlavor = rL[ i ];
+ if( rName == rFlavor.HumanPresentableName )
return static_cast<SotClipboardFormatId>(i + static_cast<int>(SotClipboardFormatId::USER_END) + 1);
}
- std::unique_ptr<DataFlavor> pNewFlavor(new DataFlavor);
- pNewFlavor->MimeType = rName;
- pNewFlavor->HumanPresentableName = rName;
- pNewFlavor->DataType = cppu::UnoType<OUString>::get();
+ DataFlavor aNewFlavor;
+ aNewFlavor.MimeType = rName;
+ aNewFlavor.HumanPresentableName = rName;
+ aNewFlavor.DataType = cppu::UnoType<OUString>::get();
- rL.push_back( std::move(pNewFlavor) );
+ rL.push_back( std::move(aNewFlavor) );
return static_cast<SotClipboardFormatId>(static_cast<int>(rL.size()-1) + static_cast<int>(SotClipboardFormatId::USER_END) + 1);
}
@@ -289,17 +281,17 @@ SotClipboardFormatId SotExchange::RegisterFormatMimeType( const OUString& rMimeT
tDataFlavorList& rL = InitFormats_Impl();
for( tDataFlavorList::size_type i = 0; i < rL.size(); i++ )
{
- auto const& pFlavor = rL[ i ];
- if( pFlavor && rMimeType == pFlavor->MimeType )
+ auto const& rFlavor = rL[ i ];
+ if( rMimeType == rFlavor.MimeType )
return static_cast<SotClipboardFormatId>(i + static_cast<int>(SotClipboardFormatId::USER_END) + 1);
}
- std::unique_ptr<DataFlavor> pNewFlavor(new DataFlavor);
- pNewFlavor->MimeType = rMimeType;
- pNewFlavor->HumanPresentableName = rMimeType;
- pNewFlavor->DataType = cppu::UnoType<OUString>::get();
+ DataFlavor aNewFlavor;
+ aNewFlavor.MimeType = rMimeType;
+ aNewFlavor.HumanPresentableName = rMimeType;
+ aNewFlavor.DataType = cppu::UnoType<OUString>::get();
- rL.push_back( std::move(pNewFlavor) );
+ rL.push_back( std::move(aNewFlavor) );
return static_cast<SotClipboardFormatId>(static_cast<int>(rL.size()-1) + static_cast<int>(SotClipboardFormatId::USER_END) + 1);
}
@@ -318,7 +310,7 @@ SotClipboardFormatId SotExchange::RegisterFormat( const DataFlavor& rFlavor )
{
tDataFlavorList& rL = InitFormats_Impl();
nRet = static_cast<SotClipboardFormatId>(rL.size() + static_cast<int>(SotClipboardFormatId::USER_END) + 1);
- rL.emplace_back( new DataFlavor( rFlavor ) );
+ rL.emplace_back( rFlavor );
}
return nRet;
@@ -351,7 +343,7 @@ bool SotExchange::GetFormatDataFlavor( SotClipboardFormatId nFormat, DataFlavor&
if( rL.size() > i )
{
- rFlavor = *rL[ i ];
+ rFlavor = rL[ i ];
bRet = true;
}
else
@@ -384,7 +376,7 @@ OUString SotExchange::GetFormatMimeType( SotClipboardFormatId nFormat )
unsigned i = static_cast<int>(nFormat) - static_cast<int>(SotClipboardFormatId::USER_END) - 1;
if( rL.size() > i )
- sMimeType = rL[ i ]->MimeType;
+ sMimeType = rL[ i ].MimeType;
}
DBG_ASSERT( !sMimeType.isEmpty(), "SotExchange::GetFormatMimeType(): DataFlavor not initialized" );
@@ -419,8 +411,8 @@ SotClipboardFormatId SotExchange::GetFormatIdFromMimeType( const OUString& rMime
for( tDataFlavorList::size_type i = 0; i < rL.size(); i++ )
{
- auto const& pFlavor = rL[ i ];
- if( pFlavor && rMimeType == pFlavor->MimeType )
+ auto const& rFlavor = rL[ i ];
+ if( rMimeType == rFlavor.MimeType )
return static_cast<SotClipboardFormatId>(i + static_cast<int>(SotClipboardFormatId::USER_END) + 1);
}
@@ -456,8 +448,7 @@ SotClipboardFormatId SotExchange::GetFormat( const DataFlavor& rFlavor )
tDataFlavorList& rL = InitFormats_Impl();
for( tDataFlavorList::size_type i = 0; i < rL.size(); i++ )
{
- auto const& pFlavor = rL[ i ];
- if( pFlavor && rMimeType == pFlavor->MimeType )
+ if( rMimeType == rL[ i ].MimeType )
return static_cast<SotClipboardFormatId>(i + static_cast<int>(SotClipboardFormatId::USER_END) + 1);
}
More information about the Libreoffice-commits
mailing list