<div class="gmail_quote">On Tue, Feb 24, 2009 at 8:48 PM, Andrea Tagliasacchi <span dir="ltr">&lt;<a href="mailto:ata2@cs.sfu.ca">ata2@cs.sfu.ca</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
This is a bit odd to me. Why would not everything be required?<br>Are there situations in which you might not need a package?<br><br>Maybe I can answer my own question...<br><br>If you have 2 libraries A and B that do the same task maybe you can <br>

use different compile rules like you showed below, while if A is the only<br>one, then &quot;REQUIRED&quot; gives the trick.</blockquote><div><br>It all depends on the needs of the software really and also how it&#39;s designed.  Many software projects have no need for optional dependencies but others would be extremely annoying to build without them because every dependency would have to be available on every platform in order to compile &amp; link the project.<br>
<br>Since you appear to be doing 3D work, a good example of optional dependencies in action could be the OpenSceneGraph&#39;s plugin architecture.  By creating well defined interfaces up front, they have made it so that the project can be built with very few mandatory dependencies (OpenGL and GLUT are the only two IIRC).  All of the 3rd party dependencies they&#39;ve added along the way have been made optional (libpng, libjpeg, libtiff, libfreetype, libcurl, libgdal, etc.) through their plugin API.  If libpng isn&#39;t available at build time (for whatever reason) the png plugin simply isn&#39;t built.  It can always be built and dropped into the system later through the magic of dynamic linking.<br>
<br><a href="http://www.openscenegraph.org/projects/osg/browser/OpenSceneGraph/trunk/src/osgPlugins">http://www.openscenegraph.org/projects/osg/browser/OpenSceneGraph/trunk/src/osgPlugins</a><br><br></div></div><br>-- <br>
Philip Lowman<br>