123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297 |
- # This is the config file for the documentation generator.
- # (c) 2016 Andreas Rumpf
- # Feel free to edit the templates as you need. If you modify this file, it
- # might be worth updating the hardcoded values in packages/docutils/rstgen.nim
- split.item.toc = "20"
- # too long entries in the table of contents wrap around
- # after this number of characters
- doc.section = """
- <div class="section" id="$sectionID">
- <h1><a class="toc-backref" href="#$sectionID">$sectionTitle</a></h1>
- <dl class="item">
- $content
- </dl></div>
- """
- doc.section.toc = """
- <li>
- <a class="reference reference-toplevel" href="#$sectionID" id="$sectionTitleID">$sectionTitle</a>
- <ul class="simple simple-toc-section">
- $content
- </ul>
- </li>
- """
- doc.section.toc2 = """
- <ul class="simple nested-toc-section">$plainName
- $content
- </ul>
- """
- # Chunk of HTML emitted for each entry in the HTML table of contents.
- # Available variables are:
- # * $desc: the actual docstring of the item.
- # * $header: the full version of name, including types, pragmas, tags, etc.
- # * $header_plain: like header but without HTML (and without pragmas, tags, etc.),
- # for attribute embedding.
- # * $itemID: numerical unique entry of the item in the HTML.
- # * $itemSym: short symbolic name of the item for easier hyperlinking.
- # * $itemSymEnc: quoted version for URLs or attributes.
- # * $itemSymOrID: the symbolic name or the ID if that is not unique.
- # * $itemSymOrIDEnc: quoted version for URLs or attributes.
- # * $name: reduced name of the item.
- # * $uniqueName: name with parameters for routine types or $name for others.
- # * $seeSrc: generated HTML from doc.item.seesrc (if some switches are used).
- doc.item = """
- <div id="$itemSymOrID">
- <dt><pre>$header</pre></dt>
- <dd>
- $deprecationMsg
- $desc
- $seeSrc
- </dd>
- </div>
- """
- # Chunk of HTML emitted for each entry in the HTML table of contents.
- # See doc.item for available substitution variables.
- # This is used for TOC items which are not overloadable (e.g. types).
- # `$header_plain` would be too verbose here, so we use $name.
- doc.item.toc = """
- <li><a class="reference" href="#$itemSymOrIDEnc"
- title="$header_plain">$name</a></li>
- """
- # This is used for TOC items which are grouped by the same name (e.g. procs).
- doc.item.tocTable = """
- <li><a class="reference" href="#$itemSymOrIDEnc"
- title="$header_plain">$header_plain</a></li>
- """
- # HTML rendered for doc.item's seeSrc variable. Note that this will render to
- # the empty string if you don't pass anything through --git.url. Available
- # substitutaion variables here are:
- # * $commit: branch/commit to use in source link.
- # * $devel: branch to use in edit link.
- # * $path: relative path to the file being processed.
- # * $line: line of the item in the original source file.
- # * $url: whatever you did pass through the --git.url switch (which also
- # gets variables path/line replaced!)
- doc.item.seesrc = """ <a
- href="${url}/tree/${commit}/${path}#L${line}"
- class="link-seesrc" target="_blank">Source</a>
- <a href="${url}/edit/${devel}/${path}#L${line}" class="link-seesrc" target="_blank" >Edit</a>
- """
- doc.deprecationmsg = """
- <div class="deprecation-message">
- <b>$label</b> $message
- </div>
- """
- doc.toc = """
- <ul class="simple simple-toc" id="toc-list">
- $content
- </ul>
- """
- doc.body_toc_groupsection = """
- <div class="search-groupby">
- Group by:
- <select onchange="groupBy(this.value)">
- <option value="section">Section</option>
- <option value="type">Type</option>
- </select>
- </div>
- """
- @if boot:
- # This is enabled with the "boot" directive to generate
- # the compiler documentation.
- # As a user, tweak the block below instead.
- # You can add your own global-links entries
- doc.body_toc_group = """
- <div class="row">
- <div class="three columns">
- <div class="theme-switch-wrapper">
- <label class="theme-switch" for="checkbox">
- <input type="checkbox" id="checkbox" />
- <div class="slider round"></div>
- </label>
- <em>Dark Mode</em>
- </div>
- <div id="global-links">
- <ul class="simple-boot">
- <li><a href="manual.html">Manual</a></li>
- <li><a href="lib.html">Standard library</a></li>
- <li> <a href="$theindexhref">Index</a></li>
- <li><a href="compiler/$theindexhref">Compiler docs</a></li>
- <li><a href="https://nim-lang.github.io/fusion/theindex.html">Fusion docs</a></li>
- <li><a href="https://nim-lang.github.io/Nim/">devel</a>, <a href="https://nim-lang.org/documentation.html">stable</a></li>
- </ul>
- </div>
- <div id="searchInputDiv">
- Search: <input type="text" id="searchInput"
- onkeyup="search()" />
- </div>
- $body_toc_groupsection
- $tableofcontents
- </div>
- $seeSrc
- <div class="nine columns" id="content">
- <div id="tocRoot"></div>
- $deprecationMsg
- <p class="module-desc">$moduledesc</p>
- $content
- </div>
- </div>
- """
- @else
- # keep in sink with other `doc.body_toc_group` or better, refactor
- doc.body_toc_group = """
- <div class="row">
- <div class="three columns">
- <div class="theme-switch-wrapper">
- <label class="theme-switch" for="checkbox">
- <input type="checkbox" id="checkbox" />
- <div class="slider round"></div>
- </label>
- <em>Dark Mode</em>
- </div>
- <div id="global-links">
- <ul class="simple">
- <li>
- <a href="$theindexhref">Index</a>
- </li>
- </ul>
- </div>
- <div id="searchInputDiv">
- Search: <input type="text" id="searchInput"
- onkeyup="search()" />
- </div>
- <div>
- Group by:
- <select onchange="groupBy(this.value)">
- <option value="section">Section</option>
- <option value="type">Type</option>
- </select>
- </div>
- $tableofcontents
- </div>
- $seeSrc
- <div class="nine columns" id="content">
- <div id="tocRoot"></div>
- $deprecationMsg
- <p class="module-desc">$moduledesc</p>
- $content
- </div>
- </div>
- """
- @end
- doc.body_toc %= "${doc.body_toc_group}" # should only be used for boot
- doc.body_no_toc = """
- $moduledesc
- $content
- """
- # $1 - number of listing in document, $2 - language (e.g. langNim), $3 - anchor
- doc.listing_start = "<pre$3 class=\"listing\">"
- doc.listing_end = "</pre>"
- # * $analytics: Google analytics location, includes <script> tags
- doc.file = """<?xml version="1.0" encoding="utf-8" ?>
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <!-- This file is generated by Nim. -->
- <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
- <!-- Favicon -->
- <link rel="shortcut icon" href=""/>
- <link rel="icon" type="image/png" sizes="32x32" href="">
- <!-- Google fonts -->
- <link href='https://fonts.googleapis.com/css?family=Lato:400,600,900' rel='stylesheet' type='text/css'/>
- <link href='https://fonts.googleapis.com/css?family=Source+Code+Pro:400,500,600' rel='stylesheet' type='text/css'/>
- <!-- CSS -->
- <title>$title</title>
- <link rel="stylesheet" type="text/css" href="$nimdoccss">
- <script type="text/javascript" src="$dochackjs"></script>
- <script type="text/javascript">
- function main() {
- var pragmaDots = document.getElementsByClassName("pragmadots");
- for (var i = 0; i < pragmaDots.length; i++) {
- pragmaDots[i].onclick = function(event) {
- // Hide tease
- event.target.parentNode.style.display = "none";
- // Show actual
- event.target.parentNode.nextElementSibling.style.display = "inline";
- }
- }
- function switchTheme(e) {
- if (e.target.checked) {
- document.documentElement.setAttribute('data-theme', 'dark');
- localStorage.setItem('theme', 'dark');
- } else {
- document.documentElement.setAttribute('data-theme', 'light');
- localStorage.setItem('theme', 'light');
- }
- }
- const toggleSwitch = document.querySelector('.theme-switch input[type="checkbox"]');
- if (toggleSwitch !== null) {
- toggleSwitch.addEventListener('change', switchTheme, false);
- }
- var currentTheme = localStorage.getItem('theme');
- if (!currentTheme && window.matchMedia('(prefers-color-scheme: dark)').matches) {
- currentTheme = 'dark';
- }
- if (currentTheme) {
- document.documentElement.setAttribute('data-theme', currentTheme);
- if (currentTheme === 'dark' && toggleSwitch !== null) {
- toggleSwitch.checked = true;
- }
- }
- }
- window.addEventListener('DOMContentLoaded', main);
- </script>
- </head>
- <body>
- <div class="document" id="documentId">
- <div class="container">
- <h1 class="title">$title</h1>$subtitle
- $content
- <div class="row">
- <div class="twelve-columns footer">
- <span class="nim-sprite"></span>
- <br/>
- <small style="color: var(--hint);">Made with Nim. Generated: $date $time UTC</small>
- </div>
- </div>
- </div>
- </div>
- $analytics
- </body>
- </html>
- """
|