From b38f47f686c70587d2265f97719bd1d8da5b5166 Mon Sep 17 00:00:00 2001 From: Stephan Bergmann Date: Tue, 20 Aug 2013 10:31:49 +0200 Subject: [PATCH] Related: rhbz#895690 Always try to do a mount when opening a file via GIO --- ...to-mount-in-gio-Content-getGFileInfo.patch | 78 +++++++++++++++++++ libreoffice.spec | 7 +- 2 files changed, 84 insertions(+), 1 deletion(-) create mode 100644 0001-Always-try-to-mount-in-gio-Content-getGFileInfo.patch diff --git a/0001-Always-try-to-mount-in-gio-Content-getGFileInfo.patch b/0001-Always-try-to-mount-in-gio-Content-getGFileInfo.patch new file mode 100644 index 0000000..25ef482 --- /dev/null +++ b/0001-Always-try-to-mount-in-gio-Content-getGFileInfo.patch @@ -0,0 +1,78 @@ +From cbeca0676595037d29c7191c38c643d47d9d6e4a Mon Sep 17 00:00:00 2001 +From: Stephan Bergmann +Date: Fri, 14 Jun 2013 11:22:51 +0200 +Subject: [PATCH] Always try to mount in gio::Content::getGFileInfo + +...and not only if the caller happens to pass in non-null ppError. Otherwise, +calling soffice with a document URL handled by the gio UCP that is not yet +gio-mounted would silently do nothing and exit with EXIT_SUCCESS, as the first +thing the type detection code does on the URL is execute "getPropertyValues" for +"IsDocument", which calls getGFileInfo with null ppError, so a void instead of a +boolean value is returned, which then derails the type detection code to +silently fail (which is another problem that needs fixing). + +Change-Id: I48a84428cdee5caead02909abc2efd3ae3722052 +(cherry picked from commit 4d8bf09305fc4e4bd652187aac0a02398413ba65) +--- + ucb/source/ucp/gio/gio_content.cxx | 42 +++++++++++++++++++++++--------------- + 1 file changed, 26 insertions(+), 16 deletions(-) + +diff --git a/ucb/source/ucp/gio/gio_content.cxx b/ucb/source/ucp/gio/gio_content.cxx +index 34857d2..4fe7e83 100644 +--- a/ucb/source/ucp/gio/gio_content.cxx ++++ b/ucb/source/ucp/gio/gio_content.cxx +@@ -337,25 +337,35 @@ MountOperation::~MountOperation() + + GFileInfo* Content::getGFileInfo(const uno::Reference< ucb::XCommandEnvironment >& xEnv, GError **ppError) + { +- /*If we don't have it already, and we're not a "pre-creation" content then query for the info"*/ +- if (!mpInfo && !mbTransient) +- { +- if (!(mpInfo = g_file_query_info(getGFile(), "*", G_FILE_QUERY_INFO_NONE, NULL, ppError))) +- { +- //Try and mount if unmounted +- if (ppError && (*ppError)->code == G_IO_ERROR_NOT_MOUNTED) +- { +- g_error_free(*ppError); +- +- MountOperation aMounter(xEnv); +- *ppError = aMounter.Mount(getGFile()); +- +- //No Mount error, reattempt query +- if (!*ppError) +- mpInfo = g_file_query_info(getGFile(), "*", G_FILE_QUERY_INFO_NONE, NULL, ppError); ++ GError * err = 0; ++ if (mpInfo == 0 && !mbTransient) { ++ for (bool retried = false;; retried = true) { ++ mpInfo = g_file_query_info( ++ getGFile(), "*", G_FILE_QUERY_INFO_NONE, 0, &err); ++ if (mpInfo != 0) { ++ break; ++ } ++ assert(err != 0); ++ if (err->code != G_IO_ERROR_NOT_MOUNTED || retried) { ++ break; ++ } ++ SAL_INFO( ++ "ucb.ucp.gio", ++ "G_IO_ERROR_NOT_MOUNTED \"" << err->message ++ << "\", trying to mount"); ++ g_error_free(err); ++ err = MountOperation(xEnv).Mount(getGFile()); ++ if (err != 0) { ++ break; + } + } + } ++ if (ppError != 0) { ++ *ppError = err; ++ } else if (err != 0) { ++ SAL_WARN("ucb.ucp.gio", "ignoring GError \"" << err->message << "\""); ++ g_error_free(err); ++ } + return mpInfo; + } + +-- +1.8.1.4 + diff --git a/libreoffice.spec b/libreoffice.spec index cea7ce6..b0b6143 100644 --- a/libreoffice.spec +++ b/libreoffice.spec @@ -43,7 +43,7 @@ Summary: Free Software Productivity Suite Name: libreoffice Epoch: 1 Version: %{libo_version}.1 -Release: 2%{?libo_prerelease}%{?dist} +Release: 3%{?libo_prerelease}%{?dist} License: (MPLv1.1 or LGPLv3+) and LGPLv3 and LGPLv2+ and BSD and (MPLv1.1 or GPLv2 or LGPLv2 or Netscape) and Public Domain and ASL 2.0 and Artistic and MPLv2.0 Group: Applications/Productivity URL: http://www.libreoffice.org/default/ @@ -257,6 +257,7 @@ Patch16: 0002-Related-rhbz-968892-discard-impossible-languages-for.patch Patch17: 0001-Resolves-fdo-48835-application-menu-for-LibreOffice.patch Patch18: 0001-Resolves-fdo-67743-user-autocorr-file-not-written.patch Patch19: 0001-only-use-the-SSPI-support-with-internal-neon.patch +Patch20: 0001-Always-try-to-mount-in-gio-Content-getGFileInfo.patch %define instdir %{_libdir} %define baseinstdir %{instdir}/libreoffice @@ -1008,6 +1009,7 @@ mv -f redhat.soc extras/source/palettes/standard.soc %patch17 -p1 -b .fdo-48835-application-menu-for-LibreOffice.patch %patch18 -p1 -b .fdo-67743-user-autocorr-file-not-written.patch %patch19 -p1 -b .only-use-the-SSPI-support-with-internal-neon.patch +%patch20 -p1 -b .Always-try-to-mount-in-gio-Content-getGFileInfo.patch # TODO: check this # these are horribly incomplete--empty translations and copied english @@ -2099,6 +2101,9 @@ update-desktop-database %{_datadir}/applications &> /dev/null || : %endif %changelog +* Tue Aug 20 2013 Stephan Bergmann - 1:4.1.1.1-3-UNBUILT +- Related: rhbz#895690 Always try to do a mount when opening a file via GIO + * Mon Aug 19 2013 Marek Kasik - 1:4.1.1.1-2 - Rebuild (poppler-0.24.0)