Kaydet (Commit) a6158500 authored tarafından Miklos Vajna's avatar Miklos Vajna

writerfilter: convert sprm:C{Lid,LidBi,RgLid0,RgLid1}

Change-Id: I07e73a792230e6dc344c7120e3ad3c5f92a40769
üst 4452fa9a
...@@ -1463,8 +1463,6 @@ void DomainMapper::sprmWithProps( Sprm& rSprm, PropertyMapPtr rContext, SprmType ...@@ -1463,8 +1463,6 @@ void DomainMapper::sprmWithProps( Sprm& rSprm, PropertyMapPtr rContext, SprmType
handleUnderlineType(nIntValue, rContext); handleUnderlineType(nIntValue, rContext);
} }
break; break;
case NS_sprm::LN_CLid:
break; // sprmCLid
case NS_sprm::LN_CIco: case NS_sprm::LN_CIco:
{ {
sal_Int32 nColor = 0; sal_Int32 nColor = 0;
...@@ -1604,30 +1602,6 @@ void DomainMapper::sprmWithProps( Sprm& rSprm, PropertyMapPtr rContext, SprmType ...@@ -1604,30 +1602,6 @@ void DomainMapper::sprmWithProps( Sprm& rSprm, PropertyMapPtr rContext, SprmType
} }
break; break;
} }
case NS_sprm::LN_CLidBi: // sprmCLidBi language complex
case NS_sprm::LN_CRgLid0: // sprmCRgLid0 language Western
case NS_sprm::LN_CRgLid1: // sprmCRgLid1 language Asian
{
lang::Locale aLocale( LanguageTag( (LanguageType)nIntValue).getLocale());
PropertyIds aPropId;
switch (nSprmId)
{
case NS_sprm::LN_CRgLid0:
aPropId = PROP_CHAR_LOCALE;
break;
case NS_sprm::LN_CRgLid1:
aPropId = PROP_CHAR_LOCALE_ASIAN;
break;
default:
aPropId = PROP_CHAR_LOCALE_COMPLEX;
break;
}
rContext->Insert(aPropId, uno::makeAny( aLocale ) );
}
break;
case NS_ooxml::LN_EG_SectPrContents_type: case NS_ooxml::LN_EG_SectPrContents_type:
/* break type /* break type
0 - No break 0 - No break
......
...@@ -131,37 +131,6 @@ ...@@ -131,37 +131,6 @@
</UML:ModelElement.taggedValue> </UML:ModelElement.taggedValue>
</UML:Class> </UML:Class>
<!--SPRM sprmCKul--> <!--SPRM sprmCKul-->
<!--SPRM sprmCLid-->
<UML:Class xmi.id="sprmCLid" name="sprmCLid">
<UML:ModelElement.stereotype>
<UML:Stereotype xmi.idref="ww8sprm"/>
</UML:ModelElement.stereotype>
<UML:ModelElement.taggedValue>
<UML:TaggedValue>
<UML:TaggedValue.dataValue>0x4A41</UML:TaggedValue.dataValue>
<UML:TaggedValue.type>
<UML:TagDefinition xmi.idref="sprmcode"/>
</UML:TaggedValue.type>
</UML:TaggedValue>
</UML:ModelElement.taggedValue>
<UML:ModelElement.taggedValue>
<UML:TaggedValue>
<UML:TaggedValue.dataValue>rtf:sprmCLid</UML:TaggedValue.dataValue>
<UML:TaggedValue.type>
<UML:TagDefinition xmi.idref="sprmid"/>
</UML:TaggedValue.type>
</UML:TaggedValue>
</UML:ModelElement.taggedValue>
<UML:ModelElement.taggedValue>
<UML:TaggedValue>
<UML:TaggedValue.dataValue>character</UML:TaggedValue.dataValue>
<UML:TaggedValue.type>
<UML:TagDefinition xmi.idref="kind"/>
</UML:TaggedValue.type>
</UML:TaggedValue>
</UML:ModelElement.taggedValue>
</UML:Class>
<!--SPRM sprmCLid-->
<!--SPRM sprmCIco--> <!--SPRM sprmCIco-->
<UML:Class xmi.id="sprmCIco" name="sprmCIco"> <UML:Class xmi.id="sprmCIco" name="sprmCIco">
<UML:ModelElement.stereotype> <UML:ModelElement.stereotype>
...@@ -286,37 +255,6 @@ ...@@ -286,37 +255,6 @@
</UML:ModelElement.taggedValue> </UML:ModelElement.taggedValue>
</UML:Class> </UML:Class>
<!--SPRM sprmCRgFtc2--> <!--SPRM sprmCRgFtc2-->
<!--SPRM sprmCLidBi-->
<UML:Class xmi.id="sprmCLidBi" name="sprmCLidBi">
<UML:ModelElement.stereotype>
<UML:Stereotype xmi.idref="ww8sprm"/>
</UML:ModelElement.stereotype>
<UML:ModelElement.taggedValue>
<UML:TaggedValue>
<UML:TaggedValue.dataValue>0x485F</UML:TaggedValue.dataValue>
<UML:TaggedValue.type>
<UML:TagDefinition xmi.idref="sprmcode"/>
</UML:TaggedValue.type>
</UML:TaggedValue>
</UML:ModelElement.taggedValue>
<UML:ModelElement.taggedValue>
<UML:TaggedValue>
<UML:TaggedValue.dataValue>rtf:sprmCLidBi</UML:TaggedValue.dataValue>
<UML:TaggedValue.type>
<UML:TagDefinition xmi.idref="sprmid"/>
</UML:TaggedValue.type>
</UML:TaggedValue>
</UML:ModelElement.taggedValue>
<UML:ModelElement.taggedValue>
<UML:TaggedValue>
<UML:TaggedValue.dataValue>character</UML:TaggedValue.dataValue>
<UML:TaggedValue.type>
<UML:TagDefinition xmi.idref="kind"/>
</UML:TaggedValue.type>
</UML:TaggedValue>
</UML:ModelElement.taggedValue>
</UML:Class>
<!--SPRM sprmCLidBi-->
<!--SPRM sprmSTextFlow--> <!--SPRM sprmSTextFlow-->
<UML:Class xmi.id="sprmSTextFlow" name="sprmSTextFlow"> <UML:Class xmi.id="sprmSTextFlow" name="sprmSTextFlow">
<UML:ModelElement.stereotype> <UML:ModelElement.stereotype>
...@@ -394,36 +332,6 @@ ...@@ -394,36 +332,6 @@
</UML:ModelElement.taggedValue> </UML:ModelElement.taggedValue>
</UML:Class> </UML:Class>
<!--SPRM sprmPDxaLeft1--> <!--SPRM sprmPDxaLeft1-->
<!--SPRM sprmCRgLid0-->
<UML:Class xmi.id="sprmCRgLid0" name="sprmCRgLid0">
<UML:ModelElement.stereotype>
<UML:Stereotype xmi.idref="ww8sprm"/>
</UML:ModelElement.stereotype>
<UML:ModelElement.taggedValue>
<UML:TaggedValue>
<UML:TaggedValue.dataValue>0x4873</UML:TaggedValue.dataValue>
<UML:TaggedValue.type>
<UML:TagDefinition xmi.idref="sprmcode"/>
</UML:TaggedValue.type>
</UML:TaggedValue>
</UML:ModelElement.taggedValue>
</UML:Class>
<!--SPRM sprmCRgLid0-->
<!--SPRM sprmCRgLid1-->
<UML:Class xmi.id="sprmCRgLid1" name="sprmCRgLid1">
<UML:ModelElement.stereotype>
<UML:Stereotype xmi.idref="ww8sprm"/>
</UML:ModelElement.stereotype>
<UML:ModelElement.taggedValue>
<UML:TaggedValue>
<UML:TaggedValue.dataValue>0x4874</UML:TaggedValue.dataValue>
<UML:TaggedValue.type>
<UML:TagDefinition xmi.idref="sprmcode"/>
</UML:TaggedValue.type>
</UML:TaggedValue>
</UML:ModelElement.taggedValue>
</UML:Class>
<!--SPRM sprmCRgLid1-->
<!--SPRMS--> <!--SPRMS-->
</UML:Namespace.ownedElement> </UML:Namespace.ownedElement>
</UML:Model> </UML:Model>
......
...@@ -2988,17 +2988,29 @@ int RTFDocumentImpl::dispatchValue(RTFKeyword nKeyword, int nParam) ...@@ -2988,17 +2988,29 @@ int RTFDocumentImpl::dispatchValue(RTFKeyword nKeyword, int nParam)
case RTF_EXPNDTW: nSprm = NS_ooxml::LN_EG_RPrBase_spacing; break; case RTF_EXPNDTW: nSprm = NS_ooxml::LN_EG_RPrBase_spacing; break;
case RTF_KERNING: nSprm = NS_ooxml::LN_EG_RPrBase_kern; break; case RTF_KERNING: nSprm = NS_ooxml::LN_EG_RPrBase_kern; break;
case RTF_CHARSCALEX: nSprm = NS_ooxml::LN_EG_RPrBase_w; break; case RTF_CHARSCALEX: nSprm = NS_ooxml::LN_EG_RPrBase_w; break;
case RTF_LANG: nSprm = NS_sprm::LN_CRgLid0; break;
case RTF_LANGFE: nSprm = NS_sprm::LN_CRgLid1; break;
case RTF_ALANG: nSprm = NS_sprm::LN_CLidBi; break;
default: break; default: break;
} }
if (nSprm > 0) if (nSprm > 0)
{ {
m_aStates.top().aCharacterSprms.set(nSprm, pIntValue); m_aStates.top().aCharacterSprms.set(nSprm, pIntValue);
return 0;
}
// Trivial character attributes.
switch (nKeyword)
{
case RTF_LANG: nSprm = NS_ooxml::LN_CT_Language_val; break;
case RTF_LANGFE: nSprm = NS_ooxml::LN_CT_Language_eastAsia; break;
case RTF_ALANG: nSprm = NS_ooxml::LN_CT_Language_bidi; break;
default: break;
}
if (nSprm > 0)
{
LanguageTag aTag((LanguageType)nParam);
RTFValue::Pointer_t pValue(new RTFValue(aTag.getBcp47()));
lcl_putNestedAttribute(m_aStates.top().aCharacterSprms, NS_ooxml::LN_EG_RPrBase_lang, nSprm, pValue);
// Language is a character property, but we should store it at a paragraph level as well for fields. // Language is a character property, but we should store it at a paragraph level as well for fields.
if (nKeyword == RTF_LANG && m_bNeedPap) if (nKeyword == RTF_LANG && m_bNeedPap)
m_aStates.top().aParagraphSprms.set(nSprm, pIntValue); lcl_putNestedAttribute(m_aStates.top().aParagraphSprms, NS_ooxml::LN_EG_RPrBase_lang, nSprm, pValue);
return 0; return 0;
} }
// Trivial paragraph sprms. // Trivial paragraph sprms.
...@@ -3221,10 +3233,12 @@ int RTFDocumentImpl::dispatchValue(RTFKeyword nKeyword, int nParam) ...@@ -3221,10 +3233,12 @@ int RTFDocumentImpl::dispatchValue(RTFKeyword nKeyword, int nParam)
m_aDefaultState.aCharacterSprms.set(NS_sprm::LN_CRgFtc0, pIntValue); m_aDefaultState.aCharacterSprms.set(NS_sprm::LN_CRgFtc0, pIntValue);
break; break;
case RTF_DEFLANG: case RTF_DEFLANG:
m_aDefaultState.aCharacterSprms.set(NS_sprm::LN_CRgLid0, pIntValue);
break;
case RTF_ADEFLANG: case RTF_ADEFLANG:
m_aDefaultState.aCharacterSprms.set(NS_sprm::LN_CLidBi, pIntValue); {
LanguageTag aTag((LanguageType)nParam);
RTFValue::Pointer_t pValue(new RTFValue(aTag.getBcp47()));
lcl_putNestedAttribute(m_aStates.top().aCharacterSprms, (nKeyword == RTF_DEFLANG ? NS_ooxml::LN_EG_RPrBase_lang : NS_ooxml::LN_CT_Language_bidi), nSprm, pValue);
}
break; break;
case RTF_CHCBPAT: case RTF_CHCBPAT:
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment