diff options
-rw-r--r-- | sc/source/filter/xml/xmlexprt.cxx | 14 |
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"); |