summaryrefslogtreecommitdiff
path: root/xmloff/source
diff options
context:
space:
mode:
authorFrank Schönheit <fs@openoffice.org>2001-05-28 14:05:34 +0000
committerFrank Schönheit <fs@openoffice.org>2001-05-28 14:05:34 +0000
commite17a01afcd9767a30bfcc9b1177e5cf13934aaa4 (patch)
treeba4b8ef5c80c653b8c2499c8c2380a3fc03cb208 /xmloff/source
parent8c74e89ae64e8a2c9ddc0024cbb74fcdd4a37461 (diff)
#86712# exportStyleAttributes: for the graphics family, export the control data style as 'data-style-name' attribute
Diffstat (limited to 'xmloff/source')
-rw-r--r--xmloff/source/style/xmlaustp.cxx55
1 files changed, 53 insertions, 2 deletions
diff --git a/xmloff/source/style/xmlaustp.cxx b/xmloff/source/style/xmlaustp.cxx
index ed4a67458568..0265cace608f 100644
--- a/xmloff/source/style/xmlaustp.cxx
+++ b/xmloff/source/style/xmlaustp.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: xmlaustp.cxx,v $
*
- * $Revision: 1.9 $
+ * $Revision: 1.10 $
*
- * last change: $Author: sab $ $Date: 2000-12-01 10:56:29 $
+ * last change: $Author: fs $ $Date: 2001-05-28 15:05:34 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -84,6 +84,9 @@
#ifndef _XMLOFF_XMLNMSPE_HXX
#include "xmlnmspe.hxx"
#endif
+#ifndef _XMLOFF_XMLTOKEN_HXX
+#include "xmltoken.hxx"
+#endif
#ifndef _XMLOFF_PAGEMASTERSTYLEMAP_HXX
#include "PageMasterStyleMap.hxx"
@@ -112,6 +115,54 @@ void SvXMLAutoStylePoolP::exportStyleAttributes(
const SvXMLUnitConverter& rUnitConverter,
const SvXMLNamespaceMap& rNamespaceMap ) const
{
+ if (XML_STYLE_FAMILY_SD_GRAPHICS_ID == nFamily)
+ { // it's a graphics style
+ UniReference< XMLPropertySetMapper > aPropertyMapper = rPropExp.getPropertySetMapper();
+ DBG_ASSERT(aPropertyMapper.is(), "SvXMLAutoStylePoolP::exportStyleAttributes: invalid property set mapper!");
+
+#ifdef DBG_UTIL
+ sal_Bool bFoundControlShapeDataStyle = sal_False;
+#endif
+ for ( vector< XMLPropertyState >::const_iterator pProp = rProperties.begin();
+ pProp != rProperties.end();
+ ++pProp
+ )
+ {
+ if (pProp->mnIndex > -1)
+ { // it's a valid property
+ if (CTF_SD_CONTROL_SHAPE_DATA_STYLE == aPropertyMapper->GetEntryContextId(pProp->mnIndex))
+ { // it's the control shape data style property
+
+#ifdef DBG_UTIL
+ if (bFoundControlShapeDataStyle)
+ {
+ DBG_ERROR("SvXMLAutoStylePoolP::exportStyleAttributes: found two properties with the ControlShapeDataStyle context id!");
+ // already added the attribute for the first occurence
+ break;
+ }
+#endif
+ // obtain the data style name
+ ::rtl::OUString sControlDataStyleName;
+ pProp->maValue >>= sControlDataStyleName;
+ DBG_ASSERT(sControlDataStyleName.getLength(), "SvXMLAutoStylePoolP::exportStyleAttributes: invalid property value for the data style name!");
+
+ // add the attribute
+ rtl::OUString sAttrName( rNamespaceMap.GetQNameByKey( aPropertyMapper->GetEntryNameSpace(pProp->mnIndex), aPropertyMapper->GetEntryXMLName(pProp->mnIndex) ) );
+ rAttrList.AddAttribute(sAttrName, ::xmloff::token::GetXMLToken(::xmloff::token::XML_CDATA), sControlDataStyleName);
+
+#ifdef DBG_UTIL
+ // in a non-pro version, check if there is another property with the special context id we're handling here
+ bFoundControlShapeDataStyle = sal_True;
+ continue;
+#else
+ // in a pro version, just leave the loop
+ break;
+#endif
+ }
+ }
+ }
+ }
+
if( nFamily == XML_STYLE_FAMILY_PAGE_MASTER )
{
for( vector< XMLPropertyState >::const_iterator pProp = rProperties.begin(); pProp != rProperties.end(); pProp++ )