2022-04-21 23:53:28 +09:00
|
|
|
|
<!DOCTYPE html>
|
|
|
|
|
<html lang="en">
|
|
|
|
|
<head>
|
|
|
|
|
<meta charset="utf-8" />
|
|
|
|
|
<meta name="generator" content="pandoc" />
|
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
|
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<title>GTK 4 tutorial</title>
|
2022-04-21 23:53:28 +09:00
|
|
|
|
<style>
|
|
|
|
|
code{white-space: pre-wrap;}
|
|
|
|
|
span.smallcaps{font-variant: small-caps;}
|
|
|
|
|
span.underline{text-decoration: underline;}
|
|
|
|
|
div.column{display: inline-block; vertical-align: top; width: 50%;}
|
|
|
|
|
div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;}
|
|
|
|
|
ul.task-list{list-style: none;}
|
|
|
|
|
pre{overflow: visible;}
|
|
|
|
|
pre > code.sourceCode { white-space: pre; position: relative; }
|
|
|
|
|
pre > code.sourceCode > span { display: inline-block; line-height: 1.25; }
|
|
|
|
|
pre > code.sourceCode > span:empty { height: 1.2em; }
|
|
|
|
|
code.sourceCode > span { color: inherit; text-decoration: inherit; }
|
|
|
|
|
div.sourceCode { margin: 1em 0; }
|
|
|
|
|
pre.sourceCode { margin: 0; }
|
|
|
|
|
@media screen {
|
|
|
|
|
div.sourceCode { overflow: auto; }
|
2022-04-17 20:54:42 +09:00
|
|
|
|
}
|
2022-04-21 23:53:28 +09:00
|
|
|
|
@media print {
|
|
|
|
|
pre > code.sourceCode { white-space: pre-wrap; }
|
|
|
|
|
pre > code.sourceCode > span { text-indent: -5em; padding-left: 5em; }
|
|
|
|
|
}
|
|
|
|
|
pre.numberSource code
|
|
|
|
|
{ counter-reset: source-line 0; }
|
|
|
|
|
pre.numberSource code > span
|
|
|
|
|
{ position: relative; left: -4em; counter-increment: source-line; }
|
|
|
|
|
pre.numberSource code > span > a:first-child::after
|
|
|
|
|
{ content: counter(source-line);
|
|
|
|
|
position: relative; left: -1em; text-align: right; vertical-align: baseline;
|
|
|
|
|
border: none; display: inline-block;
|
|
|
|
|
-webkit-touch-callout: none; -webkit-user-select: none;
|
|
|
|
|
-khtml-user-select: none; -moz-user-select: none;
|
|
|
|
|
-ms-user-select: none; user-select: none;
|
|
|
|
|
padding: 0 4px; width: 4em;
|
|
|
|
|
color: #aaaaaa;
|
|
|
|
|
}
|
|
|
|
|
pre.numberSource { margin-left: 3em; border-left: 1px solid #aaaaaa; padding-left: 4px; }
|
|
|
|
|
div.sourceCode
|
|
|
|
|
{ }
|
|
|
|
|
@media screen {
|
|
|
|
|
pre > code.sourceCode > span > a:first-child::before { text-decoration: underline; }
|
|
|
|
|
}
|
|
|
|
|
code span.al { color: #ff0000; font-weight: bold; } /* Alert */
|
|
|
|
|
code span.an { color: #60a0b0; font-weight: bold; font-style: italic; } /* Annotation */
|
|
|
|
|
code span.at { color: #7d9029; } /* Attribute */
|
|
|
|
|
code span.bn { color: #40a070; } /* BaseN */
|
|
|
|
|
code span.bu { } /* BuiltIn */
|
|
|
|
|
code span.cf { color: #007020; font-weight: bold; } /* ControlFlow */
|
|
|
|
|
code span.ch { color: #4070a0; } /* Char */
|
|
|
|
|
code span.cn { color: #880000; } /* Constant */
|
|
|
|
|
code span.co { color: #60a0b0; font-style: italic; } /* Comment */
|
|
|
|
|
code span.cv { color: #60a0b0; font-weight: bold; font-style: italic; } /* CommentVar */
|
|
|
|
|
code span.do { color: #ba2121; font-style: italic; } /* Documentation */
|
|
|
|
|
code span.dt { color: #902000; } /* DataType */
|
|
|
|
|
code span.dv { color: #40a070; } /* DecVal */
|
|
|
|
|
code span.er { color: #ff0000; font-weight: bold; } /* Error */
|
|
|
|
|
code span.ex { } /* Extension */
|
|
|
|
|
code span.fl { color: #40a070; } /* Float */
|
|
|
|
|
code span.fu { color: #06287e; } /* Function */
|
|
|
|
|
code span.im { } /* Import */
|
|
|
|
|
code span.in { color: #60a0b0; font-weight: bold; font-style: italic; } /* Information */
|
|
|
|
|
code span.kw { color: #007020; font-weight: bold; } /* Keyword */
|
|
|
|
|
code span.op { color: #666666; } /* Operator */
|
|
|
|
|
code span.ot { color: #007020; } /* Other */
|
|
|
|
|
code span.pp { color: #bc7a00; } /* Preprocessor */
|
|
|
|
|
code span.sc { color: #4070a0; } /* SpecialChar */
|
|
|
|
|
code span.ss { color: #bb6688; } /* SpecialString */
|
|
|
|
|
code span.st { color: #4070a0; } /* String */
|
|
|
|
|
code span.va { color: #19177c; } /* Variable */
|
|
|
|
|
code span.vs { color: #4070a0; } /* VerbatimString */
|
|
|
|
|
code span.wa { color: #60a0b0; font-weight: bold; font-style: italic; } /* Warning */
|
|
|
|
|
div.sourceCode { margin: 10px; padding: 16px 10px 8px 10px; border: 2px solid silver; background-color: ghostwhite; overflow-x:scroll}
|
|
|
|
|
pre:not(.sourceCode) { margin: 10px; padding: 16px 10px 8px 10px; border: 2px solid silver; background-color: ghostwhite; overflow-x:scroll}
|
|
|
|
|
table {margin-left: auto; margin-right: auto; border-collapse: collapse; border: 1px solid;}
|
|
|
|
|
th {padding: 2px 6px; border: 1px solid; background-color: ghostwhite;}
|
|
|
|
|
td {padding: 2px 6px; border: 1px solid;}
|
|
|
|
|
img {display: block; margin-left: auto; margin-right: auto;}
|
|
|
|
|
figcaption {text-align: center;}
|
|
|
|
|
</style>
|
|
|
|
|
</head>
|
|
|
|
|
<body style="padding-top: 70px;">
|
|
|
|
|
<div class="container">
|
|
|
|
|
<nav class="navbar fixed-top navbar-expand-lg navbar-dark bg-primary">
|
|
|
|
|
<div class="container-fluid">
|
|
|
|
|
<span class="navbar-brand">Gtk4 tutorial</span>
|
|
|
|
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
|
|
|
|
|
<span class="navbar-toggler-icon"></span>
|
|
|
|
|
</button>
|
|
|
|
|
<div class="collapse navbar-collapse" id="navbarSupportedContent">
|
|
|
|
|
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
|
|
|
|
|
<li class="nav-item">
|
|
|
|
|
<a class="nav-link" href="index.html">Home</a>
|
|
|
|
|
</li>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
</ul>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</nav>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<h1 id="how-to-build-gtk4-tutorial">How to build Gtk4-Tutorial</h1>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<h2 id="quick-start-guide">Quick start guide</h2>
|
|
|
|
|
<ol type="1">
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>You need linux operationg system, ruby, rake, pandoc and latex
|
|
|
|
|
system.</li>
|
2022-04-21 23:53:28 +09:00
|
|
|
|
<li>download this repository and uncompress the file.</li>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>change your current directory to the top directory of the source
|
|
|
|
|
files.</li>
|
|
|
|
|
<li>type <code>rake html</code> to create html files. The files are
|
|
|
|
|
created under the <code>docs</code> directory.</li>
|
|
|
|
|
<li>type <code>rake pdf</code> to create pdf a file. The file is created
|
|
|
|
|
under the <code>latex</code> directory.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
</ol>
|
|
|
|
|
<h2 id="prerequisites">Prerequisites</h2>
|
|
|
|
|
<ul>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>Linux operationg system. The programs in this repository has been
|
|
|
|
|
tested on Ubuntu 21.04.</li>
|
|
|
|
|
<li>Download the files in the repository. There are two ways to
|
|
|
|
|
download.
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<ol type="1">
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>Use git. Type
|
|
|
|
|
<code>git clone https://github.com/ToshioCP/Gtk4-tutorial.git</code> on
|
|
|
|
|
the command-line.</li>
|
|
|
|
|
<li>Download a zip file. Click on the <code>Code</code> button (green
|
|
|
|
|
button) on the top page of the repository. Then, click “Download
|
|
|
|
|
ZIP”.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
</ol></li>
|
|
|
|
|
<li>Ruby and rake.</li>
|
2022-04-21 23:53:28 +09:00
|
|
|
|
<li>Pandoc. It is used to convert markdown to html and/or latex.</li>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>Latex system. Texlive2020 or later version is recommended. It is
|
|
|
|
|
used to generate the pdf file.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
</ul>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<h2 id="github-flavored-markdown">GitHub Flavored Markdown</h2>
|
|
|
|
|
<p>When you see <a
|
|
|
|
|
href="https://github.com/ToshioCP/Gtk4-tutorial">gtk4_tutorial GitHub
|
|
|
|
|
repository</a>, you’ll find the contents of the <code>Readme.md</code>
|
|
|
|
|
file. This file is written in markdown language. Markdown files have
|
|
|
|
|
<code>.md</code> suffix.</p>
|
|
|
|
|
<p>There are several kinds of markdown language. <code>Readme.md</code>
|
|
|
|
|
uses ‘GitHub Flavored Markdown’, which is often shortened as GFM.
|
|
|
|
|
Markdown files in the <code>gfm</code> directory are written in GFM. If
|
|
|
|
|
you are not familiar with it, refer to the page <a
|
|
|
|
|
href="https://github.github.com/gfm/">GitHub Flavor Markdown
|
|
|
|
|
spec</a>.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<h2 id="pandocs-markdown">Pandoc’s markdown</h2>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>This tutorial also uses another markdown – ‘pandoc’s markdown’.
|
|
|
|
|
Pandoc is a converter between markdown, html, latex, word docx and so
|
|
|
|
|
on. This type of markdown is used to convert markdown to html and/or
|
|
|
|
|
latex.</p>
|
2022-04-25 17:01:44 +09:00
|
|
|
|
<h2 id="src.md-file">.Src.md file</h2>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>.Src.md file has “.src.md” suffix. The syntax of .src.md file is
|
|
|
|
|
similar to markdown but it has a special command which isn’t included in
|
|
|
|
|
markdown syntax. It is @@@ command. The command starts with a line
|
|
|
|
|
begins with “@@@” and ends with a line “@@@”. For example,</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>@@@include
|
|
|
|
|
tfeapplication.c
|
|
|
|
|
@@@</code></pre>
|
|
|
|
|
<p>There are four types of @@@ command.</p>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<h3 id="include">@@<span class="citation"
|
|
|
|
|
data-cites="include">@include</span></h3>
|
|
|
|
|
<p>This type of @@@ command starts with a line “@@<span class="citation"
|
|
|
|
|
data-cites="include">@include</span>”.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>@@@include
|
|
|
|
|
tfeapplication.c
|
|
|
|
|
@@@</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>This command replaces itself with the texts read from the C source
|
|
|
|
|
files surrounded by <code>@@@include</code> and <code>@@@</code>. If a
|
|
|
|
|
function list follows the filename, only the functions are read.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>@@@include
|
|
|
|
|
tfeapplication.c main startup
|
|
|
|
|
@@@</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>The command above is replaced by the contents of <code>main</code>
|
|
|
|
|
and <code>startup</code> functions in the file
|
|
|
|
|
<code>tfeapplication.c</code>.</p>
|
|
|
|
|
<p>Other language’s source files are also possible. The following
|
|
|
|
|
example shows that the ruby file ‘lib_src2md.rb’ is inserted by the
|
|
|
|
|
command.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>@@@include
|
|
|
|
|
lib_src2md.rb
|
|
|
|
|
@@@</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>You can’t specify functions or methods unless the file is C
|
|
|
|
|
source.</p>
|
|
|
|
|
<p>The inserted text is converted to fence code block. Fence code block
|
|
|
|
|
begins with <code>~~~</code> and ends with <code>~~~</code>. The
|
|
|
|
|
contents are displayed verbatim. <code>~~~</code> is look like a fence
|
|
|
|
|
so the block is called “fence code block”.</p>
|
|
|
|
|
<p>If the target markdown is GFM, then an info string can follow the
|
|
|
|
|
beginning fence. The following example shows that the @@@ command
|
|
|
|
|
includes a C source file <code>sample.c</code>.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>$ cat src/sample.c
|
|
|
|
|
int
|
|
|
|
|
main (int argc, char **argv) {
|
|
|
|
|
... ...
|
|
|
|
|
}
|
|
|
|
|
$cat src/sample.src.md
|
|
|
|
|
... ...
|
|
|
|
|
@@@include -N
|
|
|
|
|
sample.c
|
|
|
|
|
@@@
|
|
|
|
|
... ...
|
2022-04-25 17:01:44 +09:00
|
|
|
|
$ ruby src2md.rb src/sample.src.md
|
2022-04-17 20:54:42 +09:00
|
|
|
|
$ cat gfm/sample.md
|
|
|
|
|
... ...
|
|
|
|
|
~~~C
|
|
|
|
|
int
|
|
|
|
|
main (int argc, char **argv) {
|
|
|
|
|
... ...
|
|
|
|
|
}
|
|
|
|
|
~~~
|
|
|
|
|
... ...</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>Info strings are usually languages like C, ruby, xml and so on. This
|
|
|
|
|
string is decided with the filename extension.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<ul>
|
|
|
|
|
<li><code>.c</code> => C</li>
|
|
|
|
|
<li><code>.rb</code> => ruby</li>
|
|
|
|
|
<li><code>.xml</code> => xml</li>
|
|
|
|
|
</ul>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>The supported languages are written in the <code>lang</code> method
|
|
|
|
|
in <code>lib/lib_src2md.rb</code>.</p>
|
|
|
|
|
<p>A line number will be inserted at the top of each line in the code
|
|
|
|
|
block. If you don’t want to insert it, give “-N” option to @@<span
|
|
|
|
|
class="citation" data-cites="include">@include</span> command.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<p>Options:</p>
|
|
|
|
|
<ul>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li><code>-n</code>: Inserts a line number at the top of each line
|
|
|
|
|
(default).</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<li><code>-N</code>: No line number is inserted.</li>
|
|
|
|
|
</ul>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>The following shows that the line numbers are inserted at the
|
|
|
|
|
beginning of each line.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>$cat src/sample.src.md
|
|
|
|
|
... ...
|
|
|
|
|
@@@include
|
|
|
|
|
sample.c
|
|
|
|
|
@@@
|
|
|
|
|
... ...
|
2022-04-25 17:01:44 +09:00
|
|
|
|
$ ruby src2md.rb src/sample.src.md
|
2022-04-17 20:54:42 +09:00
|
|
|
|
$ cat gfm/sample.md
|
|
|
|
|
... ...
|
|
|
|
|
~~~C
|
|
|
|
|
1 int
|
|
|
|
|
2 main (int argc, char **argv) {
|
|
|
|
|
... ...
|
|
|
|
|
14 }
|
|
|
|
|
~~~
|
|
|
|
|
... ...</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>If a markdown is an intermediate file to html, another type of info
|
|
|
|
|
string follows the fence. If @@<span class="citation"
|
|
|
|
|
data-cites="include">@include</span> command doesn’t have -N option,
|
|
|
|
|
then the generated markdown is:</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>~~~{.C .numberLines}
|
|
|
|
|
int
|
|
|
|
|
main (int argc, char **argv) {
|
|
|
|
|
... ...
|
|
|
|
|
}
|
|
|
|
|
~~~</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>The info string <code>.C</code> specifies C language. The info string
|
|
|
|
|
<code>.numberLines</code> is a class of the pandoc markdown. If the
|
|
|
|
|
class is given, pandoc generates CSS to insert line numbers to the
|
|
|
|
|
source code in the html file. That’s why the fence code block in the
|
|
|
|
|
markdown doesn’t have line numbers, which is different from gfm
|
|
|
|
|
markdown. If <code>-N</code> option is given, then the info string is
|
|
|
|
|
<code>{.C}</code> only.</p>
|
|
|
|
|
<p>If a markdown is an intermediate file to latex, the same info string
|
|
|
|
|
follows the beginning fence.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>~~~{.C .numberLines}
|
|
|
|
|
int
|
|
|
|
|
main (int argc, char **argv) {
|
|
|
|
|
... ...
|
|
|
|
|
}
|
|
|
|
|
~~~</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>Rake uses pandoc with –listings option to convert the markdown to a
|
|
|
|
|
latex file. The generated latex file uses ‘listings package’ to list
|
|
|
|
|
source files instead of verbatim environment. The markdown above is
|
|
|
|
|
converted to the following latex source file.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>\begin{lstlisting}[language=C, numbers=left]
|
|
|
|
|
int
|
|
|
|
|
main (int argc, char **argv) {
|
|
|
|
|
... ...
|
|
|
|
|
}
|
|
|
|
|
\end{lstlisting}</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>Listing package can color or emphasize keywords, strings, comments
|
|
|
|
|
and directives. But it doesn’t really analyze the syntax of the
|
|
|
|
|
language, so the emphasis tokens are limited.</p>
|
|
|
|
|
<p>@@<span class="citation" data-cites="include">@include</span> command
|
|
|
|
|
has two advantages.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<ol type="1">
|
|
|
|
|
<li>Less typing.</li>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>You don’t need to modify your .src.md file, even if the C source
|
|
|
|
|
file is modified.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
</ol>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<h3 id="shell">@@<span class="citation"
|
|
|
|
|
data-cites="shell">@shell</span></h3>
|
|
|
|
|
<p>This type of @@@ command starts with a line begins with “@@<span
|
|
|
|
|
class="citation" data-cites="shell">@shell</span>”.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>@@@shell
|
|
|
|
|
shell command
|
|
|
|
|
... ...
|
|
|
|
|
@@@</code></pre>
|
|
|
|
|
<p>This command replaces itself with:</p>
|
|
|
|
|
<ul>
|
|
|
|
|
<li>the shell command</li>
|
|
|
|
|
<li>the standard output from the shell command</li>
|
|
|
|
|
</ul>
|
|
|
|
|
<p>For example,</p>
|
|
|
|
|
<pre><code>@@@shell
|
|
|
|
|
wc Rakefile
|
|
|
|
|
@@@</code></pre>
|
|
|
|
|
<p>This is converted to:</p>
|
|
|
|
|
<pre><code>~~~
|
|
|
|
|
$ wc Rakefile
|
|
|
|
|
164 475 4971 Rakefile
|
|
|
|
|
~~~</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<h3 id="if-series">@@<span class="citation" data-cites="if">@if</span>
|
|
|
|
|
series</h3>
|
|
|
|
|
<p>This type of @@@ command starts with a line begins with “@@<span
|
|
|
|
|
class="citation" data-cites="if">@if</span>”, and followed by “@@<span
|
|
|
|
|
class="citation" data-cites="elif">@elif</span>”, “@@<span
|
|
|
|
|
class="citation" data-cites="else">@else</span>” or “@@<span
|
|
|
|
|
class="citation" data-cites="end">@end</span>”. This command is similar
|
|
|
|
|
to “#if”, “#elif”, #else” and “#endif” directives in the C preprocessor.
|
|
|
|
|
For example,</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>@@@if gfm
|
2022-04-21 23:53:28 +09:00
|
|
|
|
Refer to [tfetextview API reference](tfetextview_doc.md)
|
2022-04-17 20:54:42 +09:00
|
|
|
|
@@@elif html
|
2022-04-21 23:53:28 +09:00
|
|
|
|
Refer to [tfetextview API reference](tfetextview_doc.html)
|
2022-04-17 20:54:42 +09:00
|
|
|
|
@@@elif latex
|
|
|
|
|
Refer to tfetextview API reference in appendix.
|
|
|
|
|
@@@end</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p><code>@@@if</code> and <code>@@@elif</code> have conditions. They are
|
|
|
|
|
<code>gfm</code>, <code>html</code> or <code>latex</code> so far.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<ul>
|
|
|
|
|
<li>gfm: if the target is GFM</li>
|
|
|
|
|
<li>html: if the target is html</li>
|
2022-04-25 17:01:44 +09:00
|
|
|
|
<li>latex: if the target is pdf.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
</ul>
|
|
|
|
|
<p>Other type of conditions may be available in the future version.</p>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>The code analyzing @@<span class="citation"
|
|
|
|
|
data-cites="if">@if</span> series command is rather complicated. It is
|
|
|
|
|
based on the state diagram below.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<figure>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<img src="image/state_diagram.png" alt="state diagram" />
|
|
|
|
|
<figcaption aria-hidden="true">state diagram</figcaption>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
</figure>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<h3 id="table">@@<span class="citation"
|
|
|
|
|
data-cites="table">@table</span></h3>
|
|
|
|
|
<p>This type of @@@ command starts with a line begins with “@@<span
|
|
|
|
|
class="citation" data-cites="table">@table</span>”. The contents of this
|
|
|
|
|
command is a table of the GFM or pandoc’s markdown. The command makes a
|
|
|
|
|
table easy to read. For example, a text file <code>sample.md</code> has
|
|
|
|
|
a table like this:</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>Price list
|
|
|
|
|
|
|
|
|
|
@@@table
|
|
|
|
|
|item|price|
|
|
|
|
|
|:---:|:---:|
|
|
|
|
|
|mouse|$10|
|
|
|
|
|
|PC|$500|
|
|
|
|
|
@@@</code></pre>
|
|
|
|
|
<p>The command changes this into:</p>
|
|
|
|
|
<pre><code>Price list
|
|
|
|
|
|
|
|
|
|
|item |price|
|
|
|
|
|
|:---:|:---:|
|
|
|
|
|
|mouse| $10 |
|
|
|
|
|
| PC |$500 |</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>This command just changes the appearance of the table. There’s no
|
|
|
|
|
influence on html/latex files that is converted from the markdown.
|
|
|
|
|
Notice that the command supports only the above type of markdown table
|
|
|
|
|
format.</p>
|
|
|
|
|
<p>A script <code>mktbl.rb</code> supports this command. If you run the
|
|
|
|
|
script like this:</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>$ ruby mktbl.rb sample.md</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>Then, the tables in ‘sample.md’ will be arranged. The script also
|
|
|
|
|
makes a backup file <code>sample.md.bak</code>.</p>
|
|
|
|
|
<p>The task of the script seems easy, but the program is not so simple.
|
|
|
|
|
The script <code>mktbl.rb</code> uses a library
|
|
|
|
|
<code>lib/lib_src2md.rb</code></p>
|
|
|
|
|
<p>@@<span class="citation" data-cites="commands">@commands</span> are
|
|
|
|
|
effective in the whole text. This means you can’t stop the @@<span
|
|
|
|
|
class="citation" data-cites="commands">@commands</span>. But sometimes
|
|
|
|
|
you want to show the commands literally like this document. One solution
|
|
|
|
|
is to add four blanks at the top of the line. Then @@<span
|
|
|
|
|
class="citation" data-cites="commands">@commands</span> are not
|
|
|
|
|
effective because @@<span class="citation"
|
|
|
|
|
data-cites="commands">@commands</span> must be at the top of the
|
|
|
|
|
line.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<h2 id="conversion">Conversion</h2>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>The @@@ commands are carried out by a method <code>src2md</code>,
|
|
|
|
|
which is in the file <code>lib/lib_src2md.rb</code>. This method
|
|
|
|
|
converts <code>.src.md</code> file into <code>.md</code> file. In
|
|
|
|
|
addition, some other conversions are made by <code>src2md</code>
|
|
|
|
|
method.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<ul>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>Relative links are changed according to the change of the base
|
|
|
|
|
directory.</li>
|
|
|
|
|
<li>Size option in an image link is removed when the destination is GFM
|
|
|
|
|
or html.</li>
|
|
|
|
|
<li>Relative link is removed except .src.md files when the destination
|
|
|
|
|
is html.</li>
|
2022-04-25 17:01:44 +09:00
|
|
|
|
<li>Relative link is removed when the destination is latex.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
</ul>
|
|
|
|
|
<p>The order of the conversions are:</p>
|
|
|
|
|
<ol type="1">
|
|
|
|
|
<li>@@<span class="citation" data-cites="if">@if</span></li>
|
|
|
|
|
<li>@@<span class="citation" data-cites="table">@table</span></li>
|
|
|
|
|
<li>@@<span class="citation" data-cites="include">@include</span></li>
|
|
|
|
|
<li>@@<span class="citation" data-cites="shell">@shell</span></li>
|
|
|
|
|
<li>others</li>
|
|
|
|
|
</ol>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>There is the <code>src2md.rb</code> file in the top directory of this
|
|
|
|
|
repository. It just invokes the method <code>src2md</code>. In the same
|
|
|
|
|
way, the method is called in the action in the
|
|
|
|
|
<code>Rakefile</code>.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<h2 id="directory-structure">Directory structure</h2>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>There are seven directories under <code>gtk4_tutorial</code>
|
|
|
|
|
directory. They are <code>gfm</code>, <code>docs</code>,
|
|
|
|
|
<code>latex</code>, <code>src</code>, <code>image</code>,
|
|
|
|
|
<code>test</code> and <code>lib</code>. Three directories
|
|
|
|
|
<code>gfm</code>, <code>docs</code> and <code>latex</code> are the
|
|
|
|
|
destination directories for GFM, html and latex files respectively. It
|
|
|
|
|
is possible that these three directories don’t exist before the
|
|
|
|
|
conversion.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<ul>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>src: This directory contains .src.md files and C-related source
|
|
|
|
|
files.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<li>image: This directory contains image files like png or jpg.</li>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>gfm: <code>rake</code> converts .src.md files to GFM files and store
|
|
|
|
|
them in this directory.</li>
|
|
|
|
|
<li>docs: <code>rake html</code> will convert .src.md files to html
|
|
|
|
|
files and store them in this directory.</li>
|
|
|
|
|
<li>latex: <code>rake pdf</code> will convert .src.md files to latex
|
|
|
|
|
files and store them in this directory. Finally it creates a pdf file in
|
|
|
|
|
<code>latex</code> directory.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<li>lib: This directory includes ruby library files.</li>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>test: This directory contains test files. The tests are carried out
|
|
|
|
|
by typing <code>rake test</code> on the terminal.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
</ul>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<h2 id="src-directory-and-the-top-directory">Src directory and the top
|
|
|
|
|
directory</h2>
|
|
|
|
|
<p>Src directory contains .src.md files and C-related source files. The
|
|
|
|
|
top directory, which is gtk_tutorial directory, contains
|
|
|
|
|
<code>Rakefile</code>, <code>src2md.rb</code> and some other files. When
|
|
|
|
|
<code>Readme.md</code> is generated, it will be located at the top
|
|
|
|
|
directory. <code>Readme.md</code> has title, abstract, table of contents
|
|
|
|
|
with links to GFM files.</p>
|
|
|
|
|
<p>Rakefile describes how to convert .src.md files into GFM, html and/or
|
|
|
|
|
pdf files. Rake carries out the conversion according to the
|
|
|
|
|
<code>Rakefile</code>.</p>
|
|
|
|
|
<h2 id="the-name-of-files-in-src-directory">The name of files in src
|
|
|
|
|
directory</h2>
|
|
|
|
|
<p>Files in <code>src</code> directory are an abstract, sections of the
|
|
|
|
|
document and other .src.md files. An <code>abstract.src.md</code>
|
|
|
|
|
contains the abstract of this tutorial. Each section filename is “sec”,
|
|
|
|
|
number of the section and “.src.md” suffix. For example, “sec1.src.md”,
|
|
|
|
|
“sec5.src.md” or “sec12.src.md”. They are the files correspond to the
|
|
|
|
|
section 1, section 5 and section 12 respectively.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<h2 id="c-source-file-directory">C source file directory</h2>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>Most of .src.md files have <code>@@@include</code> commands and they
|
|
|
|
|
include C source files. Such C source files are located in the
|
|
|
|
|
subdirectories of <code>src</code> directory.</p>
|
|
|
|
|
<p>Those C files have been compiled and tested. When you compile source
|
|
|
|
|
files, some auxiliary files and a target file like <code>a.out</code>
|
|
|
|
|
are created. Or <code>_build</code> directory is made when
|
|
|
|
|
<code>meson</code> and <code>ninja</code> is used when compiling. Those
|
|
|
|
|
files are not tracked by <code>git</code> because they are specified in
|
|
|
|
|
<code>.gitignore</code>.</p>
|
|
|
|
|
<p>The name of the subdirectories should be independent of section
|
|
|
|
|
names. It is because of renumbering, which will be explained in the next
|
|
|
|
|
subsection.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<h2 id="renumbering">Renumbering</h2>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>Sometimes you might want to insert a new section. For example, you
|
|
|
|
|
want to insert it between section 4 and section 5. You can make a
|
|
|
|
|
temporary section 4.5, that is a rational number between 4 and 5.
|
|
|
|
|
However, section numbers are usually integer so section 4.5 must be
|
|
|
|
|
changed to section 5. And the numbers of the following sections must be
|
|
|
|
|
increased by one.</p>
|
|
|
|
|
<p>This renumbering is done by the <code>renumber</code> method in the
|
|
|
|
|
<code>lib/lib_renumber.rb</code> file.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<ul>
|
|
|
|
|
<li>It changes file names.</li>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>If there are references (links) to sections in .src.md files, the
|
|
|
|
|
section numbers will be automatically renumbered.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
</ul>
|
|
|
|
|
<h2 id="rakefile">Rakefile</h2>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>Rakefile is similar to Makefile but controlled by rake, which is a
|
|
|
|
|
ruby script. Rakefile in this tutorial has the following tasks.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<ul>
|
|
|
|
|
<li>md: generate GFM markdown files. This is the default.</li>
|
|
|
|
|
<li>html: generate html files.</li>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<li>pdf: generate latex files and a pdf file, which is compiled by
|
|
|
|
|
lualatex.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<li>all: generate md, html and pdf files.</li>
|
2022-04-25 17:01:44 +09:00
|
|
|
|
<li>clean: delete latex intermediate files.</li>
|
|
|
|
|
<li>clobber: delete all the generated files.</li>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
</ul>
|
|
|
|
|
<p>Rake does renumbering before the tasks above.</p>
|
|
|
|
|
<h2 id="generate-gfm-markdown-files">Generate GFM markdown files</h2>
|
|
|
|
|
<p>Markdown files (GFM) are generated by rake.</p>
|
|
|
|
|
<pre><code>$ rake</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>This command generates <code>Readme.md</code> with
|
|
|
|
|
<code>src/abstract.src.md</code> and titles of each <code>.src.md</code>
|
|
|
|
|
file. At the same time, it converts each .src.md file into a GFM file
|
|
|
|
|
under the <code>gfm</code> directory. Navigation lines are added at the
|
|
|
|
|
top and bottom of each markdown section file.</p>
|
|
|
|
|
<p>You can describe width and height of images in .src.md files. For
|
|
|
|
|
example,</p>
|
2022-04-21 23:53:28 +09:00
|
|
|
|
<pre><code>![sample image](../image/sample_image.png){width=10cm height=6cm}</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>The size between left brace and right brace is used in latex file and
|
|
|
|
|
it is not fit to GFM syntax. So the size will be removed in the
|
|
|
|
|
conversion.</p>
|
|
|
|
|
<p>If a .src.md file has relative URL links, they will be changed by
|
|
|
|
|
conversion. Because .src.md files are located under the <code>src</code>
|
|
|
|
|
directory and GFM files are located under the <code>gfm</code>
|
|
|
|
|
directory. That means the base directory of the relative link are
|
|
|
|
|
different. For example, <code>[src/sample.c](sample.c)</code> is
|
|
|
|
|
translated to <code>[src/sample.c](../src/sample.c)</code>.</p>
|
|
|
|
|
<p>If a link points another .src.md file, then the target filename will
|
|
|
|
|
be changed to .md file. For example,
|
|
|
|
|
<code>[Section 5](sec5.src.md)</code> is translated to
|
|
|
|
|
<code>[Section 5](sec5.md)</code>.</p>
|
|
|
|
|
<p>If you want to clean the directory, that means remove all the
|
|
|
|
|
generated markdown files, type <code>rake clobber</code>.</p>
|
2022-04-21 23:53:28 +09:00
|
|
|
|
<pre><code>$ rake clobber</code></pre>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<p>Sometimes this is necessary before generating GFM files.</p>
|
2022-04-21 23:53:28 +09:00
|
|
|
|
<pre><code>$ rake clobber
|
2022-04-17 20:54:42 +09:00
|
|
|
|
$ rake</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>For example, if you append a new section and other files are still
|
|
|
|
|
the same as before, <code>rake clobber</code> is necessary. Because the
|
|
|
|
|
navigation of the previous section of the newly added section needs to
|
|
|
|
|
be updated. If you don’t do <code>rake clobber</code>, then it won’t be
|
|
|
|
|
updated because the the timestamp of .md file in gfm is newer than the
|
|
|
|
|
one of .src.md file. In this case, using <code>touch</code> to the
|
|
|
|
|
previous section .src.md also works to update the file.</p>
|
|
|
|
|
<p>If you see the GitHub repository (ToshioCP/Gtk4-tutorial),
|
|
|
|
|
<code>Readme.md</code> is shown below the code. And
|
|
|
|
|
<code>Readme.md</code> includes links to each markdown files. The
|
|
|
|
|
repository not only stores source files but also shows the whole
|
|
|
|
|
tutorial.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<h2 id="generate-html-files">Generate html files</h2>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>Src.md files can be translated to html files. You need pandoc to do
|
|
|
|
|
this. Most linux distribution has pandoc package. Refer to your
|
|
|
|
|
distribution document to install it.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<p>Type <code>rake html</code> to generate html files.</p>
|
|
|
|
|
<pre><code>$ rake html</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>First, it generates pandoc’s markdown files under <code>docs</code>
|
|
|
|
|
directory. Then, pandoc converts them to html files. The width and
|
|
|
|
|
height of image files are removed. Links to .src.md files will be
|
|
|
|
|
converted like this.</p>
|
2022-04-24 12:13:40 +09:00
|
|
|
|
<pre><code>[Section 5](sec5.src.md) => [Section 5](sec5.html)</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>Image files are copied to <code>docs/image</code> direcotiry and
|
|
|
|
|
links to them will be converted like this:</p>
|
2022-04-24 12:13:40 +09:00
|
|
|
|
<pre><code>[sample.png](../image/sample.png) => [sample.png](image/sample.png)</code></pre>
|
|
|
|
|
<p>Other relative links will be removed.</p>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p><code>index.html</code> is the top html file. If you want to clean
|
|
|
|
|
html files, type <code>rake clobber</code> or
|
|
|
|
|
<code>cleanhtml</code>.</p>
|
2022-04-21 23:53:28 +09:00
|
|
|
|
<pre><code>$ rake clobber</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>Every html file has a header
|
|
|
|
|
(<code><head> -- </head></code>). It is created by pandoc
|
|
|
|
|
with ‘-s’ option. You can customize the output with your own template
|
|
|
|
|
file for pandoc. Rake uses <code>lib/lib_mk_html_template.rb</code> to
|
|
|
|
|
create its own template. The template inserts bootstrap CSS and
|
|
|
|
|
Javascript through <code>jsDelivr</code>.</p>
|
|
|
|
|
<p>The <code>docs</code> directory contains all the necessary html
|
|
|
|
|
files. They are used in the <a
|
|
|
|
|
href="https://ToshioCP.github.io/Gtk4-tutorial">GitHub pages</a> of this
|
|
|
|
|
repository.</p>
|
|
|
|
|
<p>So if you want to publish this tutorial on your own web site, just
|
|
|
|
|
upload the files in the <code>docs</code> directory to your site.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<h2 id="generate-a-pdf-file">Generate a pdf file</h2>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>You need pandoc to convert markdown files into latex source
|
|
|
|
|
files.</p>
|
|
|
|
|
<p>Type <code>rake pdf</code> to generate latex files and finally make a
|
|
|
|
|
pdf file.</p>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<pre><code>$ rake pdf</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>First, it generates pandoc’s markdown files under <code>latex</code>
|
|
|
|
|
directory. Then, pandoc converts them into latex files. Links to files
|
|
|
|
|
or directories are removed because latex doesn’t support them. However,
|
|
|
|
|
links to full URL and image files are kept. Image size is set with the
|
|
|
|
|
size between the left brace and right brace.</p>
|
2022-04-21 23:53:28 +09:00
|
|
|
|
<pre><code>![sample image](../image/sample_image.png){width=10cm height=6cm}</code></pre>
|
2022-11-21 22:48:20 +09:00
|
|
|
|
<p>You need to specify appropriate width and height. It is almost
|
|
|
|
|
<code>0.015 x pixels</code> cm. For example, if the width of an image is
|
|
|
|
|
400 pixels, the width in a latex file will be almost 6cm.</p>
|
|
|
|
|
<p>A file <code>main.tex</code> is the root file of all the generated
|
|
|
|
|
latex files. It has <code>\input</code> commands, which inserts each
|
|
|
|
|
section file, between <code>\begin{document}</code> and
|
|
|
|
|
<code>\end{document}</code>. It also has <code>\input</code>, which
|
|
|
|
|
inserts <code>helper.tex</code>, in the preamble. Two files
|
|
|
|
|
<code>main.tex</code> and <code>helper.tex</code> are created by
|
|
|
|
|
<code>lib/lib_gen_main_tex.rb</code>. It has a sample markdown code and
|
|
|
|
|
converts it witn <code>pandoc -s</code>. Then, it extracts the preamble
|
|
|
|
|
in the generated file and puts it into <code>helper.tex</code>. You can
|
|
|
|
|
customize <code>helper.tex</code> by modifying
|
|
|
|
|
<code>lib/lib_gen_main_tex.rb</code>.</p>
|
|
|
|
|
<p>Finally, lualatex compiles the <code>main.tex</code> into a pdf
|
|
|
|
|
file.</p>
|
|
|
|
|
<p>If you want to clean <code>latex</code> directory, type
|
|
|
|
|
<code>rake clobber</code> or <code>rake cleanlatex</code></p>
|
2022-04-25 17:01:44 +09:00
|
|
|
|
<pre><code>$ rake clobber</code></pre>
|
2022-04-17 20:54:42 +09:00
|
|
|
|
<p>This removes all the latex source files and a pdf file.</p>
|
2022-04-21 23:53:28 +09:00
|
|
|
|
</div>
|
|
|
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/js/bootstrap.bundle.min.js" integrity="sha384-MrcW6ZMFYlzcLA8Nl+NtUVF0sA7MsXsP1UyJoMp4YLEuNSfAP+JcXn/tWtIaxVXM" crossorigin="anonymous"></script>
|
|
|
|
|
</body>
|
|
|
|
|
</html>
|