/*************************************************************************** * Copyright (C) 2004-2007 by Georgy Yunaev, gyunaev@ulduzsoft.com * * Please do not use email address above for bug reports; see * * the README file * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * * * * This program 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 General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #include "libchmfile.h" #include "libchmfileimpl.h" LCHMFile::LCHMFile( ) { m_impl = new LCHMFileImpl(); } LCHMFile::~ LCHMFile( ) { delete m_impl; } bool LCHMFile::loadFile( const TQString & archiveName ) { return m_impl->loadFile( archiveName ); } void LCHMFile::closeAll( ) { m_impl->closeAll(); } TQString LCHMFile::title( ) const { return m_impl->title(); } TQString LCHMFile::homeUrl( ) const { TQString url = m_impl->homeUrl(); return url.isNull() ? "/" : url; } bool LCHMFile::hasTableOfContents( ) const { return !m_impl->m_topicsFile.isNull(); } bool LCHMFile::hasIndexTable( ) const { return !m_impl->m_indexFile.isNull(); } bool LCHMFile::hasSearchTable( ) const { return m_impl->m_searchAvailable; } bool LCHMFile::parseTableOfContents( QT34VECTOR< LCHMParsedEntry > * topics ) const { return m_impl->parseFileAndFillArray( m_impl->m_topicsFile, topics, false ); } bool LCHMFile::parseIndex( QT34VECTOR< LCHMParsedEntry > * indexes ) const { return m_impl->parseFileAndFillArray( m_impl->m_indexFile, indexes, true ); } bool LCHMFile::getFileContentAsString( TQString * str, const TQString & url ) { return m_impl->getFileContentAsString( str, url ); } bool LCHMFile::getFileContentAsBinary( TQByteArray * data, const TQString & url ) { return m_impl->getFileContentAsBinary( data, url ); } bool LCHMFile::enumerateFiles( TQStringList * files ) { return m_impl->enumerateFiles( files ); } TQString LCHMFile::getTopicByUrl( const TQString & url ) { return m_impl->getTopicByUrl( url ); } const TQPixmap * LCHMFile::getBookIconPixmap( unsigned int imagenum ) { return m_impl->getBookIconPixmap( imagenum ); } const LCHMTextEncoding * LCHMFile::currentEncoding( ) const { return m_impl->m_currentEncoding; } bool LCHMFile::setCurrentEncoding( const LCHMTextEncoding * encoding ) { return m_impl->setCurrentEncoding( encoding ); } TQString LCHMFile::normalizeUrl( const TQString & url ) const { return m_impl->normalizeUrl( url ); } bool LCHMFile::getFileSize(unsigned int * size, const TQString & url) { return m_impl->getFileSize( size, url ); }