Files
2023-11-20 11:57:03 -08:00

364 lines
27 KiB
HTML
Raw Permalink Blame History

This file contains ambiguous Unicode characters

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.

<!DOCTYPE html>
<html lang="en" data-content_root="../">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Basic query for C and C++ code &#8212; CodeQL</title>
<link rel="stylesheet" type="text/css" href="../_static/pygments.css?v=fa44fd50" />
<link rel="stylesheet" type="text/css" href="../_static/alabaster.css?v=93459777" />
<script src="../_static/documentation_options.js?v=5929fcd5"></script>
<script src="../_static/doctools.js?v=888ff710"></script>
<script src="../_static/sphinx_highlight.js?v=dc90522c"></script>
<link rel="icon" href="../_static/favicon.ico"/>
<link rel="index" title="Index" href="../genindex.html" />
<link rel="search" title="Search" href="../search.html" />
<link rel="next" title="CodeQL library for C and C++" href="codeql-library-for-cpp.html" />
<link rel="prev" title="CodeQL for C and C++" href="codeql-for-cpp.html" />
<title>CodeQL docs</title>
<meta name="viewport" content="width=device-width, initial-scale=1" />
<link rel="stylesheet" href="../_static/custom.css" type="text/css" />
<link rel="stylesheet" href="../_static/primer.css" type="text/css" />
</head><body>
<header class="Header">
<div class="Header-item--full">
<a href="https://codeql.github.com/docs" class="Header-link f2 d-flex flex-items-center">
<!-- <%= octicon "mark-github", class: "mr-2", height: 32 %> -->
<svg height="32" class="octicon octicon-mark-github mr-2" viewBox="0 0 16 16" version="1.1" width="32"
aria-hidden="true">
<path fill-rule="evenodd"
d="M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0 0 16 8c0-4.42-3.58-8-8-8z">
</path>
</svg>
<span class="hide-sm">CodeQL documentation</span>
</a>
</div>
<div class="Header-item hide-sm hide-md">
<script src="https://addsearch.com/js/?key=93b4d287e2fc079a4089412b669785d5&categories=!0xhelp.semmle.com,0xcodeql.github.com,1xdocs,1xcodeql-standard-libraries,1xcodeql-query-help"></script>
</div>
<div class="Header-item">
<details class="dropdown details-reset details-overlay d-inline-block">
<summary class="btn bg-gray-dark text-white border" aria-haspopup="true">
CodeQL resources
<div class="dropdown-caret"></div>
</summary>
<ul class="dropdown-menu dropdown-menu-se dropdown-menu-dark">
<li><a class="dropdown-item" href="https://codeql.github.com/docs/codeql-overview">CodeQL overview</a></li>
<li class="dropdown-divider" role="separator"></li>
<div class="dropdown-header">
CodeQL tools
</div>
<li><a class="dropdown-item" href="https://codeql.github.com/docs/codeql-for-visual-studio-code">CodeQL for VS Code</a>
<li><a class="dropdown-item" href="https://codeql.github.com/docs/codeql-cli">CodeQL CLI</a>
</li>
<li class="dropdown-divider" role="separator"></li>
<div class="dropdown-header">
CodeQL guides
</div>
<li><a class="dropdown-item" href="https://codeql.github.com/docs/writing-codeql-queries">Writing CodeQL queries</a></li>
<li><a class="dropdown-item" href="https://codeql.github.com/docs/codeql-language-guides">CodeQL language guides</a>
<li class="dropdown-divider" role="separator"></li>
<div class="dropdown-header">
Reference docs
</div>
<li><a class="dropdown-item" href="https://codeql.github.com/docs/ql-language-reference/">QL language
reference</a>
<li><a class="dropdown-item" href="https://codeql.github.com/codeql-standard-libraries">CodeQL
standard-libraries</a>
<li><a class="dropdown-item" href="https://codeql.github.com/codeql-query-help">CodeQL
query help</a>
<li class="dropdown-divider" role="separator"></li>
<div class="dropdown-header">
Source files
</div>
<li><a class="dropdown-item" href="https://github.com/github/codeql">CodeQL repository</a>
</ul>
</details>
</div>
</header>
<main class="bg-gray-light clearfix">
<nav class="SideNav position-sticky top-0 col-lg-3 col-md-3 float-left p-4 hide-sm hide-md overflow-y-auto">
<ul class="current">
<li class="toctree-l1"><a class="reference internal" href="../codeql-overview/index.html">CodeQL overview</a></li>
<li class="toctree-l1"><a class="reference internal" href="../codeql-for-visual-studio-code/index.html">CodeQL for Visual Studio Code</a></li>
<li class="toctree-l1"><a class="reference internal" href="../codeql-cli/index.html">CodeQL CLI</a></li>
<li class="toctree-l1"><a class="reference internal" href="../writing-codeql-queries/index.html">Writing CodeQL queries</a></li>
<li class="toctree-l1 current"><a class="reference internal" href="index.html">CodeQL language guides</a><ul class="current">
<li class="toctree-l2 current"><a class="reference internal" href="codeql-for-cpp.html">CodeQL for C and C++</a><ul class="current">
<li class="toctree-l3 current"><a class="current reference internal" href="#">Basic query for C and C++ code</a></li>
<li class="toctree-l3"><a class="reference internal" href="codeql-library-for-cpp.html">CodeQL library for C and C++</a></li>
<li class="toctree-l3"><a class="reference internal" href="functions-in-cpp.html">Functions in C and C++</a></li>
<li class="toctree-l3"><a class="reference internal" href="expressions-types-and-statements-in-cpp.html">Expressions, types, and statements in C and C++</a></li>
<li class="toctree-l3"><a class="reference internal" href="conversions-and-classes-in-cpp.html">Conversions and classes in C and C++</a></li>
<li class="toctree-l3"><a class="reference internal" href="analyzing-data-flow-in-cpp.html">Analyzing data flow in C and C++</a></li>
<li class="toctree-l3"><a class="reference internal" href="refining-a-query-to-account-for-edge-cases.html">Refining a query to account for edge cases</a></li>
<li class="toctree-l3"><a class="reference internal" href="detecting-a-potential-buffer-overflow.html">Detecting a potential buffer overflow</a></li>
<li class="toctree-l3"><a class="reference internal" href="using-the-guards-library-in-cpp.html">Using the guards library in C and C++</a></li>
<li class="toctree-l3"><a class="reference internal" href="using-range-analsis-in-cpp.html">Using range analysis for C and C++</a></li>
<li class="toctree-l3"><a class="reference internal" href="hash-consing-and-value-numbering.html">Hash consing and value numbering</a></li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="codeql-for-csharp.html">CodeQL for C#</a></li>
<li class="toctree-l2"><a class="reference internal" href="codeql-for-go.html">CodeQL for Go</a></li>
<li class="toctree-l2"><a class="reference internal" href="codeql-for-java.html">CodeQL for Java</a></li>
<li class="toctree-l2"><a class="reference internal" href="codeql-for-javascript.html">CodeQL for JavaScript</a></li>
<li class="toctree-l2"><a class="reference internal" href="codeql-for-python.html">CodeQL for Python</a></li>
<li class="toctree-l2"><a class="reference internal" href="codeql-for-ruby.html">CodeQL for Ruby</a></li>
</ul>
</li>
<li class="toctree-l1"><a class="reference internal" href="../ql-language-reference/index.html">QL language reference</a></li>
</ul>
</nav>
<div class="body col-sm-12 col-md-9 col-lg-9 float-left border-left">
<div class="hide-lg hide-xl px-4 pt-4">
<div class="related" role="navigation" aria-label="related navigation">
<ul>
<li class="nav-item nav-item-0"><a href="../contents.html">CodeQL</a> &#187;</li>
<li class="nav-item nav-item-1"><a href="index.html"
>CodeQL language guides</a> &#187;</li>
<li class="nav-item nav-item-2"><a href="codeql-for-cpp.html"
accesskey="U">CodeQL for C and C++</a> &#187;</li>
</ul>
</div>
</div>
<article class="p-4 col-lg-10 col-md-10 col-sm-12">
<section id="basic-query-for-c-and-c-code">
<span id="basic-query-for-cpp-code"></span><h1>Basic query for C and C++ code<a class="headerlink" href="#basic-query-for-c-and-c-code" title="Link to this heading"></a></h1>
<p>Learn to write and run a simple CodeQL query using LGTM.</p>
<section id="about-the-query">
<h2>About the query<a class="headerlink" href="#about-the-query" title="Link to this heading"></a></h2>
<p>The query were going to run performs a basic search of the code for <code class="docutils literal notranslate"><span class="pre">if</span></code> statements that are redundant, in the sense that they have an empty then branch. For example, code such as:</p>
<div class="highlight-cpp notranslate"><div class="highlight"><pre><span></span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="n">error</span><span class="p">)</span><span class="w"> </span><span class="p">{</span><span class="w"> </span><span class="p">}</span>
</pre></div>
</div>
</section>
<section id="running-the-query">
<h2>Running the query<a class="headerlink" href="#running-the-query" title="Link to this heading"></a></h2>
<ol class="arabic">
<li><p>In the main search box on LGTM.com, search for the project you want to query. For tips, see <a class="reference external" href="https://lgtm.com/help/lgtm/searching">Searching</a>.</p></li>
<li><p>Click the project in the search results.</p></li>
<li><p>Click <strong>Query this project</strong>.</p>
<p>This opens the query console. (For information about using this, see <a class="reference external" href="https://lgtm.com/help/lgtm/using-query-console">Using the query console</a>.)</p>
<blockquote class="pull-quote">
<div><p>Note</p>
<p>Alternatively, you can go straight to the query console by clicking <strong>Query console</strong> (at the top of any page), selecting <strong>C/C++</strong> from the <strong>Language</strong> drop-down list, then choosing one or more projects to query from those displayed in the <strong>Project</strong> drop-down list.</p>
</div></blockquote>
</li>
<li><p>Copy the following query into the text box in the query console:</p>
<div class="highlight-ql notranslate"><div class="highlight"><pre><span></span>import cpp
from IfStmt ifstmt, BlockStmt block
where ifstmt.getThen() = block and
block.getNumStmt() = 0
select ifstmt, &quot;This &#39;if&#39; statement is redundant.&quot;
</pre></div>
</div>
<p>LGTM checks whether your query compiles and, if all is well, the <strong>Run</strong> button changes to green to indicate that you can go ahead and run the query.</p>
</li>
<li><p>Click <strong>Run</strong>.</p>
<p>The name of the project you are querying, and the ID of the most recently analyzed commit to the project, are listed below the query box. To the right of this is an icon that indicates the progress of the query operation:</p>
<img alt="../_images/query-progress.png" class="align-center" src="../_images/query-progress.png" />
<blockquote class="pull-quote">
<div><p>Note</p>
<p>Your query is always run against the most recently analyzed commit to the selected project.</p>
</div></blockquote>
<p>The query will take a few moments to return results. When the query completes, the results are displayed below the project name. The query results are listed in two columns, corresponding to the two expressions in the <code class="docutils literal notranslate"><span class="pre">select</span></code> clause of the query. The first column corresponds to the expression <code class="docutils literal notranslate"><span class="pre">ifstmt</span></code> and is linked to the location in the source code of the project where <code class="docutils literal notranslate"><span class="pre">ifstmt</span></code> occurs. The second column is the alert message.</p>
<p><a class="reference external" href="https://lgtm.com/query/4242591143131494898/">Example query results</a></p>
<blockquote class="pull-quote">
<div><p>Note</p>
<p>An ellipsis (…) at the bottom of the table indicates that the entire list is not displayed—click it to show more results.</p>
</div></blockquote>
</li>
<li><p>If any matching code is found, click a link in the <code class="docutils literal notranslate"><span class="pre">ifstmt</span></code> column to view the <code class="docutils literal notranslate"><span class="pre">if</span></code> statement in the code viewer.</p>
<p>The matching <code class="docutils literal notranslate"><span class="pre">if</span></code> statement is highlighted with a yellow background in the code viewer. If any code in the file also matches a query from the standard query library for that language, you will see a red alert message at the appropriate point within the code.</p>
</li>
</ol>
<section id="about-the-query-structure">
<h3>About the query structure<a class="headerlink" href="#about-the-query-structure" title="Link to this heading"></a></h3>
<p>After the initial <code class="docutils literal notranslate"><span class="pre">import</span></code> statement, this simple query comprises three parts that serve similar purposes to the FROM, WHERE, and SELECT parts of an SQL query.</p>
<table class="docutils align-default">
<thead>
<tr class="row-odd"><th class="head"><p>Query part</p></th>
<th class="head"><p>Purpose</p></th>
<th class="head"><p>Details</p></th>
</tr>
</thead>
<tbody>
<tr class="row-even"><td><p><code class="docutils literal notranslate"><span class="pre">import</span> <span class="pre">cpp</span></code></p></td>
<td><p>Imports the standard CodeQL libraries for C/C++.</p></td>
<td><p>Every query begins with one or more <code class="docutils literal notranslate"><span class="pre">import</span></code> statements.</p></td>
</tr>
<tr class="row-odd"><td><p><code class="docutils literal notranslate"><span class="pre">from</span> <span class="pre">IfStmt</span> <span class="pre">ifstmt,</span> <span class="pre">BlockStmt</span> <span class="pre">block</span></code></p></td>
<td><p>Defines the variables for the query.
Declarations are of the form:
<code class="docutils literal notranslate"><span class="pre">&lt;type&gt;</span> <span class="pre">&lt;variable</span> <span class="pre">name&gt;</span></code></p></td>
<td><p>We use:</p>
<ul class="simple">
<li><p>an <code class="docutils literal notranslate"><span class="pre">IfStmt</span></code> variable for <code class="docutils literal notranslate"><span class="pre">if</span></code> statements</p></li>
<li><p>a <code class="docutils literal notranslate"><span class="pre">BlockStmt</span></code> variable for the statement block</p></li>
</ul>
</td>
</tr>
<tr class="row-even"><td><p><code class="docutils literal notranslate"><span class="pre">where</span> <span class="pre">ifstmt.getThen()</span> <span class="pre">=</span> <span class="pre">block</span> <span class="pre">and</span> <span class="pre">block.getNumStmt()</span> <span class="pre">=</span> <span class="pre">0</span></code></p></td>
<td><p>Defines a condition on the variables.</p></td>
<td><p><code class="docutils literal notranslate"><span class="pre">ifstmt.getThen()</span> <span class="pre">=</span> <span class="pre">block</span></code> relates the two variables. The block must be the <code class="docutils literal notranslate"><span class="pre">then</span></code> branch of the <code class="docutils literal notranslate"><span class="pre">if</span></code> statement.</p>
<p><code class="docutils literal notranslate"><span class="pre">block.getNumStmt()</span> <span class="pre">=</span> <span class="pre">0</span></code> states that the block must be empty (that is, it contains no statements).</p>
</td>
</tr>
<tr class="row-odd"><td><p><code class="docutils literal notranslate"><span class="pre">select</span> <span class="pre">ifstmt,</span> <span class="pre">&quot;This</span> <span class="pre">'if'</span> <span class="pre">statement</span> <span class="pre">is</span> <span class="pre">redundant.&quot;</span></code></p></td>
<td><p>Defines what to report for each match.</p>
<p><code class="docutils literal notranslate"><span class="pre">select</span></code> statements for queries that are used to find instances of poor coding practice are always in the form:
<code class="docutils literal notranslate"><span class="pre">select</span> <span class="pre">&lt;program</span> <span class="pre">element&gt;,</span> <span class="pre">&quot;&lt;alert</span> <span class="pre">message&gt;&quot;</span></code></p>
</td>
<td><p>Reports the resulting <code class="docutils literal notranslate"><span class="pre">if</span></code> statement with a string that explains the problem.</p></td>
</tr>
</tbody>
</table>
</section>
</section>
<section id="extend-the-query">
<h2>Extend the query<a class="headerlink" href="#extend-the-query" title="Link to this heading"></a></h2>
<p>Query writing is an inherently iterative process. You write a simple query and then, when you run it, you discover examples that you had not previously considered, or opportunities for improvement.</p>
<section id="remove-false-positive-results">
<h3>Remove false positive results<a class="headerlink" href="#remove-false-positive-results" title="Link to this heading"></a></h3>
<p>Browsing the results of our basic query shows that it could be improved. Among the results you are likely to find examples of <code class="docutils literal notranslate"><span class="pre">if</span></code> statements with an <code class="docutils literal notranslate"><span class="pre">else</span></code> branch, where an empty <code class="docutils literal notranslate"><span class="pre">then</span></code> branch does serve a purpose. For example:</p>
<div class="highlight-cpp notranslate"><div class="highlight"><pre><span></span><span class="k">if</span><span class="w"> </span><span class="p">(...)</span><span class="w"> </span><span class="p">{</span>
<span class="w"> </span><span class="p">...</span>
<span class="p">}</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="o">!</span><span class="n">strcmp</span><span class="p">(</span><span class="n">option</span><span class="p">,</span><span class="w"> </span><span class="s">&quot;-verbose&quot;</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w"> </span><span class="c1">// nothing to do - handled earlier</span>
<span class="p">}</span><span class="w"> </span><span class="k">else</span><span class="w"> </span><span class="p">{</span>
<span class="w"> </span><span class="n">error</span><span class="p">(</span><span class="s">&quot;unrecognized option&quot;</span><span class="p">);</span>
<span class="p">}</span>
</pre></div>
</div>
<p>In this case, identifying the <code class="docutils literal notranslate"><span class="pre">if</span></code> statement with the empty <code class="docutils literal notranslate"><span class="pre">then</span></code> branch as redundant is a false positive. One solution to this is to modify the query to ignore empty <code class="docutils literal notranslate"><span class="pre">then</span></code> branches if the <code class="docutils literal notranslate"><span class="pre">if</span></code> statement has an <code class="docutils literal notranslate"><span class="pre">else</span></code> branch.</p>
<p>To exclude <code class="docutils literal notranslate"><span class="pre">if</span></code> statements that have an <code class="docutils literal notranslate"><span class="pre">else</span></code> branch:</p>
<ol class="arabic">
<li><p>Extend the <code class="docutils literal notranslate"><span class="pre">where</span></code> clause to include the following extra condition:</p>
<div class="highlight-ql notranslate"><div class="highlight"><pre><span></span>and not ifstmt.hasElse()
</pre></div>
</div>
<p>The <code class="docutils literal notranslate"><span class="pre">where</span></code> clause is now:</p>
<div class="highlight-ql notranslate"><div class="highlight"><pre><span></span>where ifstmt.getThen() = block and
block.getNumStmt() = 0 and
not ifstmt.hasElse()
</pre></div>
</div>
</li>
<li><p>Click <strong>Run</strong>.</p>
<p>There are now fewer results because <code class="docutils literal notranslate"><span class="pre">if</span></code> statements with an <code class="docutils literal notranslate"><span class="pre">else</span></code> branch are no longer reported.</p>
</li>
</ol>
<p><a class="reference external" href="https://lgtm.com/query/1899933116489579248/">See this in the query console</a></p>
</section>
</section>
<section id="further-reading">
<h2>Further reading<a class="headerlink" href="#further-reading" title="Link to this heading"></a></h2>
<ul class="simple">
<li><p><a class="reference external" href="https://github.com/github/codeql/tree/main/cpp/ql/src">CodeQL queries for C and C++</a></p></li>
<li><p><a class="reference external" href="https://github.com/github/codeql/tree/main/cpp/ql/examples">Example queries for C and C++</a></p></li>
<li><p><a class="reference external" href="https://codeql.github.com/codeql-standard-libraries/cpp/">CodeQL library reference for C and C++</a></p></li>
</ul>
<ul class="simple">
<li><p><a class="reference internal" href="../ql-language-reference/index.html#ql-language-reference"><span class="std std-ref">QL language reference</span></a></p></li>
<li><p><a class="reference internal" href="../codeql-overview/codeql-tools.html#codeql-tools"><span class="std std-ref">CodeQL tools</span></a></p></li>
</ul>
</section>
</section>
</article>
<!-- GitHub footer, with links to terms and privacy statement -->
<div class="px-3 px-md-6 f6 py-4 d-sm-flex flex-justify-between flex-row-reverse flex-items-center border-top">
<ul class="list-style-none d-flex flex-items-center mb-3 mb-sm-0 lh-condensed-ultra">
<li class="mr-3">
<a href="https://twitter.com/github" title="GitHub on Twitter" style="color: #959da5;">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 273.5 222.3" class="d-block" height="18">
<path
d="M273.5 26.3a109.77 109.77 0 0 1-32.2 8.8 56.07 56.07 0 0 0 24.7-31 113.39 113.39 0 0 1-35.7 13.6 56.1 56.1 0 0 0-97 38.4 54 54 0 0 0 1.5 12.8A159.68 159.68 0 0 1 19.1 10.3a56.12 56.12 0 0 0 17.4 74.9 56.06 56.06 0 0 1-25.4-7v.7a56.11 56.11 0 0 0 45 55 55.65 55.65 0 0 1-14.8 2 62.39 62.39 0 0 1-10.6-1 56.24 56.24 0 0 0 52.4 39 112.87 112.87 0 0 1-69.7 24 119 119 0 0 1-13.4-.8 158.83 158.83 0 0 0 86 25.2c103.2 0 159.6-85.5 159.6-159.6 0-2.4-.1-4.9-.2-7.3a114.25 114.25 0 0 0 28.1-29.1"
fill="currentColor"></path>
</svg>
</a>
</li>
<li class="mr-3">
<a href="https://www.facebook.com/GitHub" title="GitHub on Facebook" style="color: #959da5;">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 15.3 15.4" class="d-block" height="18">
<path
d="M14.5 0H.8a.88.88 0 0 0-.8.9v13.6a.88.88 0 0 0 .8.9h7.3v-6h-2V7.1h2V5.4a2.87 2.87 0 0 1 2.5-3.1h.5a10.87 10.87 0 0 1 1.8.1v2.1h-1.3c-1 0-1.1.5-1.1 1.1v1.5h2.3l-.3 2.3h-2v5.9h3.9a.88.88 0 0 0 .9-.8V.8a.86.86 0 0 0-.8-.8z"
fill="currentColor"></path>
</svg>
</a>
</li>
<li class="mr-3">
<a href="https://www.youtube.com/github" title="GitHub on YouTube" style="color: #959da5;">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19.17 13.6" class="d-block" height="16">
<path
d="M18.77 2.13A2.4 2.4 0 0 0 17.09.42C15.59 0 9.58 0 9.58 0a57.55 57.55 0 0 0-7.5.4A2.49 2.49 0 0 0 .39 2.13 26.27 26.27 0 0 0 0 6.8a26.15 26.15 0 0 0 .39 4.67 2.43 2.43 0 0 0 1.69 1.71c1.52.42 7.5.42 7.5.42a57.69 57.69 0 0 0 7.51-.4 2.4 2.4 0 0 0 1.68-1.71 25.63 25.63 0 0 0 .4-4.67 24 24 0 0 0-.4-4.69zM7.67 9.71V3.89l5 2.91z"
fill="currentColor"></path>
</svg>
</a>
</li>
<li class="mr-3 flex-self-start">
<a href="https://www.linkedin.com/company/github" title="GitHub on Linkedin" style="color: #959da5;">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19 18" class="d-block" height="18">
<path
d="M3.94 2A2 2 0 1 1 2 0a2 2 0 0 1 1.94 2zM4 5.48H0V18h4zm6.32 0H6.34V18h3.94v-6.57c0-3.66 4.77-4 4.77 0V18H19v-7.93c0-6.17-7.06-5.94-8.72-2.91z"
fill="currentColor"></path>
</svg>
</a>
</li>
<li>
<a href="https://github.com/github" title="GitHub's organization" style="color: #959da5;">
<svg version="1.1" width="20" height="20" viewBox="0 0 16 16" class="octicon octicon-mark-github"
aria-hidden="true">
<path fill-rule="evenodd"
d="M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0016 8c0-4.42-3.58-8-8-8z">
</path>
</svg>
</a>
</li>
</ul>
<ul class="list-style-none d-flex text-gray">
<li class="mr-3">&copy;
<script type="text/javascript">document.write(new Date().getFullYear());</script> GitHub, Inc.</li>
<li class="mr-3"><a
href="https://docs.github.com/github/site-policy/github-terms-of-service"
class="link-gray">Terms </a></li>
<li><a href="https://docs.github.com/github/site-policy/github-privacy-statement"
class="link-gray">Privacy </a></li>
</ul>
</div>
</div>
</main>
<script type="text/javascript">
$(document).ready(function () {
$(".toggle > *").hide();
$(".toggle .name").show();
$(".toggle .name").click(function () {
$(this).parent().children().not(".name").toggle(400);
$(this).parent().children(".name").toggleClass("open");
})
});
</script>
</body>
</html>