diff options
author | Miklos Vajna <vmiklos@suse.cz> | 2012-07-25 17:36:33 +0200 |
---|---|---|
committer | Miklos Vajna <vmiklos@suse.cz> | 2012-07-26 09:44:14 +0200 |
commit | cc22622f379a5dc59a00625cdace561e4ba14c14 (patch) | |
tree | 6ea22ad808ea9ff0fc4f74d939e07757d6f5a09a /starmath | |
parent | a079bacad186337feb9b7d89ac5a60deb25d02dd (diff) |
export RTF_MLIM{UPP,LOW}
Change-Id: Ic47868daa3e9bd7defbc76a1ab1bfc717c48bee7
Diffstat (limited to 'starmath')
-rw-r--r-- | starmath/source/rtfexport.cxx | 42 |
1 files changed, 40 insertions, 2 deletions
diff --git a/starmath/source/rtfexport.cxx b/starmath/source/rtfexport.cxx index 9a0a68c8946f..32b62ff1712e 100644 --- a/starmath/source/rtfexport.cxx +++ b/starmath/source/rtfexport.cxx @@ -65,6 +65,9 @@ void SmRtfExport::HandleNode(const SmNode* pNode, int nLevel) case NTEXT: HandleText(pNode,nLevel); break; + case NVERTICAL_BRACE: + HandleVerticalBrace(static_cast<const SmVerticalBraceNode*>(pNode), nLevel); + break; case NBRACE: HandleBrace( static_cast< const SmBraceNode* >( pNode ), nLevel ); break; @@ -428,9 +431,44 @@ void SmRtfExport::HandleBrace(const SmBraceNode* pNode, int nLevel) m_pBuffer->append("}"); // md } -void SmRtfExport::HandleVerticalBrace(const SmVerticalBraceNode* /*pNode*/, int /*nLevel*/) +void SmRtfExport::HandleVerticalBrace(const SmVerticalBraceNode* pNode, int nLevel) { - SAL_INFO("starmath.rtf", "TODO: " << OSL_THIS_FUNC); + SAL_INFO("starmath.rtf", "Vertical: " << int(pNode->GetToken().eType)); + switch (pNode->GetToken().eType) + { + case TOVERBRACE: + case TUNDERBRACE: + { + bool top = (pNode->GetToken().eType == TOVERBRACE); + if (top) + m_pBuffer->append("{\\mlimUpp "); + else + m_pBuffer->append("{\\mlimLow "); + m_pBuffer->append("{\\me "); + m_pBuffer->append("{\\mgroupChr "); + m_pBuffer->append("{\\mgroupChrPr "); + m_pBuffer->append("{\\mchr "); + m_pBuffer->append(mathSymbolToString(pNode->Brace())); + m_pBuffer->append("}"); // mchr + // TODO not sure if pos and vertJc are correct + m_pBuffer->append("{\\mpos ").append(top ? "top" : "bot").append("}"); + m_pBuffer->append("{\\mvertJc ").append(top ? "bot" : "top").append("}"); + m_pBuffer->append("}"); // mgroupChrPr + m_pBuffer->append("{\\me "); + HandleNode(pNode->Body(), nLevel + 1); + m_pBuffer->append("}"); // me + m_pBuffer->append("}"); // mgroupChr + m_pBuffer->append("}"); // me + m_pBuffer->append("{\\mlim "); + HandleNode(pNode->Script(), nLevel + 1); + m_pBuffer->append("}"); // mlim + m_pBuffer->append("}"); // mlimUpp or mlimLow + break; + } + default: + SAL_INFO("starmath.rtf", "TODO: " << OSL_THIS_FUNC << " unhandled vertical brace type"); + break; + } } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |