<html><head></head><body><span class="viv-signature"></span>Thank you Matthias, those future optimization possibilities sound really exciting.<div><br></div><div>Based on all your responses so far, I think I'd summarize that Processing script developers should always go for the feature sink parameter QgsProcessingParameterFeatureSink. </div><div><br></div><div>Given the info Nyall shared with me, the vector destination parameter is only used in implementations of third party tools (such as Saga/grass/otb) which are limited to outputting "plain old vector files". That's why the QgsProcessingParameterVectorDestination class exists. </div><div><br></div><div>This has been very helpful. I'll go update my materials accordingly. Thank you all.</div><div><br></div><div>Regards,</div><div>Anita</div><div><div><br></div><div><br><br>On Sunday, 23. October 2022 15:45:30 (+02:00), Matthias Kuhn wrote:<br><br><blockquote style="margin: 0 0 0.80ex; border-left: #0000FF 2px solid; padding-left: 1ex"><div dir="ltr">Hi Anita,<div><br></div><div>A QgsFeatureSink is an interface for accepting features. This can be a QgsVectorLayer but does not have to be one. It can also be a spatial index, a vector file writer or others.</div><div>I.e. your algorithm specifies that it produces "features" which can be sent to a vector layer, another algorithm or [you-name-it]. It doesn't care if it's a vector layer, which also has other properties like style.</div><div>This even leaves room for future optimization of processing pipelines, for example, features could be sent through various algorithms without waiting for the first one to be finished.</div><div><br></div><div>I hope that sheds some light</div><div>Matthias</div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Sun, Oct 23, 2022 at 1:48 PM Anita Graser via QGIS-Developer <<a href="mailto:qgis-developer@lists.osgeo.org">qgis-developer@lists.osgeo.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="padding-left:1ex;border-left-color:rgb(204, 204, 204);border-left-style:solid;border-left-width:1px;margin-left:0.8ex;margin-bottom:0px;margin-right:0px;margin-top:0px;"><div><span></span>Thank you very much, Thomas. This code comparison approach is very useful indeed. <br><br>If FeatureSink covers all functions of VectorDestination and more, that still leaves me wonder what is the downside of a FeatureSink<div><br></div><div>"Note: Consider using the more flexible <a href="https://api.qgis.org/api/3.22/classQgsProcessingParameterFeatureSink.html" title="A feature sink output for processing algorithms.">QgsProcessingParameterFeatureSink</a> wherever possible."</div><div><br></div><div>i.e. where is it not possible to use a Feature Sink? Only in older versions of QGIS? </div><div><br></div><div>Regards,</div><div>Anita</div><div><br><br>On Saturday, 22. October 2022 23:32:11 (+02:00), Thomas Gratier wrote:<br><br><blockquote style="padding-left:1ex;border-left-color:rgb(0, 0, 255);border-left-style:solid;border-left-width:2px;margin-left:0px;margin-bottom:0.8ex;margin-right:0px;margin-top:0px;"><div dir="ltr"><div>Hi,</div><div><br></div><div>Although, I do know the intend to recommend one against the other, doing some code differences helps to sort out things.</div><div>They both inherits from same classes but the constructor for QgsProcessingParameterFeatureSink accepts an additionnal arg bool <a href="https://api.qgis.org/api/3.22/classQgsProcessingParameterFeatureSink.html#acae2863d5dab37aec4c5466d7d3a84d9">supportsAppend</a>=false</div><div><br></div><div>You also find the additional methods in QgsProcessingParameterFeatureSink to manipulate the same supportsAppend.</div><div><br></div><div>```</div><div>a = QgsProcessingParameterVectorDestination(<br>  'OUTPUT',<br>  'Sortie'<br>)<br><br>b = QgsProcessingParameterFeatureSink(<br>  'OUTPUT',<br>  'Sortie'<br>)<br><br>methods_a = dir(a)<br>methods_b = dir(b)<br>common_methods = set(methods_a).intersection(methods_b)<br>print(common_methods)<br><br>only_in_a = set(methods_a).difference(methods_b)<br></div><div>print(only_in_a)</div><div><br>only_in_b = set(methods_b).difference(methods_a)</div><div>print(only_in_b)</div><div>```</div><div><br></div><div>Regards</div><div><br></div><div>Thomas Gratier</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">Le ven. 21 oct. 2022 à 18:07, Anita Graser via QGIS-Developer <<a href="mailto:qgis-developer@lists.osgeo.org">qgis-developer@lists.osgeo.org</a>> a écrit :<br></div><blockquote class="gmail_quote" style="margin-left:0.8ex;margin-bottom:0px;margin-right:0px;margin-top:0px;border-left-color:rgb(204, 204, 204);border-left-style:solid;border-left-width:1px;padding-left:1ex;"><div><div>Thank you Stefan,</div><div><br></div><div>I saw that note but was hoping some developer could shed light on what they mean by "more flexible" and "wherever possible". I guess otherwise it's just trial and error. </div><div><br></div><div>Regards,</div><div>Anita</div><span></span><br><br>On Wednesday, 19. October 2022 07:44:05 (+02:00), Stefan Giese (WhereGroup) wrote:<br><br><blockquote style="margin-left:0px;margin-bottom:0.8ex;margin-right:0px;margin-top:0px;border-left-color:rgb(0, 0, 255);border-left-style:solid;border-left-width:2px;padding-left:1ex;">
    
  
  
    <p>Hi Anita,</p>
    <p>they are very similar, but the API Documentation says to <span dir="ltr" style="margin-bottom:0px;margin-top:0px;">QgsProcessingParameterVectorDestination:</span>
      "Note: Consider using the more flexible <a href="https://api.qgis.org/api/3.22/classQgsProcessingParameterFeatureSink.html" title="A feature sink output for processing algorithms.">QgsProcessingParameterFeatureSink</a>
      wherever possible."
(<a href="https://api.qgis.org/api/3.22/classQgsProcessingParameterVectorDestination.html#details">https://api.qgis.org/api/3.22/classQgsProcessingParameterVectorDestination.html#details</a>)</p>
    <p>Best regards</p>
    <p>Stefan<br>
    </p>
    <div>Am 18.10.2022 um 20:35 schrieb Anita
      Graser via QGIS-Developer:<br>
    </div>
    <blockquote type="cite">
      
      
      <span dir="ltr" style="margin-bottom:0px;margin-top:0px;">Hi. </span>
      <br>
      <br>
      <span dir="ltr" style="margin-bottom:0px;margin-top:0px;">Does any
        one of you know the real difference between
        QgsProcessingParameterVectorDestination versus
        QgsProcessingParameterFeatureSink? They seem to be used
        interchangably in the resources I can find.</span> <br>
      <br>
      <span dir="ltr" style="margin-bottom:0px;margin-top:0px;">Thank you.</span>
      <br>
      <br>
      <span dir="ltr" style="margin-bottom:0px;margin-top:0px;">Anita</span>
      <br>
      <br>
      <fieldset></fieldset>
      <pre>_______________________________________________
QGIS-Developer mailing list
<a href="mailto:QGIS-Developer@lists.osgeo.org">QGIS-Developer@lists.osgeo.org</a>
List info: <a href="https://lists.osgeo.org/mailman/listinfo/qgis-developer">https://lists.osgeo.org/mailman/listinfo/qgis-developer</a>
Unsubscribe: <a href="https://lists.osgeo.org/mailman/listinfo/qgis-developer">https://lists.osgeo.org/mailman/listinfo/qgis-developer</a>
</pre>
    </blockquote>
    <pre cols="72">-- 
Mit freundlichen Grüßen
Stefan Giese
Projektleiter/Consultant
---------------------------------------------
Aufwind durch Wissen!
Jetzt neu: Web-Seminare und Online-Schulungen
bei der <a href="http://www.foss-academy.com">www.foss-academy.com</a>
---------------------------------------------
WhereGroup GmbH
Schwimmbadstr. 2
79100 Freiburg
Germany
Tel.: +49 (0)761 / 519 102 - 61
Fax: +49 (0)761 / 519 102 - 11
<a href="mailto:stefan.giese@wheregroup.com">stefan.giese@wheregroup.com</a>
<a href="http://www.wheregroup.com">www.wheregroup.com</a>
Geschäftsführer:
Olaf Knopp, Peter Stamm
Amtsgericht Bonn, HRB 9885</pre>
  
</blockquote><span></span></div></blockquote><span></span></div></blockquote><span class="viv-signature-below"><br>-- <br>--<br>Anita Graser<br>Home: http://anitagraser.com<br>Twitter: @underdarkgis</span></div></div></blockquote></div></blockquote></div></div></body></html>