|
|
|
/*
|
|
|
|
*
|
|
|
|
* $Id: k3bdebuggingoutputdialog.cpp 619556 2007-01-03 17:38:12Z trueg $
|
|
|
|
* Copyright (C) 2005 Sebastian Trueg <trueg@k3b.org>
|
|
|
|
*
|
|
|
|
* This file is part of the K3b project.
|
|
|
|
* Copyright (C) 1998-2007 Sebastian Trueg <trueg@k3b.org>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
* See the file "COPYING" for the exact licensing terms.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "k3bdebuggingoutputdialog.h"
|
|
|
|
|
|
|
|
#include <k3bdevicemanager.h>
|
|
|
|
#include <k3bdevice.h>
|
|
|
|
#include <k3bdeviceglobals.h>
|
|
|
|
#include <k3bcore.h>
|
|
|
|
#include <k3bversion.h>
|
|
|
|
#include <k3bglobals.h>
|
|
|
|
|
|
|
|
#include <tqtextedit.h>
|
|
|
|
#include <tqcursor.h>
|
|
|
|
#include <tqfile.h>
|
|
|
|
#include <tqclipboard.h>
|
|
|
|
|
|
|
|
#include <klocale.h>
|
|
|
|
#include <kstdguiitem.h>
|
|
|
|
#include <kglobalsettings.h>
|
|
|
|
#include <kapplication.h>
|
|
|
|
#include <kfiledialog.h>
|
|
|
|
#include <kmessagebox.h>
|
|
|
|
|
|
|
|
|
|
|
|
K3bDebuggingOutputDialog::K3bDebuggingOutputDialog( TQWidget* parent )
|
|
|
|
: KDialogBase( parent, "debugViewDialog", true, i18n("Debugging Output"), Close|User1|User2, Close,
|
|
|
|
false,
|
|
|
|
KStdGuiItem::saveAs(),
|
|
|
|
KGuiItem( i18n("Copy"), "editcopy" ) )
|
|
|
|
{
|
|
|
|
setButtonTip( User1, i18n("Save to file") );
|
|
|
|
setButtonTip( User2, i18n("Copy to clipboard") );
|
|
|
|
|
|
|
|
debugView = new TQTextEdit( this );
|
|
|
|
debugView->setReadOnly(true);
|
|
|
|
debugView->setTextFormat( TQTextEdit::PlainText );
|
|
|
|
debugView->setCurrentFont( KGlobalSettings::fixedFont() );
|
|
|
|
debugView->setWordWrap( TQTextEdit::NoWrap );
|
|
|
|
|
|
|
|
setMainWidget( debugView );
|
|
|
|
|
|
|
|
resize( 600, 300 );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void K3bDebuggingOutputDialog::setOutput( const TQMap<TQString, TQStringList>& map )
|
|
|
|
{
|
|
|
|
// the following may take some time
|
|
|
|
TQApplication::setOverrideCursor( TQCursor(TQt::WaitCursor) );
|
|
|
|
|
|
|
|
clear();
|
|
|
|
|
|
|
|
// add the debugging output
|
|
|
|
for( TQMap<TQString, TQStringList>::ConstIterator itMap = map.begin(); itMap != map.end(); ++itMap ) {
|
|
|
|
const TQStringList& list = itMap.data();
|
|
|
|
debugView->append( itMap.key() + "\n" );
|
|
|
|
debugView->append( "-----------------------\n" );
|
|
|
|
for( TQStringList::ConstIterator it = list.begin(); it != list.end(); ++it ) {
|
|
|
|
TQStringList lines = TQStringList::split( "\n", *it );
|
|
|
|
// do every line
|
|
|
|
TQStringList::ConstIterator end( lines.end() );
|
|
|
|
for( TQStringList::ConstIterator str = lines.begin(); str != end; ++str )
|
|
|
|
debugView->append( *str + "\n" );
|
|
|
|
}
|
|
|
|
m_paragraphMap[itMap.key()] = debugView->paragraphs();
|
|
|
|
debugView->append( "\n" );
|
|
|
|
}
|
|
|
|
|
|
|
|
TQApplication::restoreOverrideCursor();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void K3bDebuggingOutputDialog::addOutput( const TQString& app, const TQString& msg )
|
|
|
|
{
|
|
|
|
TQMap<TQString, int>::Iterator it = m_paragraphMap.find( app );
|
|
|
|
|
|
|
|
if( it == m_paragraphMap.end() ) {
|
|
|
|
// create new section
|
|
|
|
debugView->append( app + "\n" );
|
|
|
|
debugView->append( "-----------------------\n" );
|
|
|
|
debugView->append( msg + "\n" );
|
|
|
|
m_paragraphMap[app] = debugView->paragraphs();
|
|
|
|
debugView->append( "\n" );
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
debugView->insertParagraph( msg, *it );
|
|
|
|
// update the paragraphs map
|
|
|
|
// FIXME: we cannot count on the map to be sorted properly!
|
|
|
|
while( it != m_paragraphMap.end() ) {
|
|
|
|
it.data() += 1;
|
|
|
|
++it;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void K3bDebuggingOutputDialog::clear()
|
|
|
|
{
|
|
|
|
debugView->clear();
|
|
|
|
m_paragraphMap.clear();
|
|
|
|
|
|
|
|
addOutput( "System", "K3b Version: " + k3bcore->version() );
|
|
|
|
addOutput( "System", "KDE Version: " + TQString(KDE::versionString()) );
|
|
|
|
addOutput( "System", "QT Version: " + TQString(qVersion()) );
|
|
|
|
addOutput( "System", "Kernel: " + K3b::kernelVersion() );
|
|
|
|
|
|
|
|
// devices in the logfile
|
|
|
|
for( TQPtrListIterator<K3bDevice::Device> it( k3bcore->deviceManager()->allDevices() ); *it; ++it ) {
|
|
|
|
K3bDevice::Device* dev = *it;
|
|
|
|
addOutput( "Devices",
|
|
|
|
TQString( "%1 (%2, %3) [%5] [%6] [%7]" )
|
|
|
|
.tqarg( dev->vendor() + " " + dev->description() + " " + dev->version() )
|
|
|
|
.tqarg( dev->blockDeviceName() )
|
|
|
|
.tqarg( dev->genericDevice() )
|
|
|
|
.tqarg( K3bDevice::deviceTypeString( dev->type() ) )
|
|
|
|
.tqarg( K3bDevice::mediaTypeString( dev->supportedProfiles() ) )
|
|
|
|
.tqarg( K3bDevice::writingModeString( dev->writingModes() ) ) );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void K3bDebuggingOutputDialog::slotUser1()
|
|
|
|
{
|
|
|
|
TQString filename = KFileDialog::getSaveFileName();
|
|
|
|
if( !filename.isEmpty() ) {
|
|
|
|
TQFile f( filename );
|
|
|
|
if( !f.exists() || KMessageBox::warningContinueCancel( this,
|
|
|
|
i18n("Do you want to overwrite %1?").tqarg(filename),
|
|
|
|
i18n("File Exists"), i18n("Overwrite") )
|
|
|
|
== KMessageBox::Continue ) {
|
|
|
|
|
|
|
|
if( f.open( IO_WriteOnly ) ) {
|
|
|
|
TQTextStream t( &f );
|
|
|
|
t << debugView->text();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
KMessageBox::error( this, i18n("Could not open file %1").tqarg(filename) );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void K3bDebuggingOutputDialog::slotUser2()
|
|
|
|
{
|
|
|
|
TQApplication::tqclipboard()->setText( debugView->text(), TQClipboard::Clipboard );
|
|
|
|
}
|
|
|
|
|
|
|
|
#include "k3bdebuggingoutputdialog.moc"
|