nih-gov/www.ncbi.nlm.nih.gov/toolkit/doc/book/ch_demo/index.html

1957 lines
80 KiB
HTML
Raw Permalink Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<!-- google site verification -->
<!--
<meta name="google-site-verification" content="1E2mGo_sqU60SInLwmk-gaLIovV5oVkjJntFEf4gxcg" />
-->
<link rel="shortcut icon" type="image/x-icon" href="/cxx-toolkit/static/img/favicon.ico">
<title>NCBI C++ Toolkit Book</title>
<!-- Page headcontent begin -->
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta name="description" content="A comprehensive manual on the NCBI C++ toolkit, including its design and development framework, a C++ library reference, software examples and demos, FAQs and release notes.">
<meta name="ncbipopper" content="triggerPosition:'bottom left',destPosition:'top left',openEvent:'click',closeEvent:'click'">
<!-- PageFixtures resources end -->
<!-- STICKY HEADER begin -->
<script src="//code.jquery.com/jquery.min.js"></script>
<style id="jsbin-css">
table.floatThead-table {
border-top: none;
border-bottom: none;
background-color: #fff;
}
</style>
<!-- STICKY HEADER end -->
<!-- sidebar test begin -->
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="/cxx-toolkit/static/css/bookpage.css" type="text/css">
<!-- toggle sidebar functions -->
<script type="text/javascript">
function doSBClose() {
document.getElementById("showNav").style.display = "flex";
document.getElementById("left-column").style.display = "none";
}
function doSBOpen() {
document.getElementById("sphinxsidebar").style.display = "block";
document.getElementById("left-column").style.display = "flex";
document.getElementById("showNav").style.display = "none";
}
</script>
<!-- sidebar test end -->
<!-- updated CSS -->
<link rel="stylesheet" href="/cxx-toolkit/static/css/footer.css" type="text/css">
<link rel="stylesheet" href="/cxx-toolkit/static/css/sidebar.css" type="text/css"> </head>
<body> <!-- Header start -->
<div id="navbar">
<nav class="navbar">
<!--/.header-->
<!-- header start -->
<div class="header">
<div class="ncbi_logo">
<a href="https://www.ncbi.nlm.nih.gov/" target="_blank">
<img title="NCBI Home Page" src="/cxx-toolkit/static/img/ncbi_logo1.png">
</a>
</div>
<div class="res_logo">
<h1 class="res_name">
<a href="https://ncbi.github.io/cxx-toolkit/" title="Table of Contents Page" id="toolkit_header">
NCBI C++ Toolkit
</a>
</h1>
</div>
<div style="position: absolute; height: 80px; right: 200px; top: 0; width: 550px;" class="search" align="top">
<!-- NEW SEARCH FORM -->
<!-- form id="searchForm" method="post" -->
<form name="frmSymbolSearch" onsubmit="return SymbolSearch(&#39;toolkit&#39;)" action="https://www.ncbi.nlm.nih.gov/" id="frmSymbolSearch">
<fieldset>
<nobr>
<input id="s" name="__symbol" type="text" />
<input type="submit" value="Submit" id="submitButton" />
</nobr>
<div id="searchInContainer">
<nobr><input checked="checked" name="__symboloc" id="book_search" type="radio" onclick="toggleInHouseCheckbox(&#39;hidden&#39;);"> <label title="Search in this book" for="book_search"> Book </label>
<nobr><input name="__symboloc" id="toolkit" type="radio" onclick="toggleInHouseCheckbox(&#39;visible&#39;);"> <label title="Search in the C/C++ source code" for="toolkit">Code</label></nobr>
<nobr><input name="__symboloc" id="pLXR" type="radio" onclick="toggleInHouseCheckbox(&#39;visible&#39;);"> <label title="Search the symbol in the source code using LINUX Cross-Reference browser" for="pLXR">LXR</label></nobr>
<nobr><input name="__symboloc" id="pLib" type="radio" onclick="toggleInHouseCheckbox(&#39;visible&#39;);"> <label title="Locate the Toolkit library(es) where the symbol is defined" for="pLib">Library</label></nobr>
<nobr id="switch_nobr" style="visibility: hidden;"><input name="switch" id="switch" type="checkbox" style="margin-left: 7%;"> <label title="Switch to Internal Source" for="switch" align="right">In house</label></nobr>
</div>
</fieldset>
</form>
<!-- NEW SEARCH FORM END -->
</div>
</div>
</nav>
<nav class="navbar2">
<div class="nvgtn">
<!-- New drop down start -->
<div class="dropdown">
<button class="dropbtn">Contents ▾</button>
<div class="dropdown-content" >
<a href="https://ncbi.github.io/cxx-toolkit/" style="float: right;">Table of Contents Page</a>
<ul class="simple-list">
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/fm">Book Information</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/part1">Part 1. Overview</a>
<ul class="simple-list">
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_intro">Introduction to the C++ Toolkit</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_start">Getting Started</a>
</li>
</ul>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/part2">Part 2. Development Framework</a>
<ul class="simple-list">
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_getcode_svn">Retrieve the Source Code (FTP, Subversion and GitHub)</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_config">Configure, Build, and Use the Toolkit (autoconf/PTB)</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_build">Working with Makefiles (autoconf/PTB)</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_proj">Project Creation and Management (autoconf/PTB)</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_cmconfig">Configure, Build and Use the Toolkit with CMake</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_style">Programming Policies and Guidelines</a>
</li>
</ul>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/part3">Part 3. C++ Toolkit Library Reference</a>
<ul class="simple-list">
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_core">Portability, Core Functionality and Application Framework</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_log">Logging and Diagnostics</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_conn">Networking and IPC</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_dbapi">Database Access Support</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_cgi">CGI and Fast-CGI </a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_html">HTML</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_ser">Data Serialization (ASN.1, XML)</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_datamod">Biological Sequence Data Model</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_objmgr">Biological Object Manager</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_objmgr_dtld">Biological Object Manager Data Loaders</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_blast">BLAST API</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_dataaccess">Access to NCBI data</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_algoalign">Biological Sequence Alignment</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_gui">GUI and Graphics</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_boost">Using the Boost Unit Test Framework</a>
</li>
</ul>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/part4">Part 4. Wrappers for 3rd-Party Packages</a>
<ul class="simple-list">
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_xmlwrapp">XmlWrapp (XML parsing and handling, XSLT, XPath)</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_jsonwrapp">JSONWRAPP (JSON parsing and handling)</a>
</li>
</ul>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/part5">Part 5. Software</a>
<ul class="simple-list">
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_debug">Debugging, Exceptions, and Error Handling</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_grid">Distributed Computing</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_app">Applications</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_demo">Examples and Demos</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_res">C Toolkit Resources for C++ Toolkit Users</a>
</li>
</ul>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/part6">Part 6. Help and Support</a>
<ul class="simple-list">
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_browse">NCBI C++ Toolkit Source Browser</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_devtools">Software Development Tools</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_faq">FAQs, Useful Documentation Links, and Mailing Lists</a>
</li>
</ul>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/part7">Part 7. Library and Applications Configuration</a>
<ul class="simple-list">
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/ch_libconfig">Library Configuration</a>
</li>
</ul>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/misc">Miscellaneous</a>
</li>
<li class="half_rhythm">
<a href="https://ncbi.github.io/cxx-toolkit/pages/appendix">Appendix - Books and Styles</a>
</li>
</ul>
</div>
</div>
<!-- New drop down end -->
<div class="edit_links">
<a href="https://github.com/ncbi/cxx-toolkit/edit/gh-pages/pages/ch_demo.md"><img alt="Edit this page" src="/cxx-toolkit/static/img/button_edit_grey.gif"></a>
<a target="_blank" href="/cxx-toolkit/help_page">How to edit the page</a>
</div>
</div>
</nav>
</div>
<!-- Header end -->
<!-- content start -->
<div class="content">
<!-- sidebar start -->
<div id="left-column">
<aside id="sidebar" class="sidebar">
<div class="sphinxsidebar" id="sphinxsidebar">
<div id="sphinxsidebarwrapper" class="sphinxsidebarwrapper">
<a href="javascript:doSBClose()" class="closeNav" id="closeNav">
<<< Minimize sidebar</a>
<div id="tkb_public" class="col three_col last">
<div class="portlet">
<div class="portlet_head">
<div class="portlet_title">Source Browsers</div>
</div>
<div class="portlet_content">
<ul>
<li class="external-only">
LXR: <a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lxr/ident">public</a> / <a href="https://intranet.ncbi.nlm.nih.gov/ieb/ToolBox/CPP_DOC/lxr/ident">in-house</a>
</li>
<li class="external-only">
Doxygen: <a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/doxyhtml/modules.html">public</a> / <a href="https://intranet.ncbi.nlm.nih.gov/ieb/ToolBox/CPP_DOC/doxyhtml/modules.html">in-house</a>
</li>
</ul>
</div>
</div>
<div class="portlet">
<div class="portlet_head">
<div class="portlet_title">Sources in VCS</div>
</div>
<div class="portlet_content">
<ul>
<li class="external-only">
Git: <a href="https://github.com/ncbi/ncbi-cxx-toolkit-public">GitHub</a>
</li><li class="external-only">
SVN: <a href="https://www.ncbi.nlm.nih.gov/viewvc/v1/trunk/c++/">public</a> / <a href="https://svn.ncbi.nlm.nih.gov/viewvc/toolkit/trunk/c++">in-house</a>
</li>
<li class="external-only">
<a href="/cxx-toolkit/pages/ch_getcode_svn#read-only-access-to-the-source-code-via-subversion">How to</a>
</li>
</ul>
</div>
</div>
<div class="portlet">
<div class="portlet_head">
<div class="portlet_title">Resources</div>
</div>
<div class="portlet_content">
<ul>
<li class="external-only">
<a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lib_search/libsearch.cgi">Library Search Tool</a>
</li>
<li class="external-only">
<a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/depgraphs/dglistdeps.cgi">Library Dependencies Tool</a>
</li>
<li>
<a href="/cxx-toolkit/pages/release_notes">Release Notes</a>
</li>
<li>
<a href="/cxx-toolkit/pages/ch_getcode_svn#public-access-to-the-source-code-via-ftp">Download</a>
</li>
<li>
<a href="/cxx-toolkit/pages/ch_style">Coding Policy</a>
</li>
<li>
<a href="/cxx-toolkit/pages/ch_faq#mailing-lists">Mailing Lists</a>
</li>
<li>
<a href="mailto:cpp-doc@ncbi.nlm.nih.gov">
<span title="Contact C++ Toolkit group">Help and Support</span>
</a>
</li>
<li>
<a href="/cxx-toolkit/cite">How to cite C++ Toolkit</a>
</li>
<li>
<a href="https://www.ncbi.nlm.nih.gov/data_specs/">Data Specifications</a>
</li> </ul>
</div>
</div>
<div class="portlet">
<div class="portlet_head">
<div class="portlet_title">In House Only Resources</div>
</div>
<div class="portlet_content">
<ul>
<li class="internal-only">
<a href="https://jira.ncbi.nlm.nih.gov/projects/CXX/summary/statistics">
JIRA
</a>
</li>
<li class="internal-only">
<a href="https://intranet.ncbi.nlm.nih.gov/Service/lbsmc/search.cgi">Load Balancer
</a>
</li>
<li>
<a href="https://intranet.ncbi.nlm.nih.gov/ieb/ToolBox/GRID/dashboard/dashboard.cgi">
GRID Dashboard
</a>
</li>
<li class="internal-only">
<a href="https://confluence.ncbi.nlm.nih.gov/display/CT/Testsuite">
<span title="View results of testsuite runs on the automatic C++ Toolkit builds">Test Results</span>
</a>
</li>
<li>
<a href="https://intranet.ncbi.nlm.nih.gov/ieb/ToolBox/SC/index.html">
Stable Components
</a>
</li>
<li>
<a href="https://teamcity.ncbi.nlm.nih.gov/project/CXX">
TeamCity
</a>
</li>
<li class="internal-only">
<a href="https://confluence.ncbi.nlm.nih.gov/display/CT">Documentation
</a>
</li>
</ul>
</div>
</div>
<!------------------------------------------------------------------------------------------------------------ NEW SIDE BAR END --------------------------------------------------------------------------------------------------------------->
</div>
</div>
</aside>
</div>
<div id="main-column" class="main-column"> <a href="javascript:doSBOpen()"><span id="showNav" class="showNav">Sidebar</span></a>
<!-- sidebar end -->
<div class="document">
<div class="documentwrapper">
<div class="bodywrapper">
<div class="body">
<!-- main content start -->
<div class="section"> <h1 id="examples-and-demos">Examples and Demos</h1>
<h2 id="introduction">Introduction</h2>
<p>See <a href="ch_start.html">Getting Started</a> for basic information on using the NCBI C++ Toolkit.</p>
<h2 id="chapter-outline">Chapter Outline</h2>
<ul>
<li>
<p>Examples</p>
<ul>
<li>
<p><a href="ch_proj.html#ch_proj.new_proj_struct">Sample Applications Available with the new_project script</a></p>
<ul>
<li>
<p><a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lxr/source/src/sample/app/basic/">A basic example</a> using the <a href="ch_core.html">xncbi</a> core library</p>
</li>
<li>
<p><a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lxr/source/src/sample/app/cgi/">An example CGI application</a> using the <a href="ch_cgi.html">xcgi and xfcgi</a> libraries.</p>
</li>
<li>
<p><a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lxr/source/src/sample/app/objects/">An example for serializable ASN.1 objects and the <code class="language-plaintext highlighter-rouge">Object Manager</code></a> using the <a href="ch_ser.html">xobjects</a> library.</p>
</li>
</ul>
</li>
<li>
<p><a href="#ch_demo.id1_fetch.html">id1_fetch</a> ID1 and Entrez2 client</p>
</li>
</ul>
</li>
<li>
<p><a href="#ch_demo.examples4">Examples from the Programming Manual</a></p>
<ul>
<li>
<p><a href="#ch_demo.examples_1_3">applic.cpp</a></p>
</li>
<li>
<p><a href="ch_ser.html#ch_ser.ctypeiter_cpp.html">ctypeiter.cpp</a></p>
</li>
<li>
<p><a href="ch_cgi.html#ch_cgi.cgi_cpp.html">justcgi.cpp</a></p>
</li>
<li>
<p><a href="ch_ser.html#ch_ser.xml2asn_cpp.html">xml2asn.cpp</a></p>
</li>
<li>
<p><a href="ch_ser.html#ch_ser.traverse_cpp.html">traverseBS.cpp</a></p>
</li>
<li>
<p><a href="#ch_demo.prog_man_CARdemo_index.html">Web-CGI demo</a></p>
</li>
</ul>
</li>
<li>
<p>Test and Demo Programs in the C++ Tree</p>
<ul>
<li>
<p><a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lxr/source/src/app/asn2asn/asn2asn.cpp">asn2asn.cpp</a></p>
</li>
<li>
<p><a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lxr/source/src/cgi/test/cgitest.cpp">cgitest.cpp</a></p>
</li>
<li>
<p><a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lxr/source/src/cgi/demo/cgidemo.cpp">cgidemo.cpp</a></p>
</li>
<li>
<p><a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lxr/source/src/corelib/test/coretest.cpp">coretest.cpp</a></p>
</li>
</ul>
</li>
</ul>
<p><a name="ch_demo.id1_fetch.html"></a></p>
<h2 id="id1_fetch---the-id1-and-entrez2-client">ID1_FETCH - the ID1 and Entrez2 client</h2>
<ul>
<li>
<p><a href="#ch_demo.Synopsis">Synopsis</a></p>
</li>
<li>
<p><a href="#ch_demo.id1_fetch.html_ref_Invocation">Invocation</a></p>
<ul>
<li>
<p><a href="#ch_demo.id1_fetch.html_ref_fmt">Output Data Formats</a></p>
</li>
<li>
<p><a href="#ch_demo.id1_fetch.html_ref_lt">Lookup Types</a></p>
</li>
<li>
<p><a href="#ch_demo.id1_fetch.html_ref_maxplex">Output Complexity Levels</a></p>
</li>
<li>
<p><a href="#ch_demo.id1_fetch.html_ref_flat">Flattened Sequence ID Format</a></p>
</li>
<li>
<p><a href="#ch_demo.id1_fetch.html_ref_fasta">FASTA Sequence ID Format</a></p>
</li>
</ul>
</li>
<li>
<p><a href="#ch_demo.id1_fetch.html_ref_Examples">Examples of Usage</a></p>
</li>
</ul>
<p><strong>Location</strong>: <a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lxr/source/src/app/id1_fetch/id1_fetch.cpp">c++/src/app/id1_fetch/id1_fetch.cpp</a> (compiled executable is <code class="language-plaintext highlighter-rouge">$NCBI/c++/Release/bin/id1_fetch</code> on NCBI systems)</p>
<p><a name="ch_demo.Synopsis"></a></p>
<h3 id="synopsis">Synopsis:</h3>
<ul>
<li>
<p>Accept a list of sequences, specified either directly by ID or indirectly by an <a href="https://www.ncbi.nlm.nih.gov/books/NBK21081/">Entrez</a> query.</p>
</li>
<li>
<p>Produce more information about the sequences, either as data from the ID server or as <a href="https://www.ncbi.nlm.nih.gov/books/NBK21081/">Entrez</a> document summaries.</p>
</li>
</ul>
<p>This program corresponds to <strong>idfetch</strong> from the C Toolkit.</p>
<p><a name="ch_demo.id1_fetch.html_ref_Invocation"></a></p>
<h3 id="invocation">Invocation</h3>
<p>See <a href="#ch_demo.T1">Table 1</a>.</p>
<p><a name="ch_demo.T1"></a></p>
<p>Table 1. Invocation flags</p>
<table>
<thead>
<tr>
<th>Argument</th>
<th>Value</th>
<th>Effect</th>
</tr>
</thead>
<tbody>
<tr>
<td><code class="language-plaintext highlighter-rouge">-h</code></td>
<td> </td>
<td>Print usage message and exit.</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-gi N</code></td>
<td>integer</td>
<td>GenInfo ID of sequence to look up.</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-fmt fmt</code></td>
<td><a href="#ch_demo.id1_fetch.html_ref_fmt">format type</a></td>
<td>Output data format; default is <code class="language-plaintext highlighter-rouge">asn</code> (ASN.1 text).</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-out file</code></td>
<td>filename</td>
<td>Write output to specified file rather than stdout.</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-log file</code></td>
<td>filename</td>
<td>Write errors and messages to specified file rather than stderr.</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-db str</code></td>
<td>string</td>
<td>Use specified database. <strong>Mandatory for</strong> <a href="https://www.ncbi.nlm.nih.gov/books/NBK21081/">Entrez</a> <strong>queries</strong>, where it is normally either Nucleotide or Protein. Also specifies satellite database for sequence-entry lookups.</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-ent N</code></td>
<td>integer</td>
<td>Dump specified subentity. Only relevant for sequence-entry lookups.</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-lt type</code></td>
<td><a href="#ch_demo.id1_fetch.html_ref_lt">lookup type</a></td>
<td>Type of lookup; default is <code class="language-plaintext highlighter-rouge">entry</code> (sequence entry).</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-in file</code></td>
<td>filename</td>
<td>Read sequence IDs from file rather than command line. May contain raw GI IDs, <a href="#ch_demo.id1_fetch.html_ref_flat">flattened IDs</a>, and <a href="#ch_demo.id1_fetch.html_ref_fasta">FASTA-format IDs</a>.</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-maxplex m</code></td>
<td><a href="#ch_demo.id1_fetch.html_ref_maxplex">complexity</a></td>
<td>Maximum output complexity level; default is <code class="language-plaintext highlighter-rouge">entry</code> (entire entry).</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-flat id</code></td>
<td><a href="#ch_demo.id1_fetch.html_ref_flat">flat ID</a></td>
<td>Flattened ID of sequence to look up.</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-fasta id</code></td>
<td><a href="#ch_demo.id1_fetch.html_ref_fasta">FASTA ID</a></td>
<td><a href="https://blast.ncbi.nlm.nih.gov/blast/fasta.shtml">FASTA</a>-style ID of sequence to look up.</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-query str</code></td>
<td>string</td>
<td>Generate ID list from specified <a href="https://www.ncbi.nlm.nih.gov/books/NBK21081/">Entrez</a> query.</td>
</tr>
<tr>
<td><code class="language-plaintext highlighter-rouge">-qf file</code></td>
<td>file</td>
<td>Generate ID list from <a href="https://www.ncbi.nlm.nih.gov/books/NBK21081/">Entrez</a> query in specified file.</td>
</tr>
</tbody>
</table>
<div class="table-scroll"></div>
<p><a href="https://www.ncbi.nlm.nih.gov/IEB/ToolBox/CPP_DOC/lxr/ident?i=Note">Note</a>: You must specify exactly one of the options indicating what to look up: <code class="language-plaintext highlighter-rouge">-gi, -in, -flat, -fasta, -query, -qf</code>.</p>
<p><a name="ch_demo.id1_fetch.html_ref_fmt"></a></p>
<h4 id="output-data-formats">Output Data Formats</h4>
<p>The possible values of the <code class="language-plaintext highlighter-rouge">-fmt</code> argument are shown in <a href="#ch_demo.T2">Table 2</a>.</p>
<p><a name="ch_demo.T2"></a></p>
<p>Table 2. Output data formats</p>
<table>
<thead>
<tr>
<th>Value</th>
<th>Format</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>asn</td>
<td>ASN.1 text (default)</td>
<td> </td>
</tr>
<tr>
<td>asnb</td>
<td>ASN.1 binary</td>
<td> </td>
</tr>
<tr>
<td>docsum</td>
<td><a href="https://www.ncbi.nlm.nih.gov/books/NBK21081/">Entrez</a> document summary</td>
<td>Lookup type is irrelevant.</td>
</tr>
<tr>
<td>fasta</td>
<td><a href="https://blast.ncbi.nlm.nih.gov/blast/fasta.shtml">FASTA</a></td>
<td>Produces state as simple text; produces history in tabular form.</td>
</tr>
<tr>
<td>genbank</td>
<td><a href="https://www.ncbi.nlm.nih.gov/Genbank/index.html">GenBank</a><a href="https://www.ncbi.nlm.nih.gov/Sitemap/samplerecord.html">flat-file format</a></td>
<td>Lookup type must be entry (default).</td>
</tr>
<tr>
<td>genpept</td>
<td>GenPept flat-file format</td>
<td>Lookup type must be entry (default).</td>
</tr>
<tr>
<td>quality</td>
<td>Quality scores</td>
<td>Lookup type must be entry (default); data not always available.</td>
</tr>
<tr>
<td>xml</td>
<td>XML</td>
<td>Isomorphic to ASN.1 output.</td>
</tr>
</tbody>
</table>
<div class="table-scroll"></div>
<p><a name="ch_demo.id1_fetch.html_ref_lt"></a></p>
<h4 id="lookup-types">Lookup Types</h4>
<p>The possible values of the <code class="language-plaintext highlighter-rouge">-lt</code> argument are shown in <a href="#ch_demo.T3">Table 3</a>.</p>
<p><a name="ch_demo.T3"></a></p>
<p>Table 3. Lookup types</p>
<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>entry</td>
<td>The actual sequence entry (default)</td>
</tr>
<tr>
<td>history</td>
<td>Summary of changes to the sequence data</td>
</tr>
<tr>
<td>ids</td>
<td>All of the sequences IDs</td>
</tr>
<tr>
<td>none</td>
<td>Just the GI ID</td>
</tr>
<tr>
<td>revisions</td>
<td>Summary of changes to the sequence data or annotations</td>
</tr>
<tr>
<td>state</td>
<td>The sequences status</td>
</tr>
</tbody>
</table>
<div class="table-scroll"></div>
<p><a name="ch_demo.id1_fetch.html_ref_maxplex"></a></p>
<h4 id="output-complexity-levels">Output Complexity Levels</h4>
<p>The possible values of the <code class="language-plaintext highlighter-rouge">-maxplex</code> argument are shown in <a href="#ch_demo.T4">Table 4</a>.</p>
<p><a name="ch_demo.T4"></a></p>
<p>Table 4. Maximum output complexity level values</p>
<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>bioseq</td>
<td>Just the bioseq of interest</td>
</tr>
<tr>
<td>bioseq-set</td>
<td>Minimal bioseq-set</td>
</tr>
<tr>
<td>entry</td>
<td>Entire entry (default)</td>
</tr>
<tr>
<td>nuc-prot</td>
<td>Minimal nuc-prot</td>
</tr>
<tr>
<td>pub-set</td>
<td>Minimal pub-set</td>
</tr>
</tbody>
</table>
<div class="table-scroll"></div>
<p><a name="ch_demo.id1_fetch.html_ref_flat"></a></p>
<h4 id="flattened-sequence-id-format">Flattened Sequence ID Format</h4>
<p>A flattened sequence ID has one of the following three formats, where square brackets […] surround optional elements:</p>
<ul>
<li>
<p>type([name or locus][,[accession][,[release][,version]]])</p>
</li>
<li>
<p>type=accession[.version]</p>
</li>
<li>
<p>type:number</p>
</li>
</ul>
<p>The first format requires quotes in most shells.</p>
<p>The type is a number, indicating who assigned the ID, as follows:</p>
<ul>
<li>
<p>Local use</p>
</li>
<li>
<p>GenInfo backbone sequence ID</p>
</li>
<li>
<p>GenInfo backbone molecule type</p>
</li>
<li>
<p>GenInfo import ID</p>
</li>
<li>
<p><a href="https://www.ncbi.nlm.nih.gov/Genbank/index.html">GenBank</a></p>
</li>
<li>
<p><a href="http://www.embl-heidelberg.de">The European Molecular Biology Laboratory (EMBL)</a></p>
</li>
<li>
<p><a href="http://pir.georgetown.edu">The Protein Information Resource (PIR)</a></p>
</li>
<li>
<p><a href="http://www.ebi.ac.uk/swissprot">SWISS-PROT</a></p>
</li>
<li>
<p>A patent</p>
</li>
<li>
<p><a href="https://www.ncbi.nlm.nih.gov/projects/RefSeq">RefSeq</a></p>
</li>
<li>
<p>General database reference</p>
</li>
<li>
<p>GenInfo integrated database (GI)</p>
</li>
<li>
<p><a href="http://www.ddbj.nig.ac.jp">The DNA Data Bank of Japan (DDBJ)</a></p>
</li>
<li>
<p><a href="http://www.prf.or.jp">The Protein Research Foundation (PRF)</a></p>
</li>
<li>
<p><a href="http://www.rcsb.org/pdb">The Protein DataBase (PDB)</a></p>
</li>
<li>
<p>Third-party annotation to <a href="https://www.ncbi.nlm.nih.gov/Genbank/index.html">GenBank</a></p>
</li>
<li>
<p>Third-party annotation to <a href="http://www.embl-heidelberg.de">EMBL</a></p>
</li>
<li>
<p>Third-party annotation to <a href="http://www.ddbj.nig.ac.jp">DDBJ</a></p>
</li>
<li>
<p>TrEMBL</p>
</li>
</ul>
<p><a name="ch_demo.id1_fetch.html_ref_fasta"></a></p>
<h4 id="fasta-sequence-id-format">FASTA Sequence ID Format</h4>
<p>This format consists of a two- or three-letter tag indicating the IDs type, followed by one or more data fields, which are separated from the tag and each other by vertical bars (|). The vertical bar is a special character in most command-line shells, so command-line arguments containing IDs usually must be quoted. <a href="#ch_demo.T5">Table 5</a> shows the specific possibilities.</p>
<p><a name="ch_demo.T5"></a></p>
<p>Table 5. FASTA sequence ID format values</p>
<table>
<thead>
<tr>
<th>Type</th>
<th>Format(s) <a href="#ch_demo.TF.1"><sup>1</sup></a></th>
<th>Example(s)</th>
</tr>
</thead>
<tbody>
<tr>
<td>local</td>
<td><code class="language-plaintext highlighter-rouge">lcl|integer</code><br /><code class="language-plaintext highlighter-rouge">lcl|string</code></td>
<td><code class="language-plaintext highlighter-rouge">lcl|123</code><br /><code class="language-plaintext highlighter-rouge">lcl|hmm271</code></td>
</tr>
<tr>
<td>GenInfo backbone seqid</td>
<td><code class="language-plaintext highlighter-rouge">bbs|integer</code></td>
<td><code class="language-plaintext highlighter-rouge">bbs|123</code></td>
</tr>
<tr>
<td>GenInfo backbone moltype</td>
<td><code class="language-plaintext highlighter-rouge">bbm|integer</code></td>
<td><code class="language-plaintext highlighter-rouge">bbm|123</code></td>
</tr>
<tr>
<td>GenInfo import ID</td>
<td><code class="language-plaintext highlighter-rouge">gim|integer</code></td>
<td><code class="language-plaintext highlighter-rouge">gim|123</code></td>
</tr>
<tr>
<td><a href="https://www.ncbi.nlm.nih.gov/Genbank/index.html">GenBank</a></td>
<td><code class="language-plaintext highlighter-rouge">gb|accession|locus</code></td>
<td><code class="language-plaintext highlighter-rouge">gb|M73307|AGMA13GT</code></td>
</tr>
<tr>
<td><a href="http://www.embl-heidelberg.de">EMBL</a></td>
<td><code class="language-plaintext highlighter-rouge">emb|accession|locus</code></td>
<td><code class="language-plaintext highlighter-rouge">emb|CAM43271.1|</code></td>
</tr>
<tr>
<td><a href="http://pir.georgetown.edu">PIR</a></td>
<td><code class="language-plaintext highlighter-rouge">pir|accession|name</code></td>
<td><code class="language-plaintext highlighter-rouge">pir||G36364</code></td>
</tr>
<tr>
<td><a href="http://www.ebi.ac.uk/swissprot">SWISS-PROT</a></td>
<td><code class="language-plaintext highlighter-rouge">sp|accession|name</code></td>
<td><code class="language-plaintext highlighter-rouge">sp|P01013|OVAX_CHICK</code></td>
</tr>
<tr>
<td>patent</td>
<td><code class="language-plaintext highlighter-rouge">pat|country|patent|sequence</code></td>
<td><code class="language-plaintext highlighter-rouge">pat|US|RE33188|1</code></td>
</tr>
<tr>
<td>pre-grant patent</td>
<td><code class="language-plaintext highlighter-rouge">pgp|country|application-number|seq-number</code></td>
<td><code class="language-plaintext highlighter-rouge">pgp|EP|0238993|7</code></td>
</tr>
<tr>
<td><a href="https://www.ncbi.nlm.nih.gov/projects/RefSeq">RefSeq</a> <a href="#ch_demo.TF.2"><sup>2</sup></a></td>
<td><code class="language-plaintext highlighter-rouge">ref|accession|name</code></td>
<td><code class="language-plaintext highlighter-rouge">ref|NM_010450.1|</code></td>
</tr>
<tr>
<td>general database reference</td>
<td><code class="language-plaintext highlighter-rouge">gnl|database|integer</code><br /><code class="language-plaintext highlighter-rouge">gnl|database|string</code></td>
<td><code class="language-plaintext highlighter-rouge">gnl|taxon|9606</code><br /><code class="language-plaintext highlighter-rouge">gnl|PID|e1632</code></td>
</tr>
<tr>
<td>GenInfo integrated database</td>
<td><code class="language-plaintext highlighter-rouge">gi|integer</code></td>
<td><code class="language-plaintext highlighter-rouge">gi|21434723</code></td>
</tr>
<tr>
<td><a href="http://www.ddbj.nig.ac.jp">DDBJ</a></td>
<td><code class="language-plaintext highlighter-rouge">dbj|accession|locus</code></td>
<td><code class="language-plaintext highlighter-rouge">dbj|BAC85684.1|</code></td>
</tr>
<tr>
<td><a href="http://www.prf.or.jp">PRF</a></td>
<td><code class="language-plaintext highlighter-rouge">prf|accession|name</code></td>
<td><code class="language-plaintext highlighter-rouge">prf||0806162C</code></td>
</tr>
<tr>
<td><a href="http://www.rcsb.org/pdb">PDB</a></td>
<td><code class="language-plaintext highlighter-rouge">pdb|entry|chain</code></td>
<td><code class="language-plaintext highlighter-rouge">pdb|1I4L|D</code></td>
</tr>
<tr>
<td>third-party <a href="https://www.ncbi.nlm.nih.gov/Genbank/index.html">GenBank</a></td>
<td><code class="language-plaintext highlighter-rouge">tpg|accession|name</code></td>
<td><code class="language-plaintext highlighter-rouge">tpg|BK003456|</code></td>
</tr>
<tr>
<td>third-party <a href="http://www.embl-heidelberg.de">EMBL</a></td>
<td><code class="language-plaintext highlighter-rouge">tpe|accession|name</code></td>
<td><code class="language-plaintext highlighter-rouge">tpe|BN000123|</code></td>
</tr>
<tr>
<td>third-party <a href="http://www.ddbj.nig.ac.jp">DDBJ</a></td>
<td><code class="language-plaintext highlighter-rouge">tpd|accession|name</code></td>
<td><code class="language-plaintext highlighter-rouge">tpd|FAA00017|</code></td>
</tr>
<tr>
<td>TrEMBL</td>
<td><code class="language-plaintext highlighter-rouge">tr|accession|name</code></td>
<td><code class="language-plaintext highlighter-rouge">tr|Q90RT2|Q90RT2_9HIV1</code></td>
</tr>
<tr>
<td>genome pipeline <a href="#ch_demo.TF.3"><sup>3</sup></a></td>
<td><code class="language-plaintext highlighter-rouge">gpp|accession|name</code></td>
<td><code class="language-plaintext highlighter-rouge">gpp|GPC_123456789|</code></td>
</tr>
<tr>
<td>named annotation track <a href="#ch_demo.TF.3"><sup>3</sup></a></td>
<td><code class="language-plaintext highlighter-rouge">nat|accession|name</code></td>
<td><code class="language-plaintext highlighter-rouge">nat|AT_123456789.1|</code></td>
</tr>
</tbody>
</table>
<div class="table-scroll"></div>
<p><a name="ch_demo.TF.1"></a></p>
<p><sup>1</sup> Spaces should not be present in IDs. Its okay to leave off the final vertical bar for most text ID types (such as gb) when the locus is absent; apart from that, vertical bars must be present even if an adjacent field is omitted.</p>
<p><a name="ch_demo.TF.2"></a></p>
<p><sup>2</sup> Some RefSeq accessions have additional letters following the underscore. See the <a href="https://www.ncbi.nlm.nih.gov/RefSeq/key.html#accession">RefSeq accession format reference</a> for details.</p>
<p><a name="ch_demo.TF.3"></a></p>
<p><sup>3</sup> For NCBI internal use.</p>
<p><a name="ch_demo.id1_fetch.html_ref_Examples"></a></p>
<h3 id="example-usage">Example Usage</h3>
<div class="language-plaintext highlighter-rouge"><div class="highlight"><pre class="highlight"><code>id1_fetch -query '5-delta4 isomerase' -lt none -db Nucleotide
34
id1_fetch -fmt genbank -gi 34
LOCUS BT3BHSD 1632 bp mRNA MAM 12-SEP-1993
DEFINITION Bovine mRNA for 3 beta hydroxy-5-ene steroid dehydrogenase/delta
5-delta4 isomerase (EC 1.1.1.145, EC 5.3.3.1).
ACCESSION X17614
VERSION X17614.1 GI:34
KEYWORDS 3 beta-hydroxy-delta5-steroid dehydrogenase;
steroid delta-isomerase.
...
FEATURES Location/Qualifiers
...
CDS 105..1226
/codon_start=1
/transl_table=1
/function="3 beta-HSD (AA 1-373)"
/protein_id="CAA35615.1"
/db_xref="GI:35"
/translation="MAGWSCLVTGGGGFLGQRIICLLVEEKDLQEIRVLDKVFRPEVR
EEFSKLQSKIKLTLLEGDILDEQCLKGACQGTSVVIHTASVIDVRNAVPRETIMNVNV
KGTQLLLEACVQASVPVFIHTSTIEVAGPNSYREIIQDGREEEHHESAWSSPYPYSKK
LAEKAVLGANGWALKNGGTLYTCALRPMYIYGEGSPFLSAYMHGALNNNGILTNHCKF
SRVNPVYVGNVAWAHILALRALRDPKKVPNIQGQFYYISDDTPHQSYDDLNYTLSKEW
GFCLDSRMSLPISLQYWLAFLLEIVSFLLSPIYKYNPCFNRHLVTLSNSVFTFSYKKA
QRDLGYEPLYTWEEAKQKTKEWIGSLVKQHKETLKTKIH"
/db_xref="SWISS-PROT:P14893"
...
1441 ggacagacaa ggtgatttgc tgcagctgct ggcaccaaaa tctcagtggc agattctgag
1501 ttatttgggc ttcttgtaac ttcgagtttt gcctcttagt cccactttct ttgttaaatg
1561 tggaagcatt tcttttaaaa gttcatattc cttcatgtag ctcaataaaa atgatcaaca
1621 ttttcatgac tc
//
id1_fetch -fmt genpept -gi 35
LOCUS CAA35615 373 aa MAM 12-SEP-1993
DEFINITION Bovine mRNA for 3 beta hydroxy-5-ene steroid dehydrogenase/delta
5-delta4 isomerase (EC 1.1.1.145, EC 5.3.3.1), and translated
products.
ACCESSION CAA35615
VERSION CAA35615.1 GI:35
PID g35
SOURCE cow.
ORGANISM Bos taurus
Eukaryota; Metazoa; Chordata; Craniata; Vertebrata; Euteleostomi;
Mammalia; Eutheria; Cetartiodactyla; Ruminantia; Pecora; Bovoidea;
Bovidae; Bovinae; Bos.
...
ORIGIN
1 magwsclvtg gggflgqrii cllveekdlq eirvldkvfr pevreefskl qskikltlle
61 gdildeqclk gacqgtsvvi htasvidvrn avpretimnv nvkgtqllle acvqasvpvf
121 ihtstievag pnsyreiiqd greeehhesa wsspypyskk laekavlgan gwalknggtl
181 ytcalrpmyi ygegspflsa ymhgalnnng iltnhckfsr vnpvyvgnva wahilalral
241 rdpkkvpniq gqfyyisddt phqsyddlny tlskewgfcl dsrmslpisl qywlafllei
301 vsfllspiyk ynpcfnrhlv tlsnsvftfs ykkaqrdlgy eplytweeak qktkewigsl
361 vkqhketlkt kih
//
id1_fetch -fmt fasta -gi 35 -maxplex bioseq
&gt;emb|CAA35615.1||gi|35 Bovine mRNA for 3 beta hydroxy-5-ene steroid dehydrogenase/delta
5-delta4 isomerase (EC 1.1.1.145, EC 5.3.3.1), and translated products
MAGWSCLVTGGGGFLGQRIICLLVEEKDLQEIRVLDKVFRPEVREEFSKLQSKIKLTLLEGDILDEQCLK
GACQGTSVVIHTASVIDVRNAVPRETIMNVNVKGTQLLLEACVQASVPVFIHTSTIEVAGPNSYREIIQD
GREEEHHESAWSSPYPYSKKLAEKAVLGANGWALKNGGTLYTCALRPMYIYGEGSPFLSAYMHGALNNNG
ILTNHCKFSRVNPVYVGNVAWAHILALRALRDPKKVPNIQGQFYYISDDTPHQSYDDLNYTLSKEWGFCL
DSRMSLPISLQYWLAFLLEIVSFLLSPIYKYNPCFNRHLVTLSNSVFTFSYKKAQRDLGYEPLYTWEEAK
QKTKEWIGSLVKQHKETLKTKIH
id1_fetch -lt ids -gi 35
ID1server-back ::= ids {
embl {
accession "CAA35615",
version 1
},
general {
db "NCBI_EXT_ACC",
tag str "FPAA037960"
},
gi 35
}
id1_fetch -lt state -fasta 'emb|CAA35615' -fmt xml
&lt;?xml version="1.0"?&gt;
&lt;!DOCTYPE ID1server-back PUBLIC "-//NCBI//NCBI ID1Access/EN" "NCBI_ID1Access.dtd"&gt;
&lt;ID1server-back&gt;
&lt;ID1server-back_gistate&gt;40&lt;/ID1server-back_gistate&gt;
&lt;/ID1server-back&gt;
id1_fetch -lt state -flat '5=CAA35615.1' -fmt asnb | od -t u1
0000000 166 128 002 001 040 000 000
0000007
id1_fetch -lt state -flat '5(,CAA35615)' -fmt fasta
gi = 35, states: LIVE
id1_fetch -lt history -flat '12:35' -fmt fasta
GI Loaded DB Retrieval No.
-- ------ -- -------------
35 03/08/1999 EMBL 274319
id1_fetch -lt revisions -gi 35 -fmt fasta
GI Loaded DB Retrieval No.
-- ------ -- -------------
35 03/08/1999 EMBL 274319
35 06/06/1996 OLD02 84966
35 05/27/1995 OLDID 1524022
35 11/29/1994 OLDID 966346
35 08/31/1993 OLDID 426053
35 04/20/1993 OLDID 27
id1_fetch -fmt quality -gi 13508865
&gt;AL590146.2 Phrap Quality (Length: 121086, Min: 31, Max: 99)
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
...
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
99 54 54 56 56 54 54 54 56 56 56 56 65 65 57 60 56 56 59 59
56 56 56 49 99 31 31 49 49 54 63 63 54 51 53 55 51 51 49 58
58 58 58 53 52 49 51 51 51 52 55 51 51 51 49 49 49 63 63 60
65 65 59 54 54 54 54 54 56 60 60 65 65 65 65 70 70 65 65 65
65 65 65 65 60 59 59 66 66 66 67 65 65 63 46 65 99 99 99 99
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
...
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99 99
99 99 99 99 99 99
</code></pre></div></div>
<p><a name="ch_demo.examples4"></a></p>
<h2 id="examples-from-the-programming-manual">Examples from the Programming Manual</h2>
<ul>
<li>
<p><a href="#ch_demo.examples_1_3">applic.cpp</a></p>
</li>
<li>
<p><a href="#ch_demo.prog_man_CARdemo_index.html">An Example of a Web-based CGI Application - Source Files</a></p>
<ul>
<li>
<p><a href="#ch_demo.carcpp">car.cpp</a></p>
</li>
<li>
<p><a href="#ch_demo.carhpp">car.hpp</a></p>
</li>
<li>
<p><a href="#ch_demo.car_cgicpp">car_cgi.cpp</a></p>
</li>
<li>
<p><a href="#ch_demo.Makefilecar_app">Makefile.car_app</a></p>
</li>
<li>
<p><a href="#ch_demo.carhtml">car.html</a></p>
</li>
</ul>
</li>
</ul>
<p><a name="ch_demo.examples_1_3"></a></p>
<h3 id="appliccpp">applic.cpp</h3>
<p><a name="idp64856928"></a></p>
<div class="language-plaintext highlighter-rouge"><div class="highlight"><pre class="highlight"><code>// File name: applic.cpp
// Description: Using the CNcbiApplication class with CNcbiDiag, CArgs
// and CArgDescription classes
#include &lt;corelib/ncbistd.hpp&gt;
#include &lt;corelib/ncbiutil.hpp&gt;
#include &lt;corelib/ncbiargs.hpp&gt;
#include &lt;corelib/ncbiapp.hpp&gt;
#include &lt;corelib/ncbienv.hpp&gt;
USING_NCBI_SCOPE;
class CTestApp : public CNcbiApplication {
public:
virtual int Run();
};
int CTestApp::Run() {
unique_ptr&lt;CArgs&gt; args;
// create a CArgDescriptions object to constrain the input arguments;
// Argument descriptions are added using:
// void AddKey(string&amp; name, string&amp; synopsis, string&amp; comment, EType, TFlags);
// void AddOptionalKey(string&amp; name, string&amp; synopsis, string&amp; comment, EType,
// string&amp; default, TFlags);
// void AddFlag(string&amp; name, string&amp; comment);
{
CArgDescriptions argDesc;
// Required arguments:
argDesc.AddKey("n","integer","integer between 1 and 10",argDesc.eInteger);
argDesc.AddKey("f","float","float between 0.0 and 1.0",argDesc.eDouble);
argDesc.AddKey("i","inputFile","data file in",CArgDescriptions::eInputFile);
// optional arguments:
argDesc.AddOptionalKey("l","logFile","log errors to &lt;logFile&gt;",
argDesc.eOutputFile);
// optional flags
argDesc.AddFlag("it", "input text");
argDesc.AddFlag("ib", "input binary");
try {
args.reset(argDesc.CreateArgs(GetArguments()));
}
catch (exception&amp; e) {
string a;
argDesc.SetUsageContext(GetArguments()[0],
"CArgDescriptions demo program");
cerr &lt;&lt; e.what() &lt;&lt; endl;
cerr &lt;&lt; argDesc.PrintUsage(a);
return (-1);
}
}
int intIn = (*args)["n"].AsInteger();
float floatIn = (*args)["f"].AsDouble();
string inFile = (*args)["i"].AsString();
// process optional args
if ( args-&gt;Exest("l") ) {
SetDiagStream(&amp;(*args)["l"].AsOutputFile());
}
bool textIn = args-&gt;Exist("it");
bool binIn = (*args)["ib"].AsBoolean();
if (! (textIn ^ binIn) ) {
ERR_POST_X(1, Error &lt;&lt; "input type must be specified using -it or -ib");
}
string InputType;
if ( textIn ) {
InputType = "text";
} else if ( binIn ) {
InputType = "binary";
}
ERR_POST_X(2, Info &lt;&lt; "intIn = " &lt;&lt; intIn &lt;&lt; " floatIn = " &lt;&lt; floatIn
&lt;&lt; " inFile = " &lt;&lt; inFile &lt;&lt; " input type = " &lt;&lt; InputType);
return 0;
}
int main(int argc, const char* argv[])
{
CNcbiOfstream diag("moreApp.log");
SetDiagStream(&amp;diag);
// Set the global severity level to Info
SetDiagPostLevel(eDiag_Info);
CTestApp theTestApp;
return theTestApp.AppMain(argc, argv);
}
</code></pre></div></div>
<p><a name="ch_demo.prog_man_CARdemo_index.html"></a></p>
<h3 id="an-example-of-a-web-based-cgi-application---source-files">An Example of a Web-based CGI Application - Source Files</h3>
<p><a name="ch_demo.carcpp"></a></p>
<h4 id="carcpp">car.cpp</h4>
<p><a name="idp64914192"></a></p>
<div class="language-plaintext highlighter-rouge"><div class="highlight"><pre class="highlight"><code>// File name: car.cpp
// Description: Implement the CCarAttr class
#include "car.hpp"
BEGIN_NCBI_SCOPE
/////////////////////////////////////////////////////////////////////////////
// CCarAttr::
set&lt;string&gt; CCarAttr::sm_Features;
set&lt;string&gt; CCarAttr::sm_Colors;
CCarAttr::CCarAttr(void)
{
// make sure there is only one instance of this class
if ( !sm_Features.empty() ) {
_TROUBLE;
return;
}
// initialize static data
sm_Features.insert("Air conditioning");
sm_Features.insert("CD Player");
sm_Features.insert("Four door");
sm_Features.insert("Power windows");
sm_Features.insert("Sunroof");
sm_Colors.insert("Black");
sm_Colors.insert("Navy");
sm_Colors.insert("Silver");
sm_Colors.insert("Tan");
sm_Colors.insert("White");
}
// dummy instance of CCarAttr -- to provide initialization of
// CCarAttr::sm_Features and CCarAttr::sm_Colors
static CCarAttr s_InitCarAttr;
END_NCBI_SCOPE
</code></pre></div></div>
<p><a name="ch_demo.carhpp"></a></p>
<h4 id="carhpp">car.hpp</h4>
<p><a name="idp64929136"></a></p>
<div class="language-plaintext highlighter-rouge"><div class="highlight"><pre class="highlight"><code>// File name: car.hpp
// Description: Define the CCar and CCarAttr classes
#ifndef CAR_HPP
#define CAR_HPP
#include &lt;coreilib/ncbistd.hpp&gt;
#include &lt;set&gt;
BEGIN_NCBI_SCOPE
//////////////////////
// CCar
class CCar
{
public:
CCar(unsigned base_price = 10000) { m_Price = base_price; }
bool HasFeature(const string&amp;amp; feature_name) const
{ return m_Features.find(feature_name) != m_Features.end(); }
void AddFeature(const string&amp; feature_name)
{ m_Features.insert(feature_name); }
void SetColor(const string&amp; color_name) { m_Color = color_name; }
string GetColor(void) const { return m_Color; }
const set&lt;string&gt;&amp; GetFeatures() const { return m_Features; }
unsigned GetPrice(void) const
{ return m_Price + 1000 * m_Features.size(); }
private:
set&lt;string&gt; m_Features;
string m_Color;
unsigned m_Price;
};
//////////////////////
// CCarAttr -- use a dummy all-static class to store available car attributes
class CCarAttr {
public:
CCarAttr(void);
static const set&lt;string&gt;&amp; GetFeatures(void) { return sm_Features; }
static const set&lt;string&gt;&amp; GetColors (void) { return sm_Colors; }
private:
static set&lt;string&gt; sm_Features;
static set&lt;string&gt; sm_Colors;
};
END_NCBI_SCOPE
#endif /* CAR__HPP */
</code></pre></div></div>
<p><a name="ch_demo.car_cgicpp"></a></p>
<h4 id="car_cgicpp">car_cgi.cpp</h4>
<p><a name="idp64948608"></a></p>
<div class="language-plaintext highlighter-rouge"><div class="highlight"><pre class="highlight"><code>// File name: car_cgi.cpp
// Description: Implement the CCarCgi class and function main
#include &lt;cgi/cgiapp.hpp&gt;
#include &lt;cgi/cgictx.hpp&gt;
#include &lt;html/html.hpp&gt;
#include &lt;html/page.hpp&gt;
#include "car.hpp"
USING_NCBI_SCOPE;
/////////////////////////////////////////////////////////////////////////////
// CCarCgi:: declaration
class CCarCgi : public CCgiApplication
{
public:
virtual int ProcessRequest(CCgiContext&amp; ctx);
private:
CCar* CreateCarByRequest(const CCgiContext&amp; ctx);
void PopulatePage(CHTMLPage&amp; page, const CCar&amp; car);
static CNCBINode* ComposeSummary(const CCar&amp; car);
static CNCBINode* ComposeForm (const CCar&amp; car);
static CNCBINode* ComposePrice (const CCar&amp; car);
static const char sm_ColorTag[];
static const char sm_FeatureTag[];
};
/////////////////////////////////////////////////////////////////////////////
// CCarCgi:: implementation
const char CCarCgi::sm_ColorTag[] = "color";
const char CCarCgi::sm_FeatureTag[] = "feature";
int CCarCgi::ProcessRequest(CCgiContext&amp; ctx)
{
// Create new "car" object with the attributes retrieved
// from the CGI request parameters
unique_ptr&lt;CCar&gt; car;
try {
car.reset( CreateCarByRequest(ctx) );
} catch (exception&amp; e) {
ERR_POST_X(1, "Failed to create car: " &lt;&lt; e.what());
return 1;
}
// Create an HTML page (using the template file "car.html")
CRef&lt;CHTMLPage&gt; page;
try {
page = new CHTMLPage("Car", "car.html");
} catch (exception&amp; e) {
ERR_POST_X(2, "Failed to create the Car HTML page: " &lt;&lt; e.what());
return 2;
}
// Register all substitutions for the template parameters &lt;@XXX@&gt;
// (fill them out using the "car" attributes)
try {
PopulatePage(*page, *car);
} catch (exception&amp; e) {
ERR_POST_X(3, "Failed to populate the Car HTML page: " &lt;&lt; e.what());
return 3;
}
// Compose and flush the resultant HTML page
try {
const CCgiResponse&amp; response = ctx.GetResponse();
response.WriteHeader();
page-&gt;Print(response.out(), CNCBINode::eHTML);
response.Flush();
} catch (exception&amp; e) {
ERR_POST_X(4, "Failed to compose and send the Car HTML page: " &lt;&lt; e.what());
return 4;
}
return 0;
}
CCar* CCarCgi::CreateCarByRequest(const CCgiContext&amp; ctx)
{
unique_ptr&lt;CCar&gt; car(new CCar);
// Get the list of CGI request name/value pairs
const TCgiEntries&amp; entries = ctx.GetRequest().GetEntries();
TCgiEntriesCI it;
// load the car with selected features
pair&lt;TCgiEntriesCI,TCgiEntriesCI&gt; feature_range =
entries.equal_range(sm_FeatureTag);
for (it = feature_range.first; it != feature_range.second; ++it) {
car-&gt;AddFeature(it-&gt;second);
}
// color
if ((it = entries.find(sm_ColorTag)) != entries.end()) {
car-&gt;SetColor(it-&gt;second);
} else {
car-&gt;SetColor(*CCarAttr::GetColors().begin());
}
return car.release();
}
/************ Create a form with the following structure:
&lt;form&gt;
&lt;table&gt;
&lt;tr&gt;
&lt;td&gt; (Features) &lt;/td&gt;
&lt;td&gt; (Colors) &lt;/td&gt;
&lt;td&gt; (Submit) &lt;/td&gt;
&lt;/tr&gt;
&lt;/table&gt;
&lt;/form&gt;
********************/
CNCBINode* CCarCgi::ComposeForm(const CCar&amp; car)
{
CRef&lt;CHTML_table&gt; Table = new CHTML_table();
Table-&gt;SetCellSpacing(0)-&gt;SetCellPadding(4)
-&gt;SetBgColor("#CCCCCC")-&gt;SetAttribute("border", "0");
CRef&lt;CHTMLNode&gt; Row = new CHTML_tr();
// features (check boxes)
CRef&lt;CHTMLNode&gt; Features = new CHTML_td();
Features-&gt;SetVAlign("top")-&gt;SetWidth("200");
Features-&gt;AppendChild(new CHTMLText("Options: &lt;br&gt;"));
ITERATE(set&lt;string&gt;, it, CCarAttr::GetFeatures()) {
Features-&gt;AppendChild
(new CHTML_checkbox
(sm_FeatureTag, *it, car.HasFeature(*it), *it));
Features-&gt;AppendChild(new CHTML_br());
}
// colors (radio buttons)
CRef&lt;CHTMLNode&gt; Colors = new CHTML_td();
Colors-&gt;SetVAlign("top")-&gt;SetWidth("128");
Colors-&gt;AppendChild(new CHTMLText("Color: &lt;br&gt;"));
ITERATE(set&lt;string&gt;, it, CCarAttr::GetColors()) {
Colors-&gt;AppendChild
(new CHTML_radio
(sm_ColorTag, *it, !NStr::Compare(*it, car.GetColor()), *it));
Colors-&gt;AppendChild(new CHTML_br());
}
Row-&gt;AppendChild(&amp;*Features);
Row-&gt;AppendChild(&amp;*Colors);
Row-&gt;AppendChild
((new CHTML_td())-&gt;AppendChild
(new CHTML_submit("submit", "submit")));
Table-&gt;AppendChild(&amp;*Row);
// done
return (new CHTML_form("car.cgi", CHTML_form::eGet))-&gt;AppendChild(&amp;*Table);
}
CNCBINode* CCarCgi::ComposeSummary(const CCar&amp; car)
{
string summary = "You have ordered a " + car.GetColor() + " model";
if ( car.GetFeatures().empty() ) {
summary += " with no additional features.&lt;br&gt;";
return new CHTMLText(summary);
}
summary += " with the following features:&lt;br&gt;";
CRef&lt;CHTML_ol&gt; ol = new CHTML_ol();
ITERATE(set&lt;string&gt;, it, car.GetFeatures()) {
ol-&gt;AppendItem(*it);
}
return (new CHTMLText(summary))-&gt;AppendChild((CNodeRef&amp;)ol);
}
CNCBINode* CCarCgi::ComposePrice(const CCar&amp; car)
{
return
new CHTMLText("Total price: $" + NStr::UIntToString(car.GetPrice()));
}
void CCarCgi::PopulatePage(CHTMLPage&amp; page, const CCar&amp; car)
{
page.AddTagMap("FORM", ComposeForm (car));
page.AddTagMap("SUMMARY", ComposeSummary (car));
page.AddTagMap("PRICE", ComposePrice (car));
}
/////////////////////////////////////////////////////////////////////////////
// MAIN
int main(int argc, char* argv[])
{
SetDiagStream(&amp;NcbiCerr);
return CCarCgi().AppMain(argc, argv);
}
</code></pre></div></div>
<p><a name="ch_demo.Makefilecar_app"></a></p>
<h4 id="makefilecar_app">Makefile.car_app</h4>
<p><a name="idp65017840"></a></p>
<div class="language-plaintext highlighter-rouge"><div class="highlight"><pre class="highlight"><code># Makefile: /home/zimmerma/car/Makefile.car_app
# This file was originally generated by shell script "new_project"
### PATH TO A PRE-BUILT C++ TOOLKIT ###
builddir = /netopt/ncbi_tools/c++/GCC-Debug/build
# builddir = $(NCBI)/c++/Release/build
### DEFAULT COMPILATION FLAGS -- DON'T EDIT OR MOVE THESE 4 LINES !!! ###
include $(builddir)/Makefile.mk
srcdir = .
BINCOPY = @:
LOCAL_CPPFLAGS = -I.
#############################################################################
### EDIT SETTINGS FOR THE DEFAULT (APPLICATION) TARGET HERE ###
APP = car.cgi
SRC = car car_cgi
# PRE_LIBS = $(NCBI_C_LIBPATH) .....
LIB = xhtml xcgi xncbi
# LIB = xser xhtml xcgi xncbi xconnect
# LIBS = $(NCBI_C_LIBPATH) -lncbi $(NETWORK_LIBS) $(ORIG_LIBS)
# CPPFLAGS = $(ORIG_CPPFLAGS) $(NCBI_C_INCLUDE)
# CFLAGS = $(ORIG_CFLAGS)
# CXXFLAGS = $(ORIG_CXXFLAGS)
# LDFLAGS = $(ORIG_LDFLAGS)
# ###
#############################################################################
### APPLICATION BUILD RULES -- DON'T EDIT OR MOVE THIS LINE !!! ###
include $(builddir)/Makefile.app
### PUT YOUR OWN ADDITIONAL TARGETS (MAKE COMMANDS/RULES) BELOW HERE ###
</code></pre></div></div>
<p><a name="ch_demo.carhtml"></a></p>
<h4 id="carhtml">car.html</h4>
<div class="language-plaintext highlighter-rouge"><div class="highlight"><pre class="highlight"><code>&lt;html&gt;
&lt;head&gt;
&lt;title&gt;Automobile Order Form&lt;/title&gt;
&lt;/head&gt;
&lt;body&gt;
&lt;h1&gt;Place your order here&lt;/h1&gt;
&lt;@FORM@&gt;
&lt;@SUMMARY@&gt;
&lt;@PRICE@&gt;
&lt;/body&gt;
&lt;/html&gt;
</code></pre></div></div>
<!-- button 'back to top' start -->
<button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
<!-- button 'back to top' end -->
</div>
<!-- main content end -->
<!-- footer start -->
<div id="footer"> <!-- move tables to scrollable div -->
<!-- script language="javascript">
var x = document.getElementsByClassName("table-scroll");
var i;
for (i = 0; i < x.length; i++) {
x[i].previousElementSibling.id = "make_it_scrollable";
x[i].appendChild(x[i].previousElementSibling);
}
</script -->
<div data-section="footer">
<div xmlns="http://www.w3.org/1999/xhtml" class="footer" id="footer" xml:base="http://127.0.0.1/sites/static/header_footer/">
<section class="icon-section">
<div id="icon-section-header" class="icon-section_header">Follow NCBI</div>
<div class="grid-container container">
<div class="icon-section_container">
<a class="footer-icon" id="footer_twitter" href="https://twitter.com/ncbi" aria-label="Twitter"><svg xmlns="http://www.w3.org/2000/svg" data-name="Layer 1" viewBox="0 0 300 300">
<defs>
<style>
.cls-11 {
fill: #737373;
}
</style>
</defs>
<title>Twitter</title>
<path class="cls-11" d="M250.11,105.48c-7,3.14-13,3.25-19.27.14,8.12-4.86,8.49-8.27,11.43-17.46a78.8,78.8,0,0,1-25,9.55,39.35,39.35,0,0,0-67,35.85,111.6,111.6,0,0,1-81-41.08A39.37,39.37,0,0,0,81.47,145a39.08,39.08,0,0,1-17.8-4.92c0,.17,0,.33,0,.5a39.32,39.32,0,0,0,31.53,38.54,39.26,39.26,0,0,1-17.75.68,39.37,39.37,0,0,0,36.72,27.3A79.07,79.07,0,0,1,56,223.34,111.31,111.31,0,0,0,116.22,241c72.3,0,111.83-59.9,111.83-111.84,0-1.71,0-3.4-.1-5.09C235.62,118.54,244.84,113.37,250.11,105.48Z">
</path>
</svg></a>
<a class="footer-icon" id="footer_facebook" href="https://www.facebook.com/ncbi.nlm" aria-label="Facebook"><svg xmlns="http://www.w3.org/2000/svg" data-name="Layer 1" viewBox="0 0 300 300">
<title>Facebook</title>
<path class="cls-11" d="M210.5,115.12H171.74V97.82c0-8.14,5.39-10,9.19-10h27.14V52l-39.32-.12c-35.66,0-42.42,26.68-42.42,43.77v19.48H99.09v36.32h27.24v109h45.41v-109h35Z">
</path>
</svg></a>
<a class="footer-icon" id="footer_linkedin" href="https://www.linkedin.com/company/ncbinlm" aria-label="LinkedIn"><svg xmlns="http://www.w3.org/2000/svg" data-name="Layer 1" viewBox="0 0 300 300">
<title>LinkedIn</title>
<path class="cls-11" d="M101.64,243.37H57.79v-114h43.85Zm-22-131.54h-.26c-13.25,0-21.82-10.36-21.82-21.76,0-11.65,8.84-21.15,22.33-21.15S101.7,78.72,102,90.38C102,101.77,93.4,111.83,79.63,111.83Zm100.93,52.61A17.54,17.54,0,0,0,163,182v61.39H119.18s.51-105.23,0-114H163v13a54.33,54.33,0,0,1,34.54-12.66c26,0,44.39,18.8,44.39,55.29v58.35H198.1V182A17.54,17.54,0,0,0,180.56,164.44Z">
</path>
</svg></a>
<a class="footer-icon" id="footer_github" href="https://github.com/ncbi" aria-label="GitHub"><svg xmlns="http://www.w3.org/2000/svg" data-name="Layer 1" viewBox="0 0 300 300">
<defs>
<style>
.cls-11,
.cls-12 {
fill: #737373;
}
.cls-11 {
fill-rule: evenodd;
}
</style>
</defs>
<title>GitHub</title>
<path class="cls-11" d="M151.36,47.28a105.76,105.76,0,0,0-33.43,206.1c5.28,1,7.22-2.3,7.22-5.09,0-2.52-.09-10.85-.14-19.69-29.42,6.4-35.63-12.48-35.63-12.48-4.81-12.22-11.74-15.47-11.74-15.47-9.59-6.56.73-6.43.73-6.43,10.61.75,16.21,10.9,16.21,10.9,9.43,16.17,24.73,11.49,30.77,8.79,1-6.83,3.69-11.5,6.71-14.14C108.57,197.1,83.88,188,83.88,147.51a40.92,40.92,0,0,1,10.9-28.39c-1.1-2.66-4.72-13.42,1-28,0,0,8.88-2.84,29.09,10.84a100.26,100.26,0,0,1,53,0C198,88.3,206.9,91.14,206.9,91.14c5.76,14.56,2.14,25.32,1,28a40.87,40.87,0,0,1,10.89,28.39c0,40.62-24.74,49.56-48.29,52.18,3.79,3.28,7.17,9.71,7.17,19.58,0,14.15-.12,25.54-.12,29,0,2.82,1.9,6.11,7.26,5.07A105.76,105.76,0,0,0,151.36,47.28Z">
</path>
<path class="cls-12" d="M85.66,199.12c-.23.52-1.06.68-1.81.32s-1.2-1.06-.95-1.59,1.06-.69,1.82-.33,1.21,1.07.94,1.6Zm-1.3-1">
</path>
<path class="cls-12" d="M90,203.89c-.51.47-1.49.25-2.16-.49a1.61,1.61,0,0,1-.31-2.19c.52-.47,1.47-.25,2.17.49s.82,1.72.3,2.19Zm-1-1.08">
</path>
<path class="cls-12" d="M94.12,210c-.65.46-1.71,0-2.37-.91s-.64-2.07,0-2.52,1.7,0,2.36.89.65,2.08,0,2.54Zm0,0"></path>
<path class="cls-12" d="M99.83,215.87c-.58.64-1.82.47-2.72-.41s-1.18-2.06-.6-2.7,1.83-.46,2.74.41,1.2,2.07.58,2.7Zm0,0">
</path>
<path class="cls-12" d="M107.71,219.29c-.26.82-1.45,1.2-2.64.85s-2-1.34-1.74-2.17,1.44-1.23,2.65-.85,2,1.32,1.73,2.17Zm0,0">
</path>
<path class="cls-12" d="M116.36,219.92c0,.87-1,1.59-2.24,1.61s-2.29-.68-2.3-1.54,1-1.59,2.26-1.61,2.28.67,2.28,1.54Zm0,0">
</path>
<path class="cls-12" d="M124.42,218.55c.15.85-.73,1.72-2,1.95s-2.37-.3-2.52-1.14.73-1.75,2-2,2.37.29,2.53,1.16Zm0,0"></path>
</svg></a>
<a class="footer-icon" id="footer_blog" href="https://ncbiinsights.ncbi.nlm.nih.gov/" aria-label="Blog">
<svg xmlns="http://www.w3.org/2000/svg" id="Layer_1" data-name="Layer 1" viewBox="0 0 40 40">
<defs><style>.cls-1{fill:#737373;}</style></defs>
<title>NCBI Insights Blog</title>
<path class="cls-1" d="M14,30a4,4,0,1,1-4-4,4,4,0,0,1,4,4Zm11,3A19,19,0,0,0,7.05,15a1,1,0,0,0-1,1v3a1,1,0,0,0,.93,1A14,14,0,0,1,20,33.07,1,1,0,0,0,21,34h3a1,1,0,0,0,1-1Zm9,0A28,28,0,0,0,7,6,1,1,0,0,0,6,7v3a1,1,0,0,0,1,1A23,23,0,0,1,29,33a1,1,0,0,0,1,1h3A1,1,0,0,0,34,33Z"></path>
</svg>
</a>
</div>
</div>
</section>
<section class="container-fluid bg-primary">
<div class="container pt-5">
<div class="row mt-3">
<div class="col-lg-3 col-12">
<p><a class="text-white" href="https://www.nlm.nih.gov/socialmedia/index.html">Connect with NLM</a></p>
<ul class="list-inline social_media">
<li class="list-inline-item"><a href="https://twitter.com/NLM_NIH" aria-label="Twitter" target="_blank" rel="noopener noreferrer"><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" x="0px" y="0px" viewBox="0 0 249 249" style="enable-background:new 0 0 249 249;" xml:space="preserve">
<style type="text/css">
.st20 {
fill: #FFFFFF;
}
.st30 {
fill: none;
stroke: #FFFFFF;
stroke-width: 8;
stroke-miterlimit: 10;
}
</style>
<title>Twitter</title>
<g>
<g>
<g>
<path class="st20" d="M192.9,88.1c-5,2.2-9.2,2.3-13.6,0.1c5.7-3.4,6-5.8,8.1-12.3c-5.4,3.2-11.4,5.5-17.6,6.7 c-10.5-11.2-28.1-11.7-39.2-1.2c-7.2,6.8-10.2,16.9-8,26.5c-22.3-1.1-43.1-11.7-57.2-29C58,91.6,61.8,107.9,74,116 c-4.4-0.1-8.7-1.3-12.6-3.4c0,0.1,0,0.2,0,0.4c0,13.2,9.3,24.6,22.3,27.2c-4.1,1.1-8.4,1.3-12.5,0.5c3.6,11.3,14,19,25.9,19.3 c-11.6,9.1-26.4,13.2-41.1,11.5c12.7,8.1,27.4,12.5,42.5,12.5c51,0,78.9-42.2,78.9-78.9c0-1.2,0-2.4-0.1-3.6 C182.7,97.4,189.2,93.7,192.9,88.1z"></path>
</g>
</g>
<circle class="st30" cx="124.4" cy="128.8" r="108.2"></circle>
</g>
</svg></a></li>
<li class="list-inline-item"><a href="https://www.facebook.com/nationallibraryofmedicine" aria-label="Facebook" rel="noopener noreferrer" target="_blank">
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" x="0px" y="0px" viewBox="0 0 249 249" style="enable-background:new 0 0 249 249;" xml:space="preserve">
<style type="text/css">
.st10 {
fill: #FFFFFF;
}
.st110 {
fill: none;
stroke: #FFFFFF;
stroke-width: 8;
stroke-miterlimit: 10;
}
</style>
<title>Facebook</title>
<g>
<g>
<path class="st10" d="M159,99.1h-24V88.4c0-5,3.3-6.2,5.7-6.2h16.8V60l-24.4-0.1c-22.1,0-26.2,16.5-26.2,27.1v12.1H90v22.5h16.9 v67.5H135v-67.5h21.7L159,99.1z"></path>
</g>
</g>
<circle class="st110" cx="123.6" cy="123.2" r="108.2"></circle>
</svg>
</a></li>
<li class="list-inline-item"><a href="https://www.youtube.com/user/NLMNIH" aria-label="Youtube" target="_blank" rel="noopener noreferrer"><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" x="0px" y="0px" viewBox="0 0 249 249" style="enable-background:new 0 0 249 249;" xml:space="preserve">
<title>Youtube</title>
<style type="text/css">
.st4 {
fill: none;
stroke: #FFFFFF;
stroke-width: 8;
stroke-miterlimit: 10;
}
.st5 {
fill: #FFFFFF;
}
</style>
<circle class="st4" cx="124.2" cy="123.4" r="108.2"></circle>
<g transform="translate(0,-952.36218)">
<path class="st5" d="M88.4,1037.4c-10.4,0-18.7,8.3-18.7,18.7v40.1c0,10.4,8.3,18.7,18.7,18.7h72.1c10.4,0,18.7-8.3,18.7-18.7 v-40.1c0-10.4-8.3-18.7-18.7-18.7H88.4z M115.2,1058.8l29.4,17.4l-29.4,17.4V1058.8z"></path>
</g>
</svg></a></li>
</ul>
</div>
<div class="col-lg-3 col-12">
<p class="address_footer text-white">National Library of Medicine<br>
<a href="https://www.google.com/maps/place/8600+Rockville+Pike,+Bethesda,+MD+20894/@38.9959508,-77.101021,17z/data=!3m1!4b1!4m5!3m4!1s0x89b7c95e25765ddb:0x19156f88b27635b8!8m2!3d38.9959508!4d-77.0988323" class="text-white" target="_blank" rel="noopener noreferrer">8600 Rockville Pike<br>
Bethesda, MD 20894</a></p>
</div>
<div class="col-lg-3 col-12 centered-lg">
<p><a href="https://www.nlm.nih.gov/web_policies.html" class="text-white">Web Policies</a><br>
<a href="https://www.nih.gov/institutes-nih/nih-office-director/office-communications-public-liaison/freedom-information-act-office" class="text-white">FOIA</a><br>
<a href="https://www.hhs.gov/vulnerability-disclosure-policy/index.html" class="text-white" id="vdp">HHS Vulnerability Disclosure</a></p>
</div>
<div class="col-lg-3 col-12 centered-lg">
<p><a class="supportLink text-white" href="https://support.nlm.nih.gov/?pagename=guide%3ANONE%3AHomePage%3ANONE" data-pinger-pagename-param="true">Help</a><br>
<a href="https://www.nlm.nih.gov/accessibility.html" class="text-white">Accessibility</a><br>
<a href="https://www.nlm.nih.gov/careers/careers.html" class="text-white">Careers</a></p>
</div>
</div>
<div class="row">
<div class="col-lg-12 centered-lg">
<nav class="bottom-links">
<ul class="mt-3">
<li>
<a class="text-white" href="//www.nlm.nih.gov/">NLM</a>
</li>
<li>
<a class="text-white" href="https://www.nih.gov/">NIH</a>
</li>
<li>
<a class="text-white" href="https://www.hhs.gov/">HHS</a>
</li>
<li>
<a class="text-white" href="https://www.usa.gov/">USA.gov</a>
</li>
</ul>
</nav>
</div>
</div>
</div>
</section>
</div>
</div>
</div>
<!-- footer end -->
</div>
</div>
</div>
</div>
<div class="clearfix"></div>
</div>
<script type="text/javascript" src="/cxx-toolkit/default_files/4025445.js"></script>
<!-- Script for 'Top' button -->
<script type="text/javascript">
mybutton = document.getElementById("myBtn");
// When the user scrolls down 20px from the top of the document, show the button
window.onscroll = function() {
scrollFunction()
};
function scrollFunction() {
if(document.body.scrollTop > 20 || document.documentElement.scrollTop > 20) {
mybutton.style.display = "block";
} else {
mybutton.style.display = "none";
}
}
// When the user clicks on the button, scroll to the top of the document
function topFunction() {
document.body.scrollTop = 0; // For Safari
document.documentElement.scrollTop = 0; // For Chrome, Firefox, IE and Opera
}
</script>
<!-- STICKY HEADER start -->
<script>
!function(a){function b(a,b,c){if(8==g){var d=j.width(),e=f.debounce(function(){var a=j.width();d!=a&&(d=a,c())},a);j.on(b,e)}else j.on(b,f.debounce(c,a))}function c(a){window.console&&window.console&&window.console.log&&window.console.log(a)}function d(){var b=a('<div style="width:50px;height:50px;overflow-y:scroll;position:absolute;top:-200px;left:-200px;"><div style="height:100px;width:100%"></div>');a("body").append(b);var c=b.innerWidth(),d=a("div",b).innerWidth();return b.remove(),c-d}function e(a){if(a.dataTableSettings)for(var b=0;b<a.dataTableSettings.length;b++){var c=a.dataTableSettings[b].nTable;if(a[0]==c)return!0}return!1}a.floatThead=a.floatThead||{},a.floatThead.defaults={cellTag:null,headerCellSelector:"tr:first>th:visible",zIndex:1001,debounceResizeMs:10,useAbsolutePositioning:!0,scrollingTop:0,scrollingBottom:0,scrollContainer:function(){return a([])},getSizingRow:function(a){return a.find("tbody tr:visible:first>*")},floatTableClass:"floatThead-table",floatWrapperClass:"floatThead-wrapper",floatContainerClass:"floatThead-container",copyTableClass:!0,debug:!1};var f=window._,g=function(){for(var a=3,b=document.createElement("b"),c=b.all||[];a=1+a,b.innerHTML="<!--[if gt IE "+a+"]><i><![endif]-->",c[0];);return a>4?a:document.documentMode}(),h=null,i=function(){if(g)return!1;var b=a("<table><colgroup><col></colgroup><tbody><tr><td style='width:10px'></td></tbody></table>");a("body").append(b);var c=b.find("col").width();return b.remove(),0==c},j=a(window),k=0;a.fn.floatThead=function(l){if(l=l||{},!f&&(f=window._||a.floatThead._,!f))throw new Error("jquery.floatThead-slim.js requires underscore. You should use the non-lite version since you do not have underscore.");if(8>g)return this;if(null==h&&(h=i(),h&&(document.createElement("fthtr"),document.createElement("fthtd"),document.createElement("fthfoot"))),f.isString(l)){var m=l,n=this;return this.filter("table").each(function(){var b=a(this).data("floatThead-attached");if(b&&f.isFunction(b[m])){var c=b[m]();"undefined"!=typeof c&&(n=c)}}),n}var o=a.extend({},a.floatThead.defaults||{},l);return a.each(l,function(b){b in a.floatThead.defaults||!o.debug||c("jQuery.floatThead: used ["+b+"] key to init plugin, but that param is not an option for the plugin. Valid options are: "+f.keys(a.floatThead.defaults).join(", "))}),this.filter(":not(."+o.floatTableClass+")").each(function(){function c(a){return a+".fth-"+y+".floatTHead"}function i(){var b=0;A.find("tr:visible").each(function(){b+=a(this).outerHeight(!0)}),Z.outerHeight(b),$.outerHeight(b)}function l(){var a=z.outerWidth(),b=I.width()||a;if(X.width(b-F.vertical),O){var c=100*a/(b-F.vertical);S.css("width",c+"%")}else S.outerWidth(a)}function m(){C=(f.isFunction(o.scrollingTop)?o.scrollingTop(z):o.scrollingTop)||0,D=(f.isFunction(o.scrollingBottom)?o.scrollingBottom(z):o.scrollingBottom)||0}function n(){var b,c;if(V)b=U.find("col").length;else{var d;d=null==o.cellTag&&o.headerCellSelector?o.headerCellSelector:"tr:first>"+o.cellTag,c=A.find(d),b=0,c.each(function(){b+=parseInt(a(this).attr("colspan")||1,10)})}if(b!=H){H=b;for(var e=[],f=[],g=[],i=0;b>i;i++)e.push('<th class="floatThead-col"/>'),f.push("<col/>"),g.push("<fthtd style='display:table-cell;height:0;width:auto;'/>");f=f.join(""),e=e.join(""),h&&(g=g.join(""),W.html(g),bb=W.find("fthtd")),Z.html(e),$=Z.find("th"),V||U.html(f),_=U.find("col"),T.html(f),ab=T.find("col")}return b}function p(){if(!E){if(E=!0,J){var a=z.width(),b=Q.width();a>b&&z.css("minWidth",a)}z.css(db),S.css(db),S.append(A),B.before(Y),i()}}function q(){E&&(E=!1,J&&z.width(fb),Y.detach(),z.prepend(A),z.css(eb),S.css(eb))}function r(a){J!=a&&(J=a,X.css({position:J?"absolute":"fixed"}))}function s(a,b,c,d){return h?c:d?o.getSizingRow(a,b,c):b}function t(){var a,b=n();return function(){var c=s(z,_,bb,g);if(c.length==b&&b>0){if(!V)for(a=0;b>a;a++)_.eq(a).css("width","");q();var d=[];for(a=0;b>a;a++)d[a]=c.get(a).offsetWidth;for(a=0;b>a;a++)ab.eq(a).width(d[a]),_.eq(a).width(d[a]);p()}else S.append(A),z.css(eb),S.css(eb),i()}}function u(a){var b=I.css("border-"+a+"-width"),c=0;return b&&~b.indexOf("px")&&(c=parseInt(b,10)),c}function v(){var a,b=I.scrollTop(),c=0,d=L?K.outerHeight(!0):0,e=M?d:-d,f=X.height(),g=z.offset(),i=0;if(O){var k=I.offset();c=g.top-k.top+b,L&&M&&(c+=d),c-=u("top"),i=u("left")}else a=g.top-C-f+D+F.horizontal;var l=j.scrollTop(),m=j.scrollLeft(),n=I.scrollLeft();return b=I.scrollTop(),function(k){if("windowScroll"==k?(l=j.scrollTop(),m=j.scrollLeft()):"containerScroll"==k?(b=I.scrollTop(),n=I.scrollLeft()):"init"!=k&&(l=j.scrollTop(),m=j.scrollLeft(),b=I.scrollTop(),n=I.scrollLeft()),!h||!(0>l||0>m)){if(R)r("windowScrollDone"==k?!0:!1);else if("windowScrollDone"==k)return null;g=z.offset(),L&&M&&(g.top+=d);var o,s,t=z.outerHeight();if(O&&J){if(c>=b){var u=c-b;o=u>0?u:0}else o=P?0:b;s=i}else!O&&J?(l>a+t+e?o=t-f+e:g.top>l+C?(o=0,q()):(o=C+l-g.top+c+(M?d:0),p()),s=0):O&&!J?(c>b||b-c>t?(o=g.top-l,q()):(o=g.top+b-l-c,p()),s=g.left+n-m):O||J||(l>a+t+e?o=t+C-l+a+e:g.top>l+C?(o=g.top-l,p()):o=C,s=g.left-m);return{top:o,left:s}}}}function w(){var a=null,b=null,c=null;return function(d,e,f){null==d||a==d.top&&b==d.left||(X.css({top:d.top,left:d.left}),a=d.top,b=d.left),e&&l(),f&&i();var g=I.scrollLeft();J&&c==g||(X.scrollLeft(g),c=g)}}function x(){if(I.length){var a=I.width(),b=I.height(),c=z.height(),d=z.width(),e=d>a?G:0,f=c>b?G:0;F.horizontal=d>a-f?G:0,F.vertical=c>b-e?G:0}}var y=k,z=a(this);if(z.data("floatThead-attached"))return!0;if(!z.is("table"))throw new Error('jQuery.floatThead must be run on a table element. ex: $("table").floatThead();');var A=z.find("thead:first"),B=z.find("tbody:first");if(0==A.length)throw new Error("jQuery.floatThead must be run on a table that contains a <thead> element");var C,D,E=!1,F={vertical:0,horizontal:0},G=d(),H=0,I=o.scrollContainer(z)||a([]),J=o.useAbsolutePositioning;null==J&&(J=o.scrollContainer(z).length);var K=z.find("caption"),L=1==K.length;if(L)var M="top"===(K.css("caption-side")||K.attr("align")||"top");var N=a('<fthfoot style="display:table-footer-group;"/>'),O=I.length>0,P=!1,Q=a([]),R=9>=g&&!O&&J,S=a("<table/>"),T=a("<colgroup/>"),U=z.find("colgroup:first"),V=!0;0==U.length&&(U=a("<colgroup/>"),V=!1);var W=a('<fthrow style="display:table-row;height:0;"/>'),X=a('<div style="overflow: hidden;"></div>'),Y=a("<thead/>"),Z=a('<tr class="size-row"/>'),$=a([]),_=a([]),ab=a([]),bb=a([]);if(Y.append(Z),z.prepend(U),h&&(N.append(W),z.append(N)),S.append(T),X.append(S),o.copyTableClass&&S.attr("class",z.attr("class")),S.attr({cellpadding:z.attr("cellpadding"),cellspacing:z.attr("cellspacing"),border:z.attr("border")}),S.css({borderCollapse:z.css("borderCollapse"),border:z.css("border")}),S.addClass(o.floatTableClass).css("margin",0),J){var cb=function(a,b){var c=a.css("position"),d="relative"==c||"absolute"==c;if(!d||b){var e={paddingLeft:a.css("paddingLeft"),paddingRight:a.css("paddingRight")};X.css(e),a=a.wrap("<div class='"+o.floatWrapperClass+"' style='position: relative; clear:both;'></div>").parent(),P=!0}return a};O?(Q=cb(I,!0),Q.append(X)):(Q=cb(z),z.after(X))}else z.after(X);X.css({position:J?"absolute":"fixed",marginTop:0,top:J?0:"auto",zIndex:o.zIndex}),X.addClass(o.floatContainerClass),m();var db={"table-layout":"fixed"},eb={"table-layout":z.css("tableLayout")||"auto"},fb=z[0].style.width||"";x();var gb,hb=function(){(gb=t())()};hb();var ib=v(),jb=w();jb(ib("init"),!0);var kb=f.debounce(function(){jb(ib("windowScrollDone"),!1)},300),lb=function(){jb(ib("windowScroll"),!1),kb()},mb=function(){jb(ib("containerScroll"),!1)},nb=function(){m(),x(),hb(),ib=v(),(jb=w())(ib("resize"),!0,!0)},ob=f.debounce(function(){x(),m(),hb(),ib=v(),jb(ib("reflow"),!0)},1);O?J?I.on(c("scroll"),mb):(I.on(c("scroll"),mb),j.on(c("scroll"),lb)):j.on(c("scroll"),lb),j.on(c("load"),ob),b(o.debounceResizeMs,c("resize"),nb),z.on("reflow",ob),e(z)&&z.on("filter",ob).on("sort",ob).on("page",ob),z.data("floatThead-attached",{destroy:function(){var a=".fth-"+y;q(),z.css(eb),U.remove(),h&&N.remove(),Y.parent().length&&Y.replaceWith(A),z.off("reflow"),I.off(a),P&&(I.length?I.unwrap():z.unwrap()),J&&z.css("minWidth",""),X.remove(),z.data("floatThead-attached",!1),j.off(a)},reflow:function(){ob()},setHeaderHeight:function(){i()},getFloatContainer:function(){return X},getRowGroups:function(){return E?X.find("thead").add(z.find("tbody,tfoot")):z.find("thead,tbody,tfoot")}}),k++}),this}}(jQuery),function(a){a.floatThead=a.floatThead||{},a.floatThead._=window._||function(){var b={},c=Object.prototype.hasOwnProperty,d=["Arguments","Function","String","Number","Date","RegExp"];return b.has=function(a,b){return c.call(a,b)},b.keys=function(a){if(a!==Object(a))throw new TypeError("Invalid object");var c=[];for(var d in a)b.has(a,d)&&c.push(d);return c},a.each(d,function(){var a=this;b["is"+a]=function(b){return Object.prototype.toString.call(b)=="[object "+a+"]"}}),b.debounce=function(a,b,c){var d,e,f,g,h;return function(){f=this,e=arguments,g=new Date;var i=function(){var j=new Date-g;b>j?d=setTimeout(i,b-j):(d=null,c||(h=a.apply(f,e)))},j=c&&!d;return d||(d=setTimeout(i,b)),j&&(h=a.apply(f,e)),h}},b}()}(jQuery);
$(document).ready(function(){
$("div.section > table").floatThead({scrollingTop:110});
});
</script>
<!-- STICKY HEADER end -->
</body>
</html>