Branch data Line data Source code
1 : : /*************************************************************************** 2 : : qgsvectorfilewritertask.cpp 3 : : --------------------------- 4 : : begin : Feb 2017 5 : : copyright : (C) 2017 by Nyall Dawson 6 : : email : nyall dot dawson at gmail dot com 7 : : ***************************************************************************/ 8 : : 9 : : /*************************************************************************** 10 : : * * 11 : : * This program is free software; you can redistribute it and/or modify * 12 : : * it under the terms of the GNU General Public License as published by * 13 : : * the Free Software Foundation; either version 2 of the License, or * 14 : : * (at your option) any later version. * 15 : : * * 16 : : ***************************************************************************/ 17 : : 18 : : #include "qgsvectorfilewritertask.h" 19 : : #include "qgsvectorlayer.h" 20 : : 21 : 0 : QgsVectorFileWriterTask::QgsVectorFileWriterTask( QgsVectorLayer *layer, const QString &fileName, const QgsVectorFileWriter::SaveVectorOptions &options ) 22 : 0 : : QgsTask( tr( "Saving %1" ).arg( fileName ), QgsTask::CanCancel ) 23 : 0 : , mDestFileName( fileName ) 24 : 0 : , mOptions( options ) 25 : 0 : { 26 : 0 : if ( mOptions.fieldValueConverter ) 27 : : { 28 : : // fieldValueConverter is not owned - so we need to clone it here 29 : : // to ensure it exists for lifetime of task 30 : 0 : mFieldValueConverter.reset( mOptions.fieldValueConverter->clone() ); 31 : 0 : mOptions.fieldValueConverter = mFieldValueConverter.get(); 32 : 0 : } 33 : 0 : if ( !mOptions.feedback ) 34 : : { 35 : 0 : mOwnedFeedback.reset( new QgsFeedback() ); 36 : 0 : mOptions.feedback = mOwnedFeedback.get(); 37 : 0 : } 38 : : 39 : 0 : if ( layer ) 40 : : { 41 : 0 : mTransformContext = layer->transformContext(); 42 : 0 : } 43 : : 44 : 0 : mError = QgsVectorFileWriter::prepareWriteAsVectorFormat( layer, mOptions, mWriterDetails ); 45 : 0 : } 46 : : 47 : 0 : void QgsVectorFileWriterTask::cancel() 48 : : { 49 : 0 : mOptions.feedback->cancel(); 50 : 0 : QgsTask::cancel(); 51 : 0 : } 52 : : 53 : 0 : bool QgsVectorFileWriterTask::run() 54 : : { 55 : 0 : if ( mError != QgsVectorFileWriter::NoError ) 56 : 0 : return false; 57 : : 58 : 0 : connect( mOptions.feedback, &QgsFeedback::progressChanged, this, &QgsVectorFileWriterTask::setProgress ); 59 : : 60 : : 61 : 0 : mError = QgsVectorFileWriter::writeAsVectorFormatV2( 62 : 0 : mWriterDetails, mDestFileName, mTransformContext, mOptions, &mNewFilename, &mNewLayer, &mErrorMessage ); 63 : 0 : return mError == QgsVectorFileWriter::NoError; 64 : 0 : } 65 : : 66 : 0 : void QgsVectorFileWriterTask::finished( bool result ) 67 : : { 68 : 0 : if ( result ) 69 : : { 70 : 0 : emit writeComplete( mNewFilename ); 71 : 0 : emit completed( mNewFilename, mNewLayer ); 72 : 0 : } 73 : : else 74 : : { 75 : 0 : emit errorOccurred( mError, mErrorMessage ); 76 : : } 77 : 0 : }