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

Change-Id: I07e73a792230e6dc344c7120e3ad3c5f92a40769
This commit is contained in:
Miklos Vajna 2014-03-03 20:29:13 +01:00
parent 4452fa9a2e
commit a6158500ab
3 changed files with 21 additions and 125 deletions

View file

@ -1463,8 +1463,6 @@ void DomainMapper::sprmWithProps( Sprm& rSprm, PropertyMapPtr rContext, SprmType
handleUnderlineType(nIntValue, rContext);
}
break;
case NS_sprm::LN_CLid:
break; // sprmCLid
case NS_sprm::LN_CIco:
{
sal_Int32 nColor = 0;
@ -1604,30 +1602,6 @@ void DomainMapper::sprmWithProps( Sprm& rSprm, PropertyMapPtr rContext, SprmType
}
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:
/* break type
0 - No break

View file

@ -131,37 +131,6 @@
</UML:ModelElement.taggedValue>
</UML:Class>
<!--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-->
<UML:Class xmi.id="sprmCIco" name="sprmCIco">
<UML:ModelElement.stereotype>
@ -286,37 +255,6 @@
</UML:ModelElement.taggedValue>
</UML:Class>
<!--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-->
<UML:Class xmi.id="sprmSTextFlow" name="sprmSTextFlow">
<UML:ModelElement.stereotype>
@ -394,36 +332,6 @@
</UML:ModelElement.taggedValue>
</UML:Class>
<!--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-->
</UML:Namespace.ownedElement>
</UML:Model>

View file

@ -2988,17 +2988,29 @@ int RTFDocumentImpl::dispatchValue(RTFKeyword nKeyword, int nParam)
case RTF_EXPNDTW: nSprm = NS_ooxml::LN_EG_RPrBase_spacing; 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_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;
}
if (nSprm > 0)
{
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.
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;
}
// Trivial paragraph sprms.
@ -3221,10 +3233,12 @@ int RTFDocumentImpl::dispatchValue(RTFKeyword nKeyword, int nParam)
m_aDefaultState.aCharacterSprms.set(NS_sprm::LN_CRgFtc0, pIntValue);
break;
case RTF_DEFLANG:
m_aDefaultState.aCharacterSprms.set(NS_sprm::LN_CRgLid0, pIntValue);
break;
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;
case RTF_CHCBPAT:
{