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