You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdepim/kioslaves/mbox/readmbox.cc

205 lines
4.2 KiB

/*
* This is a simple kioslave to handle mbox-files.
* Copyright (C) 2004 Mart Kelder (mart.kde@hccnet.nl)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include <config.h>
#include "readmbox.h"
#include "mbox.h"
#include "urlinfo.h"
#include <kdebug.h>
#include <kio/global.h>
#include <tqfile.h>
#include <tqfileinfo.h>
#include <tqstring.h>
#include <textstream.h>
#ifdef HAVE_SYS_TYPES_H
#include <sys/types.h>
#endif
#include <utime.h>
ReadMBox::ReadMBox( const UrlInfo* info, MBoxProtocol* parent, bool onlynew, bool savetime )
: MBoxFile( info, parent ),
m_file( 0 ),
m_stream( 0 ),
m_current_line( new TQString( TQString() ) ),
m_current_id( new TQString( TQString() ) ),
m_atend( true ),
m_prev_time( 0 ),
m_only_new( onlynew ),
m_savetime( savetime ),
m_status( false ),
m_prev_status( false ),
m_header( true )
{
if( m_info->type() == UrlInfo::invalid )
m_mbox->emitError( KIO::ERR_DOES_NOT_EXIST, info->url() );
if( !open( savetime ) )
m_mbox->emitError( KIO::ERR_CANNOT_OPEN_FOR_READING, info->url() );
if( m_info->type() == UrlInfo::message )
if( !searchMessage( m_info->id() ) )
m_mbox->emitError( KIO::ERR_DOES_NOT_EXIST, info->url() );
}
ReadMBox::~ReadMBox()
{
delete m_current_line;
close();
}
TQString ReadMBox::currentLine() const
{
return *m_current_line;
}
TQString ReadMBox::currentID() const
{
return *m_current_id;
}
bool ReadMBox::nextLine()
{
if( !m_stream )
return true;
*m_current_line = m_stream->readLine();
m_atend = m_current_line->isNull();
if( m_atend ) // Cursor was at EOF
{
*m_current_id = TQString();
m_prev_status = m_status;
return true;
}
//New message
if( m_current_line->left( 5 ) == "From " )
{
*m_current_id = *m_current_line;
m_prev_status = m_status;
m_status = true;
m_header = true;
return true;
} else if( m_only_new )
{
if( m_header && m_current_line->left( 7 ) == "Status:" &&
! m_current_line->contains( "U" ) && ! m_current_line->contains( "N" ) )
{
m_status = false;
}
}
if( m_current_line->stripWhiteSpace().isEmpty() )
m_header = false;
return false;
}
bool ReadMBox::searchMessage( const TQString& id )
{
if( !m_stream )
return false;
while( !m_atend && *m_current_id != id )
nextLine();
return *m_current_id == id;
}
unsigned int ReadMBox::skipMessage()
{
unsigned int result = m_current_line->length();
if( !m_stream )
return 0;
while( !nextLine() )
result += m_current_line->length();
return result;
}
void ReadMBox::rewind()
{
if( !m_stream )
return; //Rewinding not possible
m_stream->device()->reset();
m_atend = m_stream->atEnd();
}
bool ReadMBox::atEnd() const
{
if( !m_stream )
return true;
return m_atend || ( m_info->type() == UrlInfo::message && *m_current_id != m_info->id() );
}
bool ReadMBox::inListing() const
{
return !m_only_new || m_prev_status;
}
bool ReadMBox::open( bool savetime )
{
if( savetime )
{
TQFileInfo info( m_info->filename() );
m_prev_time = new utimbuf;
m_prev_time->actime = info.lastRead().toTime_t();
m_prev_time->modtime = info.lastModified().toTime_t();
}
if( m_file )
return false; //File already open
m_file = new TQFile( m_info->filename() );
if( !m_file->open( IO_ReadOnly ) )
{
delete m_file;
m_file = 0;
return false;
}
m_stream = new TQTextStream( m_file );
skipMessage();
return true;
}
void ReadMBox::close()
{
if( !m_stream )
return;
delete m_stream; m_stream = 0;
m_file->close();
delete m_file; m_file = 0;
if( m_prev_time )
utime( TQFile::encodeName( m_info->filename() ), m_prev_time );
}