/usr/share/doc/libosgi-compendium-java/api/info/dmtree/Uri.html is in libosgi-compendium-java-doc 4.3.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 | <!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_23) on Wed Nov 09 19:45:53 UTC 2011 -->
<TITLE>
Uri
</TITLE>
<META NAME="date" CONTENT="2011-11-09">
<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="Uri";
}
}
</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> </TD>
<TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1"> <A HREF="package-summary.html"><FONT CLASS="NavBarFont1"><B>Package</B></FONT></A> </TD>
<TD BGCOLOR="#FFFFFF" CLASS="NavBarCell1Rev"> <FONT CLASS="NavBarFont1Rev"><B>Class</B></FONT> </TD>
<TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1"> <A HREF="package-tree.html"><FONT CLASS="NavBarFont1"><B>Tree</B></FONT></A> </TD>
<TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1"> <A HREF="../../deprecated-list.html"><FONT CLASS="NavBarFont1"><B>Deprecated</B></FONT></A> </TD>
<TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1"> <A HREF="../../index-all.html"><FONT CLASS="NavBarFont1"><B>Index</B></FONT></A> </TD>
<TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1"> <A HREF="../../help-doc.html"><FONT CLASS="NavBarFont1"><B>Help</B></FONT></A> </TD>
</TR>
</TABLE>
</TD>
<TD ALIGN="right" VALIGN="top" ROWSPAN=3><EM>
</EM>
</TD>
</TR>
<TR>
<TD BGCOLOR="white" CLASS="NavBarCell2"><FONT SIZE="-2">
<A HREF="../../info/dmtree/MetaNode.html" title="interface in info.dmtree"><B>PREV CLASS</B></A>
NEXT CLASS</FONT></TD>
<TD BGCOLOR="white" CLASS="NavBarCell2"><FONT SIZE="-2">
<A HREF="../../index.html?info/dmtree/Uri.html" target="_top"><B>FRAMES</B></A>
<A HREF="Uri.html" target="_top"><B>NO FRAMES</B></A>
<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: NESTED | FIELD | CONSTR | <A HREF="#method_summary">METHOD</A></FONT></TD>
<TD VALIGN="top" CLASS="NavBarCell3"><FONT SIZE="-2">
DETAIL: FIELD | CONSTR | <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">
info.dmtree</FONT>
<BR>
Class Uri</H2>
<PRE>
java.lang.Object
<IMG SRC="../../resources/inherit.gif" ALT="extended by "><B>info.dmtree.Uri</B>
</PRE>
<HR>
<DL>
<DT><PRE>public final class <B>Uri</B><DT>extends java.lang.Object</DL>
</PRE>
<P>
This class contains static utility methods to manipulate DMT URIs.
<p>
Syntax of valid DMT URIs:
<ul>
<li>A slash (<code>'/'</code> \u002F) is the separator of the node names.
Slashes used in node name must therefore be escaped using a backslash slash (
<code>"\/"</code>). The backslash must be escaped with a double backslash sequence. A
backslash found must be ignored when it is not followed by a slash or
backslash.
<li>The node name can be constructed using full Unicode character set (except
the Supplementary code, not being supported by CLDC/CDC). However, using the
full Unicode character set for node names is discouraged because the encoding
in the underlying storage as well as the encoding needed in communications
can create significant performance and memory usage overhead. Names that are
restricted to the URI set <code>[-a-zA-Z0-9_.!~*'()]</code> are most efficient.
<li>URIs used in the DMT must be treated and interpreted as case sensitive.
<li>No End Slash: URI must not end with the delimiter slash (<code>'/'</code>
\u002F). This implies that the root node must be denoted as
<code>"."</code> and not <code>"./"</code>.
<li>No parent denotation: URI must not be constructed using the character
sequence <code>"../"</code> to traverse the tree upwards.
<li>Single Root: The character sequence <code>"./"</code> must not be used
anywhere else but in the beginning of a URI.
</ul>
<P>
<P>
<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>static int</CODE></FONT></TD>
<TD><CODE><B><A HREF="../../info/dmtree/Uri.html#getMaxSegmentNameLength()">getMaxSegmentNameLength</A></B>()</CODE>
<BR>
Returns the maximum allowed length of a URI segment.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>static int</CODE></FONT></TD>
<TD><CODE><B><A HREF="../../info/dmtree/Uri.html#getMaxUriLength()">getMaxUriLength</A></B>()</CODE>
<BR>
Returns the maximum allowed length of a URI.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>static int</CODE></FONT></TD>
<TD><CODE><B><A HREF="../../info/dmtree/Uri.html#getMaxUriSegments()">getMaxUriSegments</A></B>()</CODE>
<BR>
Returns the maximum allowed number of URI segments.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>static boolean</CODE></FONT></TD>
<TD><CODE><B><A HREF="../../info/dmtree/Uri.html#isAbsoluteUri(java.lang.String)">isAbsoluteUri</A></B>(java.lang.String uri)</CODE>
<BR>
Checks whether the specified URI is an absolute URI.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>static boolean</CODE></FONT></TD>
<TD><CODE><B><A HREF="../../info/dmtree/Uri.html#isValidUri(java.lang.String)">isValidUri</A></B>(java.lang.String uri)</CODE>
<BR>
Checks whether the specified URI is valid.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>static java.lang.String</CODE></FONT></TD>
<TD><CODE><B><A HREF="../../info/dmtree/Uri.html#mangle(java.lang.String)">mangle</A></B>(java.lang.String nodeName)</CODE>
<BR>
Returns a node name that is valid for the tree operation methods, based
on the given node name.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>static java.lang.String[]</CODE></FONT></TD>
<TD><CODE><B><A HREF="../../info/dmtree/Uri.html#toPath(java.lang.String)">toPath</A></B>(java.lang.String uri)</CODE>
<BR>
Split the specified URI along the path separator '/' charaters and return
an array of URI segments.</TD>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD ALIGN="right" VALIGN="top" WIDTH="1%"><FONT SIZE="-1">
<CODE>static java.lang.String</CODE></FONT></TD>
<TD><CODE><B><A HREF="../../info/dmtree/Uri.html#toUri(java.lang.String[])">toUri</A></B>(java.lang.String[] path)</CODE>
<BR>
Construct a URI from the specified URI segments.</TD>
</TR>
</TABLE>
<A NAME="methods_inherited_from_class_java.lang.Object"><!-- --></A>
<TABLE BORDER="1" WIDTH="100%" CELLPADDING="3" CELLSPACING="0" SUMMARY="">
<TR BGCOLOR="#EEEEFF" CLASS="TableSubHeadingColor">
<TH ALIGN="left"><B>Methods inherited from class java.lang.Object</B></TH>
</TR>
<TR BGCOLOR="white" CLASS="TableRowColor">
<TD><CODE>clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait</CODE></TD>
</TR>
</TABLE>
<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="mangle(java.lang.String)"><!-- --></A><H3>
mangle</H3>
<PRE>
public static java.lang.String <B>mangle</B>(java.lang.String nodeName)</PRE>
<DL>
<DD>Returns a node name that is valid for the tree operation methods, based
on the given node name. This transformation is not idempotent, so it must
not be called with a parameter that is the result of a previous
<code>mangle</code> method call.
<p>
Node name mangling is needed in the following cases:
<ul>
<li>if the name contains '/' or '\' characters
<li>if the length of the name exceeds the limit defined by the
implementation
</ul>
<p>
A node name that does not suffer from either of these problems is
guaranteed to remain unchanged by this method. Therefore the client may
skip the mangling if the node name is known to be valid (though it is
always safe to call this method).
<p>
The method returns the normalized <code>nodeName</code> as described
below. Invalid node names are normalized in different ways, depending on
the cause. If the length of the name does not exceed the limit, but the
name contains '/' or '\' characters, then these are simply escaped by
inserting an additional '\' before each occurrence. If the length of the
name does exceed the limit, the following mechanism is used to normalize
it:
<ul>
<li>the SHA 1 digest of the name is calculated
<li>the digest is encoded with the base 64 algorithm
<li>all '/' characters in the encoded digest are replaced with '_'
<li>trailing '=' signs are removed
</ul>
<P>
<DD><DL>
<DT><B>Parameters:</B><DD><CODE>nodeName</CODE> - the node name to be mangled (if necessary), must not be
<code>null</code> or empty
<DT><B>Returns:</B><DD>the normalized node name that is valid for tree operations
<DT><B>Throws:</B>
<DD><CODE>java.lang.NullPointerException</CODE> - if <code>nodeName</code> is
<code>null</code>
<DD><CODE>java.lang.IllegalArgumentException</CODE> - if <code>nodeName</code> is empty</DL>
</DD>
</DL>
<HR>
<A NAME="toUri(java.lang.String[])"><!-- --></A><H3>
toUri</H3>
<PRE>
public static java.lang.String <B>toUri</B>(java.lang.String[] path)</PRE>
<DL>
<DD>Construct a URI from the specified URI segments. The segments must
already be mangled.
<p>
If the specified path is an empty array then an empty URI
(<code>""</code>) is returned.
<P>
<DD><DL>
<DT><B>Parameters:</B><DD><CODE>path</CODE> - a possibly empty array of URI segments, must not be
<code>null</code>
<DT><B>Returns:</B><DD>the URI created from the specified segments
<DT><B>Throws:</B>
<DD><CODE>java.lang.NullPointerException</CODE> - if the specified path or any of its
segments are <code>null</code>
<DD><CODE>java.lang.IllegalArgumentException</CODE> - if the specified path contains too many
or malformed segments or the resulting URI is too long</DL>
</DD>
</DL>
<HR>
<A NAME="toPath(java.lang.String)"><!-- --></A><H3>
toPath</H3>
<PRE>
public static java.lang.String[] <B>toPath</B>(java.lang.String uri)</PRE>
<DL>
<DD>Split the specified URI along the path separator '/' charaters and return
an array of URI segments. Special characters in the returned segments are
escaped. The returned array may be empty if the specifed URI was empty.
<P>
<DD><DL>
<DT><B>Parameters:</B><DD><CODE>uri</CODE> - the URI to be split, must not be <code>null</code>
<DT><B>Returns:</B><DD>an array of URI segments created by splitting the specified URI
<DT><B>Throws:</B>
<DD><CODE>java.lang.NullPointerException</CODE> - if the specified URI is <code>null</code>
<DD><CODE>java.lang.IllegalArgumentException</CODE> - if the specified URI is malformed</DL>
</DD>
</DL>
<HR>
<A NAME="getMaxUriSegments()"><!-- --></A><H3>
getMaxUriSegments</H3>
<PRE>
public static int <B>getMaxUriSegments</B>()</PRE>
<DL>
<DD>Returns the maximum allowed number of URI segments. The returned value is
implementation specific.
<p>
The return value of <code>Integer.MAX_VALUE</code> indicates that there
is no upper limit on the number of URI segments.
<P>
<DD><DL>
<DT><B>Returns:</B><DD>maximum number of URI segments supported by the implementation</DL>
</DD>
</DL>
<HR>
<A NAME="getMaxUriLength()"><!-- --></A><H3>
getMaxUriLength</H3>
<PRE>
public static int <B>getMaxUriLength</B>()</PRE>
<DL>
<DD>Returns the maximum allowed length of a URI. The value is implementation
specific. The length of the URI is defined as the number of bytes in the
unescaped, UTF-8 encoded represenation of the URI.
<p>
The return value of <code>Integer.MAX_VALUE</code> indicates that there
is no upper limit on the length of URIs.
<P>
<DD><DL>
<DT><B>Returns:</B><DD>maximum URI length supported by the implementation</DL>
</DD>
</DL>
<HR>
<A NAME="getMaxSegmentNameLength()"><!-- --></A><H3>
getMaxSegmentNameLength</H3>
<PRE>
public static int <B>getMaxSegmentNameLength</B>()</PRE>
<DL>
<DD>Returns the maximum allowed length of a URI segment. The value is
implementation specific. The length of the URI segment is defined as the
number of bytes in the unescaped, UTF-8 encoded represenation of the
segment.
<p>
The return value of <code>Integer.MAX_VALUE</code> indicates that there
is no upper limit on the length of segment names.
<P>
<DD><DL>
<DT><B>Returns:</B><DD>maximum URI segment length supported by the implementation</DL>
</DD>
</DL>
<HR>
<A NAME="isAbsoluteUri(java.lang.String)"><!-- --></A><H3>
isAbsoluteUri</H3>
<PRE>
public static boolean <B>isAbsoluteUri</B>(java.lang.String uri)</PRE>
<DL>
<DD>Checks whether the specified URI is an absolute URI. An absolute URI
contains the complete path to a node in the DMT starting from the DMT
root (".").
<P>
<DD><DL>
<DT><B>Parameters:</B><DD><CODE>uri</CODE> - the URI to be checked, must not be <code>null</code> and must
contain a valid URI
<DT><B>Returns:</B><DD>whether the specified URI is absolute
<DT><B>Throws:</B>
<DD><CODE>java.lang.NullPointerException</CODE> - if the specified URI is <code>null</code>
<DD><CODE>java.lang.IllegalArgumentException</CODE> - if the specified URI is malformed</DL>
</DD>
</DL>
<HR>
<A NAME="isValidUri(java.lang.String)"><!-- --></A><H3>
isValidUri</H3>
<PRE>
public static boolean <B>isValidUri</B>(java.lang.String uri)</PRE>
<DL>
<DD>Checks whether the specified URI is valid. A URI is considered valid if
it meets the following constraints:
<ul>
<li>the URI is not <code>null</code>;
<li>the URI follows the syntax defined for valid DMT URIs;
<li>the length of the URI is not more than <A HREF="../../info/dmtree/Uri.html#getMaxUriLength()"><CODE>getMaxUriLength()</CODE></A>;
<li>the URI doesn't contain more than <A HREF="../../info/dmtree/Uri.html#getMaxUriSegments()"><CODE>getMaxUriSegments()</CODE></A>
segments;
<li>the length of each segment of the URI is less than or equal to
<A HREF="../../info/dmtree/Uri.html#getMaxSegmentNameLength()"><CODE>getMaxSegmentNameLength()</CODE></A>.
</ul>
The exact definition of the length of a URI and its segments is
given in the descriptions of the <code>getMaxUriLength()</code> and
<code>getMaxSegmentNameLength()</code> methods.
<P>
<DD><DL>
<DT><B>Parameters:</B><DD><CODE>uri</CODE> - the URI to be validated
<DT><B>Returns:</B><DD>whether the specified URI is valid</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> </TD>
<TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1"> <A HREF="package-summary.html"><FONT CLASS="NavBarFont1"><B>Package</B></FONT></A> </TD>
<TD BGCOLOR="#FFFFFF" CLASS="NavBarCell1Rev"> <FONT CLASS="NavBarFont1Rev"><B>Class</B></FONT> </TD>
<TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1"> <A HREF="package-tree.html"><FONT CLASS="NavBarFont1"><B>Tree</B></FONT></A> </TD>
<TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1"> <A HREF="../../deprecated-list.html"><FONT CLASS="NavBarFont1"><B>Deprecated</B></FONT></A> </TD>
<TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1"> <A HREF="../../index-all.html"><FONT CLASS="NavBarFont1"><B>Index</B></FONT></A> </TD>
<TD BGCOLOR="#EEEEFF" CLASS="NavBarCell1"> <A HREF="../../help-doc.html"><FONT CLASS="NavBarFont1"><B>Help</B></FONT></A> </TD>
</TR>
</TABLE>
</TD>
<TD ALIGN="right" VALIGN="top" ROWSPAN=3><EM>
</EM>
</TD>
</TR>
<TR>
<TD BGCOLOR="white" CLASS="NavBarCell2"><FONT SIZE="-2">
<A HREF="../../info/dmtree/MetaNode.html" title="interface in info.dmtree"><B>PREV CLASS</B></A>
NEXT CLASS</FONT></TD>
<TD BGCOLOR="white" CLASS="NavBarCell2"><FONT SIZE="-2">
<A HREF="../../index.html?info/dmtree/Uri.html" target="_top"><B>FRAMES</B></A>
<A HREF="Uri.html" target="_top"><B>NO FRAMES</B></A>
<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: NESTED | FIELD | CONSTR | <A HREF="#method_summary">METHOD</A></FONT></TD>
<TD VALIGN="top" CLASS="NavBarCell3"><FONT SIZE="-2">
DETAIL: FIELD | CONSTR | <A HREF="#method_detail">METHOD</A></FONT></TD>
</TR>
</TABLE>
<A NAME="skip-navbar_bottom"></A>
<!-- ======== END OF BOTTOM NAVBAR ======= -->
<HR>
</BODY>
</HTML>
|