Files
libreoffice/shell/source/all/ooofilereader/contentreader.cxx

252 lines
8.0 KiB
C++
Raw Normal View History

/*************************************************************************
*
* $RCSfile: contentreader.cxx,v $
*
* $Revision: 1.2 $
*
* last change: $Author: hr $ $Date: 2004-09-08 14:28:49 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (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.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#ifndef CONTENTREADER_HXX_INCLUDED
#include "internal/contentreader.hxx"
#endif
#ifndef DUMMYTAG_HXX_INCLUDED
#include "dummytag.hxx"
#endif
#ifndef SIMPLETAG_HXX_INCLUDED
#include "simpletag.hxx"
#endif
#ifndef AUTOSTYLETAG_HXX_INCLUDED
#include "autostyletag.hxx"
#endif
#include "assert.h"
/** constructor.
*/
CContentReader::CContentReader( const std::string& DocumentName, LocaleSet_t const & DocumentLocale ):
CBaseReader( DocumentName )
{
try
{
m_DefaultLocale = DocumentLocale;
Initialize( DOC_CONTENT_NAME );
}
catch(xml_parser_exception& ex)
{
ENSURE(false, ex.what());
}
catch(...)
{
ENSURE(false, "Unknown error");
}
}
/** destructor.
*/
CContentReader::~CContentReader( void )
{
}
/*********************** helper functions ***********************/
/** choose an appropriate tag reader
*/
ITag* CContentReader::chooseTagReader( const std::wstring& tag_name, const XmlTagAttributes_t& XmlAttributes )
{
if (( tag_name == CONTENT_TEXT_A )||( tag_name == CONTENT_TEXT_P )||
( tag_name == CONTENT_TEXT_SPAN ) ||( tag_name == CONTENT_TEXT_H )||
( tag_name == CONTENT_TEXT_SEQUENCE ) ||( tag_name == CONTENT_TEXT_BOOKMARK_REF )||
( tag_name == CONTENT_TEXT_INDEX_TITLE_TEMPLATE ) )
return new CSimpleTag(XmlAttributes);
else if ( tag_name == CONTENT_STYLE_STYLE )
{
// if style:style | style:name is exist,, fill the style field, otherwise do nothing;
if ( XmlAttributes.find(CONTENT_STYLE_STYLE_NAME) != XmlAttributes.end())
return new CAutoStyleTag(XmlAttributes);
else
return new CDummyTag();
}
else if ( ( tag_name == CONTENT_STYLE_PROPERTIES ) || ( tag_name == CONTENT_TEXT_STYLE_PROPERTIES ) )
{
assert( !m_TagBuilderStack.empty() );
//here we presume that if CONTENT_STYLE_PROPERTIES tag is present, it just follow CONTENT_STYLE_STYLE;
ITag* pTagBuilder = m_TagBuilderStack.top();
pTagBuilder->addAttributes( XmlAttributes );
return new CDummyTag();
}
else
return new CDummyTag();
}
/** get style of the current content.
*/
::std::wstring CContentReader::getCurrentContentStyle( void )
{
assert( !m_TagBuilderStack.empty() );
ITag* pTagBuilder = m_TagBuilderStack.top();
return ( pTagBuilder->getTagAttribute(CONTENT_TEXT_STYLENAME) );
}
/** add chunk into Chunk Buffer.
*/
void CContentReader::addChunk( LocaleSet_t const & Locale, Content_t const & Content )
{
if ( Content == EMPTY_STRING )
return;
if ( ( ( m_ChunkBuffer.empty() ) || ( m_ChunkBuffer.back().first != Locale ) ) &&
( ( Content != SPACE ) && ( Content != LF ) ) )
{
// if met a new locale, add a blank new chunk;
Chunk_t Chunk;
Chunk.first = Locale;
Chunk.second = EMPTY_STRING;
m_ChunkBuffer.push_back( Chunk );
}
if ( !m_ChunkBuffer.empty() )
m_ChunkBuffer.back().second += Content;
}
/** get a style's locale field.
*/
LocaleSet_t const & CContentReader::getLocale( const StyleName_t Style )
{
if ( m_StyleMap.empty() )
return m_DefaultLocale;
StyleLocaleMap_t :: const_iterator style_Iter;
if ( ( style_Iter = m_StyleMap.find( Style ) ) == m_StyleMap.end( ) )
return m_DefaultLocale;
else
return style_Iter->second;
}
/*********************** event handler functions ***********************/
//------------------------------
// start_element occurs when a tag is start
//------------------------------
void CContentReader::start_element(
const std::wstring& /*raw_name*/,
const std::wstring& local_name,
const XmlTagAttributes_t& attributes)
{
//get appropriate Xml Tag Builder using MetaInfoBuilderFactory;
ITag* pTagBuilder = chooseTagReader( local_name,attributes );
assert( m_pTagBuilder != NULL );
pTagBuilder->startTag( );
m_TagBuilderStack.push( pTagBuilder );
}
//------------------------------
// end_element occurs when a tag is closed
//------------------------------
void CContentReader::end_element(const std::wstring& /*raw_name*/, const std::wstring& local_name)
{
assert( !m_TagBuilderStack.empty() );
ITag* pTagBuilder = m_TagBuilderStack.top();
if ( local_name == CONTENT_STYLE_STYLE )
{
StyleLocalePair_t StyleLocalePair = reinterpret_cast<CAutoStyleTag * >( pTagBuilder)->getStyleLocalePair();
if ( ( reinterpret_cast<CAutoStyleTag * >( pTagBuilder)->isFull() ) && ( StyleLocalePair.second != m_DefaultLocale ) )
m_StyleMap.insert( StyleLocalePair );
}
if (( local_name == CONTENT_TEXT_A )||( local_name == CONTENT_TEXT_SPAN ) ||
( local_name == CONTENT_TEXT_SEQUENCE )||( local_name == CONTENT_TEXT_BOOKMARK_REF ))
addChunk( getLocale( getCurrentContentStyle() ), ::std::wstring( SPACE ) );
if ((( local_name == CONTENT_TEXT_P )||( local_name == CONTENT_TEXT_H ) ||
( local_name == CONTENT_TEXT_INDEX_TITLE_TEMPLATE ) )&&
( EMPTY_STRING != pTagBuilder->getTagContent( ) ) )
addChunk( getLocale( getCurrentContentStyle() ), ::std::wstring( LF ) );
m_TagBuilderStack.pop();
pTagBuilder->endTag();
delete pTagBuilder;
}
//------------------------------
// characters occurs when receiving characters
//------------------------------
void CContentReader::characters( const std::wstring& character )
{
if ( character.length() > 0 && !HasOnlySpaces( character ) )
{
addChunk( getLocale( getCurrentContentStyle() ), ::std::wstring( character ) );
ITag* pTagBuilder = m_TagBuilderStack.top();
pTagBuilder->addCharacters( character );
}
}