Add debug output to the ClearMountsJob code path.

This commit is contained in:
Teo Mrnjavac 2015-02-13 11:56:10 +01:00
parent 1495e6604d
commit 1eff260637
2 changed files with 21 additions and 0 deletions

View File

@ -293,6 +293,16 @@ PartitionCoreModule::jobs() const
}
lst << Calamares::job_ptr( new FillGlobalStorageJob( devices, m_bootLoaderInstallPath ) );
QStringList jobsDebug;
foreach ( auto job, lst )
{
jobsDebug.append( job->prettyName() );
}
cDebug() << "PartitionCodeModule has been asked for jobs. About to return:"
<< jobsDebug.join( "\n" );
return lst;
}

View File

@ -23,6 +23,7 @@
#include <core/PartitionInfo.h>
#include <core/PartitionIterator.h>
#include <util/report.h>
#include <utils/Logger.h>
#include <QStringList>
@ -45,30 +46,40 @@ ClearMountsJob::prettyName() const
Calamares::JobResult
ClearMountsJob::exec()
{
cDebug() << "Executing ClearMounts job for device" << m_device->deviceNode();
QStringList goodNews;
for ( auto it = PartitionIterator::begin( m_device );
it != PartitionIterator::end( m_device ); ++it )
{
cDebug() << "Now examining device" << (*it)->partitionPath();
if ( (*it)->isMounted() )
{
cDebug() << "\tIt's mounted!";
if ( (*it)->canUnmount() )
{
cDebug() << "\tTrying to umount...";
Report report( 0, QString() );
(*it)->unmount( report );
goodNews.append( report.toText() );
cDebug() << "\tUmounted" << (*it)->partitionPath();
}
else
{
cDebug() << "\tCannot umount. This is very bad.";
return Calamares::JobResult::error( tr( "Cannot umount partition %1" )
.arg( (*it)->deviceNode() ),
tr( "Cannot proceed with partitioning operations "
"because some partitions are still mounted." ) );
}
}
else
cDebug() << "\tIt's not mounted.";
}
Calamares::JobResult ok = Calamares::JobResult::ok();
ok.setMessage( tr( "Cleared all mounts for %1" )
.arg( m_device->deviceNode() ) );
ok.setDetails( goodNews.join( "\n" ) );
cDebug() << "Finished ClearMounts job.";
return ok;
}