summaryrefslogtreecommitdiff
path: root/vcl/ios
diff options
context:
space:
mode:
authorTor Lillqvist <tml@collabora.com>2019-05-28 22:10:06 +0300
committerTor Lillqvist <tml@collabora.com>2019-09-20 14:13:54 +0200
commiteae01c626cd6a9ae2ef5898e2dc9a6354479215b (patch)
treec9472ecc882053205bad18fd49a94fc349f8b700 /vcl/ios
parent1db820d9132ad3e813d018b8d847749a91cbe08b (diff)
tdf#124752: Simplify the iOS DataFlavorMapping thing a lot
Now it works to copy and paste images (PNG ones at least) between the iOS Collabora Office app and other apps. We don't seem to need the PNGDataProvider after all, as we use it only for data that is already in PNG format. Possibly I am missing somethin, though. Change-Id: Ia6bcc8aefbe1a6687f13e28454b96658fc66c856 (cherry picked from commit 313984a59af43b00cc58c9e13ef9bf3aeccca30f) Reviewed-on: https://gerrit.libreoffice.org/79232 Reviewed-by: Tor Lillqvist <tml@collabora.com> Tested-by: Tor Lillqvist <tml@collabora.com>
Diffstat (limited to 'vcl/ios')
-rw-r--r--vcl/ios/DataFlavorMapping.cxx127
1 files changed, 1 insertions, 126 deletions
diff --git a/vcl/ios/DataFlavorMapping.cxx b/vcl/ios/DataFlavorMapping.cxx
index c42677f70b6b..e90a8f9b245c 100644
--- a/vcl/ios/DataFlavorMapping.cxx
+++ b/vcl/ios/DataFlavorMapping.cxx
@@ -46,65 +46,6 @@ using namespace cppu;
namespace
{
-bool ImageToPNG(css::uno::Sequence<sal_Int8> const& rImgData,
- css::uno::Sequence<sal_Int8>& rPngData)
-{
-#if 1
- // Skip this complexity for now. Work in progress.
- (void)rImgData;
- (void)rPngData;
- return false;
-#else
- NSData* pData = [NSData dataWithBytesNoCopy:const_cast<sal_Int8*>(rImgData.getConstArray())
- length:rImgData.getLength()
- freeWhenDone:0];
- if (!pData)
- return false;
-
- NSBitmapImageRep* pRep = [NSBitmapImageRep imageRepWithData:pData];
- if (!pRep)
- return false;
-
- NSData* pOut = [pRep representationUsingType:NSPNGFileType properties:@{}];
- if (!pOut)
- return false;
-
- const size_t nPngSize = [pOut length];
- rPngData.realloc(nPngSize);
- [pOut getBytes:rPngData.getArray() length:nPngSize];
- return (nPngSize > 0);
-#endif
-}
-
-bool PNGToImage(css::uno::Sequence<sal_Int8> const& rPngData,
- css::uno::Sequence<sal_Int8>& rImgData)
-{
-#if 1
- (void)rPngData;
- (void)rImgData;
- return false;
-#else
- NSData* pData = [NSData dataWithBytesNoCopy:const_cast<sal_Int8*>(rPngData.getConstArray())
- length:rPngData.getLength()
- freeWhenDone:0];
- if (!pData)
- return false;
-
- NSBitmapImageRep* pRep = [NSBitmapImageRep imageRepWithData:pData];
- if (!pRep)
- return false;
-
- NSData* pOut = [pRep representationUsingType:eOutFormat properties:@{}];
- if (!pOut)
- return false;
-
- const size_t nImgSize = [pOut length];
- rImgData.realloc(nImgSize);
- [pOut getBytes:rImgData.getArray() length:nImgSize];
- return (nImgSize > 0);
-#endif
-}
-
/* Determine whether or not a DataFlavor is valid.
*/
bool isValidFlavor(const DataFlavor& aFlavor)
@@ -396,61 +337,6 @@ Any HTMLFormatDataProvider::getOOoData()
return oOOData;
}
-class PNGDataProvider : public DataProviderBaseImpl
-{
-public:
- PNGDataProvider(const Any&);
- PNGDataProvider(NSData*);
-
- NSData* getSystemData() override;
- Any getOOoData() override;
-};
-
-PNGDataProvider::PNGDataProvider(const Any& data)
- : DataProviderBaseImpl(data)
-{
-}
-
-PNGDataProvider::PNGDataProvider(NSData* data)
- : DataProviderBaseImpl(data)
-{
-}
-
-NSData* PNGDataProvider::getSystemData()
-{
- Sequence<sal_Int8> pngData;
- mData >>= pngData;
-
- Sequence<sal_Int8> imgData;
- NSData* sysData = nullptr;
- if (PNGToImage(pngData, imgData))
- sysData = [NSData dataWithBytes:imgData.getArray() length:imgData.getLength()];
-
- return sysData;
-}
-
-Any PNGDataProvider::getOOoData()
-{
- Any oOOData;
-
- if (mSystemData)
- {
- const unsigned int flavorDataLength = [mSystemData length];
- Sequence<sal_Int8> imgData(flavorDataLength);
- memcpy(imgData.getArray(), [mSystemData bytes], flavorDataLength);
-
- Sequence<sal_Int8> pngData;
- if (ImageToPNG(imgData, pngData))
- oOOData <<= pngData;
- }
- else
- {
- oOOData = mData;
- }
-
- return oOOData;
-}
-
DataFlavorMapper::DataFlavorMapper()
{
Reference<XComponentContext> xContext = comphelper::getProcessComponentContext();
@@ -564,14 +450,7 @@ DataFlavorMapper::getDataProvider(const NSString* systemFlavor,
if (isByteSequenceType(data.getValueType()))
{
- if ([systemFlavor caseInsensitiveCompare:PBTYPE_PNG] == NSOrderedSame)
- {
- dp = DataProviderPtr_t(new PNGDataProvider(data));
- }
- else
- {
- dp = DataProviderPtr_t(new ByteSequenceDataProvider(data));
- }
+ dp = DataProviderPtr_t(new ByteSequenceDataProvider(data));
}
else // Must be OUString type
{
@@ -601,10 +480,6 @@ DataProviderPtr_t DataFlavorMapper::getDataProvider(const NSString* systemFlavor
{
dp = DataProviderPtr_t(new HTMLFormatDataProvider(systemData));
}
- else if ([systemFlavor caseInsensitiveCompare:PBTYPE_PNG] == NSOrderedSame)
- {
- dp = DataProviderPtr_t(new PNGDataProvider(systemData));
- }
else
{
dp = DataProviderPtr_t(new ByteSequenceDataProvider(systemData));