<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html401/loose.dtd"> <html> <!-- Created by texi2html 1.76 --> <!-- Written by: Lionel Cons <Lionel.Cons@cern.ch> (original author) Karl Berry <karl@freefriends.org> Olaf Bachmann <obachman@mathematik.uni-kl.de> and many others. Maintained by: Many creative people <dev@texi2html.cvshome.org> Send bugs and suggestions to <users@texi2html.cvshome.org> --> <head> <title>Crystal Space 1.2.1: 4.3.1.9 Plugin Discovery</title> <meta name="description" content="Crystal Space 1.2.1: 4.3.1.9 Plugin Discovery"> <meta name="keywords" content="Crystal Space 1.2.1: 4.3.1.9 Plugin Discovery"> <meta name="resource-type" content="document"> <meta name="distribution" content="global"> <meta name="Generator" content="texi2html 1.76"> <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> <style type="text/css"> <!-- a.summary-letter {text-decoration: none} pre.display {font-family: serif} pre.format {font-family: serif} pre.menu-comment {font-family: serif} pre.menu-preformatted {font-family: serif} pre.smalldisplay {font-family: serif; font-size: smaller} pre.smallexample {font-size: smaller} pre.smallformat {font-family: serif; font-size: smaller} pre.smalllisp {font-size: smaller} span.sansserif {font-family:sans-serif; font-weight:normal;} ul.toc {list-style: none} --> </style> </head> <body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000"> <a name="SCF-Plugin-Discovery"></a> <a name="0"></a> <table cellpadding="1" cellspacing="1" border="0"> <tr><td valign="middle" align="left">[<a href="SCF-Meta-Info-Embedding.html#0" title="Previous section in reading order"> < </a>]</td> <td valign="middle" align="left">[<a href="SCF-Example.html#0" title="Next section in reading order"> > </a>]</td> <td valign="middle" align="left"> </td> <td valign="middle" align="left">[<a href="Using-Crystal-Space.html#0" title="Beginning of this chapter or previous chapter"> << </a>]</td> <td valign="middle" align="left">[<a href="SCF.html#0" title="Up section"> Up </a>]</td> <td valign="middle" align="left">[<a href="Working-with-Engine-Content.html#0" title="Next chapter"> >> </a>]</td> <td valign="middle" align="left"> </td> <td valign="middle" align="left"> </td> <td valign="middle" align="left"> </td> <td valign="middle" align="left"> </td> <td valign="middle" align="left">[<a href="index.html#SEC_Top" title="Cover (top) of document">Top</a>]</td> <td valign="middle" align="left">[<a href="cs_toc.html#SEC_Contents" title="Table of contents">Contents</a>]</td> <td valign="middle" align="left">[<a href="cs_Index.html#0" title="Index">Index</a>]</td> <td valign="middle" align="left">[<a href="cs_abt.html#SEC_About" title="About (help)"> ? </a>]</td> </tr></table> <hr size="1"> <h4 class="subsubsection"> 4.3.1.9 Plugin Discovery </h4> <p>At program launch time, <small>SCF</small> discovers plugins automatically by searching a set of directories, and creates an internal database associating available <small>SCF</small> class names with the plugin modules which implement them. The directories which <small>SCF</small> searches by default are: </p> <ul> <li> The application resource directory as returned by <code>csGetResourceDir()</code>. On most platforms, this is the same as the directory containing the application, however, on MacOS/X, it is the <tt>‘Resources’</tt> directory within the Cocoa application wrapper. </li><li> The directory containing the application (or containing the Cocoa application wrapper for MacOS/X) as returned by <code>csGetAppDir()</code>. </li><li> The installed Crystal Space resource directories as returned by <code>csGetConfigPath()</code>. This is often the value of the <samp>‘CRYSTAL’</samp> environment variable, or the <samp>‘CrystalSpaceRoot’</samp> default setting on MacOS/X (which is often stored within the <samp>‘NSGlobalDomain’</samp> domain). </li></ul> <p>If you would like <small>SCF</small> to scan additional directories, you can invoke either of these two functions: </p> <ul> <li> <code>scfInitialize (csPluginPaths const*)</code> </li><li> <code>iSCF::ScanPluginsPath(char const*, bool, char const*)</code> </li></ul> <p>Finally, if need to manually register a single plugin module with <small>SCF</small> for which you know the native pathname (not a <small>VFS</small> pathname), you can invoke <code>iSCF::RegisterPlugin()</code>. </p> <hr size="1"> <p> <font size="-1"> This document was generated using <a href="http://texi2html.cvshome.org/"><em>texi2html 1.76</em></a>. </font> <br> </p> </body> </html>