/usr/share/doc/libosgi-compendium-java/api/org/osgi/service/dmt/Uri.html is in libosgi-compendium-java-doc 5.0.0-3.
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 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<!-- NewPage -->
<html lang="en">
<head>
<title>Uri</title>
<link rel="stylesheet" type="text/css" href="../../../../stylesheet.css" title="Style">
</head>
<body>
<script type="text/javascript"><!--
if (location.href.indexOf('is-external=true') == -1) {
parent.document.title="Uri";
}
//-->
</script>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
<!-- ========= START OF TOP NAVBAR ======= -->
<div class="topNav"><a name="navbar_top">
<!-- -->
</a><a href="#skip-navbar_top" title="Skip navigation links"></a><a name="navbar_top_firstrow">
<!-- -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../../overview-summary.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</li>
<li><a href="package-tree.html">Tree</a></li>
<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
<li><a href="../../../../index-all.html">Index</a></li>
<li><a href="../../../../help-doc.html">Help</a></li>
</ul>
</div>
<div class="subNav">
<ul class="navList">
<li><a href="../../../../org/osgi/service/dmt/MetaNode.html" title="interface in org.osgi.service.dmt"><span class="strong">Prev Class</span></a></li>
<li>Next Class</li>
</ul>
<ul class="navList">
<li><a href="../../../../index.html?org/osgi/service/dmt/Uri.html" target="_top">Frames</a></li>
<li><a href="Uri.html" target="_top">No Frames</a></li>
</ul>
<ul class="navList" id="allclasses_navbar_top">
<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
</ul>
<div>
<script type="text/javascript"><!--
allClassesLink = document.getElementById("allclasses_navbar_top");
if(window==top) {
allClassesLink.style.display = "block";
}
else {
allClassesLink.style.display = "none";
}
//-->
</script>
</div>
<div>
<ul class="subNavList">
<li>Summary: </li>
<li>Nested | </li>
<li><a href="#field_summary">Field</a> | </li>
<li>Constr | </li>
<li><a href="#method_summary">Method</a></li>
</ul>
<ul class="subNavList">
<li>Detail: </li>
<li><a href="#field_detail">Field</a> | </li>
<li>Constr | </li>
<li><a href="#method_detail">Method</a></li>
</ul>
</div>
<a name="skip-navbar_top">
<!-- -->
</a></div>
<!-- ========= END OF TOP NAVBAR ========= -->
<!-- ======== START OF CLASS DATA ======== -->
<div class="header">
<div class="subTitle">org.osgi.service.dmt</div>
<h2 title="Class Uri" class="title">Class Uri</h2>
</div>
<div class="contentContainer">
<ul class="inheritance">
<li>java.lang.Object</li>
<li>
<ul class="inheritance">
<li>org.osgi.service.dmt.Uri</li>
</ul>
</li>
</ul>
<div class="description">
<ul class="blockList">
<li class="blockList">
<hr>
<br>
<pre>public final class <span class="strong">Uri</span>
extends java.lang.Object</pre>
<div class="block">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>
<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>
<li>URIs used in the DMT must be treated and interpreted as case sensitive.</li>
<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>
<li>No parent denotation: URI must not be constructed using the character
sequence <code>"../"</code> to traverse the tree upwards.</li>
<li>Single Root: The character sequence <code>"./"</code> must not be used
anywhere else but in the beginning of a URI.</li>
</ul></div>
</li>
</ul>
</div>
<div class="summary">
<ul class="blockList">
<li class="blockList">
<!-- =========== FIELD SUMMARY =========== -->
<ul class="blockList">
<li class="blockList"><a name="field_summary">
<!-- -->
</a>
<h3>Field Summary</h3>
<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" summary="Field Summary table, listing fields, and an explanation">
<caption><span>Fields</span><span class="tabEnd"> </span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colLast" scope="col">Field and Description</th>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static java.lang.String</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#PATH_SEPARATOR">PATH_SEPARATOR</a></strong></code>
<div class="block">This constant stands for a string identifying the path separator in the
DmTree ("/").</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static char</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#PATH_SEPARATOR_CHAR">PATH_SEPARATOR_CHAR</a></strong></code>
<div class="block">This constant stands for a char identifying the path separator in the
DmTree ('/').</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static java.lang.String</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#ROOT_NODE">ROOT_NODE</a></strong></code>
<div class="block">This constant stands for a string identifying the root of the DmTree
(".").</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static char</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#ROOT_NODE_CHAR">ROOT_NODE_CHAR</a></strong></code>
<div class="block">This constant stands for a char identifying the root of the DmTree ('.').</div>
</td>
</tr>
</table>
</li>
</ul>
<!-- ========== METHOD SUMMARY =========== -->
<ul class="blockList">
<li class="blockList"><a name="method_summary">
<!-- -->
</a>
<h3>Method Summary</h3>
<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" summary="Method Summary table, listing methods, and an explanation">
<caption><span>Methods</span><span class="tabEnd"> </span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colLast" scope="col">Method and Description</th>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static java.lang.String</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#decode(java.lang.String)">decode</a></strong>(java.lang.String nodeName)</code>
<div class="block">Decode the node name so that back slash and forward slash are un-escaped
from a back slash.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static java.lang.String</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#encode(java.lang.String)">encode</a></strong>(java.lang.String nodeName)</code>
<div class="block">Encode the node name so that back slash and forward slash are escaped
with a back slash.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static boolean</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#isAbsoluteUri(java.lang.String)">isAbsoluteUri</a></strong>(java.lang.String uri)</code>
<div class="block">Checks whether the specified URI is an absolute URI.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static boolean</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#isValidUri(java.lang.String)">isValidUri</a></strong>(java.lang.String uri)</code>
<div class="block">Checks whether the specified URI is valid.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static java.lang.String</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#mangle(java.lang.String)">mangle</a></strong>(java.lang.String nodeName)</code>
<div class="block">Returns a node name that is valid for the tree operation methods, based
on the given node name.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static java.lang.String[]</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#toPath(java.lang.String)">toPath</a></strong>(java.lang.String uri)</code>
<div class="block">Split the specified URI along the path separator '/' characters and
return an array of URI segments.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static java.lang.String</code></td>
<td class="colLast"><code><strong><a href="../../../../org/osgi/service/dmt/Uri.html#toUri(java.lang.String[])">toUri</a></strong>(java.lang.String[] path)</code>
<div class="block">Construct a URI from the specified URI segments.</div>
</td>
</tr>
</table>
<ul class="blockList">
<li class="blockList"><a name="methods_inherited_from_class_java.lang.Object">
<!-- -->
</a>
<h3>Methods inherited from class java.lang.Object</h3>
<code>clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait</code></li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
<div class="details">
<ul class="blockList">
<li class="blockList">
<!-- ============ FIELD DETAIL =========== -->
<ul class="blockList">
<li class="blockList"><a name="field_detail">
<!-- -->
</a>
<h3>Field Detail</h3>
<a name="ROOT_NODE">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>ROOT_NODE</h4>
<pre>public static final java.lang.String ROOT_NODE</pre>
<div class="block">This constant stands for a string identifying the root of the DmTree
(".").</div>
<dl><dt><span class="strong">Since:</span></dt>
<dd>2.0</dd>
<dt><span class="strong">See Also:</span></dt><dd><a href="../../../../constant-values.html#org.osgi.service.dmt.Uri.ROOT_NODE">Constant Field Values</a></dd></dl>
</li>
</ul>
<a name="ROOT_NODE_CHAR">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>ROOT_NODE_CHAR</h4>
<pre>public static final char ROOT_NODE_CHAR</pre>
<div class="block">This constant stands for a char identifying the root of the DmTree ('.').</div>
<dl><dt><span class="strong">Since:</span></dt>
<dd>2.0</dd>
<dt><span class="strong">See Also:</span></dt><dd><a href="../../../../constant-values.html#org.osgi.service.dmt.Uri.ROOT_NODE_CHAR">Constant Field Values</a></dd></dl>
</li>
</ul>
<a name="PATH_SEPARATOR">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>PATH_SEPARATOR</h4>
<pre>public static final java.lang.String PATH_SEPARATOR</pre>
<div class="block">This constant stands for a string identifying the path separator in the
DmTree ("/").</div>
<dl><dt><span class="strong">Since:</span></dt>
<dd>2.0</dd>
<dt><span class="strong">See Also:</span></dt><dd><a href="../../../../constant-values.html#org.osgi.service.dmt.Uri.PATH_SEPARATOR">Constant Field Values</a></dd></dl>
</li>
</ul>
<a name="PATH_SEPARATOR_CHAR">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>PATH_SEPARATOR_CHAR</h4>
<pre>public static final char PATH_SEPARATOR_CHAR</pre>
<div class="block">This constant stands for a char identifying the path separator in the
DmTree ('/').</div>
<dl><dt><span class="strong">Since:</span></dt>
<dd>2.0</dd>
<dt><span class="strong">See Also:</span></dt><dd><a href="../../../../constant-values.html#org.osgi.service.dmt.Uri.PATH_SEPARATOR_CHAR">Constant Field Values</a></dd></dl>
</li>
</ul>
</li>
</ul>
<!-- ============ METHOD DETAIL ========== -->
<ul class="blockList">
<li class="blockList"><a name="method_detail">
<!-- -->
</a>
<h3>Method Detail</h3>
<a name="mangle(java.lang.String)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>mangle</h4>
<pre>public static java.lang.String mangle(java.lang.String nodeName)</pre>
<div class="block">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>
</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 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>
<li>the digest is encoded with the base 64 algorithm</li>
<li>all '/' characters in the encoded digest are replaced with '_'</li>
<li>trailing '=' signs are removed</li>
</ul></div>
<dl><dt><span class="strong">Parameters:</span></dt><dd><code>nodeName</code> - the node name to be mangled (if necessary), must not be
<code>null</code> or empty</dd>
<dt><span class="strong">Returns:</span></dt><dd>the normalized node name that is valid for tree operations</dd>
<dt><span class="strong">Throws:</span></dt>
<dd><code>java.lang.NullPointerException</code> - if <code>nodeName</code> is <code>null</code></dd>
<dd><code>java.lang.IllegalArgumentException</code> - if <code>nodeName</code> is empty</dd></dl>
</li>
</ul>
<a name="toUri(java.lang.String[])">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>toUri</h4>
<pre>public static java.lang.String toUri(java.lang.String[] path)</pre>
<div class="block">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.</div>
<dl><dt><span class="strong">Parameters:</span></dt><dd><code>path</code> - a possibly empty array of URI segments, must not be
<code>null</code></dd>
<dt><span class="strong">Returns:</span></dt><dd>the URI created from the specified segments</dd>
<dt><span class="strong">Throws:</span></dt>
<dd><code>java.lang.NullPointerException</code> - if the specified path or any of its segments
are <code>null</code></dd>
<dd><code>java.lang.IllegalArgumentException</code> - if the specified path contains too many
or malformed segments or the resulting URI is too long</dd></dl>
</li>
</ul>
<a name="toPath(java.lang.String)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>toPath</h4>
<pre>public static java.lang.String[] toPath(java.lang.String uri)</pre>
<div class="block">Split the specified URI along the path separator '/' characters and
return an array of URI segments. Special characters in the returned
segments are escaped. The returned array may be empty if the specified
URI was empty.</div>
<dl><dt><span class="strong">Parameters:</span></dt><dd><code>uri</code> - the URI to be split, must not be <code>null</code></dd>
<dt><span class="strong">Returns:</span></dt><dd>an array of URI segments created by splitting the specified URI</dd>
<dt><span class="strong">Throws:</span></dt>
<dd><code>java.lang.NullPointerException</code> - if the specified URI is <code>null</code></dd>
<dd><code>java.lang.IllegalArgumentException</code> - if the specified URI is malformed</dd></dl>
</li>
</ul>
<a name="isAbsoluteUri(java.lang.String)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>isAbsoluteUri</h4>
<pre>public static boolean isAbsoluteUri(java.lang.String uri)</pre>
<div class="block">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 (".").</div>
<dl><dt><span class="strong">Parameters:</span></dt><dd><code>uri</code> - the URI to be checked, must not be <code>null</code> and must
contain a valid URI</dd>
<dt><span class="strong">Returns:</span></dt><dd>whether the specified URI is absolute</dd>
<dt><span class="strong">Throws:</span></dt>
<dd><code>java.lang.NullPointerException</code> - if the specified URI is <code>null</code></dd>
<dd><code>java.lang.IllegalArgumentException</code> - if the specified URI is malformed</dd></dl>
</li>
</ul>
<a name="encode(java.lang.String)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>encode</h4>
<pre>public static java.lang.String encode(java.lang.String nodeName)</pre>
<div class="block">Encode the node name so that back slash and forward slash are escaped
with a back slash. This method is the reverse of <a href="../../../../org/osgi/service/dmt/Uri.html#decode(java.lang.String)"><code>decode(String)</code></a>.</div>
<dl><dt><span class="strong">Parameters:</span></dt><dd><code>nodeName</code> - the node name to be encoded</dd>
<dt><span class="strong">Returns:</span></dt><dd>the encoded node name</dd><dt><span class="strong">Since:</span></dt>
<dd>2.0</dd></dl>
</li>
</ul>
<a name="decode(java.lang.String)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>decode</h4>
<pre>public static java.lang.String decode(java.lang.String nodeName)</pre>
<div class="block">Decode the node name so that back slash and forward slash are un-escaped
from a back slash.</div>
<dl><dt><span class="strong">Parameters:</span></dt><dd><code>nodeName</code> - the node name to be decoded</dd>
<dt><span class="strong">Returns:</span></dt><dd>the decoded node name</dd><dt><span class="strong">Since:</span></dt>
<dd>2.0</dd></dl>
</li>
</ul>
<a name="isValidUri(java.lang.String)">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>isValidUri</h4>
<pre>public static boolean isValidUri(java.lang.String uri)</pre>
<div class="block">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>
<li>the URI follows the syntax defined for valid DMT URIs;</li>
</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.</div>
<dl><dt><span class="strong">Parameters:</span></dt><dd><code>uri</code> - the URI to be validated</dd>
<dt><span class="strong">Returns:</span></dt><dd>whether the specified URI is valid</dd></dl>
</li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
</div>
<!-- ========= END OF CLASS DATA ========= -->
<!-- ======= START OF BOTTOM NAVBAR ====== -->
<div class="bottomNav"><a name="navbar_bottom">
<!-- -->
</a><a href="#skip-navbar_bottom" title="Skip navigation links"></a><a name="navbar_bottom_firstrow">
<!-- -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../../overview-summary.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</li>
<li><a href="package-tree.html">Tree</a></li>
<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
<li><a href="../../../../index-all.html">Index</a></li>
<li><a href="../../../../help-doc.html">Help</a></li>
</ul>
</div>
<div class="subNav">
<ul class="navList">
<li><a href="../../../../org/osgi/service/dmt/MetaNode.html" title="interface in org.osgi.service.dmt"><span class="strong">Prev Class</span></a></li>
<li>Next Class</li>
</ul>
<ul class="navList">
<li><a href="../../../../index.html?org/osgi/service/dmt/Uri.html" target="_top">Frames</a></li>
<li><a href="Uri.html" target="_top">No Frames</a></li>
</ul>
<ul class="navList" id="allclasses_navbar_bottom">
<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
</ul>
<div>
<script type="text/javascript"><!--
allClassesLink = document.getElementById("allclasses_navbar_bottom");
if(window==top) {
allClassesLink.style.display = "block";
}
else {
allClassesLink.style.display = "none";
}
//-->
</script>
</div>
<div>
<ul class="subNavList">
<li>Summary: </li>
<li>Nested | </li>
<li><a href="#field_summary">Field</a> | </li>
<li>Constr | </li>
<li><a href="#method_summary">Method</a></li>
</ul>
<ul class="subNavList">
<li>Detail: </li>
<li><a href="#field_detail">Field</a> | </li>
<li>Constr | </li>
<li><a href="#method_detail">Method</a></li>
</ul>
</div>
<a name="skip-navbar_bottom">
<!-- -->
</a></div>
<!-- ======== END OF BOTTOM NAVBAR ======= -->
</body>
</html>
|