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.
tdeutils/superkaramba/src/textfilesensor.cpp

110 lines
3.2 KiB

/***************************************************************************
* Copyright (C) 2003 by Hans Karlsson *
* karlsson.h@home.se *
* *
* 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. *
***************************************************************************/
#include "textfilesensor.h"
#include "tqdom.h"
TextFileSensor::TextFileSensor( const TQString &fn, bool iRdf, int interval, const TQString &encoding )
: Sensor( interval )
{
fileName = fn;
rdf = iRdf;
if( !encoding.isEmpty() )
{
codec = TQTextCodec::codecForName( encoding.ascii() );
if ( codec == 0)
codec = TQTextCodec::codecForLocale();
}
else
codec = TQTextCodec::codecForLocale();
}
TextFileSensor::~TextFileSensor()
{}
void TextFileSensor::update()
{
TQValueVector<TQString> lines;
TQFile file(fileName);
TQString line;
if ( file.open(IO_ReadOnly | IO_Translate) )
{
if (rdf)
{
TQDomDocument doc;
if ( !doc.setContent( &file ) )
{
file.close();
return;
}
TQDomElement docElem = doc.documentElement();
TQDomNode n = docElem.firstChild();
if (!n.isNull())
{
TQDomNodeList titles = docElem.elementsByTagName( "title" );
TQDomNodeList links = docElem.elementsByTagName( "link" );
uint i;
for ( i = 0; i < titles.count(); ++i )
{
TQDomElement element = titles.item( i ).toElement();
lines.push_back(element.text());
element = links.item( i ).toElement();
lines.push_back(element.text());
}
}
}
else
{
TQTextStream t( &file ); // use a text stream
while( (line = t.readLine()) !=0 )
{
lines.push_back(line);
}
}
file.close();
}
int lineNbr;
SensorParams *sp;
Meter *meter;
int count = (int) lines.size();
TQObjectListIt it( *objList );
while (it != 0)
{
sp = (SensorParams*)(*it);
meter = sp->getMeter();
lineNbr = (sp->getParam("LINE")).toInt();
if ( lineNbr >= 1 && lineNbr <= (int) count )
{
meter->setValue(lines[lineNbr-1]);
}
if ( -lineNbr >= 1 && -lineNbr <= (int) count )
{
meter->setValue(lines[count+lineNbr]);
}
if ( lineNbr == 0 )
{
TQString text;
for( int i=0; i < count; i++ )
{
text += lines[i] + "\n";
}
meter->setValue( text );
}
++it;
}
}
#include "textfilesensor.moc"