|
|
|
/***************************************************************************
|
|
|
|
* 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"
|