blob: 7535c1a3b1856e4467abdce0cd3c6cbad122def4 [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
#include "rtfattributeoutput.hxx"
#include "rtfexport.hxx"
#include "rtfsdrexport.hxx"
#include "writerwordglue.hxx"
#include "wrtww8.hxx"
#include "ww8par.hxx"
#include "fmtcntnt.hxx"
#include "fmtsrnd.hxx"
#include "fchrfmt.hxx"
#include "tgrditem.hxx"
#include "fmtruby.hxx"
#include "charfmt.hxx"
#include "breakit.hxx"
#include <i18npool/mslangid.hxx>
#include <hintids.hxx>
#include <svl/poolitem.hxx>
#include <svtools/rtfkeywd.hxx>
#include <editeng/fontitem.hxx>
#include <editeng/tstpitem.hxx>
#include <editeng/adjitem.hxx>
#include <editeng/spltitem.hxx>
#include <editeng/widwitem.hxx>
#include <editeng/lspcitem.hxx>
#include <editeng/keepitem.hxx>
#include <editeng/shaditem.hxx>
#include <editeng/brshitem.hxx>
#include <editeng/postitem.hxx>
#include <editeng/wghtitem.hxx>
#include <editeng/kernitem.hxx>
#include <editeng/crsditem.hxx>
#include <editeng/cmapitem.hxx>
#include <editeng/wrlmitem.hxx>
#include <editeng/udlnitem.hxx>
#include <editeng/langitem.hxx>
#include <editeng/escpitem.hxx>
#include <editeng/fhgtitem.hxx>
#include <editeng/colritem.hxx>
#include <editeng/hyznitem.hxx>
#include <editeng/brkitem.hxx>
#include <editeng/lrspitem.hxx>
#include <editeng/ulspitem.hxx>
#include <editeng/boxitem.hxx>
#include <editeng/cntritem.hxx>
#include <editeng/shdditem.hxx>
#include <editeng/akrnitem.hxx>
#include <editeng/pbinitem.hxx>
#include <editeng/emphitem.hxx>
#include <editeng/twolinesitem.hxx>
#include <editeng/charscaleitem.hxx>
#include <editeng/charrotateitem.hxx>
#include <editeng/charreliefitem.hxx>
#include <editeng/paravertalignitem.hxx>
#include <editeng/pgrditem.hxx>
#include <editeng/frmdiritem.hxx>
#include <editeng/blnkitem.hxx>
#include <editeng/charhiddenitem.hxx>
#include <svx/svdmodel.hxx>
#include <svx/svdobj.hxx>
#include <svx/fmglob.hxx>
#include <svx/svdouno.hxx>
#include <filter/msfilter/msoleexp.hxx>
#include <docufld.hxx>
#include <flddropdown.hxx>
#include <format.hxx>
#include <fmtclds.hxx>
#include <fmtinfmt.hxx>
#include <fmtfld.hxx>
#include <fmtfsize.hxx>
#include <fmtftn.hxx>
#include <fmtrowsplt.hxx>
#include <fmtline.hxx>
#include <fmtanchr.hxx>
#include <frmfmt.hxx>
#include <frmatr.hxx>
#include <ftninfo.hxx>
#include <htmltbl.hxx>
#include <ndgrf.hxx>
#include <ndtxt.hxx>
#include <node.hxx>
#include <pagedesc.hxx>
#include <paratr.hxx>
#include <swmodule.hxx>
#include <swtable.hxx>
#include <txtftn.hxx>
#include <txtinet.hxx>
#include <numrule.hxx>
#include <grfatr.hxx>
#include <ndole.hxx>
#include <lineinfo.hxx>
#include <rtf.hxx>
#include <rtl/strbuf.hxx>
#include <rtl/ustrbuf.hxx>
#include <rtl/ustring.hxx>
#include <tools/color.hxx>
#include <vcl/cvtgrf.hxx>
#include <com/sun/star/i18n/ScriptType.hdl>
#include <com/sun/star/drawing/XShape.hpp>
#include <com/sun/star/frame/XModel.hpp>
#include <com/sun/star/chart2/XChartDocument.hpp>
#include <com/sun/star/beans/XPropertySet.hpp>
#include <com/sun/star/container/XNamed.hpp>
#include <osl/diagnose.h>
using rtl::OString;
using rtl::OStringBuffer;
using rtl::OUString;
using rtl::OUStringBuffer;
using rtl::OUStringToOString;
using namespace nsSwDocInfoSubType;
using namespace nsFieldFlags;
using namespace sw::util;
using namespace ::com::sun::star;
//////////////////////////////////////////////////////////////////////////////
class MultiBufferEntry
{
private:
public:
MultiBufferEntry();
virtual ~MultiBufferEntry();
virtual void writeAndClear(SvStream& rTarget) = 0;
};
MultiBufferEntry::MultiBufferEntry()
{
}
MultiBufferEntry::~MultiBufferEntry()
{
}
//////////////////////////////////////////////////////////////////////////////
class MultiBufferString : public MultiBufferEntry
{
private:
rtl::OStringBuffer maBuffer;
public:
MultiBufferString(rtl::OStringBuffer& rBuffer);
virtual ~MultiBufferString();
rtl::OStringBuffer& getBuffer() { return maBuffer; }
virtual void writeAndClear(SvStream& rTarget);
};
MultiBufferString::MultiBufferString(rtl::OStringBuffer& rBuffer)
: MultiBufferEntry(),
maBuffer(rBuffer)
{
}
MultiBufferString::~MultiBufferString()
{
}
void MultiBufferString::writeAndClear(SvStream& rTarget)
{
rTarget << maBuffer.makeStringAndClear();
}
//////////////////////////////////////////////////////////////////////////////
class MultiBufferHex : public MultiBufferEntry
{
private:
sal_uInt8* mpData;
sal_uInt32 mnSize;
sal_uInt32 mnLimit;
public:
MultiBufferHex(
const sal_uInt8* pData,
sal_uInt32 nSize,
sal_uInt32 nLimit = 64);
virtual ~MultiBufferHex();
virtual void writeAndClear(SvStream& rTarget);
};
MultiBufferHex::MultiBufferHex(
const sal_uInt8* pData,
sal_uInt32 nSize,
sal_uInt32 nLimit)
: MultiBufferEntry(),
mpData(0),
mnSize(nSize),
mnLimit(nLimit)
{
if(mnSize)
{
mpData = new sal_uInt8[mnSize];
memcpy(mpData, pData, nSize);
}
}
MultiBufferHex::~MultiBufferHex()
{
if(mpData)
{
delete mpData;
}
}
void MultiBufferHex::writeAndClear(SvStream& rTarget)
{
if(mpData)
{
static OString hexArray[16] = {
OString('0'), OString('1'), OString('2'), OString('3'),
OString('4'), OString('5'), OString('6'), OString('7'),
OString('8'), OString('9'), OString('a'), OString('b'),
OString('c'), OString('d'), OString('e'), OString('f') };
for(sal_uInt32 a(0), nBreak(0); a < mnSize; a++, nBreak++)
{
const sal_uInt8 aData(mpData[a]);
rTarget << hexArray[aData >> 4];
rTarget << hexArray[aData & 0x0f];
if(mnLimit == nBreak)
{
static OString aNewLine = OString(RtfExport::sNewLine);
nBreak = 0;
rTarget << aNewLine;
}
}
delete mpData;
mpData = 0;
mnSize = 0;
}
}
//////////////////////////////////////////////////////////////////////////////
void MultiBuffer::clearContentVector()
{
while(!maContent.empty())
{
delete maContent.back();
maContent.pop_back();
}
}
MultiBuffer::MultiBuffer()
: maBuffer(),
maContent()
{
}
MultiBuffer::~MultiBuffer()
{
clearContentVector();
}
bool MultiBuffer::empty() const
{
return 0 == maBuffer.getLength() && maContent.empty();
}
void MultiBuffer::writeAndClear(SvStream& rTarget)
{
for(sal_uInt32 a(0); a < maContent.size(); a++)
{
maContent[a]->writeAndClear(rTarget);
}
clearContentVector();
rTarget << maBuffer.makeStringAndClear();
}
void MultiBuffer::appendAndClear(MultiBuffer& rSource)
{
if(!rSource.maContent.empty())
{
if(maBuffer.getLength())
{
maContent.push_back(new MultiBufferString(maBuffer));
maBuffer.setLength(0);
}
for(sal_uInt32 a(0); a < rSource.maContent.size(); a++)
{
maContent.push_back(rSource.maContent[a]);
}
rSource.maContent.clear();
}
maBuffer.append(rSource.maBuffer.getStr());
rSource.maBuffer.setLength(0);
}
void MultiBuffer::clear()
{
clearContentVector();
maBuffer.setLength(0);
}
void MultiBuffer::appendHexData(const sal_uInt8 *pGraphicAry, sal_uInt32 nSize, sal_uInt32 nLimit)
{
if(nSize)
{
if(maBuffer.getLength())
{
maContent.push_back(new MultiBufferString(maBuffer));
maBuffer.setLength(0);
}
maContent.push_back(new MultiBufferHex(pGraphicAry, nSize, nLimit));
}
}
//////////////////////////////////////////////////////////////////////////////
static OString OutTBLBorderLine(RtfExport &rExport, const SvxBorderLine* pLine, const sal_Char* pStr)
{
OStringBuffer aRet;
aRet.append(pStr);
if( pLine->GetInWidth() )
{
// double line
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDRDB);
switch( pLine->GetInWidth() )
{
case DEF_LINE_WIDTH_0:
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDRW "15");
break;
case DEF_LINE_WIDTH_1:
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDRW "30");
break;
case DEF_LINE_WIDTH_2:
case DEF_LINE_WIDTH_3:
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDRW "45");
break;
}
}
else
{
// single line
if( DEF_LINE_WIDTH_1 >= pLine->GetOutWidth() )
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDRS OOO_STRING_SVTOOLS_RTF_BRDRW).append((sal_Int32)pLine->GetOutWidth());
else
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDRTH OOO_STRING_SVTOOLS_RTF_BRDRW).append((sal_Int32)pLine->GetOutWidth() / 2);
}
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDRCF);
aRet.append((sal_Int32)rExport.GetColor(pLine->GetColor()));
return aRet.makeStringAndClear();
}
static OString OutBorderLine(RtfExport &rExport, const SvxBorderLine* pLine,
const sal_Char* pStr, sal_uInt16 nDist)
{
OStringBuffer aRet;
aRet.append(OutTBLBorderLine(rExport, pLine, pStr));
aRet.append(OOO_STRING_SVTOOLS_RTF_BRSP);
aRet.append((sal_Int32)nDist);
return aRet.makeStringAndClear();
}
static OString OutBorderLine( RtfExport &rExport, const SvxBorderLine* pLine,
const char* pStr )
{
OStringBuffer aRet;
aRet.append(pStr);
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDLNCOL);
aRet.append((sal_Int32)rExport.GetColor( pLine->GetColor() ) );
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDLNIN);
aRet.append((sal_Int32)pLine->GetInWidth());
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDLNOUT);
aRet.append((sal_Int32)pLine->GetOutWidth());
aRet.append(OOO_STRING_SVTOOLS_RTF_BRDLNDIST);
aRet.append((sal_Int32)pLine->GetDistance());
return aRet.makeStringAndClear();
}
void RtfAttributeOutput::RTLAndCJKState( bool bIsRTL, sal_uInt16 nScript )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
/*
You would have thought that
m_rExport.Strm() << (bIsRTL ? OOO_STRING_SVTOOLS_RTF_RTLCH : OOO_STRING_SVTOOLS_RTF_LTRCH); would be sufficent here ,
but looks like word needs to see the other directional token to be
satisified that all is kosher, otherwise it seems in ver 2003 to go and
semi-randomlyly stick strike through about the place. Perhaps
strikethrough is some ms developers "something is wrong signal" debugging
code that we're triggering ?
*/
if (bIsRTL) {
m_aStylesEnd.append(OOO_STRING_SVTOOLS_RTF_LTRCH);
m_aStylesEnd.append(' ');
m_aStylesEnd.append(OOO_STRING_SVTOOLS_RTF_RTLCH);
} else {
m_aStylesEnd.append(OOO_STRING_SVTOOLS_RTF_RTLCH);
m_aStylesEnd.append(' ');
m_aStylesEnd.append(OOO_STRING_SVTOOLS_RTF_LTRCH);
}
switch (nScript) {
case i18n::ScriptType::LATIN:
m_aStylesEnd.append(OOO_STRING_SVTOOLS_RTF_LOCH);
break;
case i18n::ScriptType::ASIAN:
m_aStylesEnd.append(OOO_STRING_SVTOOLS_RTF_DBCH);
break;
case i18n::ScriptType::COMPLEX:
/* noop */
break;
default:
/* should not happen? */
break;
}
}
void RtfAttributeOutput::StartParagraph( ww8::WW8TableNodeInfo::Pointer_t pTextNodeInfo )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
// Output table/table row/table cell starts if needed
if ( pTextNodeInfo.get() )
{
sal_uInt32 nRow = pTextNodeInfo->getRow();
sal_uInt32 nCell = pTextNodeInfo->getCell();
// New cell/row?
if ( m_nTableDepth > 0 && !m_bTableCellOpen )
{
ww8::WW8TableNodeInfoInner::Pointer_t pDeepInner( pTextNodeInfo->getInnerForDepth( m_nTableDepth ) );
OSL_ENSURE( pDeepInner, "TableNodeInfoInner not found");
if ( pDeepInner && pDeepInner->getCell() == 0 )
StartTableRow( pDeepInner );
StartTableCell( pDeepInner );
}
if ( nRow == 0 && nCell == 0 )
{
// Do we have to start the table?
// [If we are at the rigth depth already, it means that we
// continue the table cell]
sal_uInt32 nCurrentDepth = pTextNodeInfo->getDepth();
if ( nCurrentDepth > m_nTableDepth )
{
// Start all the tables that begin here
for ( sal_uInt32 nDepth = m_nTableDepth + 1; nDepth <= pTextNodeInfo->getDepth(); ++nDepth )
{
ww8::WW8TableNodeInfoInner::Pointer_t pInner( pTextNodeInfo->getInnerForDepth( nDepth ) );
m_bLastTable = (nDepth == pTextNodeInfo->getDepth());
StartTable( pInner );
StartTableRow( pInner );
StartTableCell( pInner );
}
m_nTableDepth = nCurrentDepth;
}
}
}
OSL_ENSURE(m_aRun.empty(), "m_aRun is not empty");
}
void RtfAttributeOutput::EndParagraph( ww8::WW8TableNodeInfoInner::Pointer_t pTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
FinishTableRowCell( pTextNodeInfoInner );
MultiBuffer aParagraph;
aParagraph.appendAndClear(m_aRun);
aParagraph.getOStringBuffer().append(m_aAfterRuns.makeStringAndClear());
if (m_bTblAfterCell)
m_bTblAfterCell = false;
else
{
aParagraph.getOStringBuffer().append(m_rExport.sNewLine);
aParagraph.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_PAR);
aParagraph.getOStringBuffer().append(' ');
}
if (m_nColBreakNeeded)
{
aParagraph.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_COLUMN);
m_nColBreakNeeded = false;
}
if (!m_bBufferSectionHeaders)
{
aParagraph.writeAndClear(m_rExport.Strm());
}
else
{
m_aSectionHeaders.appendAndClear(aParagraph);
}
}
void RtfAttributeOutput::EmptyParagraph()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << m_rExport.sNewLine << OOO_STRING_SVTOOLS_RTF_PAR << ' ';
}
void RtfAttributeOutput::StartParagraphProperties( const SwTxtNode& rNode )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
OSL_ENSURE(m_aStyles.getLength() == 0, "m_aStyles is not empty");
// output page/section breaks
SwNodeIndex aNextIndex( rNode, 1 );
m_rExport.Strm() << m_aSectionBreaks.makeStringAndClear();
m_bBufferSectionBreaks = true;
// output section headers / footers
if (!m_bBufferSectionHeaders)
{
m_aSectionHeaders.writeAndClear(m_rExport.Strm());
}
if ( aNextIndex.GetNode().IsTxtNode() )
{
const SwTxtNode* pTxtNode = static_cast< SwTxtNode* >( &aNextIndex.GetNode() );
m_rExport.OutputSectionBreaks( pTxtNode->GetpSwAttrSet(), *pTxtNode );
}
else if ( aNextIndex.GetNode().IsTableNode() )
{
const SwTableNode* pTableNode = static_cast< SwTableNode* >( &aNextIndex.GetNode() );
const SwFrmFmt *pFmt = pTableNode->GetTable().GetFrmFmt();
m_rExport.OutputSectionBreaks( &(pFmt->GetAttrSet()), *pTableNode );
}
m_bBufferSectionBreaks = false;
MultiBuffer aPar;
if (!m_rExport.bRTFFlySyntax)
{
aPar.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_PARD);
aPar.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_PLAIN);
aPar.getOStringBuffer().append(' ');
}
if (!m_bBufferSectionHeaders)
{
aPar.writeAndClear(m_rExport.Strm());
}
else
{
m_aSectionHeaders.appendAndClear(aPar);
}
}
void RtfAttributeOutput::EndParagraphProperties()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(m_aStylesEnd.makeStringAndClear());
m_rExport.Strm() << m_aStyles.makeStringAndClear();
}
void RtfAttributeOutput::StartRun( const SwRedlineData* pRedlineData )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aRun.getOStringBuffer().append('{');
// if there is some redlining in the document, output it
Redline( pRedlineData );
OSL_ENSURE(m_aRunText.empty(), "m_aRunText is not empty");
}
void RtfAttributeOutput::EndRun()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aRun.getOStringBuffer().append(m_rExport.sNewLine);
m_aRun.appendAndClear(m_aRunText);
m_aRun.getOStringBuffer().append('}');
}
void RtfAttributeOutput::StartRunProperties()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
OSL_ENSURE(m_aStyles.getLength() == 0, "m_aStyles is not empty");
}
void RtfAttributeOutput::EndRunProperties( const SwRedlineData* /*pRedlineData*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(m_aStylesEnd.makeStringAndClear());
m_aRun.getOStringBuffer().append(m_aStyles.makeStringAndClear());
}
void RtfAttributeOutput::RunText( const String& rText, rtl_TextEncoding eCharSet )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
RawText( rText, 0, eCharSet );
}
rtl::OStringBuffer& RtfAttributeOutput::RunText()
{
return m_aRunText.getOStringBuffer();
}
OStringBuffer& RtfAttributeOutput::Styles()
{
return m_aStyles;
}
void RtfAttributeOutput::RawText( const String& rText, bool /*bForceUnicode*/, rtl_TextEncoding eCharSet )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aRunText.getOStringBuffer().append(m_rExport.OutString(rText, eCharSet));
}
void RtfAttributeOutput::StartRuby( const SwTxtNode& /*rNode*/, const SwFmtRuby& /*rRuby*/ )
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
void RtfAttributeOutput::EndRuby()
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
bool RtfAttributeOutput::StartURL( const String& rUrl, const String& rTarget )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append('{');
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_FIELD);
m_aStyles.append('{');
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_IGNORE);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_FLDINST);
m_aStyles.append(" HYPERLINK ");
String sURL( rUrl );
if( sURL.Len() )
{
m_aStyles.append("\"");
m_aStyles.append(m_rExport.OutString( sURL, m_rExport.eCurrentEncoding));
m_aStyles.append("\" ");
}
if( rTarget.Len() )
{
m_aStyles.append("\\\\t \"");
m_aStyles.append(m_rExport.OutString( rTarget, m_rExport.eCurrentEncoding));
m_aStyles.append("\" ");
}
m_aStyles.append("}");
return true;
}
bool RtfAttributeOutput::EndURL()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
// close the fldrslt group
m_aRunText.getOStringBuffer().append('}');
// close the field group
m_aRunText.getOStringBuffer().append('}');
return true;
}
void RtfAttributeOutput::FieldVanish( const String& /*rTxt*/, ww::eField /*eType*/ )
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
void RtfAttributeOutput::Redline( const SwRedlineData* pRedline )
{
if (!pRedline)
return;
OSL_TRACE("%s", OSL_THIS_FUNC);
if (pRedline->GetType() == nsRedlineType_t::REDLINE_INSERT)
{
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_REVISED);
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_REVAUTH);
m_aRun.getOStringBuffer().append((sal_Int32)m_rExport.GetRedline(SW_MOD()->GetRedlineAuthor(pRedline->GetAuthor())));
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_REVDTTM);
}
else if(pRedline->GetType() == nsRedlineType_t::REDLINE_DELETE)
{
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_DELETED);
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_REVAUTHDEL);
m_aRun.getOStringBuffer().append((sal_Int32)m_rExport.GetRedline(SW_MOD()->GetRedlineAuthor(pRedline->GetAuthor())));
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_REVDTTMDEL);
}
m_aRun.getOStringBuffer().append((sal_Int32)sw::ms::DateTime2DTTM(pRedline->GetTimeStamp()));
m_aRun.getOStringBuffer().append(' ');
}
void RtfAttributeOutput::FormatDrop( const SwTxtNode& /*rNode*/, const SwFmtDrop& /*rSwFmtDrop*/, sal_uInt16 /*nStyle*/, ww8::WW8TableNodeInfo::Pointer_t /*pTextNodeInfo*/, ww8::WW8TableNodeInfoInner::Pointer_t /*pTextNodeInfoInner*/ )
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
void RtfAttributeOutput::ParagraphStyle( sal_uInt16 nStyle )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
OString *pStyle = m_rExport.GetStyle(nStyle);
MultiBuffer aStyle;
aStyle.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_S);
aStyle.getOStringBuffer().append((sal_Int32)nStyle);
if (pStyle)
{
aStyle.getOStringBuffer().append(pStyle->getStr());
}
if (!m_bBufferSectionHeaders)
{
aStyle.writeAndClear(m_rExport.Strm());
}
else
{
m_aSectionHeaders.appendAndClear(aStyle);
}
}
void RtfAttributeOutput::TableInfoCell( ww8::WW8TableNodeInfoInner::Pointer_t /*pTableTextNodeInfoInner*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_INTBL);
if ( m_nTableDepth > 1 )
{
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_ITAP);
m_aStyles.append((sal_Int32)m_nTableDepth);
}
m_bWroteCellInfo = true;
}
void RtfAttributeOutput::TableInfoRow( ww8::WW8TableNodeInfoInner::Pointer_t /*pTableTextNodeInfo*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
/* noop */
}
void RtfAttributeOutput::TableDefinition( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( !m_pTableWrt )
InitTableHelper( pTableTextNodeInfoInner );
const SwTableBox *pTblBox = pTableTextNodeInfoInner->getTableBox( );
SwFrmFmt *pFmt = pTblBox->GetFrmFmt( );
m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_TROWD);
TableOrientation( pTableTextNodeInfoInner );
TableBidi( pTableTextNodeInfoInner );
TableHeight( pTableTextNodeInfoInner );
TableCanSplit( pTableTextNodeInfoInner );
// Cell margins
const SvxBoxItem& rBox = pFmt->GetBox( );
static const sal_uInt16 aBorders[] =
{
BOX_LINE_TOP, BOX_LINE_LEFT, BOX_LINE_BOTTOM, BOX_LINE_RIGHT
};
static const char* aRowPadNames[] =
{
OOO_STRING_SVTOOLS_RTF_TRPADDT, OOO_STRING_SVTOOLS_RTF_TRPADDL, OOO_STRING_SVTOOLS_RTF_TRPADDB, OOO_STRING_SVTOOLS_RTF_TRPADDR
};
static const char* aRowPadUnits[] =
{
OOO_STRING_SVTOOLS_RTF_TRPADDFT, OOO_STRING_SVTOOLS_RTF_TRPADDFL, OOO_STRING_SVTOOLS_RTF_TRPADDFB, OOO_STRING_SVTOOLS_RTF_TRPADDFR
};
for (int i = 0; i < 4; ++i)
{
m_aRowDefs.append(aRowPadUnits[i]);
m_aRowDefs.append((sal_Int32)3);
m_aRowDefs.append(aRowPadNames[i]);
m_aRowDefs.append((sal_Int32)rBox.GetDistance(aBorders[i]));
}
// The cell-dependent properties
const SwWriteTableRows& aRows = m_pTableWrt->GetRows( );
SwWriteTableRow *pRow = aRows[ pTableTextNodeInfoInner->getRow( ) ];
SwTwips nSz = 0;
Point aPt;
SwRect aRect( pFmt->FindLayoutRect( false, &aPt ));
SwTwips nPageSize = aRect.Width();
SwTwips nTblSz = pFmt->GetFrmSize().GetWidth();
for( sal_uInt16 i = 0; i < pRow->GetCells().Count(); i++ )
{
SwWriteTableCell *pCell = pRow->GetCells( )[ i ];
const SwFrmFmt *pCellFmt = pCell->GetBox()->GetFrmFmt();
pTableTextNodeInfoInner->setCell( i );
TableCellProperties(pTableTextNodeInfoInner);
// Right boundary: this can't be in TableCellProperties as the old
// value of nSz is needed.
nSz += pCellFmt->GetFrmSize().GetWidth();
m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_CELLX);
SwTwips nCalc = nSz;
nCalc *= nPageSize;
nCalc /= nTblSz;
m_aRowDefs.append( (sal_Int32)(pFmt->GetLRSpace().GetLeft() + nCalc) );
}
}
void RtfAttributeOutput::TableDefaultBorders( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
/*
* The function name is a bit misleading: given that we write borders
* before each row, we just have borders, not default ones. Additionally,
* this function actually writes borders for a specific cell only and is
* called for each cell.
*/
const SwTableBox *pTblBox = pTableTextNodeInfoInner->getTableBox( );
SwFrmFmt *pFmt = pTblBox->GetFrmFmt( );
const SvxBoxItem& rDefault = pFmt->GetBox( );
const SwWriteTableRows& aRows = m_pTableWrt->GetRows( );
SwWriteTableRow *pRow = aRows[ pTableTextNodeInfoInner->getRow( ) ];
SwWriteTableCell *pCell = pRow->GetCells( )[ pTableTextNodeInfoInner->getCell( ) ];
const SwFrmFmt *pCellFmt = pCell->GetBox()->GetFrmFmt();
const SfxPoolItem* pItem;
if (SFX_ITEM_SET == pCellFmt->GetAttrSet().GetItemState(RES_BOX, sal_True, &pItem))
{
const SvxBoxItem& rBox = (SvxBoxItem&)*pItem;
static const sal_uInt16 aBorders[] =
{
BOX_LINE_TOP, BOX_LINE_LEFT, BOX_LINE_BOTTOM, BOX_LINE_RIGHT
};
static const char* aBorderNames[] =
{
OOO_STRING_SVTOOLS_RTF_CLBRDRT, OOO_STRING_SVTOOLS_RTF_CLBRDRL, OOO_STRING_SVTOOLS_RTF_CLBRDRB, OOO_STRING_SVTOOLS_RTF_CLBRDRR
};
//Yes left and top are swapped with eachother for cell padding! Because
//that's what the thunderingly annoying rtf export/import word xp does.
static const char* aCellPadNames[] =
{
OOO_STRING_SVTOOLS_RTF_CLPADL, OOO_STRING_SVTOOLS_RTF_CLPADT, OOO_STRING_SVTOOLS_RTF_CLPADB, OOO_STRING_SVTOOLS_RTF_CLPADR
};
static const char* aCellPadUnits[] =
{
OOO_STRING_SVTOOLS_RTF_CLPADFL, OOO_STRING_SVTOOLS_RTF_CLPADFT, OOO_STRING_SVTOOLS_RTF_CLPADFB, OOO_STRING_SVTOOLS_RTF_CLPADFR
};
for (int i = 0; i < 4; ++i)
{
if (const SvxBorderLine* pLn = rBox.GetLine(aBorders[i]))
m_aRowDefs.append(OutTBLBorderLine(m_rExport, pLn, aBorderNames[i]));
if (rDefault.GetDistance(aBorders[i]) !=
rBox.GetDistance(aBorders[i]))
{
m_aRowDefs.append(aCellPadUnits[i]);
m_aRowDefs.append((sal_Int32)3);
m_aRowDefs.append(aCellPadNames[i]);
m_aRowDefs.append((sal_Int32)rBox.GetDistance(aBorders[i]));
}
}
}
}
void RtfAttributeOutput::TableBackgrounds( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const SwWriteTableRows& aRows = m_pTableWrt->GetRows( );
SwWriteTableRow *pRow = aRows[ pTableTextNodeInfoInner->getRow( ) ];
SwWriteTableCell *pCell = pRow->GetCells( )[ pTableTextNodeInfoInner->getCell( ) ];
const SwFrmFmt *pCellFmt = pCell->GetBox()->GetFrmFmt();
const SfxPoolItem* pItem;
if( SFX_ITEM_SET == pCellFmt->GetAttrSet().GetItemState(
RES_BACKGROUND, sal_True, &pItem ))
{
const SvxBrushItem& rBack = (SvxBrushItem&)*pItem;
if( !rBack.GetColor().GetTransparency() )
{
m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_CLCBPAT);
m_aRowDefs.append((sal_Int32)m_rExport.GetColor(rBack.GetColor()));
}
}
}
void RtfAttributeOutput::TableHeight( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const SwTableBox * pTabBox = pTableTextNodeInfoInner->getTableBox();
const SwTableLine * pTabLine = pTabBox->GetUpper();
const SwFrmFmt * pLineFmt = pTabLine->GetFrmFmt();
const SwFmtFrmSize& rLSz = pLineFmt->GetFrmSize();
if ( ATT_VAR_SIZE != rLSz.GetHeightSizeType() && rLSz.GetHeight() )
{
sal_Int32 nHeight = 0;
switch ( rLSz.GetHeightSizeType() )
{
case ATT_FIX_SIZE: nHeight = -rLSz.GetHeight(); break;
case ATT_MIN_SIZE: nHeight = rLSz.GetHeight(); break;
default: break;
}
if ( nHeight )
{
m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_TRRH);
m_aRowDefs.append(nHeight);
}
}
}
void RtfAttributeOutput::TableCanSplit( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const SwTableBox * pTabBox = pTableTextNodeInfoInner->getTableBox();
const SwTableLine * pTabLine = pTabBox->GetUpper();
const SwFrmFmt * pLineFmt = pTabLine->GetFrmFmt();
const SwFmtRowSplit& rSplittable = pLineFmt->GetRowSplit( );
// The rtf default is to allow a row to break
if (rSplittable.GetValue() == 0)
m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_TRKEEP);
}
void RtfAttributeOutput::TableBidi( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const SwTable * pTable = pTableTextNodeInfoInner->getTable();
const SwFrmFmt * pFrmFmt = pTable->GetFrmFmt();
if ( m_rExport.TrueFrameDirection( *pFrmFmt ) != FRMDIR_HORI_RIGHT_TOP )
m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_LTRROW);
else
m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_RTLROW);
}
void RtfAttributeOutput::TableVerticalCell( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const SwWriteTableRows& aRows = m_pTableWrt->GetRows( );
SwWriteTableRow *pRow = aRows[ pTableTextNodeInfoInner->getRow( ) ];
SwWriteTableCell *pCell = pRow->GetCells( )[ pTableTextNodeInfoInner->getCell( ) ];
const SwFrmFmt *pCellFmt = pCell->GetBox()->GetFrmFmt();
const SfxPoolItem* pItem;
// vertical merges
if (pCell->GetRowSpan() > 1)
m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_CLVMGF);
else if (pCell->GetRowSpan() == 0)
m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_CLVMRG);
// vertical alignment
if( SFX_ITEM_SET == pCellFmt->GetAttrSet().GetItemState(
RES_VERT_ORIENT, sal_True, &pItem ) )
switch( ((SwFmtVertOrient*)pItem)->GetVertOrient() )
{
case text::VertOrientation::CENTER: m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_CLVERTALC); break;
case text::VertOrientation::BOTTOM: m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_CLVERTALB); break;
default: m_aRowDefs.append(OOO_STRING_SVTOOLS_RTF_CLVERTALT); break;
}
}
void RtfAttributeOutput::TableNodeInfo( ww8::WW8TableNodeInfo::Pointer_t /*pNodeInfo*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
/* noop */
}
void RtfAttributeOutput::TableNodeInfoInner( ww8::WW8TableNodeInfoInner::Pointer_t pNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
// This is called when the nested table ends in a cell, and there's no
// paragraph benhind that; so we must check for the ends of cell, rows,
// and tables
// ['true' to write an empty paragraph, MS Word insists on that]
FinishTableRowCell( pNodeInfoInner, true );
}
void RtfAttributeOutput::TableOrientation( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const SwTable *pTable = pTableTextNodeInfoInner->getTable();
SwFrmFmt *pFmt = pTable->GetFrmFmt( );
OStringBuffer aTblAdjust( OOO_STRING_SVTOOLS_RTF_TRQL );
switch (pFmt->GetHoriOrient().GetHoriOrient())
{
case text::HoriOrientation::CENTER:
aTblAdjust.setLength(0);
aTblAdjust.append(OOO_STRING_SVTOOLS_RTF_TRQC);
break;
case text::HoriOrientation::RIGHT:
aTblAdjust.setLength(0);
aTblAdjust.append(OOO_STRING_SVTOOLS_RTF_TRQR);
break;
case text::HoriOrientation::NONE:
case text::HoriOrientation::LEFT_AND_WIDTH:
aTblAdjust.append(OOO_STRING_SVTOOLS_RTF_TRLEFT);
aTblAdjust.append((sal_Int32)pFmt->GetLRSpace().GetLeft());
break;
default:
break;
}
m_aRowDefs.append(aTblAdjust.makeStringAndClear());
}
void RtfAttributeOutput::TableSpacing( ww8::WW8TableNodeInfoInner::Pointer_t /*pTableTextNodeInfoInner*/ )
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
void RtfAttributeOutput::TableRowEnd( sal_uInt32 /*nDepth*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
/* noop, see EndTableRow() */
}
/*
* Our private table methods.
*/
void RtfAttributeOutput::InitTableHelper( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
sal_uInt32 nPageSize = 0;
bool bRelBoxSize = false;
// Create the SwWriteTable instance to use col spans
GetTablePageSize( pTableTextNodeInfoInner.get(), nPageSize, bRelBoxSize );
const SwTable* pTable = pTableTextNodeInfoInner->getTable( );
const SwFrmFmt *pFmt = pTable->GetFrmFmt( );
SwTwips nTblSz = pFmt->GetFrmSize( ).GetWidth( );
const SwHTMLTableLayout *pLayout = pTable->GetHTMLTableLayout();
if( pLayout && pLayout->IsExportable() )
m_pTableWrt = new SwWriteTable( pLayout );
else
m_pTableWrt = new SwWriteTable( pTable->GetTabLines(), (sal_uInt16)nPageSize,
(sal_uInt16)nTblSz, false);
}
void RtfAttributeOutput::StartTable( ww8::WW8TableNodeInfoInner::Pointer_t /*pTableTextNodeInfoInner*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
// To trigger calling InitTableHelper()
delete m_pTableWrt, m_pTableWrt = NULL;
}
void RtfAttributeOutput::StartTableRow( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
sal_uInt32 nCurrentDepth = pTableTextNodeInfoInner->getDepth();
OSL_TRACE("%s, (depth is %d)", OSL_THIS_FUNC, (int)nCurrentDepth);
TableDefinition(pTableTextNodeInfoInner);
if (!m_bLastTable)
m_aTables.push_back(m_aRowDefs.makeStringAndClear());
// We'll write the table definition for nested tables later
if ( nCurrentDepth > 1 )
return;
m_rExport.Strm() << m_aRowDefs.makeStringAndClear();
}
void RtfAttributeOutput::StartTableCell( ww8::WW8TableNodeInfoInner::Pointer_t /*pTableTextNodeInfoInner*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_bTableCellOpen = true;
}
void RtfAttributeOutput::TableCellProperties( ww8::WW8TableNodeInfoInner::Pointer_t pTableTextNodeInfoInner )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
TableDefaultBorders(pTableTextNodeInfoInner);
TableBackgrounds(pTableTextNodeInfoInner);
TableVerticalCell(pTableTextNodeInfoInner);
}
void RtfAttributeOutput::EndTableCell( )
{
OSL_TRACE("%s, (depth is %d)", OSL_THIS_FUNC, (int)m_nTableDepth);
if (!m_bWroteCellInfo)
{
m_aAfterRuns.append(OOO_STRING_SVTOOLS_RTF_INTBL);
m_aAfterRuns.append(OOO_STRING_SVTOOLS_RTF_ITAP);
m_aAfterRuns.append((sal_Int32)m_nTableDepth);
}
if ( m_nTableDepth > 1 )
m_aAfterRuns.append(OOO_STRING_SVTOOLS_RTF_NESTCELL);
else
m_aAfterRuns.append(OOO_STRING_SVTOOLS_RTF_CELL);
m_bTableCellOpen = false;
m_bTblAfterCell = true;
m_bWroteCellInfo = false;
}
void RtfAttributeOutput::EndTableRow( )
{
OSL_TRACE("%s, (depth is %d)", OSL_THIS_FUNC, (int)m_nTableDepth);
if ( m_nTableDepth > 1 )
{
m_aAfterRuns.append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_NESTTABLEPROPRS);
if (m_aRowDefs.getLength() > 0)
m_aAfterRuns.append(m_aRowDefs.makeStringAndClear());
else if (m_aTables.size() > 0)
{
m_aAfterRuns.append(m_aTables.back());
m_aTables.pop_back();
}
m_aAfterRuns.append(OOO_STRING_SVTOOLS_RTF_NESTROW "}" "{" OOO_STRING_SVTOOLS_RTF_NONESTTABLES OOO_STRING_SVTOOLS_RTF_PAR "}");
}
else
{
if (m_aTables.size() > 0)
{
m_aAfterRuns.append(m_aTables.back());
m_aTables.pop_back();
}
m_aAfterRuns.append(OOO_STRING_SVTOOLS_RTF_ROW);
}
}
void RtfAttributeOutput::EndTable()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( m_nTableDepth > 0 ) {
m_nTableDepth--;
delete m_pTableWrt, m_pTableWrt = NULL;
}
// We closed the table; if it is a nested table, the cell that contains it
// still continues
m_bTableCellOpen = true;
// Cleans the table helper
delete m_pTableWrt, m_pTableWrt = NULL;
}
void RtfAttributeOutput::FinishTableRowCell( ww8::WW8TableNodeInfoInner::Pointer_t pInner, bool /*bForceEmptyParagraph*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( pInner.get() )
{
// Where are we in the table
sal_uInt32 nRow = pInner->getRow( );
const SwTable *pTable = pInner->getTable( );
const SwTableLines& rLines = pTable->GetTabLines( );
sal_uInt16 nLinesCount = rLines.Count( );
if ( pInner->isEndOfCell() )
EndTableCell();
// This is a line end
if ( pInner->isEndOfLine() )
EndTableRow();
// This is the end of the table
if ( pInner->isEndOfLine( ) && ( nRow + 1 ) == nLinesCount )
EndTable();
}
}
void RtfAttributeOutput::StartStyles()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << m_rExport.sNewLine << '{' << OOO_STRING_SVTOOLS_RTF_COLORTBL;
m_rExport.OutColorTable();
OSL_ENSURE(m_aStylesheet.getLength() == 0, "m_aStylesheet is not empty");
m_aStylesheet.append(m_rExport.sNewLine);
m_aStylesheet.append('{');
m_aStylesheet.append(OOO_STRING_SVTOOLS_RTF_STYLESHEET);
}
void RtfAttributeOutput::EndStyles( sal_uInt16 /*nNumberOfStyles*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << '}';
m_rExport.Strm() << m_aStylesheet.makeStringAndClear();
m_rExport.Strm() << '}';
}
void RtfAttributeOutput::DefaultStyle( sal_uInt16 /*nStyle*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
/* noop, the default style is always 0 in RTF */
}
void RtfAttributeOutput::StartStyle( const String& rName, bool bPapFmt,
sal_uInt16 nBase, sal_uInt16 nNext, sal_uInt16 /*nWwId*/, sal_uInt16 nId )
{
OSL_TRACE("%s, rName = '%s'", OSL_THIS_FUNC,
OUStringToOString( OUString( rName ), m_rExport.eCurrentEncoding ).getStr());
m_aStylesheet.append('{');
if (bPapFmt)
m_aStylesheet.append(OOO_STRING_SVTOOLS_RTF_S);
else
m_aStylesheet.append( OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_CS);
m_aStylesheet.append( (sal_Int32)nId );
if ( nBase != 0x0FFF )
{
m_aStylesheet.append(OOO_STRING_SVTOOLS_RTF_SBASEDON);
m_aStylesheet.append((sal_Int32)nBase);
}
m_aStylesheet.append(OOO_STRING_SVTOOLS_RTF_SNEXT);
m_aStylesheet.append((sal_Int32)nNext);
m_rStyleName = rName;
m_nStyleId = nId;
}
void RtfAttributeOutput::EndStyle()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(m_aStylesEnd.makeStringAndClear());
OString aStyles = m_aStyles.makeStringAndClear();
m_rExport.InsStyle(m_nStyleId, aStyles);
m_aStylesheet.append(aStyles);
m_aStylesheet.append(' ');
m_aStylesheet.append(OUStringToOString( OUString( m_rStyleName ), m_rExport.eCurrentEncoding ));
m_aStylesheet.append(";}");
m_aStylesheet.append(m_rExport.sNewLine);
}
void RtfAttributeOutput::StartStyleProperties( bool /*bParProp*/, sal_uInt16 /*nStyle*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
/* noop */
}
void RtfAttributeOutput::EndStyleProperties( bool /*bParProp*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
/* noop */
}
void RtfAttributeOutput::OutlineNumbering( sal_uInt8 nLvl, const SwNumFmt& /*rNFmt*/, const SwFmt& /*rFmt*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( nLvl >= WW8ListManager::nMaxLevel )
nLvl = WW8ListManager::nMaxLevel - 1;
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_ILVL);
m_aStyles.append((sal_Int32)nLvl);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_OUTLINELEVEL);
m_aStyles.append((sal_Int32)nLvl);
}
void RtfAttributeOutput::PageBreakBefore( bool bBreak )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if (bBreak)
{
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_PAGEBB;
}
}
void RtfAttributeOutput::SectionBreak( sal_uInt8 nC, const WW8_SepInfo* pSectionInfo )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
switch (nC)
{
case msword::ColumnBreak:
m_nColBreakNeeded = true;
break;
case msword::PageBreak:
if ( pSectionInfo )
m_rExport.SectionProperties( *pSectionInfo );
break;
}
}
void RtfAttributeOutput::StartSection()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_SECT OOO_STRING_SVTOOLS_RTF_SECTD);
if (!m_bBufferSectionBreaks)
m_rExport.Strm() << m_aSectionBreaks.makeStringAndClear();
}
void RtfAttributeOutput::EndSection()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
/*
* noop, \sect must go to StartSection or Word won't notice multiple
* columns...
*/
}
void RtfAttributeOutput::SectionFormProtection( bool bProtected )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_SECTUNLOCKED);
m_aSectionBreaks.append((sal_Int32)!bProtected);
}
void RtfAttributeOutput::SectionLineNumbering( sal_uLong /*nRestartNo*/, const SwLineNumberInfo& rLnNumInfo )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LINEMOD;
m_rExport.OutLong(rLnNumInfo.GetCountBy());
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LINEX;
m_rExport.OutLong(rLnNumInfo.GetPosFromLeft());
if (!rLnNumInfo.IsRestartEachPage())
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LINECONT;
}
void RtfAttributeOutput::SectionTitlePage()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
/*
* noop, handled in RtfExport::WriteHeaderFooter()
*/
}
void RtfAttributeOutput::SectionPageBorders( const SwFrmFmt* pFmt, const SwFrmFmt* /*pFirstPageFmt*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const SvxBoxItem& rBox = pFmt->GetBox();
const SvxBorderLine *pLine = rBox.GetTop();
if(pLine)
m_aSectionBreaks.append(OutBorderLine( m_rExport, pLine,
OOO_STRING_SVTOOLS_RTF_PGBRDRT,
rBox.GetDistance(BOX_LINE_TOP) ));
pLine = rBox.GetBottom();
if(pLine)
m_aSectionBreaks.append(OutBorderLine( m_rExport, pLine,
OOO_STRING_SVTOOLS_RTF_PGBRDRB,
rBox.GetDistance(BOX_LINE_BOTTOM) ));
pLine = rBox.GetLeft();
if(pLine)
m_aSectionBreaks.append(OutBorderLine( m_rExport, pLine,
OOO_STRING_SVTOOLS_RTF_PGBRDRL,
rBox.GetDistance(BOX_LINE_LEFT) ));
pLine = rBox.GetRight();
if(pLine)
m_aSectionBreaks.append(OutBorderLine( m_rExport, pLine,
OOO_STRING_SVTOOLS_RTF_PGBRDRR,
rBox.GetDistance(BOX_LINE_RIGHT) ));
}
void RtfAttributeOutput::SectionBiDi( bool bBiDi )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << (bBiDi ? OOO_STRING_SVTOOLS_RTF_RTLSECT : OOO_STRING_SVTOOLS_RTF_LTRSECT);
}
void RtfAttributeOutput::SectionPageNumbering( sal_uInt16 nNumType, sal_uInt16 nPageRestartNumber )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if (nPageRestartNumber > 0)
{
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_PGNSTARTS);
m_aSectionBreaks.append((sal_Int32)nPageRestartNumber);
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_PGNRESTART);
}
const char* pStr = 0;
switch ( nNumType )
{
case SVX_NUM_CHARS_UPPER_LETTER:
case SVX_NUM_CHARS_UPPER_LETTER_N: pStr = OOO_STRING_SVTOOLS_RTF_PGNUCLTR; break;
case SVX_NUM_CHARS_LOWER_LETTER:
case SVX_NUM_CHARS_LOWER_LETTER_N: pStr = OOO_STRING_SVTOOLS_RTF_PGNLCLTR; break;
case SVX_NUM_ROMAN_UPPER: pStr = OOO_STRING_SVTOOLS_RTF_PGNUCRM; break;
case SVX_NUM_ROMAN_LOWER: pStr = OOO_STRING_SVTOOLS_RTF_PGNLCRM; break;
case SVX_NUM_ARABIC: pStr = OOO_STRING_SVTOOLS_RTF_PGNDEC; break;
}
if (pStr)
m_aSectionBreaks.append(pStr);
}
void RtfAttributeOutput::SectionType( sal_uInt8 nBreakCode )
{
OSL_TRACE("%s, nBreakCode = %d", OSL_THIS_FUNC, nBreakCode);
/*
* break code: 0 No break, 1 New column
* 2 New page, 3 Even page, 4 Odd page
*/
const char* sType = NULL;
switch ( nBreakCode )
{
case 1: sType = OOO_STRING_SVTOOLS_RTF_SBKCOL; break;
case 2: sType = OOO_STRING_SVTOOLS_RTF_SBKPAGE; break;
case 3: sType = OOO_STRING_SVTOOLS_RTF_SBKEVEN; break;
case 4: sType = OOO_STRING_SVTOOLS_RTF_SBKODD; break;
default: sType = OOO_STRING_SVTOOLS_RTF_SBKNONE; break;
}
m_aSectionBreaks.append(sType);
if (!m_bBufferSectionBreaks)
m_rExport.Strm() << m_aSectionBreaks.makeStringAndClear();
}
void RtfAttributeOutput::NumberingDefinition( sal_uInt16 nId, const SwNumRule &/*rRule*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << '{' << OOO_STRING_SVTOOLS_RTF_LISTOVERRIDE;
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LISTID;
m_rExport.OutULong(nId);
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LISTOVERRIDECOUNT << '0';
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LS;
m_rExport.OutULong(nId) << '}';
}
void RtfAttributeOutput::StartAbstractNumbering( sal_uInt16 nId )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << '{' << OOO_STRING_SVTOOLS_RTF_LIST << OOO_STRING_SVTOOLS_RTF_LISTTEMPLATEID;
m_rExport.OutULong( nId );
m_nListId = nId;
}
void RtfAttributeOutput::EndAbstractNumbering()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LISTID;
m_rExport.OutULong( m_nListId ) << '}' << m_rExport.sNewLine;
}
void RtfAttributeOutput::NumberingLevel( sal_uInt8 nLevel,
sal_uInt16 nStart,
sal_uInt16 nNumberingType,
SvxAdjust eAdjust,
const sal_uInt8 * pNumLvlPos,
sal_uInt8 /*nFollow*/,
const wwFont * pFont,
const SfxItemSet * pOutSet,
sal_Int16 nIndentAt,
sal_Int16 nFirstLineIndex,
sal_Int16 /*nListTabPos*/,
const String &rNumberingString,
const SvxBrushItem* /* pBrush */)
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << m_rExport.sNewLine;
if( nLevel > 8 ) // RTF knows only 9 levels
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_IGNORE << OOO_STRING_SVTOOLS_RTF_SOUTLVL;
m_rExport.Strm() << '{' << OOO_STRING_SVTOOLS_RTF_LISTLEVEL;
sal_uInt16 nVal = 0;
switch( nNumberingType )
{
case SVX_NUM_ROMAN_UPPER: nVal = 1; break;
case SVX_NUM_ROMAN_LOWER: nVal = 2; break;
case SVX_NUM_CHARS_UPPER_LETTER:
case SVX_NUM_CHARS_UPPER_LETTER_N: nVal = 3; break;
case SVX_NUM_CHARS_LOWER_LETTER:
case SVX_NUM_CHARS_LOWER_LETTER_N: nVal = 4; break;
case SVX_NUM_BITMAP:
case SVX_NUM_CHAR_SPECIAL: nVal = 23; break;
}
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LEVELNFC;
m_rExport.OutULong( nVal );
switch( eAdjust )
{
case SVX_ADJUST_CENTER: nVal = 1; break;
case SVX_ADJUST_RIGHT: nVal = 2; break;
default: nVal = 0; break;
}
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LEVELJC;
m_rExport.OutULong( nVal );
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LEVELSTARTAT;
m_rExport.OutULong( nStart );
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_LEVELFOLLOW << "0";
// leveltext group
m_rExport.Strm() << '{' << OOO_STRING_SVTOOLS_RTF_LEVELTEXT << ' ';
if( SVX_NUM_CHAR_SPECIAL == nNumberingType ||
SVX_NUM_BITMAP == nNumberingType )
{
m_rExport.Strm() << "\\'01";
sal_Unicode cChar = rNumberingString.GetChar(0);
m_rExport.Strm() << "\\u";
m_rExport.OutULong(cChar);
m_rExport.Strm() << " ?";
}
else
{
m_rExport.Strm() << "\\'" << m_rExport.OutHex( rNumberingString.Len(), 2 );
m_rExport.Strm() << m_rExport.OutString( rNumberingString, m_rExport.eDefaultEncoding );
}
m_rExport.Strm() << ";}";
// write the levelnumbers
m_rExport.Strm() << "{" << OOO_STRING_SVTOOLS_RTF_LEVELNUMBERS;
for( sal_uInt8 i = 0; i <= nLevel && pNumLvlPos[ i ]; ++i )
{
m_rExport.Strm() << "\\'" << m_rExport.OutHex(pNumLvlPos[ i ], 2).getStr();
}
m_rExport.Strm() << ";}";
if( pOutSet )
{
if (pFont)
{
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_F;
m_rExport.OutULong(m_rExport.maFontHelper.GetId(*pFont));
}
m_rExport.OutputItemSet( *pOutSet, false, true, i18n::ScriptType::LATIN, m_rExport.mbExportModeRTF );
m_rExport.Strm() << m_aStyles.makeStringAndClear();
}
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_FI;
m_rExport.OutLong( nFirstLineIndex ) << OOO_STRING_SVTOOLS_RTF_LI;
m_rExport.OutLong( nIndentAt );
m_rExport.Strm() << '}';
if( nLevel > 8 )
m_rExport.Strm() << '}';
}
void RtfAttributeOutput::WriteField_Impl( const SwField* pFld, ww::eField /*eType*/, const String& rFldCmd, sal_uInt8 /*nMode*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
// NEEDSWORK this has beeen tested only with page numbers
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_FIELD);
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FLDINST " ");
m_aRunText.getOStringBuffer().append(m_rExport.OutString(rFldCmd, m_rExport.eCurrentEncoding));
m_aRunText.getOStringBuffer().append("}{" OOO_STRING_SVTOOLS_RTF_FLDRSLT " ");
if (pFld)
m_aRunText.getOStringBuffer().append(m_rExport.OutString(pFld->ExpandField(true), m_rExport.eDefaultEncoding));
m_aRunText.getOStringBuffer().append("}}");
}
void RtfAttributeOutput::WriteBookmarks_Impl( std::vector< rtl::OUString >& rStarts, std::vector< rtl::OUString >& rEnds )
{
for ( std::vector< OUString >::const_iterator it = rStarts.begin(), end = rStarts.end(); it < end; ++it )
{
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_BKMKSTART " ");
m_aRun.getOStringBuffer().append(m_rExport.OutString(*it, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
}
rStarts.clear();
for ( std::vector< OUString >::const_iterator it = rEnds.begin(), end = rEnds.end(); it < end; ++it )
{
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_BKMKEND " ");
m_aRun.getOStringBuffer().append(m_rExport.OutString(*it, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
}
rEnds.clear();
}
void RtfAttributeOutput::WriteHeaderFooter_Impl( const SwFrmFmt& rFmt, bool bHeader, const sal_Char* pStr )
{
OStringBuffer aSectionBreaks = m_aSectionBreaks;
m_aSectionBreaks.setLength(0);
MultiBuffer aTemp;
aTemp.appendAndClear(m_aRun);
m_aSectionHeaders.getOStringBuffer().append(bHeader ? OOO_STRING_SVTOOLS_RTF_HEADERY : OOO_STRING_SVTOOLS_RTF_FOOTERY);
m_aSectionHeaders.getOStringBuffer().append((sal_Int32)m_rExport.pAktPageDesc->GetMaster().GetULSpace().GetUpper());
m_aSectionHeaders.getOStringBuffer().append('{');
m_aSectionHeaders.getOStringBuffer().append(pStr);
m_bBufferSectionHeaders = true;
m_rExport.WriteHeaderFooterText(rFmt, bHeader);
m_bBufferSectionHeaders = false;
m_aSectionHeaders.getOStringBuffer().append('}');
m_aSectionBreaks = aSectionBreaks;
m_aRun.clear();
m_aRun.appendAndClear(aTemp);
}
void RtfAttributeOutput::OutputFlyFrame_Impl( const sw::Frame& rFrame, const Point& /*rNdTopLeft*/ )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const SwNode *pNode = rFrame.GetContent();
const SwGrfNode *pGrfNode = pNode ? pNode->GetGrfNode() : 0;
switch ( rFrame.GetWriterType() )
{
case sw::Frame::eTxtBox:
OSL_ENSURE(m_aRunText.empty(), "m_aRunText is not empty");
m_rExport.mpParentFrame = &rFrame;
m_rExport.bOutFlyFrmAttrs = m_rExport.bRTFFlySyntax = true;
m_rExport.OutputFormat( rFrame.GetFrmFmt(), false, false, true );
m_aRunText.writeAndClear(m_rExport.Strm());
m_rExport.Strm() << m_aStyles.makeStringAndClear();
m_rExport.bOutFlyFrmAttrs = m_rExport.bRTFFlySyntax = false;
m_rExport.Strm() << "{" OOO_STRING_SVTOOLS_RTF_IGNORE;
m_rExport.OutputFormat( rFrame.GetFrmFmt(), false, false, true );
m_aRunText.writeAndClear(m_rExport.Strm());
m_rExport.Strm() << m_aStyles.makeStringAndClear();
m_rExport.Strm() << '}';
{
/*
* Save m_aRun as we should not loose the opening brace.
* OTOH, just drop the contents of m_aRunText in case something
* would be there, causing a problem later.
*/
MultiBuffer aTemp;
aTemp.appendAndClear(m_aRun);
m_rExport.bRTFFlySyntax = true;
const SwFrmFmt& rFrmFmt = rFrame.GetFrmFmt( );
const SwNodeIndex* pNodeIndex = rFrmFmt.GetCntnt().GetCntntIdx();
sal_uLong nStt = pNodeIndex ? pNodeIndex->GetIndex()+1 : 0;
sal_uLong nEnd = pNodeIndex ? pNodeIndex->GetNode().EndOfSectionIndex() : 0;
m_rExport.SaveData( nStt, nEnd );
m_rExport.mpParentFrame = &rFrame;
m_rExport.WriteText( );
m_rExport.RestoreData();
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_PARD;
m_rExport.bRTFFlySyntax = false;
m_aRun.appendAndClear(aTemp);
m_aRunText.clear();
}
m_rExport.mpParentFrame = NULL;
m_rExport.Strm() << RtfExport::sNewLine;
break;
case sw::Frame::eGraphic:
if (!rFrame.IsInline())
{
m_rExport.mpParentFrame = &rFrame;
m_rExport.bRTFFlySyntax = true;
m_rExport.OutputFormat( rFrame.GetFrmFmt(), false, false, true );
m_rExport.bRTFFlySyntax = false;
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE);
m_rExport.OutputFormat( rFrame.GetFrmFmt(), false, false, true );
m_aRunText.getOStringBuffer().append('}');
m_rExport.mpParentFrame = NULL;
}
if ( pGrfNode )
FlyFrameGraphic( dynamic_cast<const SwFlyFrmFmt*>( &rFrame.GetFrmFmt() ), *pGrfNode, rFrame.GetLayoutSize() );
break;
case sw::Frame::eDrawing:
{
const SdrObject* pSdrObj = rFrame.GetFrmFmt().FindRealSdrObject();
if ( pSdrObj )
{
bool bSwapInPage = false;
if ( !pSdrObj->GetPage() )
{
if ( SdrModel* pModel = m_rExport.pDoc->GetDrawModel() )
{
if ( SdrPage *pPage = pModel->GetPage( 0 ) )
{
bSwapInPage = true;
const_cast< SdrObject* >( pSdrObj )->SetPage( pPage );
}
}
}
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_FIELD "{");
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_IGNORE);
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FLDINST);
m_aRunText.getOStringBuffer().append(" SHAPE ");
m_aRunText.getOStringBuffer().append("}" "{" OOO_STRING_SVTOOLS_RTF_FLDRSLT);
m_rExport.SdrExporter().AddSdrObject( *pSdrObj );
m_aRunText.getOStringBuffer().append('}');
m_aRunText.getOStringBuffer().append('}');
if ( bSwapInPage )
const_cast< SdrObject* >( pSdrObj )->SetPage( 0 );
}
}
break;
case sw::Frame::eFormControl:
{
const SwFrmFmt &rFrmFmt = rFrame.GetFrmFmt();
const SdrObject *pObject = rFrmFmt.FindRealSdrObject();
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_FIELD);
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FLDINST);
if (pObject && pObject->GetObjInventor() == FmFormInventor)
{
if (SdrUnoObj *pFormObj = PTR_CAST(SdrUnoObj,pObject))
{
uno::Reference< awt::XControlModel > xControlModel =
pFormObj->GetUnoControlModel();
uno::Reference< lang::XServiceInfo > xInfo(xControlModel, uno::UNO_QUERY);
uno::Reference<beans::XPropertySet> xPropSet(xControlModel, uno::UNO_QUERY);
uno::Reference<beans::XPropertySetInfo> xPropSetInfo = xPropSet->getPropertySetInfo();
OUString sName;
if (xInfo->supportsService(C2U("com.sun.star.form.component.CheckBox")))
{
m_aRun.getOStringBuffer().append(OUStringToOString(OUString(FieldString(ww::eFORMCHECKBOX)), m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FORMFIELD "{");
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFTYPE "1"); // 1 = checkbox
// checkbox size in half points, this seems to be always 20, see WW8Export::DoCheckBox()
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFHPS "20");
OUString aStr;
sName = C2U("Name");
if (xPropSetInfo->hasPropertyByName(sName))
{
xPropSet->getPropertyValue(sName) >>= aStr;
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FFNAME " ");
m_aRun.getOStringBuffer().append(OUStringToOString(aStr, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
}
sName = C2U("HelpText");
if (xPropSetInfo->hasPropertyByName(sName))
{
xPropSet->getPropertyValue(sName) >>= aStr;
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFOWNHELP);
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FFHELPTEXT " ");
m_aRun.getOStringBuffer().append(OUStringToOString(aStr, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
}
sName = C2U("HelpF1Text");
if (xPropSetInfo->hasPropertyByName(sName))
{
xPropSet->getPropertyValue(sName) >>= aStr;
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFOWNSTAT);
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FFSTATTEXT " ");
m_aRun.getOStringBuffer().append(OUStringToOString(aStr, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
}
sal_Int16 nTemp = 0;
xPropSet->getPropertyValue(C2U("DefaultState")) >>= nTemp;
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFDEFRES);
m_aRun.getOStringBuffer().append((sal_Int32)nTemp);
xPropSet->getPropertyValue(C2U("State")) >>= nTemp;
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFRES);
m_aRun.getOStringBuffer().append((sal_Int32)nTemp);
m_aRun.getOStringBuffer().append("}}");
// field result is empty, ffres already contains the form result
m_aRun.getOStringBuffer().append("}{" OOO_STRING_SVTOOLS_RTF_FLDRSLT " ");
}
else if (xInfo->supportsService(C2U("com.sun.star.form.component.TextField")))
{
OStringBuffer aBuf;
OString aStr;
OUString aTmp;
const sal_Char* pStr;
m_aRun.getOStringBuffer().append(OUStringToOString(OUString(FieldString(ww::eFORMTEXT)), m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_DATAFIELD " ");
for (int i = 0; i < 8; i++) aBuf.append((sal_Char)0x00);
xPropSet->getPropertyValue(C2U("Name")) >>= aTmp;
aStr = OUStringToOString(aTmp, m_rExport.eCurrentEncoding);
aBuf.append((sal_Char)aStr.getLength());
aBuf.append(aStr);
aBuf.append((sal_Char)0x00);
xPropSet->getPropertyValue(C2U("DefaultText")) >>= aTmp;
aStr = OUStringToOString(aTmp, m_rExport.eCurrentEncoding);
aBuf.append((sal_Char)aStr.getLength());
aBuf.append(aStr);
for (int i = 0; i < 11; i++) aBuf.append((sal_Char)0x00);
aStr = aBuf.makeStringAndClear();
pStr = aStr.getStr();
for (int i = 0; i < aStr.getLength(); i++, pStr++)
m_aRun.getOStringBuffer().append(m_rExport.OutHex(*pStr, 2));
m_aRun.getOStringBuffer().append('}');
m_aRun.getOStringBuffer().append("}{" OOO_STRING_SVTOOLS_RTF_FLDRSLT " ");
xPropSet->getPropertyValue(C2U("Text")) >>= aTmp;
m_aRun.getOStringBuffer().append(OUStringToOString(aTmp, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FORMFIELD "{");
sName = C2U("HelpText");
if (xPropSetInfo->hasPropertyByName(sName))
{
xPropSet->getPropertyValue(sName) >>= aTmp;
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFOWNHELP);
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FFHELPTEXT " ");
m_aRun.getOStringBuffer().append(OUStringToOString(aTmp, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
}
sName = C2U("HelpF1Text");
if (xPropSetInfo->hasPropertyByName(sName))
{
xPropSet->getPropertyValue(sName) >>= aTmp;
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFOWNSTAT);
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FFSTATTEXT " ");
m_aRun.getOStringBuffer().append(OUStringToOString(aTmp, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
}
m_aRun.getOStringBuffer().append("}");
}
else if (xInfo->supportsService(C2U("com.sun.star.form.component.ListBox")))
{
OUString aStr;
uno::Sequence<sal_Int16> aIntSeq;
uno::Sequence<OUString> aStrSeq;
m_aRun.getOStringBuffer().append(OUStringToOString(OUString(FieldString(ww::eFORMDROPDOWN)), m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FORMFIELD "{");
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFTYPE "2"); // 2 = list
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFHASLISTBOX);
xPropSet->getPropertyValue(C2U("DefaultSelection")) >>= aIntSeq;
if( aIntSeq.getLength() )
{
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFDEFRES);
// a dropdown list can have only one 'selected item by default'
m_aRun.getOStringBuffer().append((sal_Int32)aIntSeq[0]);
}
xPropSet->getPropertyValue(C2U("SelectedItems")) >>= aIntSeq;
if( aIntSeq.getLength() )
{
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFRES);
// a dropdown list can have only one 'currently selected item'
m_aRun.getOStringBuffer().append((sal_Int32)aIntSeq[0]);
}
sName = C2U("Name");
if (xPropSetInfo->hasPropertyByName(sName))
{
xPropSet->getPropertyValue(sName) >>= aStr;
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FFNAME " ");
m_aRun.getOStringBuffer().append(OUStringToOString(aStr, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
}
sName = C2U("HelpText");
if (xPropSetInfo->hasPropertyByName(sName))
{
xPropSet->getPropertyValue(sName) >>= aStr;
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFOWNHELP);
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FFHELPTEXT " ");
m_aRun.getOStringBuffer().append(OUStringToOString(aStr, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
}
sName = C2U("HelpF1Text");
if (xPropSetInfo->hasPropertyByName(sName))
{
xPropSet->getPropertyValue(sName) >>= aStr;
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FFOWNSTAT);
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FFSTATTEXT " ");
m_aRun.getOStringBuffer().append(OUStringToOString(aStr, m_rExport.eCurrentEncoding));
m_aRun.getOStringBuffer().append('}');
}
xPropSet->getPropertyValue(C2U("StringItemList")) >>= aStrSeq;
sal_uInt32 nListItems = aStrSeq.getLength();
for (sal_uInt32 i = 0; i < nListItems; i++)
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FFL " ")
.append(OUStringToOString(aStrSeq[i], m_rExport.eCurrentEncoding)).append('}');
m_aRun.getOStringBuffer().append("}}");
// field result is empty, ffres already contains the form result
m_aRun.getOStringBuffer().append("}{" OOO_STRING_SVTOOLS_RTF_FLDRSLT " ");
}
else
OSL_TRACE("%s unhandled form control: '%s'", OSL_THIS_FUNC,
OUStringToOString(xInfo->getImplementationName(), m_rExport.eCurrentEncoding).getStr());
m_aRun.getOStringBuffer().append('}');
}
}
m_aRun.getOStringBuffer().append('}');
}
break;
case sw::Frame::eOle:
{
const SwFrmFmt &rFrmFmt = rFrame.GetFrmFmt();
const SdrObject *pSdrObj = rFrmFmt.FindRealSdrObject();
if ( pSdrObj )
{
SwNodeIndex aIdx(*rFrmFmt.GetCntnt().GetCntntIdx(), 1);
SwOLENode& rOLENd = *aIdx.GetNode().GetOLENode();
FlyFrameOLE(dynamic_cast<const SwFlyFrmFmt*>( &rFrmFmt ), rOLENd, rFrame.GetLayoutSize());
}
}
break;
default:
OSL_TRACE("%s: unknown type (%d)", OSL_THIS_FUNC, rFrame.GetWriterType());
break;
}
}
void RtfAttributeOutput::CharCaseMap( const SvxCaseMapItem& rCaseMap )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
switch ( rCaseMap.GetValue() )
{
case SVX_CASEMAP_KAPITAELCHEN:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_SCAPS);
break;
case SVX_CASEMAP_VERSALIEN:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_CAPS);
break;
default: // Something that rtf does not support
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_SCAPS);
m_aStyles.append((sal_Int32)0);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_CAPS);
m_aStyles.append((sal_Int32)0);
break;
}
}
void RtfAttributeOutput::CharColor( const SvxColorItem& rColor )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const Color aColor( rColor.GetValue() );
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_CF);
m_aStyles.append( (sal_Int32)m_rExport.GetColor( aColor ));
}
void RtfAttributeOutput::CharContour( const SvxContourItem& rContour )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_OUTL);
if ( !rContour.GetValue() )
m_aStyles.append((sal_Int32)0);
}
void RtfAttributeOutput::CharCrossedOut( const SvxCrossedOutItem& rCrossedOut )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
switch ( rCrossedOut.GetStrikeout() )
{
case STRIKEOUT_NONE:
if (!m_bStrikeDouble)
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_STRIKE);
else
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_STRIKED);
m_aStyles.append((sal_Int32)0);
break;
case STRIKEOUT_DOUBLE:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_STRIKED);
m_aStyles.append((sal_Int32)1);
break;
default:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_STRIKE);
break;
}
}
void RtfAttributeOutput::CharEscapement( const SvxEscapementItem& rEsc )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const char * pUpDn;
SwTwips nH = ((SvxFontHeightItem&)m_rExport.GetItem( RES_CHRATR_FONTSIZE )).GetHeight();
if( 0 < rEsc.GetEsc() )
pUpDn = OOO_STRING_SVTOOLS_RTF_UP;
else if( 0 > rEsc.GetEsc() )
{
pUpDn = OOO_STRING_SVTOOLS_RTF_DN;
nH = -nH;
}
else
return;
short nEsc = rEsc.GetEsc();
short nProp = rEsc.GetProp() * 100;
if( DFLT_ESC_AUTO_SUPER == nEsc )
{
nEsc = 100 - rEsc.GetProp();
++nProp;
}
else if( DFLT_ESC_AUTO_SUB == nEsc )
{
nEsc = - 100 + rEsc.GetProp();
++nProp;
}
m_aStyles.append('{');
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_IGNORE);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_UPDNPROP);
m_aStyles.append( (sal_Int32)nProp );
m_aStyles.append('}');
m_aStyles.append(pUpDn);
/*
* Calculate the act. FontSize and the percentage of the displacement;
* RTF file expects half points, while internally it's in twips.
* Formally : (FontSize * 1/20 ) pts x * 2
* ----------------------- = ------------
* 100% Escapement
*/
m_aStyles.append( (sal_Int32) ( (long( nEsc ) * nH) + 500L ) / 1000L );
// 500L to round !!
}
void RtfAttributeOutput::CharFont( const SvxFontItem& rFont)
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStylesEnd.append(OOO_STRING_SVTOOLS_RTF_LOCH);
m_aStylesEnd.append(OOO_STRING_SVTOOLS_RTF_F);
m_aStylesEnd.append((sal_Int32)m_rExport.maFontHelper.GetId(rFont));
m_rExport.eCurrentEncoding = rtl_getTextEncodingFromWindowsCharset(sw::ms::rtl_TextEncodingToWinCharset(rFont.GetCharSet()));
}
void RtfAttributeOutput::CharFontSize( const SvxFontHeightItem& rFontSize)
{
OSL_TRACE("%s", OSL_THIS_FUNC);
switch ( rFontSize.Which() )
{
case RES_CHRATR_FONTSIZE:
m_aStylesEnd.append(OOO_STRING_SVTOOLS_RTF_FS);
m_aStylesEnd.append((sal_Int32)(rFontSize.GetHeight() / 10 ));
break;
case RES_CHRATR_CJK_FONTSIZE:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_FS);
m_aStyles.append((sal_Int32)(rFontSize.GetHeight() / 10 ));
break;
case RES_CHRATR_CTL_FONTSIZE:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_AFS);
m_aStyles.append((sal_Int32)(rFontSize.GetHeight() / 10 ));
break;
}
}
void RtfAttributeOutput::CharKerning( const SvxKerningItem& rKerning )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
// in quater points then in twips
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_EXPND);
m_aStyles.append((sal_Int32)(rKerning.GetValue() / 5));
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_EXPNDTW);
m_aStyles.append((sal_Int32)(rKerning.GetValue()));
}
void RtfAttributeOutput::CharLanguage( const SvxLanguageItem& rLanguage )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
switch (rLanguage.Which())
{
case RES_CHRATR_LANGUAGE:
m_aStylesEnd.append(OOO_STRING_SVTOOLS_RTF_LANG);
m_aStylesEnd.append((sal_Int32)rLanguage.GetLanguage());
break;
case RES_CHRATR_CJK_LANGUAGE:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_LANGFE);
m_aStyles.append((sal_Int32)rLanguage.GetLanguage());
break;
case RES_CHRATR_CTL_LANGUAGE:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_LANG);
m_aStyles.append((sal_Int32)rLanguage.GetLanguage());
break;
}
}
void RtfAttributeOutput::CharPosture( const SvxPostureItem& rPosture )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_I);
if ( rPosture.GetPosture() == ITALIC_NONE )
m_aStyles.append((sal_Int32)0);
}
void RtfAttributeOutput::CharShadow( const SvxShadowedItem& rShadow )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_SHAD);
if ( !rShadow.GetValue() )
m_aStyles.append((sal_Int32)0);
}
void RtfAttributeOutput::CharUnderline( const SvxUnderlineItem& rUnderline )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const char* pStr = 0;
const SfxPoolItem* pItem = m_rExport.HasItem( RES_CHRATR_WORDLINEMODE );
bool bWord = false;
if (pItem)
bWord = ((const SvxWordLineModeItem*)pItem)->GetValue() ? true : false;
switch(rUnderline.GetLineStyle() )
{
case UNDERLINE_SINGLE:
pStr = bWord ? OOO_STRING_SVTOOLS_RTF_ULW : OOO_STRING_SVTOOLS_RTF_UL;
break;
case UNDERLINE_DOUBLE:
pStr = OOO_STRING_SVTOOLS_RTF_ULDB;
break;
case UNDERLINE_NONE:
pStr = OOO_STRING_SVTOOLS_RTF_ULNONE;
break;
case UNDERLINE_DOTTED:
pStr = OOO_STRING_SVTOOLS_RTF_ULD;
break;
case UNDERLINE_DASH:
pStr = OOO_STRING_SVTOOLS_RTF_ULDASH;
break;
case UNDERLINE_DASHDOT:
pStr = OOO_STRING_SVTOOLS_RTF_ULDASHD;
break;
case UNDERLINE_DASHDOTDOT:
pStr = OOO_STRING_SVTOOLS_RTF_ULDASHDD;
break;
case UNDERLINE_BOLD:
pStr = OOO_STRING_SVTOOLS_RTF_ULTH;
break;
case UNDERLINE_WAVE:
pStr = OOO_STRING_SVTOOLS_RTF_ULWAVE;
break;
case UNDERLINE_BOLDDOTTED:
pStr = OOO_STRING_SVTOOLS_RTF_ULTHD;
break;
case UNDERLINE_BOLDDASH:
pStr = OOO_STRING_SVTOOLS_RTF_ULTHDASH;
break;
case UNDERLINE_LONGDASH:
pStr = OOO_STRING_SVTOOLS_RTF_ULLDASH;
break;
case UNDERLINE_BOLDLONGDASH:
pStr = OOO_STRING_SVTOOLS_RTF_ULTHLDASH;
break;
case UNDERLINE_BOLDDASHDOT:
pStr = OOO_STRING_SVTOOLS_RTF_ULTHDASHD;
break;
case UNDERLINE_BOLDDASHDOTDOT:
pStr = OOO_STRING_SVTOOLS_RTF_ULTHDASHDD;
break;
case UNDERLINE_BOLDWAVE:
pStr = OOO_STRING_SVTOOLS_RTF_ULHWAVE;
break;
case UNDERLINE_DOUBLEWAVE:
pStr = OOO_STRING_SVTOOLS_RTF_ULULDBWAVE;
break;
default:
break;
}
if( pStr )
{
m_aStyles.append(pStr);
// NEEDSWORK looks like here rUnderline.GetColor() is always black,
// even if the color in the odt is for example green...
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_ULC);
m_aStyles.append( (sal_Int32)m_rExport.GetColor(rUnderline.GetColor()) );
}
}
void RtfAttributeOutput::CharWeight( const SvxWeightItem& rWeight )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_B);
if ( rWeight.GetWeight() != WEIGHT_BOLD )
m_aStyles.append((sal_Int32)0);
}
void RtfAttributeOutput::CharAutoKern( const SvxAutoKernItem& rAutoKern)
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_KERNING);
m_aStyles.append((sal_Int32) (rAutoKern.GetValue() ? 1 : 0));
}
void RtfAttributeOutput::CharAnimatedText( const SvxBlinkItem& rBlink )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_ANIMTEXT);
m_aStyles.append((sal_Int32) (rBlink.GetValue() ? 2 : 0));
}
void RtfAttributeOutput::CharBackground( const SvxBrushItem& rBrush )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if( !rBrush.GetColor().GetTransparency() )
{
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_CHCBPAT);
m_aStyles.append((sal_Int32)m_rExport.GetColor(rBrush.GetColor()));
}
}
void RtfAttributeOutput::CharFontCJK( const SvxFontItem& rFont )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_HICH);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_AF);
m_aStyles.append((sal_Int32)m_rExport.maFontHelper.GetId(rFont));
}
void RtfAttributeOutput::CharFontSizeCJK( const SvxFontHeightItem& rFontSize )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
CharFontSize( rFontSize );
}
void RtfAttributeOutput::CharLanguageCJK( const SvxLanguageItem& rLanguageItem )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
CharLanguage( rLanguageItem );
}
void RtfAttributeOutput::CharPostureCJK( const SvxPostureItem& rPosture )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_I);
if ( rPosture.GetPosture() == ITALIC_NONE )
m_aStyles.append((sal_Int32)0);
}
void RtfAttributeOutput::CharWeightCJK( const SvxWeightItem& rWeight )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_B);
if ( rWeight.GetWeight() != WEIGHT_BOLD )
m_aStyles.append((sal_Int32)0);
}
void RtfAttributeOutput::CharFontCTL( const SvxFontItem& rFont )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_DBCH);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_AF);
m_aStyles.append((sal_Int32)m_rExport.maFontHelper.GetId(rFont));
}
void RtfAttributeOutput::CharFontSizeCTL( const SvxFontHeightItem& rFontSize )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
CharFontSize( rFontSize );
}
void RtfAttributeOutput::CharLanguageCTL( const SvxLanguageItem& rLanguageItem )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
CharLanguage( rLanguageItem );
}
void RtfAttributeOutput::CharPostureCTL( const SvxPostureItem& rPosture)
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_AI);
if ( rPosture.GetPosture() == ITALIC_NONE )
m_aStyles.append((sal_Int32)0);
}
void RtfAttributeOutput::CharWeightCTL( const SvxWeightItem& rWeight )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_AB);
if ( rWeight.GetWeight() != WEIGHT_BOLD )
m_aStyles.append((sal_Int32)0);
}
void RtfAttributeOutput:: CharBidiRTL( const SfxPoolItem& )
{
}
void RtfAttributeOutput:: CharIdctHint( const SfxPoolItem&)
{
}
void RtfAttributeOutput::CharRotate( const SvxCharRotateItem& rRotate)
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_HORZVERT);
m_aStyles.append((sal_Int32)(rRotate.IsFitToLine() ? 1 : 0));
}
void RtfAttributeOutput::CharEmphasisMark( const SvxEmphasisMarkItem& rEmphasisMark )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const sal_Char* pStr;
switch( rEmphasisMark.GetEmphasisMark())
{
case EMPHASISMARK_NONE: pStr = OOO_STRING_SVTOOLS_RTF_ACCNONE; break;
case EMPHASISMARK_SIDE_DOTS: pStr = OOO_STRING_SVTOOLS_RTF_ACCCOMMA; break;
default: pStr = OOO_STRING_SVTOOLS_RTF_ACCDOT; break;
}
m_aStyles.append(pStr);
}
void RtfAttributeOutput::CharTwoLines( const SvxTwoLinesItem& rTwoLines )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if( rTwoLines.GetValue() )
{
sal_Unicode cStart = rTwoLines.GetStartBracket();
sal_Unicode cEnd = rTwoLines.GetEndBracket();
sal_uInt16 nType;
if( !cStart && !cEnd )
nType = 0;
else if( '{' == cStart || '}' == cEnd )
nType = 4;
else if( '<' == cStart || '>' == cEnd )
nType = 3;
else if( '[' == cStart || ']' == cEnd )
nType = 2;
else // all other kind of brackets
nType = 1;
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_TWOINONE);
m_aStyles.append((sal_Int32)nType);
}
}
void RtfAttributeOutput::CharScaleWidth( const SvxCharScaleWidthItem& rScaleWidth )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_CHARSCALEX);
m_aStyles.append((sal_Int32)rScaleWidth.GetValue());
}
void RtfAttributeOutput::CharRelief( const SvxCharReliefItem& rRelief )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const sal_Char* pStr;
switch (rRelief.GetValue())
{
case RELIEF_EMBOSSED:
pStr = OOO_STRING_SVTOOLS_RTF_EMBO;
break;
case RELIEF_ENGRAVED:
pStr = OOO_STRING_SVTOOLS_RTF_IMPR;
break;
default:
pStr = 0;
break;
}
if (pStr)
m_aStyles.append(pStr);
}
void RtfAttributeOutput::CharHidden( const SvxCharHiddenItem& rHidden )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_V);
if ( !rHidden.GetValue() )
m_aStyles.append((sal_Int32)0);
}
void RtfAttributeOutput::TextINetFormat( const SwFmtINetFmt& rURL )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if( rURL.GetValue().Len() )
{
const SwCharFmt* pFmt;
const SwTxtINetFmt* pTxtAtr = rURL.GetTxtINetFmt();
m_aStyles.append("{" OOO_STRING_SVTOOLS_RTF_FLDRSLT " ");
if( pTxtAtr && 0 != ( pFmt = pTxtAtr->GetCharFmt() ))
{
sal_uInt16 nStyle = m_rExport.GetId( *pFmt );
OString* pString = m_rExport.GetStyle(nStyle);
if (pString)
m_aStyles.append(*pString);
}
}
}
void RtfAttributeOutput::TextCharFormat( const SwFmtCharFmt& rCharFmt )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
sal_uInt16 nStyle = m_rExport.GetId( *rCharFmt.GetCharFmt() );
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_CS);
m_aStyles.append((sal_Int32)nStyle);
OString* pString = m_rExport.GetStyle(nStyle);
if (pString)
m_aStyles.append(*pString);
}
void RtfAttributeOutput::WriteTextFootnoteNumStr(const SwFmtFtn& rFootnote)
{
if (!rFootnote.GetNumStr().Len())
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_CHFTN);
else
m_aRun.getOStringBuffer().append(m_rExport.OutString(rFootnote.GetNumStr(), m_rExport.eCurrentEncoding));
}
void RtfAttributeOutput::TextFootnote_Impl( const SwFmtFtn& rFootnote )
{
OSL_TRACE("%s start", OSL_THIS_FUNC);
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_SUPER " ");
WriteTextFootnoteNumStr(rFootnote);
m_aRun.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_FOOTNOTE);
if( rFootnote.IsEndNote() )
m_aRun.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FTNALT);
m_aRun.getOStringBuffer().append(' ');
WriteTextFootnoteNumStr(rFootnote);
/*
* The footnote contains a whole paragraph, so we have to:
* 1) Reset, then later restore the contents of our run buffer.
* 2) Buffer the output of the whole paragraph, as we do so for section headers already.
*/
const SwNodeIndex* pIndex = rFootnote.GetTxtFtn()->GetStartNode();
MultiBuffer aTemp;
aTemp.appendAndClear(m_aRun);
m_bBufferSectionHeaders = true;
m_rExport.WriteSpecialText( pIndex->GetIndex() + 1,
pIndex->GetNode().EndOfSectionIndex(),
!rFootnote.IsEndNote() ? TXT_FTN : TXT_EDN);
m_bBufferSectionHeaders = false;
m_aRun.clear();
m_aRun.appendAndClear(aTemp);
m_aRun.appendAndClear(m_aSectionHeaders);
m_aRun.getOStringBuffer().append("}");
m_aRun.getOStringBuffer().append("}");
OSL_TRACE("%s end", OSL_THIS_FUNC);
}
void RtfAttributeOutput::ParaLineSpacing_Impl( short nSpace, short nMulti )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_SL);
m_aStyles.append((sal_Int32)nSpace);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_SLMULT);
m_aStyles.append((sal_Int32)nMulti);
}
void RtfAttributeOutput::ParaAdjust( const SvxAdjustItem& rAdjust )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
switch ( rAdjust.GetAdjust() )
{
case SVX_ADJUST_LEFT:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_QL);
break;
case SVX_ADJUST_RIGHT:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_QR);
break;
case SVX_ADJUST_BLOCKLINE:
case SVX_ADJUST_BLOCK:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_QJ);
break;
case SVX_ADJUST_CENTER:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_QC);
break;
default:
break;
}
}
void RtfAttributeOutput::ParaSplit( const SvxFmtSplitItem& rSplit )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if( !rSplit.GetValue() )
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_KEEP);
}
void RtfAttributeOutput::ParaWidows( const SvxWidowsItem& rWidows )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if (rWidows.GetValue())
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_WIDCTLPAR);
else
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_NOWIDCTLPAR);
}
void RtfAttributeOutput::ParaTabStop( const SvxTabStopItem& rTabStop )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
long nOffset = ((SvxLRSpaceItem&)m_rExport.GetItem( RES_LR_SPACE )).GetTxtLeft();
for( sal_uInt16 n = 0; n < rTabStop.Count(); n++ )
{
const SvxTabStop & rTS = rTabStop[ n ];
if( SVX_TAB_ADJUST_DEFAULT != rTS.GetAdjustment() )
{
const char* pFill = 0;
switch( rTS.GetFill() )
{
case cDfltFillChar:
break;
case '.': pFill = OOO_STRING_SVTOOLS_RTF_TLDOT; break;
case '_': pFill = OOO_STRING_SVTOOLS_RTF_TLUL; break;
case '-': pFill = OOO_STRING_SVTOOLS_RTF_TLTH; break;
case '=': pFill = OOO_STRING_SVTOOLS_RTF_TLEQ; break;
default:
break;
}
if( pFill )
m_aStyles.append(pFill);
const sal_Char* pAdjStr = 0;
switch (rTS.GetAdjustment())
{
case SVX_TAB_ADJUST_RIGHT:
pAdjStr = OOO_STRING_SVTOOLS_RTF_TQR;
break;
case SVX_TAB_ADJUST_DECIMAL:
pAdjStr = OOO_STRING_SVTOOLS_RTF_TQDEC;
break;
case SVX_TAB_ADJUST_CENTER:
pAdjStr = OOO_STRING_SVTOOLS_RTF_TQC;
break;
default:
break;
}
if (pAdjStr)
m_aStyles.append(pAdjStr);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_TX);
m_aStyles.append((sal_Int32)(rTS.GetTabPos() + nOffset));
}
else
{
m_aTabStop.append( OOO_STRING_SVTOOLS_RTF_DEFTAB );
m_aTabStop.append( (sal_Int32)rTabStop[0].GetTabPos() );
}
}
}
void RtfAttributeOutput::ParaHyphenZone( const SvxHyphenZoneItem& rHyphenZone )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
sal_Int32 nFlags = rHyphenZone.IsHyphen() ? 1 : 0;
if( rHyphenZone.IsPageEnd() )
nFlags += 2;
m_aStyles.append('{');
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_IGNORE);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_HYPHEN);
m_aStyles.append((sal_Int32)nFlags);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_HYPHLEAD);
m_aStyles.append((sal_Int32)rHyphenZone.GetMinLead());
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_HYPHTRAIL);
m_aStyles.append((sal_Int32)rHyphenZone.GetMinTrail());
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_HYPHMAX);
m_aStyles.append((sal_Int32)rHyphenZone.GetMaxHyphens());
m_aStyles.append('}');
}
void RtfAttributeOutput::ParaNumRule_Impl( const SwTxtNode* pTxtNd, sal_Int32 nLvl, sal_Int32 nNumId )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( USHRT_MAX == nNumId || 0 == nNumId || 0 == pTxtNd)
return;
const SwNumRule* pRule = pTxtNd->GetNumRule();
// --> OD 2008-03-18 #refactorlists#
// if( pRule && MAXLEVEL > pTxtNd->GetActualListLevel() )
if( pRule && pTxtNd->IsInList() )
// <--
{
// --> OD 2008-03-18 #refactorlists#
ASSERT( pTxtNd->GetActualListLevel() >= 0 && pTxtNd->GetActualListLevel() < MAXLEVEL,
"<SwRTFWriter::OutListNum(..)> - text node does not have valid list level. Serious defect -> please inform OD" );
// <--
const bool bExportNumRule = USHRT_MAX != nNumId;
const SwNumFmt* pFmt = pRule->GetNumFmt( nLvl );
if( !pFmt )
pFmt = &pRule->Get( nLvl );
const SfxItemSet& rNdSet = pTxtNd->GetSwAttrSet();
if ( bExportNumRule ) {
m_aStyles.append('{');
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_LISTTEXT);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_PARD);
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_PLAIN);
m_aStyles.append(' ');
}
SvxLRSpaceItem aLR( (SvxLRSpaceItem&)rNdSet.Get( RES_LR_SPACE ) );
aLR.SetTxtLeft( aLR.GetTxtLeft() + pFmt->GetIndentAt() );
aLR.SetTxtFirstLineOfst( pFmt->GetFirstLineOffset() );
sal_uInt16 nStyle = m_rExport.GetId( *pFmt->GetCharFmt() );
OString* pString = m_rExport.GetStyle(nStyle);
if (pString)
m_aStyles.append(*pString);
{
String sTxt;
if( SVX_NUM_CHAR_SPECIAL == pFmt->GetNumberingType() || SVX_NUM_BITMAP == pFmt->GetNumberingType() )
sTxt = pFmt->GetBulletChar();
else
sTxt = pTxtNd->GetNumString();
m_aStyles.append(' ');
if (sTxt.Len())
{
m_aStyles.append(m_rExport.OutString(sTxt, m_rExport.eDefaultEncoding));
}
if( bExportNumRule )
{
if( OUTLINE_RULE != pRule->GetRuleType() )
{
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_TAB);
m_aStyles.append('}');
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_ILVL);
if( nLvl > 8 ) // RTF knows only 9 levels
{
m_aStyles.append((sal_Int32)8);
m_aStyles.append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_SOUTLVL);
m_aStyles.append((sal_Int32)nLvl);
m_aStyles.append('}');
}
else
m_aStyles.append((sal_Int32)nLvl);
}
else
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_TAB "}");
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_LS);
m_aStyles.append((sal_Int32)m_rExport.GetId(*pRule)+1);
m_aStyles.append(' ');
}
else if( sTxt.Len() )
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_TAB);
}
FormatLRSpace(aLR);
}
}
void RtfAttributeOutput::ParaScriptSpace( const SfxBoolItem& rScriptSpace )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if (!rScriptSpace.GetValue( ))
return;
switch ( rScriptSpace.Which( ) )
{
case RES_PARATR_SCRIPTSPACE:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_ASPALPHA);
break;
/* Is this needed?
case RES_PARATR_HANGINGPUNCTUATION:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_NOOVERFLOW);
break;
case RES_PARATR_FORBIDDEN_RULES:
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_NOCWRAP);
break;*/
default:
break;
}
}
void RtfAttributeOutput::ParaVerticalAlign( const SvxParaVertAlignItem& rAlign )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const char* pStr;
switch ( rAlign.GetValue() )
{
case SvxParaVertAlignItem::TOP: pStr = OOO_STRING_SVTOOLS_RTF_FAHANG; break;
case SvxParaVertAlignItem::BOTTOM: pStr = OOO_STRING_SVTOOLS_RTF_FAVAR; break;
case SvxParaVertAlignItem::CENTER: pStr = OOO_STRING_SVTOOLS_RTF_FACENTER; break;
case SvxParaVertAlignItem::BASELINE: pStr = OOO_STRING_SVTOOLS_RTF_FAROMAN; break;
// default == SvxParaVertAlignItem::AUTOMATIC
default: pStr = OOO_STRING_SVTOOLS_RTF_FAAUTO; break;
}
m_aStyles.append(pStr);
}
void RtfAttributeOutput::ParaSnapToGrid( const SvxParaGridItem& /*rGrid*/ )
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
void RtfAttributeOutput::FormatFrameSize( const SwFmtFrmSize& rSize )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( m_rExport.bOutFlyFrmAttrs && m_rExport.bRTFFlySyntax )
{
if( rSize.GetWidth() )
{
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_ABSW);
m_aRunText.getOStringBuffer().append((sal_Int32)rSize.GetWidth());
}
if( rSize.GetHeight() )
{
long nH = rSize.GetHeight();
if( ATT_FIX_SIZE == rSize.GetHeightSizeType() )
nH = -nH;
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_ABSH);
m_aRunText.getOStringBuffer().append((sal_Int32)nH);
}
}
else if (m_rExport.bOutPageDescs)
{
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_PGWSXN);
m_aSectionBreaks.append((sal_Int32)rSize.GetWidth());
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_PGHSXN);
m_aSectionBreaks.append((sal_Int32)rSize.GetHeight());
if (!m_bBufferSectionBreaks)
m_rExport.Strm() << m_aSectionBreaks.makeStringAndClear();
}
}
void RtfAttributeOutput::FormatPaperBin( const SvxPaperBinItem& )
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
void RtfAttributeOutput::FormatLRSpace( const SvxLRSpaceItem& rLRSpace )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( !m_rExport.bOutFlyFrmAttrs )
{
if( m_rExport.bOutPageDescs )
{
if( rLRSpace.GetLeft() )
{
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_MARGLSXN);
m_aSectionBreaks.append((sal_Int32)rLRSpace.GetLeft());
}
if( rLRSpace.GetRight() )
{
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_MARGRSXN);
m_aSectionBreaks.append((sal_Int32)rLRSpace.GetRight());
}
if (!m_bBufferSectionBreaks)
m_rExport.Strm() << m_aSectionBreaks.makeStringAndClear();
}
else
{
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_LI);
m_aStyles.append( (sal_Int32) rLRSpace.GetTxtLeft() );
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_RI);
m_aStyles.append( (sal_Int32) rLRSpace.GetRight() );
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_LIN);
m_aStyles.append( (sal_Int32) rLRSpace.GetTxtLeft() );
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_RIN);
m_aStyles.append( (sal_Int32) rLRSpace.GetRight() );
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_FI);
m_aStyles.append( (sal_Int32) rLRSpace.GetTxtFirstLineOfst() );
}
}
else if (rLRSpace.GetLeft() == rLRSpace.GetRight() && m_rExport.bRTFFlySyntax)
{
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_DFRMTXTX;
m_rExport.OutLong( rLRSpace.GetLeft() );
}
}
void RtfAttributeOutput::FormatULSpace( const SvxULSpaceItem& rULSpace )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( !m_rExport.bOutFlyFrmAttrs )
{
if( m_rExport.bOutPageDescs )
{
ASSERT( m_rExport.GetCurItemSet(), "Impossible" );
if ( !m_rExport.GetCurItemSet() )
return;
HdFtDistanceGlue aDistances( *m_rExport.GetCurItemSet() );
if( aDistances.dyaTop )
{
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_MARGTSXN);
m_aSectionBreaks.append((sal_Int32)aDistances.dyaTop);
}
if ( aDistances.HasHeader() )
{
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_HEADERY);
m_aSectionBreaks.append((sal_Int32)aDistances.dyaHdrTop);
}
if( aDistances.dyaBottom )
{
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_MARGBSXN);
m_aSectionBreaks.append((sal_Int32)aDistances.dyaBottom);
}
if( aDistances.HasFooter() )
{
m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_FOOTERY);
m_aSectionBreaks.append((sal_Int32)aDistances.dyaHdrBottom);
}
if (!m_bBufferSectionBreaks)
m_rExport.Strm() << m_aSectionBreaks.makeStringAndClear();
}
else
{
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_SB);
m_aStyles.append( (sal_Int32) rULSpace.GetUpper() );
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_SA);
m_aStyles.append( (sal_Int32) rULSpace.GetLower() );
}
}
else if (rULSpace.GetUpper() == rULSpace.GetLower() && m_rExport.bRTFFlySyntax)
{
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_DFRMTXTY;
m_rExport.OutLong( rULSpace.GetLower() );
}
}
void RtfAttributeOutput::FormatSurround( const SwFmtSurround& rSurround )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( m_rExport.bOutFlyFrmAttrs && !m_rExport.bRTFFlySyntax )
{
SwSurround eSurround = rSurround.GetSurround();
sal_Bool bGold = SURROUND_IDEAL == eSurround;
if( bGold )
eSurround = SURROUND_PARALLEL;
RTFSurround aMC( bGold, static_cast< sal_uInt8 >(eSurround) );
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FLYMAINCNT);
m_aRunText.getOStringBuffer().append( (sal_Int32) aMC.GetValue() );
}
}
void RtfAttributeOutput::FormatVertOrientation( const SwFmtVertOrient& rFlyVert )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( m_rExport.bOutFlyFrmAttrs && m_rExport.bRTFFlySyntax )
{
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_PVPARA);
switch (rFlyVert.GetVertOrient())
{
case text::VertOrientation::TOP:
case text::VertOrientation::LINE_TOP:
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_POSYT);
break;
case text::VertOrientation::BOTTOM:
case text::VertOrientation::LINE_BOTTOM:
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_POSYB);
break;
case text::VertOrientation::CENTER:
case text::VertOrientation::LINE_CENTER:
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_POSYC);
break;
case text::VertOrientation::NONE:
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_POSY);
m_aRunText.getOStringBuffer().append((sal_Int32)rFlyVert.GetPos());
break;
default:
break;
}
}
else if ( !m_rExport.bRTFFlySyntax )
{
RTFVertOrient aVO( static_cast< sal_uInt16 >(rFlyVert.GetVertOrient()), static_cast< sal_uInt16 >(rFlyVert.GetRelationOrient()) );
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FLYVERT);
m_aRunText.getOStringBuffer().append((sal_Int32)aVO.GetValue());
}
}
void RtfAttributeOutput::FormatHorizOrientation( const SwFmtHoriOrient& rFlyHori )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( m_rExport.bOutFlyFrmAttrs && m_rExport.bRTFFlySyntax )
{
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_PHCOL);
const char* pS = 0;
switch(rFlyHori.GetHoriOrient())
{
case text::HoriOrientation::RIGHT:
pS = rFlyHori.IsPosToggle() ? OOO_STRING_SVTOOLS_RTF_POSXO : OOO_STRING_SVTOOLS_RTF_POSXR;
break;
case text::HoriOrientation::LEFT:
pS = rFlyHori.IsPosToggle() ? OOO_STRING_SVTOOLS_RTF_POSXI : OOO_STRING_SVTOOLS_RTF_POSXL;
break;
case text::HoriOrientation::CENTER:
pS = OOO_STRING_SVTOOLS_RTF_POSXC;
break;
case text::HoriOrientation::NONE:
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_POSX);
m_aRunText.getOStringBuffer().append((sal_Int32)rFlyHori.GetPos());
break;
default:
break;
}
if (pS)
m_aRunText.getOStringBuffer().append(pS);
} else if ( !m_rExport.bRTFFlySyntax )
{
RTFHoriOrient aHO( static_cast< sal_uInt16 >(rFlyHori.GetHoriOrient()),
static_cast< sal_uInt16 >(rFlyHori.GetRelationOrient()) );
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FLYHORZ);
m_aRunText.getOStringBuffer().append((sal_Int32)aHO.GetValue());
}
}
void RtfAttributeOutput::FormatAnchor( const SwFmtAnchor& rAnchor )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( !m_rExport.bRTFFlySyntax )
{
sal_uInt16 nId = static_cast< sal_uInt16 >(rAnchor.GetAnchorId());
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FLYANCHOR);
m_aRunText.getOStringBuffer().append((sal_Int32)nId);
switch( nId )
{
case FLY_AT_PAGE:
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FLYPAGE);
m_aRunText.getOStringBuffer().append((sal_Int32)rAnchor.GetPageNum());
break;
case FLY_AT_PARA:
case FLY_AS_CHAR:
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_FLYCNTNT);
break;
}
}
}
void RtfAttributeOutput::FormatBackground( const SvxBrushItem& rBrush )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if( !rBrush.GetColor().GetTransparency() )
{
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_CBPAT);
m_aStyles.append((sal_Int32)m_rExport.GetColor(rBrush.GetColor()));
}
}
void RtfAttributeOutput::FormatBox( const SvxBoxItem& rBox )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
static sal_uInt16 __READONLY_DATA aBorders[] = {
BOX_LINE_TOP, BOX_LINE_LEFT, BOX_LINE_BOTTOM, BOX_LINE_RIGHT };
static const sal_Char* aBorderNames[] = {
OOO_STRING_SVTOOLS_RTF_BRDRT, OOO_STRING_SVTOOLS_RTF_BRDRL, OOO_STRING_SVTOOLS_RTF_BRDRB, OOO_STRING_SVTOOLS_RTF_BRDRR };
sal_uInt16 nDist = rBox.GetDistance();
if ( m_rExport.bRTFFlySyntax )
return;
if( rBox.GetTop() && rBox.GetBottom() &&
rBox.GetLeft() && rBox.GetRight() &&
*rBox.GetTop() == *rBox.GetBottom() &&
*rBox.GetTop() == *rBox.GetLeft() &&
*rBox.GetTop() == *rBox.GetRight() &&
nDist == rBox.GetDistance( BOX_LINE_TOP ) &&
nDist == rBox.GetDistance( BOX_LINE_LEFT ) &&
nDist == rBox.GetDistance( BOX_LINE_BOTTOM ) &&
nDist == rBox.GetDistance( BOX_LINE_RIGHT ))
m_aSectionBreaks.append(OutBorderLine( m_rExport, rBox.GetTop(), OOO_STRING_SVTOOLS_RTF_BOX, nDist ));
else
{
const sal_uInt16* pBrd = aBorders;
const sal_Char** pBrdNms = (const sal_Char**)aBorderNames;
for(int i = 0; i < 4; ++i, ++pBrd, ++pBrdNms)
{
if (const SvxBorderLine* pLn = rBox.GetLine(*pBrd))
{
m_aSectionBreaks.append(OutBorderLine(m_rExport, pLn, *pBrdNms,
rBox.GetDistance(*pBrd)));
}
}
}
const sal_uInt16* pBrd = aBorders;
const sal_Char** pBrdNms = (const sal_Char**)aBorderNames;
for( int i = 0; i < 4; ++i, ++pBrd, ++pBrdNms )
{
const SvxBorderLine* pLn = rBox.GetLine( *pBrd );
if( pLn )
{
m_aSectionBreaks.append("{" OOO_STRING_SVTOOLS_RTF_IGNORE);
m_aSectionBreaks.append(OutBorderLine( m_rExport, pLn, *pBrdNms ));
m_aSectionBreaks.append("}" OOO_STRING_SVTOOLS_RTF_BRSP);
m_aSectionBreaks.append((sal_Int32)rBox.GetDistance( *pBrd ));
}
}
if (!m_bBufferSectionBreaks)
m_aStyles.append(m_aSectionBreaks.makeStringAndClear());
}
void RtfAttributeOutput::FormatColumns_Impl( sal_uInt16 nCols, const SwFmtCol& rCol, bool bEven, SwTwips nPageSize )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_COLS;
m_rExport.OutLong( nCols );
if( bEven )
{
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_COLSX;
m_rExport.OutLong( rCol.GetGutterWidth( sal_True ) );
}
else
{
const SwColumns & rColumns = rCol.GetColumns( );
for( sal_uInt16 n = 0; n < nCols; )
{
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_COLNO;
m_rExport.OutLong( n+1 );
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_COLW;
m_rExport.OutLong( rCol.CalcPrtColWidth( n, nPageSize ) );
if( ++n != nCols )
{
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_COLSR;
m_rExport.OutLong( rColumns[ n-1 ]->GetRight() +
rColumns[ n ]->GetLeft() );
}
}
}
}
void RtfAttributeOutput::FormatKeep( const SvxFmtKeepItem& rItem )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if( rItem.GetValue() )
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_KEEPN);
}
void RtfAttributeOutput::FormatTextGrid( const SwTextGridItem& /*rGrid*/ )
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
void RtfAttributeOutput::FormatLineNumbering( const SwFmtLineNumber& rNumbering )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if ( !rNumbering.IsCount( ) )
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_NOLINE);
}
void RtfAttributeOutput::FormatFrameDirection( const SvxFrameDirectionItem& rDirection )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
if (!m_rExport.bOutPageDescs)
{
if (rDirection.GetValue() == FRMDIR_HORI_RIGHT_TOP)
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_RTLPAR);
else
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_LTRPAR);
}
}
void RtfAttributeOutput::WriteExpand( const SwField* pFld )
{
String sStr; // fuer optionale Parameter
switch (pFld->GetTyp()->Which())
{
//#119803# Export user field and DB field for RTF filter
case RES_DBFLD:
sStr = FieldString(ww::eMERGEFIELD);
// kein break !!
case RES_USERFLD:
sStr += pFld->GetTyp()->GetName();
m_rExport.OutputField(pFld, ww::eNONE, sStr);
break;
}
}
void RtfAttributeOutput::RefField( const SwField& /*rFld*/, const String& /*rRef*/ )
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
void RtfAttributeOutput::HiddenField( const SwField& /*rFld*/ )
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
void RtfAttributeOutput::SetField( const SwField& /*rFld*/, ww::eField /*eType*/, const String& /*rCmd*/ )
{
OSL_TRACE("TODO: %s", OSL_THIS_FUNC);
}
void RtfAttributeOutput::PostitField( const SwField* pFld )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
const SwPostItField& rPFld = *(SwPostItField*)pFld;
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_ATNID " ");
m_aRunText.getOStringBuffer().append(OUStringToOString(OUString(rPFld.GetPar1()), m_rExport.eCurrentEncoding));
m_aRunText.getOStringBuffer().append("}");
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_ATNAUTHOR " ");
m_aRunText.getOStringBuffer().append(OUStringToOString(OUString(rPFld.GetPar1()), m_rExport.eCurrentEncoding));
m_aRunText.getOStringBuffer().append("}");
m_aRunText.getOStringBuffer().append(OOO_STRING_SVTOOLS_RTF_CHATN);
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_ANNOTATION);
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_ATNDATE " ");
m_aRunText.getOStringBuffer().append((sal_Int32)sw::ms::DateTime2DTTM(rPFld.GetDate()));
m_aRunText.getOStringBuffer().append('}');
m_aRunText.getOStringBuffer().append(OUStringToOString(OUString(rPFld.GetContent()), m_rExport.eCurrentEncoding));
m_aRunText.getOStringBuffer().append('}');
}
bool RtfAttributeOutput::DropdownField( const SwField* /*pFld*/ )
{
// this is handled in OutputFlyFrame_Impl()
return true;
}
RtfAttributeOutput::RtfAttributeOutput( RtfExport &rExport )
: m_rExport( rExport ),
m_pTableWrt( NULL ),
m_bTableCellOpen( false ),
m_nTableDepth( 0 ),
m_bTblAfterCell( false ),
m_nColBreakNeeded( false ),
m_bBufferSectionBreaks( false ),
m_bBufferSectionHeaders( false ),
m_bLastTable( true ),
m_bWroteCellInfo( false )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
}
RtfAttributeOutput::~RtfAttributeOutput()
{
OSL_TRACE("%s", OSL_THIS_FUNC);
}
MSWordExportBase& RtfAttributeOutput::GetExport()
{
return m_rExport;
}
// These are used by wwFont::WriteRtf()
/// Start the font.
void RtfAttributeOutput::StartFont( const String& rFamilyName ) const
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << OUStringToOString( OUString( rFamilyName ), m_rExport.eCurrentEncoding ).getStr();
}
/// End the font.
void RtfAttributeOutput::EndFont() const
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << ";}";
}
/// Alternate name for the font.
void RtfAttributeOutput::FontAlternateName( const String& rName ) const
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << '{' << OOO_STRING_SVTOOLS_RTF_IGNORE << OOO_STRING_SVTOOLS_RTF_FALT << ' ';
m_rExport.Strm() << OUStringToOString( OUString( rName ), m_rExport.eCurrentEncoding ) << '}';
}
/// Font charset.
void RtfAttributeOutput::FontCharset( sal_uInt8 nCharSet ) const
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_FCHARSET;
m_rExport.OutULong( nCharSet );
m_rExport.Strm() << ' ';
}
/// Font family.
void RtfAttributeOutput::FontFamilyType( FontFamily eFamily, const wwFont &rFont ) const
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << '{' << OOO_STRING_SVTOOLS_RTF_F;
const char* pStr = OOO_STRING_SVTOOLS_RTF_FNIL;
switch (eFamily)
{
case FAMILY_ROMAN:
pStr = OOO_STRING_SVTOOLS_RTF_FROMAN;
break;
case FAMILY_SWISS:
pStr = OOO_STRING_SVTOOLS_RTF_FSWISS;
break;
case FAMILY_MODERN:
pStr = OOO_STRING_SVTOOLS_RTF_FMODERN;
break;
case FAMILY_SCRIPT:
pStr = OOO_STRING_SVTOOLS_RTF_FSCRIPT;
break;
case FAMILY_DECORATIVE:
pStr = OOO_STRING_SVTOOLS_RTF_FDECOR;
break;
default:
break;
}
m_rExport.OutULong(m_rExport.maFontHelper.GetId(rFont)) << pStr;
}
/// Font pitch.
void RtfAttributeOutput::FontPitchType( FontPitch ePitch ) const
{
OSL_TRACE("%s", OSL_THIS_FUNC);
m_rExport.Strm() << OOO_STRING_SVTOOLS_RTF_FPRQ;
sal_uInt16 nVal = 0;
switch (ePitch)
{
case PITCH_FIXED:
nVal = 1;
break;
case PITCH_VARIABLE:
nVal = 2;
break;
default:
break;
}
m_rExport.OutULong(nVal);
}
static bool IsEMF(const sal_uInt8 *pGraphicAry, unsigned long nSize)
{
if (pGraphicAry && (nSize > 0x2c ))
{
// check the magic number
if (
(pGraphicAry[0x28] == 0x20 ) && (pGraphicAry[0x29] == 0x45) &&
(pGraphicAry[0x2a] == 0x4d ) && (pGraphicAry[0x2b] == 0x46)
)
{
//emf detected
return true;
}
}
return false;
}
static bool StripMetafileHeader(const sal_uInt8 *&rpGraphicAry, unsigned long &rSize)
{
if (rpGraphicAry && (rSize > 0x22))
{
if (
(rpGraphicAry[0] == 0xd7) && (rpGraphicAry[1] == 0xcd) &&
(rpGraphicAry[2] == 0xc6) && (rpGraphicAry[3] == 0x9a)
)
{ // we have to get rid of the metafileheader
rpGraphicAry += 22;
rSize -= 22;
return true;
}
}
return false;
}
static OString WriteHex(const sal_uInt8* pData, sal_uInt32 nSize, sal_uInt32 nLimit = 64)
{
OStringBuffer aRet;
sal_uInt32 nBreak = 0;
for (sal_uInt32 i = 0; i < nSize; i++)
{
OString sNo = OString::valueOf(sal_Int32(pData[i]), 16);
if (sNo.getLength() < 2)
aRet.append('0');
aRet.append(sNo);
if (++nBreak == nLimit)
{
aRet.append(RtfExport::sNewLine);
nBreak = 0;
}
}
return aRet.makeStringAndClear();
}
static OString WriteHex(sal_Int32 nNum)
{
return WriteHex((sal_uInt8*)&nNum, sizeof(sal_Int32));
}
static OString WriteHex(OString sString)
{
OStringBuffer aRet;
aRet.append(WriteHex(sString.getLength()+1));
aRet.append(WriteHex((sal_uInt8*)sString.getStr(), sString.getLength()+1));
return aRet.makeStringAndClear();
}
void lcl_AppendSP( OStringBuffer& rBuffer,
const char cName[],
const ::rtl::OUString& rValue,
const RtfExport& rExport )
{
rBuffer.append( "{" OOO_STRING_SVTOOLS_RTF_SP "{" ); // "{\sp{"
rBuffer.append( OOO_STRING_SVTOOLS_RTF_SN " " );//" \sn "
rBuffer.append( cName ); //"PropName"
rBuffer.append( "}{" OOO_STRING_SVTOOLS_RTF_SV " " );
// "}{ \sv "
rBuffer.append( rExport.OutString( rValue, rExport.eCurrentEncoding ) );
rBuffer.append( "}}" );
}
void ExportPICT(
MultiBuffer& rTarget,
const SwFlyFrmFmt* pFlyFrmFmt,
const Size &rOrig,
const Size &rRendered,
const Size &rMapped,
const SwCropGrf &rCr,
const char *pBLIPType,
const sal_uInt8 *pGraphicAry,
unsigned long nSize,
const RtfExport& rExport )
{
bool bIsWMF = (const char *)pBLIPType == (const char *)OOO_STRING_SVTOOLS_RTF_WMETAFILE ? true : false;
if (pBLIPType && nSize && pGraphicAry)
{
rtl::OStringBuffer& rBuffer = rTarget.getOStringBuffer();
rBuffer.append("{" OOO_STRING_SVTOOLS_RTF_PICT);
if( pFlyFrmFmt )
{
String sDescription = pFlyFrmFmt->GetObjDescription();
//write picture properties - wzDescription at first
//looks like: "{\*\picprop{\sp{\sn PropertyName}{\sv PropertyValue}}}"
rBuffer.append( "{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_PICPROP );//"{\*\picprop
lcl_AppendSP( rBuffer, "wzDescription", sDescription, rExport );
String sName = pFlyFrmFmt->GetObjTitle();
lcl_AppendSP( rBuffer, "wzName", sName, rExport );
rBuffer.append( "}" ); //"}"
}
long nXCroppedSize = rOrig.Width()-(rCr.GetLeft() + rCr.GetRight());
long nYCroppedSize = rOrig.Height()-(rCr.GetTop() + rCr.GetBottom());
/* #127543#: Graphic with a zero height or width, typically copied from webpages, caused
crashes. */
if( !nXCroppedSize )
nXCroppedSize = 100;
if( !nYCroppedSize )
nYCroppedSize = 100;
//Given the original size and taking cropping into account
//first, how much has the original been scaled to get the
//final rendered size
rBuffer.append(OOO_STRING_SVTOOLS_RTF_PICSCALEX);
rBuffer.append((sal_Int32)((100 * rRendered.Width()) / nXCroppedSize));
rBuffer.append(OOO_STRING_SVTOOLS_RTF_PICSCALEY);
rBuffer.append((sal_Int32)((100 * rRendered.Height()) / nYCroppedSize));
rBuffer.append(OOO_STRING_SVTOOLS_RTF_PICCROPL);
rBuffer.append((sal_Int32)rCr.GetLeft());
rBuffer.append(OOO_STRING_SVTOOLS_RTF_PICCROPR);
rBuffer.append((sal_Int32)rCr.GetRight());
rBuffer.append(OOO_STRING_SVTOOLS_RTF_PICCROPT);
rBuffer.append((sal_Int32)rCr.GetTop());
rBuffer.append(OOO_STRING_SVTOOLS_RTF_PICCROPB);
rBuffer.append((sal_Int32)rCr.GetBottom());
rBuffer.append(OOO_STRING_SVTOOLS_RTF_PICW);
rBuffer.append((sal_Int32)rMapped.Width());
rBuffer.append(OOO_STRING_SVTOOLS_RTF_PICH);
rBuffer.append((sal_Int32)rMapped.Height());
rBuffer.append(OOO_STRING_SVTOOLS_RTF_PICWGOAL);
rBuffer.append((sal_Int32)rOrig.Width());
rBuffer.append(OOO_STRING_SVTOOLS_RTF_PICHGOAL);
rBuffer.append((sal_Int32)rOrig.Height());
rBuffer.append(pBLIPType);
if (bIsWMF)
{
rBuffer.append((sal_Int32)8);
StripMetafileHeader(pGraphicAry, nSize);
}
rBuffer.append(RtfExport::sNewLine);
// append binary data for later streaming
// anotation: it is okay to append further to the remembered rBuffer since
// the address of this basic buffer at MultiBuffer does not change; it will
// be reset to length zero, though, after this call
rTarget.appendHexData(pGraphicAry, nSize);
rBuffer.append('}');
}
}
void RtfAttributeOutput::FlyFrameOLEData( SwOLENode& rOLENode )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
uno::Reference < embed::XEmbeddedObject > xObj(const_cast<SwOLENode&>(rOLENode).GetOLEObj().GetOleRef());
sal_Int64 nAspect = rOLENode.GetAspect();
svt::EmbeddedObjectRef aObjRef( xObj, nAspect );
SvGlobalName aObjName(aObjRef->getClassID());
if (SotExchange::IsMath(aObjName))
{
// ObjectHeader
m_aRunText.getOStringBuffer().append(WriteHex(0x00000501)); // OLEVersion
m_aRunText.getOStringBuffer().append(WriteHex(0x00000002)); // FormatID
m_aRunText.getOStringBuffer().append(WriteHex(OString("Equation.3"))); // ClassName
m_aRunText.getOStringBuffer().append(WriteHex(0x00000000)); // TopicName
m_aRunText.getOStringBuffer().append(WriteHex(0x00000000)); // ItemName
// NativeData
SvMemoryStream *pStream = new SvMemoryStream;
SvStorage* pStorage = new SvStorage(*pStream);
m_rExport.pOLEExp->ExportOLEObject( aObjRef, *pStorage );
pStream->Seek(STREAM_SEEK_TO_END);
sal_uInt32 nNativeDataSize = pStream->Tell();
const sal_uInt8* pNativeData = (sal_uInt8*)pStream->GetData();
m_aRunText.getOStringBuffer().append(WriteHex(nNativeDataSize));
m_aRunText.getOStringBuffer().append(RtfExport::sNewLine);
// append binary data for later streaming
m_aRunText.appendHexData(pNativeData, nNativeDataSize, 126);
m_aRunText.getOStringBuffer().append(RtfExport::sNewLine);
delete pStream;
// MetaFilePresentationObject
pStream = new SvMemoryStream;
Graphic* pGraphic = rOLENode.GetGraphic();
if (GraphicConverter::Export(*pStream, *pGraphic, CVT_WMF) != ERRCODE_NONE)
OSL_ENSURE(false, "failed to export the presentation data");
pStream->Seek(STREAM_SEEK_TO_END);
sal_uInt32 nPresentationDataSize = pStream->Tell();
const sal_uInt8* pPresentationData = (sal_uInt8*)pStream->GetData();
// append binary data for later streaming
m_aRunText.appendHexData(pPresentationData, nPresentationDataSize, 126);
}
}
void RtfAttributeOutput::FlyFrameOLE( const SwFlyFrmFmt* pFlyFrmFmt, SwOLENode& rOLENode, const Size& rSize )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
SvMemoryStream aStream;
const sal_uInt8* pGraphicAry = 0;
sal_uInt32 nSize = 0;
Graphic* pGraphic = rOLENode.GetGraphic();
Size aSize(sw::util::GetSwappedInSize(rOLENode));
Size aRendered(aSize);
aRendered.Width() = rSize.Width();
aRendered.Height() = rSize.Height();
Size aMapped(pGraphic->GetPrefSize());
const SwCropGrf &rCr = (const SwCropGrf &)rOLENode.GetAttr(RES_GRFATR_CROPGRF);
const sal_Char* pBLIPType = OOO_STRING_SVTOOLS_RTF_WMETAFILE;
if (GraphicConverter::Export(aStream, *pGraphic, CVT_WMF) != ERRCODE_NONE)
OSL_ENSURE(false, "failed to export the graphic");
aStream.Seek(STREAM_SEEK_TO_END);
nSize = aStream.Tell();
pGraphicAry = (sal_uInt8*)aStream.GetData();
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_OBJECT OOO_STRING_SVTOOLS_RTF_OBJEMB);
// export the object data in the appropriate format; RTF requires the usage of the OLE 1.0 format
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_OBJDATA " ");
FlyFrameOLEData(rOLENode);
m_aRunText.getOStringBuffer().append("}{" OOO_STRING_SVTOOLS_RTF_RESULT);
SwTwips nHeight = aSize.Height();
nHeight/=20; //nHeight was in twips, want it in half points, but then half of total height.
long nFontHeight = ((const SvxFontHeightItem&)m_rExport.GetItem(RES_CHRATR_FONTSIZE)).GetHeight();
nHeight-=nFontHeight/20;
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_DN).append(nHeight);
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_SHPPICT);
ExportPICT( m_aRunText, pFlyFrmFmt, aSize, aRendered, aMapped, rCr, pBLIPType, pGraphicAry, nSize, m_rExport );
m_aRunText.getOStringBuffer().append("}}}}");
}
void RtfAttributeOutput::FlyFrameGraphic( const SwFlyFrmFmt* pFlyFrmFmt, const SwGrfNode& rGrfNode, const Size& rSize )
{
OSL_TRACE("%s", OSL_THIS_FUNC);
SvMemoryStream aStream;
const sal_uInt8* pGraphicAry = 0;
sal_uInt32 nSize = 0;
Graphic aGraphic(rGrfNode.GetGrf());
// If there is no graphic there is not much point in parsing it
if(aGraphic.GetType()==GRAPHIC_NONE)
return;
GfxLink aGraphicLink;
const sal_Char* pBLIPType = 0;
if (aGraphic.IsLink())
{
aGraphicLink = aGraphic.GetLink();
nSize = aGraphicLink.GetDataSize();
pGraphicAry = aGraphicLink.GetData();
switch (aGraphicLink.GetType())
{
// #15508# trying to add BMP type for better exports, need to check if this works
// checked, does not work. Also need to reset pGraphicAry to NULL to force conversion
// to PNG, else the BMP array will be used.
// It may work using direct DIB data, but that needs to be checked eventually
//
// #15508# before GFX_LINK_TYPE_NATIVE_BMP was added the graphic data
// (to be hold in pGraphicAry) was not available; thus for now to stay
// compatible, keep it that way by assigning NULL value to pGraphicAry
case GFX_LINK_TYPE_NATIVE_BMP:
// pBLIPType = OOO_STRING_SVTOOLS_RTF_WBITMAP;
pGraphicAry = 0;
break;
case GFX_LINK_TYPE_NATIVE_JPG:
pBLIPType = OOO_STRING_SVTOOLS_RTF_JPEGBLIP;
break;
case GFX_LINK_TYPE_NATIVE_PNG:
pBLIPType = OOO_STRING_SVTOOLS_RTF_PNGBLIP;
break;
case GFX_LINK_TYPE_NATIVE_WMF:
pBLIPType =
IsEMF(pGraphicAry, nSize) ? OOO_STRING_SVTOOLS_RTF_EMFBLIP : OOO_STRING_SVTOOLS_RTF_WMETAFILE;
break;
default:
break;
}
}
GraphicType eGraphicType = aGraphic.GetType();
if (!pGraphicAry)
{
if (ERRCODE_NONE == GraphicConverter::Export(aStream, aGraphic,
(eGraphicType == GRAPHIC_BITMAP) ? CVT_PNG : CVT_WMF))
{
pBLIPType = (eGraphicType == GRAPHIC_BITMAP) ?
OOO_STRING_SVTOOLS_RTF_PNGBLIP : OOO_STRING_SVTOOLS_RTF_WMETAFILE;
aStream.Seek(STREAM_SEEK_TO_END);
nSize = aStream.Tell();
pGraphicAry = (sal_uInt8*)aStream.GetData();
}
}
Size aMapped(eGraphicType == GRAPHIC_BITMAP ? aGraphic.GetSizePixel() : aGraphic.GetPrefSize());
const SwCropGrf &rCr = (const SwCropGrf &)rGrfNode.GetAttr(RES_GRFATR_CROPGRF);
//Get original size in twips
Size aSize(sw::util::GetSwappedInSize(rGrfNode));
Size aRendered(aSize);
aRendered.Width() = rSize.Width();
aRendered.Height() = rSize.Height();
/*
If the graphic is not of type WMF then we will have to store two
graphics, one in the native format wrapped in shppict, and the other in
the wmf format wrapped in nonshppict, so as to keep wordpad happy. If its
a wmf already then we don't need any such wrapping
*/
bool bIsWMF = (const sal_Char*)pBLIPType == (const sal_Char*)OOO_STRING_SVTOOLS_RTF_WMETAFILE ? true : false;
if (!bIsWMF)
m_aRunText.getOStringBuffer().append("{" OOO_STRING_SVTOOLS_RTF_IGNORE OOO_STRING_SVTOOLS_RTF_SHPPICT);
if (pBLIPType)
{
ExportPICT( m_aRunText, pFlyFrmFmt, aSize, aRendered, aMapped, rCr, pBLIPType, pGraphicAry, nSize, m_rExport);
}
else
{
aStream.Seek(0);
GraphicConverter::Export(aStream, aGraphic, CVT_WMF);
pBLIPType = OOO_STRING_SVTOOLS_RTF_WMETAFILE;
aStream.Seek(STREAM_SEEK_TO_END);
nSize = aStream.Tell();
pGraphicAry = (sal_uInt8*)aStream.GetData();
ExportPICT( m_aRunText, pFlyFrmFmt, aSize, aRendered, aMapped, rCr, pBLIPType, pGraphicAry, nSize, m_rExport );
}
if (!bIsWMF)
{
m_aRunText.getOStringBuffer().append("}" "{" OOO_STRING_SVTOOLS_RTF_NONSHPPICT);
aStream.Seek(0);
GraphicConverter::Export(aStream, aGraphic, CVT_WMF);
pBLIPType = OOO_STRING_SVTOOLS_RTF_WMETAFILE;
aStream.Seek(STREAM_SEEK_TO_END);
nSize = aStream.Tell();
pGraphicAry = (sal_uInt8*)aStream.GetData();
ExportPICT( m_aRunText, pFlyFrmFmt, aSize, aRendered, aMapped, rCr, pBLIPType, pGraphicAry, nSize, m_rExport );
m_aRunText.getOStringBuffer().append('}');
}
m_aRunText.getOStringBuffer().append(m_rExport.sNewLine);
}
/* vi:set shiftwidth=4 expandtab: */