summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sc/source/filter/xml/xmlexprt.cxx14
1 files changed, 14 insertions, 0 deletions
diff --git a/sc/source/filter/xml/xmlexprt.cxx b/sc/source/filter/xml/xmlexprt.cxx
index 2b4cbef96e06..70243ebf6638 100644
--- a/sc/source/filter/xml/xmlexprt.cxx
+++ b/sc/source/filter/xml/xmlexprt.cxx
@@ -105,6 +105,7 @@
#include <rtl/ustring.hxx>
#include <tools/color.hxx>
+#include <tools/urlobj.hxx>
#include <rtl/math.hxx>
#include <svl/zforlist.hxx>
#include <svx/unoshape.hxx>
@@ -117,6 +118,9 @@
#include <svx/svdpage.hxx>
#include <svtools/miscopt.hxx>
+#include <officecfg/Office/Common.hxx>
+
+#include <com/sun/star/uno/XComponentContext.hpp>
#include <comphelper/processfactory.hxx>
#include <com/sun/star/beans/XPropertySet.hpp>
#include <com/sun/star/container/XNamed.hpp>
@@ -3080,7 +3084,17 @@ void writeContent(
{
// <text:a xlink:href="url" xlink:type="simple">value</text:a>
+ Reference< uno::XComponentContext > xContext = comphelper::getProcessComponentContext();
+ bool bUseRelative = officecfg::Office::Common::Save::URL::FileSystem::get( xContext );
OUString aURL = static_cast<const SvxURLField*>(pField)->GetURL();
+ if(bUseRelative)
+ {
+ OUString aBase = rExport.GetOrigFileName();
+ INetURLObject aURLObject(aBase);
+ aURLObject.removeSegment();
+ aURLObject.removeSegment();
+ aURL = INetURLObject::GetRelURL(aURLObject.GetMainURL(INetURLObject::DECODE_TO_IURI), aURL);
+ }
rExport.AddAttribute(XML_NAMESPACE_XLINK, XML_HREF, aURL);
rExport.AddAttribute(XML_NAMESPACE_XLINK, XML_TYPE, "simple");