2020-12-21 13:12:05 +01:00
|
|
|
# How to build Gtk4 Tutorial
|
|
|
|
|
|
|
|
## Src.md file and .md file (markdown file)
|
|
|
|
|
|
|
|
This tutorial uses 'github flavored markdown', which is often shortened as GFM.
|
|
|
|
We will call it `markdown' as a simple form in this document.
|
|
|
|
If you are not familiar with it, refer the website [github flavoer markdown spec](https://github.github.com/gfm/).
|
|
|
|
|
|
|
|
However, if you want to generate html or latex using pandoc, you need to use the markdown within the syntax common to GFM and pandoc.
|
|
|
|
|
|
|
|
### Definition
|
|
|
|
|
|
|
|
Src.md is similar to markdown but it has two commands which isn't included in markdown.
|
|
|
|
They are @@@ command and $$$ command.
|
|
|
|
|
|
|
|
@@@ C\_source\_file \[function_list\]
|
|
|
|
|
|
|
|
This command includes the C source file, but if a function list is given, only the functions in the C source file are included.
|
2021-01-09 07:35:06 +01:00
|
|
|
If no function list is given, the command can include any text files even it is not C source file.
|
2020-12-21 13:12:05 +01:00
|
|
|
|
|
|
|
$$$
|
|
|
|
shell command
|
|
|
|
... ...
|
|
|
|
$$$
|
|
|
|
|
|
|
|
This command executes the shell command and substitutes the strings in the standard output for the lines between $$$ inclusive.
|
|
|
|
|
2021-01-09 07:35:06 +01:00
|
|
|
These two commands are carried out by scripts src2md.rb, which is described in the next subsection.
|
2020-12-21 13:12:05 +01:00
|
|
|
|
|
|
|
### Conversion
|
|
|
|
|
|
|
|
A ruby script src2md converts src.md file to md file.
|
|
|
|
|
|
|
|
ruby src2md.rb src.md_file md_file
|
|
|
|
|
|
|
|
This script recognizes and carrys out the commands described in the previous subsection.
|
2021-01-09 07:35:06 +01:00
|
|
|
For example, it is assumed that there are two files sample.src.md and sample.c, which have contents as follows.
|
2020-12-21 13:12:05 +01:00
|
|
|
|
|
|
|
$ cat sample.src.md
|
|
|
|
The following is the contents of the file 'sample.c'.
|
|
|
|
|
|
|
|
@@@ sample.c
|
|
|
|
|
|
|
|
$ cat sample.c
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
int
|
|
|
|
main(int argc, char **argv) {
|
|
|
|
printf("Hello world.\n");
|
|
|
|
}
|
|
|
|
|
2021-01-09 07:35:06 +01:00
|
|
|
Now, convert sample.src.md to a markdown file sample.md.
|
2020-12-21 13:12:05 +01:00
|
|
|
|
|
|
|
$ ruby src2md.rb sample.src.md sample.md
|
|
|
|
$ cat sample.md
|
|
|
|
The following is the contents of the file 'sample.c'.
|
|
|
|
|
2021-01-09 07:35:06 +01:00
|
|
|
#include <stdio.h>
|
2020-12-21 13:12:05 +01:00
|
|
|
|
2021-01-09 07:35:06 +01:00
|
|
|
int
|
|
|
|
main(int argc, char **argv) {
|
|
|
|
printf("Hello world.\n");
|
|
|
|
}
|
2020-12-21 13:12:05 +01:00
|
|
|
|
|
|
|
Compare sample.src.md and sample.md.
|
|
|
|
The contents of sample.c is substituted for the line `@@@ sample.c`.
|
2021-01-09 07:35:06 +01:00
|
|
|
In addition for spaces are added at the top of each line of sample.c.
|
2020-12-21 13:12:05 +01:00
|
|
|
|
|
|
|
These two commands have two advantages.
|
|
|
|
|
|
|
|
1. Less typing.
|
|
|
|
2. You don't need to modify your src.md file, even if the C sourcefile, which is included by @@@ command, is modified.
|
|
|
|
In the same way, any upgrade of the shell commands described between $$$ commands doesn't affect the src.md file.
|
|
|
|
|
2021-01-09 07:35:06 +01:00
|
|
|
There's a method `src2md` in the src2md.rb script.
|
2020-12-21 13:12:05 +01:00
|
|
|
This method converts src.md file into md file.
|
|
|
|
This method is also used in other ruby scripts like Rakefile.
|
|
|
|
|
|
|
|
## Directory structure
|
|
|
|
|
2021-01-09 07:35:06 +01:00
|
|
|
There are five directories under `gtk4_tutorial` directory.
|
|
|
|
They are `src`, `image`, `html`, `latex` and `lib`.
|
2020-12-21 13:12:05 +01:00
|
|
|
|
2021-01-09 07:35:06 +01:00
|
|
|
-src: This directory contains src.md files and C-related source files.
|
2020-12-21 13:12:05 +01:00
|
|
|
-image: This directory contains image files like png or jpg.
|
2021-01-09 07:35:06 +01:00
|
|
|
-html: This directory is empty at first. A ruby script will convert src.md files to html files and store them in this directory.
|
|
|
|
-latex: This directory is empty at first. A ruby script will convert src.md files to latexl files and store them in this directory.
|
2020-12-21 13:12:05 +01:00
|
|
|
-lib: This directory includes ruby library files.
|
|
|
|
|
|
|
|
### Src and top directories
|
|
|
|
|
2021-01-09 07:35:06 +01:00
|
|
|
Src directory contains src.md files and C-related source files.
|
|
|
|
The top directory, which is gtk\_tutorial directory, contains md files correspond to src.md files in src directory.
|
2020-12-21 13:12:05 +01:00
|
|
|
They are generated by scripts like src2md.rb.
|
|
|
|
However, usually they are generated by Rakefile.
|
|
|
|
|
|
|
|
Md files are generated from src.md files, so most of the lines in each md file corresponds to the lines in the original src.md file.
|
|
|
|
But some lines in md files don't have their original lines and they are newly generated by ruby scripts.
|
|
|
|
Those are mainly links to other md files.
|
|
|
|
In addition, readme.md file, which have title, table of contents and abstract, is generated by ruby script
|
|
|
|
and it doesn't have an original src.md file.
|
|
|
|
|
|
|
|
### The name of files in src directory
|
|
|
|
|
|
|
|
Each file in src directory is a section of the whole document.
|
|
|
|
The name of the files are "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 section 1, section 5 and section 12 respectively.
|
|
|
|
|
|
|
|
### C source file directory
|
|
|
|
|
|
|
|
Src.md files might have @@@ commands and they include C source files.
|
|
|
|
Such C source files are located in the src directory or its subdirectories.
|
|
|
|
|
|
|
|
Usually, those C files are compiled and tested.
|
|
|
|
At that time, some auxiliary files and target file like a.out are generated.
|
|
|
|
If you locate the C source files under src directory, those temporary files make the directory messy.
|
|
|
|
Therefore, It is a good idea to make subdirectories under src directory and put each C source file under the corresponding subdirectory.
|
|
|
|
|
|
|
|
The name of the subdirectories should be independent of section names.
|
|
|
|
It is because of renumbering, which will be explained in the next subsection.
|
|
|
|
|
|
|
|
### Renumbering
|
|
|
|
|
|
|
|
Sometimes you want to insert a section.
|
|
|
|
For example, inserting 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 it must change to section 5 and the following sections also must be added by one.
|
|
|
|
|
|
|
|
This renumbering is done by a ruby script `renumber.rb`.
|
|
|
|
|
|
|
|
- It changes file names.
|
|
|
|
- If there are references to sections in src.md files, the section numbers will be automatically renumbered.
|
|
|
|
|
|
|
|
## Rakefile
|
|
|
|
|
2021-01-09 07:35:06 +01:00
|
|
|
Rakefile is a similar file to Makefile but controlled by rake, which is a make-like program written in ruby.
|
2020-12-21 13:12:05 +01:00
|
|
|
Rakefile has the following tasks.
|
|
|
|
|
|
|
|
- md: generate markdown files. This is the default.
|
|
|
|
- html: generate html files.
|
|
|
|
- latex: generate latex files and a pdf file, which is generated by latex.
|
|
|
|
- all: generate md, html, latex and pdf files.
|
|
|
|
|
|
|
|
If renumbering is necessary, rake does it before the tasks above.
|
|
|
|
|
|
|
|
### Generate markdown files
|
2021-01-09 07:35:06 +01:00
|
|
|
|
|
|
|
Markdown files are generated by rake.
|
|
|
|
|
|
|
|
$ rake
|
|
|
|
|
|
|
|
All the markdown files are located under the top directory (`gtk4_tutorial` directory).
|
|
|
|
They are translated from src.md files except `Readme.md`, which is newly created.
|
|
|
|
When translated, it is added a navigation line at the top and bottom.
|
|
|
|
|
|
|
|
If you want to clean the directory, that means remove all the generated markdown files, type `rake clean`.
|
|
|
|
|
|
|
|
$ rake clean
|
|
|
|
|
|
|
|
`Readme.md` is shown below the code directory in the github repository.
|
|
|
|
And `Readme.md` includes links to each markdown files.
|
|
|
|
Therefore, the repository not only stores source files but also shows the tutorial in it.
|
|
|
|
|
2020-12-21 13:12:05 +01:00
|
|
|
### Generate html files
|
2021-01-09 07:35:06 +01:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
Type `rake html` to generate html files.
|
|
|
|
|
|
|
|
$ rake html
|
|
|
|
|
|
|
|
The files are located under html directory.
|
|
|
|
`index.html` is the top html file.
|
|
|
|
If you want to clean `html` directory, type `rake cleanhtml`
|
|
|
|
|
|
|
|
$ rake cleanhtml
|
|
|
|
|
|
|
|
Every html file has stylesheet in its header.
|
|
|
|
This comes from `header` string in `Rakefile`.
|
|
|
|
You can customize the style by modifying `Rakefile`.
|
|
|
|
|
2020-12-21 13:12:05 +01:00
|
|
|
### Generate latex files and a pdf file
|