<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<!--NewPage-->
<HTML>
<HEAD>
<!-- Generated by javadoc (build 1.6.0_20) on Wed Mar 14 23:31:23 PDT 2012 -->
<TITLE>
Adaptor
</TITLE>

<META NAME="date" CONTENT="2012-03-14">

<LINK REL ="stylesheet" TYPE="text/css" HREF="../stylesheet.css" TITLE="Style">

<SCRIPT type="text/javascript">
function windowTitle()
{
    if (location.href.indexOf('is-external=true') == -1) {
        parent.document.title="Adaptor";
    }
}
</SCRIPT>
<NOSCRIPT>
</NOSCRIPT>

</HEAD>

<BODY BGCOLOR="white" onload="windowTitle();">
<HR>


<!-- ========= START OF TOP NAVBAR ======= -->
<A NAME="navbar_top"><!-- --></A>
<A HREF="#skip-navbar_top" title="Skip navigation links"></A>
<TABLE BORDER="0" WIDTH="100%" CELLPADDING="1" CELLSPACING="0" SUMMARY="">
<TR>
<TD COLSPAN=2 BGCOLOR="#EEEEFF" CLASS="NavBarCell1">
<A NAME="navbar_top_firstrow"><!-- --></A>
<TABLE BORDER="0" CELLPADDING="0" CELLSPACING="3" SUMMARY="">
  <TR ALIGN="center" VALIGN="top">
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="../overview-summary.html"><FONT CLASS="NavBarFont1"><B>Overview</B></FONT></A>&nbsp;</TD>
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="package-summary.html"><FONT CLASS="NavBarFont1"><B>Package</B></FONT></A>&nbsp;</TD>
  <TD BGCOLOR="#FFFFFF" CLASS="NavBarCell1Rev"> &nbsp;<FONT CLASS="NavBarFont1Rev"><B>Class</B></FONT>&nbsp;</TD>
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="package-tree.html"><FONT CLASS="NavBarFont1"><B>Tree</B></FONT></A>&nbsp;</TD>
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="../deprecated-list.html"><FONT CLASS="NavBarFont1"><B>Deprecated</B></FONT></A>&nbsp;</TD>
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="../index-all.html"><FONT CLASS="NavBarFont1"><B>Index</B></FONT></A>&nbsp;</TD>
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="../help-doc.html"><FONT CLASS="NavBarFont1"><B>Help</B></FONT></A>&nbsp;</TD>
  </TR>
</TABLE>
</TD>
<TD ALIGN="right" VALIGN="top" ROWSPAN=3><EM>
</EM>
</TD>
</TR>

<TR>
<TD BGCOLOR="white" CLASS="NavBarCell2"><FONT SIZE="-2">
&nbsp;<A HREF="../adaptorlib/Acl.InheritanceType.html" title="enum in adaptorlib"><B>PREV CLASS</B></A>&nbsp;
&nbsp;<A HREF="../adaptorlib/AdaptorContext.html" title="interface in adaptorlib"><B>NEXT CLASS</B></A></FONT></TD>
<TD BGCOLOR="white" CLASS="NavBarCell2"><FONT SIZE="-2">
  <A HREF="../index.html?adaptorlib/Adaptor.html" target="_top"><B>FRAMES</B></A>  &nbsp;
&nbsp;<A HREF="Adaptor.html" target="_top"><B>NO FRAMES</B></A>  &nbsp;
&nbsp;<SCRIPT type="text/javascript">
  <!--
  if(window==top) {
    document.writeln('<A HREF="../allclasses-noframe.html"><B>All Classes</B></A>');
  }
  //-->
</SCRIPT>
<NOSCRIPT>
  <A HREF="../allclasses-noframe.html"><B>All Classes</B></A>
</NOSCRIPT>


</FONT></TD>
</TR>
<TR>
<TD VALIGN="top" CLASS="NavBarCell3"><FONT SIZE="-2">
  SUMMARY:&nbsp;NESTED&nbsp;|&nbsp;FIELD&nbsp;|&nbsp;CONSTR&nbsp;|&nbsp;<A HREF="#method_summary">METHOD</A></FONT></TD>
<TD VALIGN="top" CLASS="NavBarCell3"><FONT SIZE="-2">
DETAIL:&nbsp;FIELD&nbsp;|&nbsp;CONSTR&nbsp;|&nbsp;<A HREF="#method_detail">METHOD</A></FONT></TD>
</TR>
</TABLE>
<A NAME="skip-navbar_top"></A>
<!-- ========= END OF TOP NAVBAR ========= -->

<HR>
<!-- ======== START OF CLASS DATA ======== -->
<H2>
<FONT SIZE="-1">
adaptorlib</FONT>
<BR>
Interface Adaptor</H2>
<DL>
<DT><B>All Known Subinterfaces:</B> <DD><A HREF="../adaptorlib/PollingIncrementalAdaptor.html" title="interface in adaptorlib">PollingIncrementalAdaptor</A></DD>
</DL>
<DL>
<DT><B>All Known Implementing Classes:</B> <DD><A HREF="../adaptorlib/AbstractAdaptor.html" title="class in adaptorlib">AbstractAdaptor</A>, <A HREF="../adaptorlib/examples/AdaptorTemplate.html" title="class in adaptorlib.examples">AdaptorTemplate</A>, <A HREF="../adaptorlib/examples/AdaptorWithCrawlTimeMetadataTemplate.html" title="class in adaptorlib.examples">AdaptorWithCrawlTimeMetadataTemplate</A>, <A HREF="../adaptorlib/prebuilt/CommandLineAdaptor.html" title="class in adaptorlib.prebuilt">CommandLineAdaptor</A>, <A HREF="../adaptorlib/examples/DbAdaptorTemplate.html" title="class in adaptorlib.examples">DbAdaptorTemplate</A>, <A HREF="../adaptorlib/examples/FileSystemAdaptor.html" title="class in adaptorlib.examples">FileSystemAdaptor</A>, <A HREF="../adaptorlib/prebuilt/FileSystemAdaptor.html" title="class in adaptorlib.prebuilt">FileSystemAdaptor</A></DD>
</DL>
<HR>
<DL>
<DT><PRE>public interface <B>Adaptor</B></DL>
</PRE>

<P>
Interface for user-specific implementation details of an Adaptor.
 Implementations must be thread-safe. Implementations are encouraged to not
 keep any state or only soft-state like a connection cache.

 <p>Once configuration is prepared, <A HREF="../adaptorlib/Adaptor.html#init(adaptorlib.AdaptorContext)"><CODE>init(adaptorlib.AdaptorContext)</CODE></A> will be called. This is
 guaranteed to occur before any calls to <A HREF="../adaptorlib/Adaptor.html#getDocContent(adaptorlib.Request, adaptorlib.Response)"><CODE>getDocContent(adaptorlib.Request, adaptorlib.Response)</CODE></A>, <A HREF="../adaptorlib/Adaptor.html#getDocIds(adaptorlib.DocIdPusher)"><CODE>getDocIds(adaptorlib.DocIdPusher)</CODE></A>, or <A HREF="../adaptorlib/Adaptor.html#isUserAuthorized(adaptorlib.AuthnIdentity, java.util.Collection)"><CODE>isUserAuthorized(adaptorlib.AuthnIdentity, java.util.Collection<adaptorlib.DocId>)</CODE></A>. When the adaptor needs to
 shutdown, <A HREF="../adaptorlib/Adaptor.html#destroy()"><CODE>destroy()</CODE></A> will be called.

 <p>If the adaptor is using <A HREF="../adaptorlib/AbstractAdaptor.html#main(adaptorlib.Adaptor, java.lang.String[])"><CODE>AbstractAdaptor.main(adaptorlib.Adaptor, java.lang.String[])</CODE></A>, then <A HREF="../adaptorlib/Adaptor.html#initConfig(adaptorlib.Config)"><CODE>initConfig(adaptorlib.Config)</CODE></A> will be called before <A HREF="../adaptorlib/Adaptor.html#init(adaptorlib.AdaptorContext)"><CODE>init(adaptorlib.AdaptorContext)</CODE></A> to allow the adaptor an
 opportunity to set and override default configuration values.
<P>

<P>
<DL>
<DT><B>See Also:</B><DD><A HREF="../adaptorlib/examples/AdaptorTemplate.html" title="class in adaptorlib.examples"><CODE>AdaptorTemplate</CODE></A>, 
<A HREF="../adaptorlib/AbstractAdaptor.html" title="class in adaptorlib"><CODE>AbstractAdaptor</CODE></A>, 
<A HREF="../adaptorlib/PollingIncrementalAdaptor.html" title="interface in adaptorlib"><CODE>PollingIncrementalAdaptor</CODE></A></DL>
<HR>

<P>

<!-- ========== METHOD SUMMARY =========== -->

<A NAME="method_summary"><!-- --></A>
<TABLE BORDER="1" WIDTH="100%" CELLPADDING="3" CELLSPACING="0" SUMMARY="">
<TR BGCOLOR="#CCCCFF" CLASS="TableHeadingColor">
<TH ALIGN="left" COLSPAN="2"><FONT SIZE="+2">
<B>Method Summary</B></FONT></TH>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>&nbsp;void</CODE></FONT></TD>
<TD><CODE><B><A HREF="../adaptorlib/Adaptor.html#destroy()">destroy</A></B>()</CODE>

<BR>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Shutdown and release resources of adaptor.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>&nbsp;void</CODE></FONT></TD>
<TD><CODE><B><A HREF="../adaptorlib/Adaptor.html#getDocContent(adaptorlib.Request, adaptorlib.Response)">getDocContent</A></B>(<A HREF="../adaptorlib/Request.html" title="interface in adaptorlib">Request</A>&nbsp;request,
              <A HREF="../adaptorlib/Response.html" title="interface in adaptorlib">Response</A>&nbsp;response)</CODE>

<BR>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Provides contents and metadata of particular document.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>&nbsp;void</CODE></FONT></TD>
<TD><CODE><B><A HREF="../adaptorlib/Adaptor.html#getDocIds(adaptorlib.DocIdPusher)">getDocIds</A></B>(<A HREF="../adaptorlib/DocIdPusher.html" title="interface in adaptorlib">DocIdPusher</A>&nbsp;pusher)</CODE>

<BR>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Pushes all the <code>DocId</code>s that are suppose to be indexed by the GSA.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>&nbsp;void</CODE></FONT></TD>
<TD><CODE><B><A HREF="../adaptorlib/Adaptor.html#init(adaptorlib.AdaptorContext)">init</A></B>(<A HREF="../adaptorlib/AdaptorContext.html" title="interface in adaptorlib">AdaptorContext</A>&nbsp;context)</CODE>

<BR>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Initialize adaptor with the current context.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>&nbsp;void</CODE></FONT></TD>
<TD><CODE><B><A HREF="../adaptorlib/Adaptor.html#initConfig(adaptorlib.Config)">initConfig</A></B>(<A HREF="../adaptorlib/Config.html" title="class in adaptorlib">Config</A>&nbsp;config)</CODE>

<BR>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Provides the opportunity for the Adaptor to create new configuration values
 or override default values.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>&nbsp;<A HREF="http://download.oracle.com/javase/6/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</A>&lt;<A HREF="../adaptorlib/DocId.html" title="class in adaptorlib">DocId</A>,<A HREF="../adaptorlib/AuthzStatus.html" title="enum in adaptorlib">AuthzStatus</A>&gt;</CODE></FONT></TD>
<TD><CODE><B><A HREF="../adaptorlib/Adaptor.html#isUserAuthorized(adaptorlib.AuthnIdentity, java.util.Collection)">isUserAuthorized</A></B>(<A HREF="../adaptorlib/AuthnIdentity.html" title="interface in adaptorlib">AuthnIdentity</A>&nbsp;userIdentity,
                 <A HREF="http://download.oracle.com/javase/6/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</A>&lt;<A HREF="../adaptorlib/DocId.html" title="class in adaptorlib">DocId</A>&gt;&nbsp;ids)</CODE>

<BR>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Determines whether the user identified is allowed to access the <code>DocId</code>s.</TD>
</TR>
</TABLE>
&nbsp;
<P>

<!-- ============ METHOD DETAIL ========== -->

<A NAME="method_detail"><!-- --></A>
<TABLE BORDER="1" WIDTH="100%" CELLPADDING="3" CELLSPACING="0" SUMMARY="">
<TR BGCOLOR="#CCCCFF" CLASS="TableHeadingColor">
<TH ALIGN="left" COLSPAN="1"><FONT SIZE="+2">
<B>Method Detail</B></FONT></TH>
</TR>
</TABLE>

<A NAME="getDocContent(adaptorlib.Request, adaptorlib.Response)"><!-- --></A><H3>
getDocContent</H3>
<PRE>
void <B>getDocContent</B>(<A HREF="../adaptorlib/Request.html" title="interface in adaptorlib">Request</A>&nbsp;request,
                   <A HREF="../adaptorlib/Response.html" title="interface in adaptorlib">Response</A>&nbsp;response)
                   throws <A HREF="http://download.oracle.com/javase/6/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</A></PRE>
<DL>
<DD>Provides contents and metadata of particular document. This method should
 be highly parallelizable and support twenty or more concurrent calls. Two
 to three concurrent calls may be average during initial GSA crawling, but
 twenty or more concurrent calls is typical when the GSA is recrawling
 unmodified content.
<P>
<DD><DL>

<DT><B>Throws:</B>
<DD><CODE><A HREF="http://download.oracle.com/javase/6/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</A></CODE></DL>
</DD>
</DL>
<HR>

<A NAME="getDocIds(adaptorlib.DocIdPusher)"><!-- --></A><H3>
getDocIds</H3>
<PRE>
void <B>getDocIds</B>(<A HREF="../adaptorlib/DocIdPusher.html" title="interface in adaptorlib">DocIdPusher</A>&nbsp;pusher)
               throws <A HREF="http://download.oracle.com/javase/6/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</A>,
                      <A HREF="http://download.oracle.com/javase/6/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</A></PRE>
<DL>
<DD>Pushes all the <code>DocId</code>s that are suppose to be indexed by the GSA.
 This will frequently involve re-sending <code>DocId</code>s to the GSA, but this
 allows healing previous errors and cache inconsistencies. Re-sending <code>DocIds</code> is very fast and should be considered free on the GSA. This method
 should determine a list of <code>DocId</code>s to push and call <A HREF="../adaptorlib/DocIdPusher.html#pushDocIds(java.lang.Iterable)"><CODE>DocIdPusher.pushDocIds(java.lang.Iterable<adaptorlib.DocId>)</CODE></A> one or more times and <A HREF="../adaptorlib/DocIdPusher.html#pushNamedResources(java.util.Map)"><CODE>DocIdPusher.pushNamedResources(java.util.Map<adaptorlib.DocId, adaptorlib.Acl>)</CODE></A> if using named resources.

 <p><code>pusher</code> is provided as convenience and is the same object
 provided to <A HREF="../adaptorlib/Adaptor.html#init(adaptorlib.AdaptorContext)"><CODE>init(adaptorlib.AdaptorContext)</CODE></A> previously. This method may take a while and
 implementations are free to call <A HREF="http://download.oracle.com/javase/6/docs/api/java/lang/Thread.html?is-external=true#sleep(long)" title="class or interface in java.lang"><CODE>Thread.sleep(long)</CODE></A> occasionally to
 reduce load.
<P>
<DD><DL>

<DT><B>Throws:</B>
<DD><CODE><A HREF="http://download.oracle.com/javase/6/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</A></CODE>
<DD><CODE><A HREF="http://download.oracle.com/javase/6/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</A></CODE></DL>
</DD>
</DL>
<HR>

<A NAME="isUserAuthorized(adaptorlib.AuthnIdentity, java.util.Collection)"><!-- --></A><H3>
isUserAuthorized</H3>
<PRE>
<A HREF="http://download.oracle.com/javase/6/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</A>&lt;<A HREF="../adaptorlib/DocId.html" title="class in adaptorlib">DocId</A>,<A HREF="../adaptorlib/AuthzStatus.html" title="enum in adaptorlib">AuthzStatus</A>&gt; <B>isUserAuthorized</B>(<A HREF="../adaptorlib/AuthnIdentity.html" title="interface in adaptorlib">AuthnIdentity</A>&nbsp;userIdentity,
                                        <A HREF="http://download.oracle.com/javase/6/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</A>&lt;<A HREF="../adaptorlib/DocId.html" title="class in adaptorlib">DocId</A>&gt;&nbsp;ids)
                                        throws <A HREF="http://download.oracle.com/javase/6/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</A></PRE>
<DL>
<DD>Determines whether the user identified is allowed to access the <code>DocId</code>s. The user is either anonymous or assumed to be previously
 authenticated. If an anonymous user is denied access to a document, then
 the caller may prompt the user to go through an authentication process and
 then try again.

 <p>Returns <A HREF="../adaptorlib/AuthzStatus.html#PERMIT"><CODE>AuthzStatus.PERMIT</CODE></A> for <A HREF="../adaptorlib/DocId.html" title="class in adaptorlib"><CODE>DocId</CODE></A>s the user is
 allowed to access. Retutrns <A HREF="../adaptorlib/AuthzStatus.html#DENY"><CODE>AuthzStatus.DENY</CODE></A> for <code>DocId</code>s the
 user is not allowed to access. If the document exists, <A HREF="../adaptorlib/AuthzStatus.html#INDETERMINATE"><CODE>AuthzStatus.INDETERMINATE</CODE></A> will not be returned for that <code>DocId</code>.

 <p>If the document doesn't exist, then there are several possibilities. If
 the repository is fully-public then it will return <code>PERMIT</code>. This
 will allow the caller to provide a cached version of the file to the user
 or call <A HREF="../adaptorlib/Adaptor.html#getDocContent(adaptorlib.Request, adaptorlib.Response)"><CODE>getDocContent(adaptorlib.Request, adaptorlib.Response)</CODE></A> which should call <A HREF="../adaptorlib/Response.html#respondNotFound()"><CODE>Response.respondNotFound()</CODE></A>. If the adaptor is not sensitive to users knowing
 that certain documents do not exist, then it will return <code>INDETERMINATE</code>. This will be interpreted as the document does not exist; no
 cached copy will be provided to the user but the user may be informed the
 document doesn't exist. Highly sensitive repositories may return <code>DENY</code>.
<P>
<DD><DL>
<DT><B>Parameters:</B><DD><CODE>userIdentity</CODE> - user to authorize, or <code>null</code> for anonymous
        users<DD><CODE>ids</CODE> - Collection of <code>DocId</code>s that need to be checked
<DT><B>Returns:</B><DD>an <code>AuthzStatus</code> for each <code>DocId</code> provided in <code>ids</code>
<DT><B>Throws:</B>
<DD><CODE><A HREF="http://download.oracle.com/javase/6/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</A></CODE></DL>
</DD>
</DL>
<HR>

<A NAME="initConfig(adaptorlib.Config)"><!-- --></A><H3>
initConfig</H3>
<PRE>
void <B>initConfig</B>(<A HREF="../adaptorlib/Config.html" title="class in adaptorlib">Config</A>&nbsp;config)</PRE>
<DL>
<DD>Provides the opportunity for the Adaptor to create new configuration values
 or override default values. Only <A HREF="../adaptorlib/Config.html#addKey(java.lang.String, java.lang.String)"><CODE>Config.addKey(java.lang.String, java.lang.String)</CODE></A> should likely be
 called. The user's configuration will override any values set in this way.
 This method is called by <A HREF="../adaptorlib/AbstractAdaptor.html#main(adaptorlib.Adaptor, java.lang.String[])"><CODE>AbstractAdaptor.main(adaptorlib.Adaptor, java.lang.String[])</CODE></A> before <A HREF="../adaptorlib/Adaptor.html#init(adaptorlib.AdaptorContext)"><CODE>init(adaptorlib.AdaptorContext)</CODE></A>
 is called.
<P>
<DD><DL>
</DL>
</DD>
</DL>
<HR>

<A NAME="init(adaptorlib.AdaptorContext)"><!-- --></A><H3>
init</H3>
<PRE>
void <B>init</B>(<A HREF="../adaptorlib/AdaptorContext.html" title="interface in adaptorlib">AdaptorContext</A>&nbsp;context)
          throws <A HREF="http://download.oracle.com/javase/6/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</A></PRE>
<DL>
<DD>Initialize adaptor with the current context. This is the ideal time to
 start any threads to do extra behind-the-scenes work. The <code>context</code>
 points to other useful objects that can be used at any time. For example,
 methods on <A HREF="../adaptorlib/DocIdPusher.html" title="interface in adaptorlib"><CODE>DocIdPusher</CODE></A> provided via <A HREF="../adaptorlib/AdaptorContext.html#getDocIdPusher()"><CODE>AdaptorContext.getDocIdPusher()</CODE></A> are allowed to be called whenever the
 Adaptor wishes. This allows doing event-based incremental pushes at any
 time.

 <p>The method is called at the end of <A HREF="../adaptorlib/GsaCommunicationHandler.html#start()"><CODE>GsaCommunicationHandler.start()</CODE></A>.
<P>
<DD><DL>

<DT><B>Throws:</B>
<DD><CODE><A HREF="http://download.oracle.com/javase/6/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</A></CODE></DL>
</DD>
</DL>
<HR>

<A NAME="destroy()"><!-- --></A><H3>
destroy</H3>
<PRE>
void <B>destroy</B>()</PRE>
<DL>
<DD>Shutdown and release resources of adaptor.
<P>
<DD><DL>
</DL>
</DD>
</DL>
<!-- ========= END OF CLASS DATA ========= -->
<HR>


<!-- ======= START OF BOTTOM NAVBAR ====== -->
<A NAME="navbar_bottom"><!-- --></A>
<A HREF="#skip-navbar_bottom" title="Skip navigation links"></A>
<TABLE BORDER="0" WIDTH="100%" CELLPADDING="1" CELLSPACING="0" SUMMARY="">
<TR>
<TD COLSPAN=2 BGCOLOR="#EEEEFF" CLASS="NavBarCell1">
<A NAME="navbar_bottom_firstrow"><!-- --></A>
<TABLE BORDER="0" CELLPADDING="0" CELLSPACING="3" SUMMARY="">
  <TR ALIGN="center" VALIGN="top">
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="../overview-summary.html"><FONT CLASS="NavBarFont1"><B>Overview</B></FONT></A>&nbsp;</TD>
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="package-summary.html"><FONT CLASS="NavBarFont1"><B>Package</B></FONT></A>&nbsp;</TD>
  <TD BGCOLOR="#FFFFFF" CLASS="NavBarCell1Rev"> &nbsp;<FONT CLASS="NavBarFont1Rev"><B>Class</B></FONT>&nbsp;</TD>
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="package-tree.html"><FONT CLASS="NavBarFont1"><B>Tree</B></FONT></A>&nbsp;</TD>
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="../deprecated-list.html"><FONT CLASS="NavBarFont1"><B>Deprecated</B></FONT></A>&nbsp;</TD>
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="../index-all.html"><FONT CLASS="NavBarFont1"><B>Index</B></FONT></A>&nbsp;</TD>
  <TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1">    <A HREF="../help-doc.html"><FONT CLASS="NavBarFont1"><B>Help</B></FONT></A>&nbsp;</TD>
  </TR>
</TABLE>
</TD>
<TD ALIGN="right" VALIGN="top" ROWSPAN=3><EM>
</EM>
</TD>
</TR>

<TR>
<TD BGCOLOR="white" CLASS="NavBarCell2"><FONT SIZE="-2">
&nbsp;<A HREF="../adaptorlib/Acl.InheritanceType.html" title="enum in adaptorlib"><B>PREV CLASS</B></A>&nbsp;
&nbsp;<A HREF="../adaptorlib/AdaptorContext.html" title="interface in adaptorlib"><B>NEXT CLASS</B></A></FONT></TD>
<TD BGCOLOR="white" CLASS="NavBarCell2"><FONT SIZE="-2">
  <A HREF="../index.html?adaptorlib/Adaptor.html" target="_top"><B>FRAMES</B></A>  &nbsp;
&nbsp;<A HREF="Adaptor.html" target="_top"><B>NO FRAMES</B></A>  &nbsp;
&nbsp;<SCRIPT type="text/javascript">
  <!--
  if(window==top) {
    document.writeln('<A HREF="../allclasses-noframe.html"><B>All Classes</B></A>');
  }
  //-->
</SCRIPT>
<NOSCRIPT>
  <A HREF="../allclasses-noframe.html"><B>All Classes</B></A>
</NOSCRIPT>


</FONT></TD>
</TR>
<TR>
<TD VALIGN="top" CLASS="NavBarCell3"><FONT SIZE="-2">
  SUMMARY:&nbsp;NESTED&nbsp;|&nbsp;FIELD&nbsp;|&nbsp;CONSTR&nbsp;|&nbsp;<A HREF="#method_summary">METHOD</A></FONT></TD>
<TD VALIGN="top" CLASS="NavBarCell3"><FONT SIZE="-2">
DETAIL:&nbsp;FIELD&nbsp;|&nbsp;CONSTR&nbsp;|&nbsp;<A HREF="#method_detail">METHOD</A></FONT></TD>
</TR>
</TABLE>
<A NAME="skip-navbar_bottom"></A>
<!-- ======== END OF BOTTOM NAVBAR ======= -->

<HR>

</BODY>
</HTML>
