parent
f2d50d439e
commit
14c608a492
File diff suppressed because it is too large
Load Diff
@ -1,103 +0,0 @@
|
||||
From 764836cb00e8e6dfd2ab48e080a166ec90359e01 Mon Sep 17 00:00:00 2001
|
||||
From: David Tardon <dtardon@redhat.com>
|
||||
Date: Sun, 7 Dec 2014 21:48:55 +0100
|
||||
Subject: [PATCH] Revert "No need to have OpenCL optional at configure-time"
|
||||
|
||||
As long as this requires bundling clcc, not allowing to disable it is
|
||||
unacceptable.
|
||||
|
||||
This reverts commit 3b0b76462aa54f60bc9823d9c6ef64e5e35c1208.
|
||||
|
||||
Conflicts:
|
||||
configure.ac
|
||||
|
||||
Change-Id: I12b3d5e3325bbd03cd98e1fb5139705d694493c2
|
||||
---
|
||||
configure.ac | 14 +++++++++++++-
|
||||
sc/CppunitTest_sc_opencl_test.mk | 2 +-
|
||||
sc/Module_sc.mk | 2 +-
|
||||
sc/source/ui/optdlg/calcoptionsdlg.hxx | 2 ++
|
||||
4 files changed, 17 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/configure.ac b/configure.ac
|
||||
index b6ae6db..e969fbf 100644
|
||||
--- a/configure.ac
|
||||
+++ b/configure.ac
|
||||
@@ -1096,6 +1096,10 @@ AC_ARG_ENABLE(cairo-canvas,
|
||||
platforms where Cairo is available.
|
||||
])
|
||||
|
||||
+AC_ARG_ENABLE(opencl,
|
||||
+ AS_HELP_STRING([--disable-opencl],
|
||||
+ [Determines whether to build with OpenCL support.]))
|
||||
+
|
||||
AC_ARG_ENABLE(dbus,
|
||||
AS_HELP_STRING([--disable-dbus],
|
||||
[Determines whether to enable features that depend on dbus.
|
||||
@@ -10263,13 +10267,21 @@ dnl =================================================
|
||||
dnl Check whether to build with OpenCL support.
|
||||
dnl =================================================
|
||||
|
||||
-if test $_os != iOS -a $_os != Android; then
|
||||
+AC_MSG_CHECKING([whether to build with the OpenCL support.])
|
||||
+ENABLE_OPENCL=
|
||||
+
|
||||
+if test $_os != iOS -a $_os != Android -a "x$enable_opencl" != "xno"; then
|
||||
+ AC_MSG_RESULT([yes])
|
||||
# CLCC in BUILD_TYPE tells that we are building a bundled clcc (just the clew part), OPENCL in
|
||||
# BUILD_TYPE tells that OpenCL is potentially available on the platform (optional at run-time,
|
||||
# used through clew).
|
||||
BUILD_TYPE="$BUILD_TYPE CLCC OPENCL"
|
||||
+ ENABLE_OPENCL=TRUE
|
||||
AC_DEFINE(HAVE_FEATURE_OPENCL)
|
||||
+else
|
||||
+ AC_MSG_RESULT([no])
|
||||
fi
|
||||
+AC_SUBST(ENABLE_OPENCL)
|
||||
|
||||
dnl ===================================================================
|
||||
dnl Check whether to enable glTF support
|
||||
diff --git a/sc/CppunitTest_sc_opencl_test.mk b/sc/CppunitTest_sc_opencl_test.mk
|
||||
index 65aedde..76061ad 100644
|
||||
--- a/sc/CppunitTest_sc_opencl_test.mk
|
||||
+++ b/sc/CppunitTest_sc_opencl_test.mk
|
||||
@@ -15,7 +15,7 @@ $(eval $(call gb_CppunitTest_add_exception_objects,sc_opencl_test, \
|
||||
|
||||
$(eval $(call gb_CppunitTest_use_externals,sc_opencl_test, \
|
||||
boost_headers \
|
||||
- clew \
|
||||
+ $(call gb_Helper_optional,OPENCL,clew) \
|
||||
mdds_headers \
|
||||
orcus \
|
||||
orcus-parser \
|
||||
diff --git a/sc/Module_sc.mk b/sc/Module_sc.mk
|
||||
index 9385dc5..3bf84cd 100644
|
||||
--- a/sc/Module_sc.mk
|
||||
+++ b/sc/Module_sc.mk
|
||||
@@ -54,7 +54,7 @@ $(eval $(call gb_Module_add_slowcheck_targets,sc, \
|
||||
CppunitTest_sc_subsequent_filters_test \
|
||||
CppunitTest_sc_subsequent_export_test \
|
||||
CppunitTest_sc_html_export_test \
|
||||
- CppunitTest_sc_opencl_test \
|
||||
+ $(call gb_Helper_optional,OPENCL,CppunitTest_sc_opencl_test) \
|
||||
))
|
||||
|
||||
# Disabled to allow the check tinderbox execute the sd tests
|
||||
diff --git a/sc/source/ui/optdlg/calcoptionsdlg.hxx b/sc/source/ui/optdlg/calcoptionsdlg.hxx
|
||||
index c7bfe4d..b56b4c1 100644
|
||||
--- a/sc/source/ui/optdlg/calcoptionsdlg.hxx
|
||||
+++ b/sc/source/ui/optdlg/calcoptionsdlg.hxx
|
||||
@@ -64,8 +64,10 @@ private:
|
||||
OUString toString(sal_Int32 nVal) const;
|
||||
SvTreeListEntry *createItem(const OUString &rCaption, const OUString& sValue) const;
|
||||
void setValueAt(size_t nPos, const OUString &rString);
|
||||
+#if HAVE_FEATURE_OPENCL
|
||||
OpenCLConfig::ImplMatcherSet& CurrentWhiteOrBlackList();
|
||||
const OpenCLConfig::ImplMatcher& CurrentWhiteOrBlackListEntry();
|
||||
+#endif
|
||||
|
||||
private:
|
||||
SvxCheckListBox* mpLbSettings;
|
||||
--
|
||||
2.1.0
|
||||
|
@ -1,26 +0,0 @@
|
||||
From a68a7b831a5d1756ea9428e12bb89f69dc30950f Mon Sep 17 00:00:00 2001
|
||||
From: David Tardon <dtardon@redhat.com>
|
||||
Date: Tue, 9 Dec 2014 22:12:03 +0100
|
||||
Subject: [PATCH] fdo#37682 paint the right area
|
||||
|
||||
Change-Id: Ic3d1f6e47bf068e60dca711c97e3f6b194d14049
|
||||
---
|
||||
svx/source/unodraw/UnoGraphicExporter.cxx | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/svx/source/unodraw/UnoGraphicExporter.cxx b/svx/source/unodraw/UnoGraphicExporter.cxx
|
||||
index b884528..30b6727 100644
|
||||
--- a/svx/source/unodraw/UnoGraphicExporter.cxx
|
||||
+++ b/svx/source/unodraw/UnoGraphicExporter.cxx
|
||||
@@ -763,7 +763,7 @@ bool GraphicExporter::GetGraphic( ExportSettings& rSettings, Graphic& aGraphic,
|
||||
// Use new StandardCheckVisisbilityRedirector
|
||||
ImplExportCheckVisisbilityRedirector aRedirector( mpCurrentPage );
|
||||
|
||||
- pView->CompleteRedraw(&aVDev, vcl::Region(Rectangle(Point(), aNewSize)), &aRedirector);
|
||||
+ pView->CompleteRedraw(&aVDev, vcl::Region(Rectangle(aNewOrg, aNewSize)), &aRedirector);
|
||||
|
||||
aVDev.Pop();
|
||||
|
||||
--
|
||||
2.1.0
|
||||
|
@ -1,228 +0,0 @@
|
||||
From bf97980c8d5d5fbc63a08b8834c10fe903152b75 Mon Sep 17 00:00:00 2001
|
||||
From: David Tardon <dtardon@redhat.com>
|
||||
Date: Fri, 12 Dec 2014 17:09:45 +0100
|
||||
Subject: [PATCH] rhbz#1116534 crash when pasting over a formula
|
||||
|
||||
When pasting CSV data into existing document, we cannot use the
|
||||
ScImportExport optimization for insertion, because the cells can already
|
||||
have content (a grouped formula in this case). So use appropriate
|
||||
ScDocument functions, even if that means the import is slower.
|
||||
|
||||
This is a regression from commit 93959db4d8846cfdfb87ab647c4d457fb09bb869
|
||||
"use DocumentImport for csv import, related fdo#69006".
|
||||
|
||||
Change-Id: I92f70abca0542d796e3aa674b28a31053fff00d0
|
||||
---
|
||||
sc/source/ui/docshell/impex.cxx | 69 ++++++++++++++++++++++++++++-------------
|
||||
sc/source/ui/inc/impex.hxx | 4 +++
|
||||
sc/source/ui/view/viewfun5.cxx | 2 +-
|
||||
3 files changed, 52 insertions(+), 23 deletions(-)
|
||||
|
||||
diff --git a/sc/source/ui/docshell/impex.cxx b/sc/source/ui/docshell/impex.cxx
|
||||
index 75c7566..0d2aa7b1 100644
|
||||
--- a/sc/source/ui/docshell/impex.cxx
|
||||
+++ b/sc/source/ui/docshell/impex.cxx
|
||||
@@ -85,7 +85,8 @@ ScImportExport::ScImportExport( ScDocument* p )
|
||||
bFormulas( false ), bIncludeFiltered( true ),
|
||||
bAll( true ), bSingle( true ), bUndo( false ),
|
||||
bOverflowRow( false ), bOverflowCol( false ), bOverflowCell( false ),
|
||||
- mbApi( true ), mbImportBroadcast(false), mExportTextOptions()
|
||||
+ mbApi( true ), mbImportBroadcast(false), mbOverwriting( false ),
|
||||
+ mExportTextOptions()
|
||||
{
|
||||
pUndoDoc = NULL;
|
||||
pExtOptions = NULL;
|
||||
@@ -99,7 +100,8 @@ ScImportExport::ScImportExport( ScDocument* p, const ScAddress& rPt )
|
||||
bFormulas( false ), bIncludeFiltered( true ),
|
||||
bAll( false ), bSingle( true ), bUndo( pDocSh != NULL ),
|
||||
bOverflowRow( false ), bOverflowCol( false ), bOverflowCell( false ),
|
||||
- mbApi( true ), mbImportBroadcast(false), mExportTextOptions()
|
||||
+ mbApi( true ), mbImportBroadcast(false), mbOverwriting( false ),
|
||||
+ mExportTextOptions()
|
||||
{
|
||||
pUndoDoc = NULL;
|
||||
pExtOptions = NULL;
|
||||
@@ -114,7 +116,8 @@ ScImportExport::ScImportExport( ScDocument* p, const ScRange& r )
|
||||
bFormulas( false ), bIncludeFiltered( true ),
|
||||
bAll( false ), bSingle( false ), bUndo( pDocSh != NULL ),
|
||||
bOverflowRow( false ), bOverflowCol( false ), bOverflowCell( false ),
|
||||
- mbApi( true ), mbImportBroadcast(false), mExportTextOptions()
|
||||
+ mbApi( true ), mbImportBroadcast(false), mbOverwriting( false ),
|
||||
+ mExportTextOptions()
|
||||
{
|
||||
pUndoDoc = NULL;
|
||||
pExtOptions = NULL;
|
||||
@@ -130,7 +133,8 @@ ScImportExport::ScImportExport( ScDocument* p, const OUString& rPos )
|
||||
bFormulas( false ), bIncludeFiltered( true ),
|
||||
bAll( false ), bSingle( true ), bUndo( pDocSh != NULL ),
|
||||
bOverflowRow( false ), bOverflowCol( false ), bOverflowCell( false ),
|
||||
- mbApi( true ), mbImportBroadcast(false), mExportTextOptions()
|
||||
+ mbApi( true ), mbImportBroadcast(false), mbOverwriting( false ),
|
||||
+ mExportTextOptions()
|
||||
{
|
||||
pUndoDoc = NULL;
|
||||
pExtOptions = NULL;
|
||||
@@ -927,7 +931,8 @@ bool ScImportExport::Text2Doc( SvStream& rStrm )
|
||||
// Extended Ascii-Import
|
||||
|
||||
static bool lcl_PutString(
|
||||
- ScDocumentImport& rDocImport, SCCOL nCol, SCROW nRow, SCTAB nTab, const OUString& rStr, sal_uInt8 nColFormat,
|
||||
+ ScDocumentImport& rDocImport, bool bUseDocImport,
|
||||
+ SCCOL nCol, SCROW nRow, SCTAB nTab, const OUString& rStr, sal_uInt8 nColFormat,
|
||||
SvNumberFormatter* pFormatter, bool bDetectNumFormat,
|
||||
::utl::TransliterationWrapper& rTransliteration, CalendarWrapper& rCalendar,
|
||||
::utl::TransliterationWrapper* pSecondTransliteration, CalendarWrapper* pSecondCalendar )
|
||||
@@ -951,17 +956,24 @@ static bool lcl_PutString(
|
||||
pDoc->ApplyPattern(nCol, nRow, nTab, aNewAttrs);
|
||||
|
||||
}
|
||||
- if(ScStringUtil::isMultiline(rStr))
|
||||
+ if ( bUseDocImport )
|
||||
{
|
||||
- ScFieldEditEngine& rEngine = pDoc->GetEditEngine();
|
||||
- rEngine.SetText(rStr);
|
||||
- rDocImport.setEditCell(ScAddress(nCol, nRow, nTab), rEngine.CreateTextObject());
|
||||
- return true;
|
||||
- }
|
||||
- else
|
||||
+ if(ScStringUtil::isMultiline(rStr))
|
||||
+ {
|
||||
+ ScFieldEditEngine& rEngine = pDoc->GetEditEngine();
|
||||
+ rEngine.SetText(rStr);
|
||||
+ rDocImport.setEditCell(ScAddress(nCol, nRow, nTab), rEngine.CreateTextObject());
|
||||
+ return true;
|
||||
+ }
|
||||
+ else
|
||||
+ {
|
||||
+ rDocImport.setStringCell(ScAddress(nCol, nRow, nTab), rStr);
|
||||
+ return false;
|
||||
+ }
|
||||
+ } else
|
||||
{
|
||||
- rDocImport.setStringCell(ScAddress(nCol, nRow, nTab), rStr);
|
||||
- return false;
|
||||
+ pDoc->SetTextCell(ScAddress(nCol, nRow, nTab), rStr);
|
||||
+ return bMultiLine;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -975,7 +987,10 @@ static bool lcl_PutString(
|
||||
if ( pDocFormatter->IsNumberFormat( rStr, nEnglish, fVal ) )
|
||||
{
|
||||
// Numberformat will not be set to English
|
||||
- rDocImport.setNumericCell( ScAddress( nCol, nRow, nTab ), fVal );
|
||||
+ if ( bUseDocImport )
|
||||
+ rDocImport.setNumericCell( ScAddress( nCol, nRow, nTab ), fVal );
|
||||
+ else
|
||||
+ pDoc->SetValue( nCol, nRow, nTab, fVal );
|
||||
return bMultiLine;
|
||||
}
|
||||
// else, continue with SetString
|
||||
@@ -1164,7 +1179,10 @@ static bool lcl_PutString(
|
||||
nFormat = pDocFormatter->GetStandardFormat( fDays, nFormat, nType, eDocLang);
|
||||
|
||||
ScAddress aPos(nCol,nRow,nTab);
|
||||
- rDocImport.setNumericCell(aPos, fDays);
|
||||
+ if ( bUseDocImport )
|
||||
+ rDocImport.setNumericCell(aPos, fDays);
|
||||
+ else
|
||||
+ pDoc->SetValue( aPos, fDays );
|
||||
pDoc->SetNumberFormat(aPos, nFormat);
|
||||
|
||||
return bMultiLine; // success
|
||||
@@ -1181,14 +1199,20 @@ static bool lcl_PutString(
|
||||
aParam.mbDetectNumberFormat = bDetectNumFormat;
|
||||
aParam.meSetTextNumFormat = ScSetStringParam::SpecialNumberOnly;
|
||||
aParam.mbHandleApostrophe = false;
|
||||
- rDocImport.setAutoInput(ScAddress(nCol, nRow, nTab), rStr, &aParam);
|
||||
+ if ( bUseDocImport )
|
||||
+ rDocImport.setAutoInput(ScAddress(nCol, nRow, nTab), rStr, &aParam);
|
||||
+ else
|
||||
+ pDoc->SetString( nCol, nRow, nTab, rStr, &aParam );
|
||||
}
|
||||
else
|
||||
{
|
||||
bMultiLine = true;
|
||||
ScFieldEditEngine& rEngine = pDoc->GetEditEngine();
|
||||
rEngine.SetText(rStr);
|
||||
- rDocImport.setEditCell(ScAddress(nCol, nRow, nTab), rEngine.CreateTextObject());
|
||||
+ if ( bUseDocImport )
|
||||
+ rDocImport.setEditCell(ScAddress(nCol, nRow, nTab), rEngine.CreateTextObject());
|
||||
+ else
|
||||
+ pDoc->SetEditText( ScAddress( nCol, nRow, nTab ), rEngine.CreateTextObject() );
|
||||
}
|
||||
return bMultiLine;
|
||||
}
|
||||
@@ -1345,7 +1369,7 @@ bool ScImportExport::ExtText2Doc( SvStream& rStrm )
|
||||
nFmt = SC_COL_TEXT;
|
||||
|
||||
bMultiLine |= lcl_PutString(
|
||||
- aDocImport, nCol, nRow, nTab, aCell, nFmt,
|
||||
+ aDocImport, !mbOverwriting, nCol, nRow, nTab, aCell, nFmt,
|
||||
&aNumFormatter, bDetectNumFormat, aTransliteration, aCalendar,
|
||||
pEnglishTransliteration.get(), pEnglishCalendar.get());
|
||||
}
|
||||
@@ -1388,7 +1412,7 @@ bool ScImportExport::ExtText2Doc( SvStream& rStrm )
|
||||
nFmt = SC_COL_TEXT;
|
||||
|
||||
bMultiLine |= lcl_PutString(
|
||||
- aDocImport, nCol, nRow, nTab, aCell, nFmt,
|
||||
+ aDocImport, !mbOverwriting, nCol, nRow, nTab, aCell, nFmt,
|
||||
&aNumFormatter, bDetectNumFormat, aTransliteration,
|
||||
aCalendar, pEnglishTransliteration.get(), pEnglishCalendar.get());
|
||||
}
|
||||
@@ -1446,13 +1470,14 @@ bool ScImportExport::ExtText2Doc( SvStream& rStrm )
|
||||
|
||||
bDetermineRange = !bDetermineRange; // toggle
|
||||
} while (!bDetermineRange);
|
||||
- aDocImport.finalize();
|
||||
+ if ( !mbOverwriting )
|
||||
+ aDocImport.finalize();
|
||||
|
||||
xProgress.reset(); // make room for AdjustRowHeight progress
|
||||
if (bRangeIsDetermined)
|
||||
EndPaste(false);
|
||||
|
||||
- if (mbImportBroadcast)
|
||||
+ if (mbImportBroadcast && !mbOverwriting)
|
||||
{
|
||||
pDoc->BroadcastCells(aRange, SC_HINT_DATACHANGED);
|
||||
pDocSh->PostDataChanged();
|
||||
diff --git a/sc/source/ui/inc/impex.hxx b/sc/source/ui/inc/impex.hxx
|
||||
index 7bd3914..22ced95 100644
|
||||
--- a/sc/source/ui/inc/impex.hxx
|
||||
+++ b/sc/source/ui/inc/impex.hxx
|
||||
@@ -67,6 +67,9 @@ class ScImportExport
|
||||
bool bOverflowCell; // too much data for a cell
|
||||
bool mbApi;
|
||||
bool mbImportBroadcast; // whether or not to broadcast after data import.
|
||||
+ bool mbOverwriting; // Whether we could be overwriting existing values (paste).
|
||||
+ // In this case we cannot use the insert optimization, but we
|
||||
+ // do not need to broadcast after the import.
|
||||
ScExportTextOptions mExportTextOptions;
|
||||
|
||||
ScAsciiOptions* pExtOptions; // extended options
|
||||
@@ -155,6 +158,7 @@ public:
|
||||
bool IsApi() const { return mbApi; }
|
||||
void SetApi( bool bApi ) { mbApi = bApi; }
|
||||
void SetImportBroadcast( bool b ) { mbImportBroadcast = b; }
|
||||
+ void SetOverwriting( const bool bOverwriting ) { mbOverwriting = bOverwriting; }
|
||||
const ScExportTextOptions& GetExportTextOptions() { return mExportTextOptions; }
|
||||
void SetExportTextOptions( const ScExportTextOptions& options ) { mExportTextOptions = options; }
|
||||
};
|
||||
diff --git a/sc/source/ui/view/viewfun5.cxx b/sc/source/ui/view/viewfun5.cxx
|
||||
index 27ff0f4..983a39e 100644
|
||||
--- a/sc/source/ui/view/viewfun5.cxx
|
||||
+++ b/sc/source/ui/view/viewfun5.cxx
|
||||
@@ -293,7 +293,7 @@ bool ScViewFunc::PasteDataFormat( sal_uLong nFormatId,
|
||||
{
|
||||
ScAddress aCellPos( nPosX, nPosY, GetViewData().GetTabNo() );
|
||||
ScImportExport aObj( GetViewData().GetDocument(), aCellPos );
|
||||
- aObj.SetImportBroadcast(true);
|
||||
+ aObj.SetOverwriting( true );
|
||||
|
||||
OUString aStr;
|
||||
SotStorageStreamRef xStream;
|
||||
--
|
||||
2.1.0
|
||||
|
Loading…
Reference in new issue