Thothglyph Language

はじめに

この文書は Thothglyph Language (トトグリフ言語) のリファレンスマニュアルです。

言語の特徴

Thothglyph Language は、マークアップシンボルの多くに非 ASCII 文字を使っています。 これらの文字を使うことで、既存のプログラミング言語やマークアップ言語の構文との衝突を避け、 様々なソースコードやドキュメントをエスケープなしで文書に含められます。 また、シンボルに使用可能な文字が増えたことで、視認のしやすさと構文の単純化を両立できます。

一方で、通常の文書にはあまり出現しない文字をシンボルに使用しているため、書きにくく感じるかもしれません。 その書きにくさを軽減するために各種エディタ向けに Thothglyph 用の入力補助やシンタックスハイライトのプラグインを用意しています。 例として VSCode拡張 があります。

Preprocess

Thothglyph はドキュメントを構文解析する前に簡単なプリプロセスを実行します。

Config

⑇⑇⑇のみの行で囲まれたテキストは Config ブロックとなります。 ドキュメントの最初のみ記述可能な構文です。 ドキュメントの設定を Python 言語で記述します。

⑇⑇⑇
title = 'Document Title'
version = '1.2.3'
author = cmd("git config user.name")
attrs = {'author': 'Foo Bar'}
templatedir = './my_template'  # copy from thothglyph/template
theme = 'preview'  # or 'default'
⑇⑇⑇

後述の Include ロールで外部ファイルをインクルードできます。

⑇⑇⑇
¤include⸨./conf.py⸩
⑇⑇⑇

代表的な設定には次のものがあります。

title

ドキュメントのタイトル。表紙のタイトルやファイル名に反映される。

version

ドキュメントのバージョン。

author

ドキュメントの著者。

date

ドキュメントの日付。

attrs

ドキュメント内の変数。

templatedir

出力ファイルのテンプレートディレクトリ。

theme

テンプレートのテーマ。テンプレートは最終的に <templatedir>/<output-format>/<theme>/ が選択される。

コマンドラインと Config

コマンドラインでいくつかの Config 設定を指定できます。コマンドラインの設定はドキュメント内の設定より優先されます。

–template

templatedir を指定します。

相対パスで設定した場合、ドキュメント内の templatedir は最初の入力ファイルがあるディレクトリを起点にしますが、 コマンドラインの設定はコマンド実行時のカレントディレクトリを起点にします。

–theme

theme を指定します。

ControlFlow

1文字のの後に特定のキーワードを記入すると ControlFlow となります。 ドキュメントの一部分を条件により表示/非表示できます。 サポートしているキーワードは if, elif, end です。 条件には Python 構文が使用でき、Config ブロックで定義した attrs の値を使用できます。

⑇if author == 'Smith'
Profile about Smith.
⑇elif author == 'Tanaka'
Profile about Tanaka.
⑇end

Comment

2文字のに続く行末までの文字列はコメントとなります。 コメントはプリプロセスの段階で文中から削除されます。

This line includes comment --> ⑇⑇ This is comment.

Blocks

ドキュメントはブロックの木構造で構成されています。 ブロックは基本的に行単位でまとまっています。

Section

1文字以上のの後に空白とテキストを記入すると Section (見出し) となります。 ドキュメントの最も大枠となるブロックです。 の文字数が見出しレベルに相当します。

▮ Section Lv.1 Title
▮▮ Section Lv.2 Title
▮▮▮ Section Lv.3 Title
▮▮▮▮ Section Lv.4 Title
▮▮▮▮▮ Section Lv.5 Title
▮▮▮▮▮▮ Section Lv.6 Title
▮▮▮▮▮▮▮ Section Lv.7 Title

見出しレベル1, 2のみ ATX-style の記法をサポートしています。 見出しの次の行にレベル1では=、レベル2では-を4文字以上記入します。

Section Lv.1 ATX-style
======================

Section Lv.2 ATX-style
----------------------

各見出しにはラベルを付けられます。ラベルは後述の Cross Reference で利用できます。

▮ Section Title ⟦sect1⟧

の末尾に*を記入すると見出しの番号付けをスキップし、目次に表示されなくなります。 +を記入すると見出しの番号付をスキップしますが、目次には表示されます。

▮ まえがき (1. まえがき)
▮* 目次 (目次)
▮ XXとは (2. XXとは)
▮ YYとは (3. YYとは)

Paragraph

通常の文字から始まる行は Paragraph (段落) となります。 Paragraph は空行が出現するまで継続します。

これは段落1のテキストです。
改行しても段落は継続します。

これは段落2のテキストです。

段落終端記号を行末に挿入すると空行なしで次の段落に移行できます。

これは段落1のテキストです。⊹
これは段落2のテキストです。

Bullet List

1文字以上のと空白から始まるブロックは Bullet List (箇条書きリスト) となります。

• apple
• orange
• grape

の文字数がリストのレベルに相当します。

• List item 1
•• List item 1-1
••• List item 1-1-1
••• List item 1-1-2
•• List item 1-2
••• List item 1-2-1
••• List item 1-2-2
• List item 2

リストの各アイテムの本文には複数ブロックを記入できます。 行頭のインデントを揃える必要はありません。

• Item 1 paragraph 1.
new line.

paragraph 2.

• Item 2 paragraph 1.
new line.

paragraph 2.

リストを終了して別のリストや段落を開始するには、そのレベルと同数のから成る行を記入します。

• My favorite food
•• apple
•• orange
•• grape
◃◃
•• sushi
•• tempura
◃
New Paragraph.

Ordered List

1文字以上のと空白から始まるブロックは Ordered List (順序付きリスト) となります。 の文字数がリストのレベルに相当します。

꓾ List item 1
꓾꓾ List item 1-1
꓾꓾꓾ List item 1-1-1
꓾꓾꓾ List item 1-1-2
꓾꓾ List item 1-2
꓾꓾꓾ List item 1-2-1
꓾꓾꓾ List item 1-2-2
꓾ List item 2
◃
꓾ List item new 1

Description List

1文字以上のから始まり途中 ``\ \ (記号のあと空白が含まれる)ブロックは Description List (説明リスト) となります。 最初の\ ``ᛝの文字数がリストのレベルに相当します。 で囲まれた文字列は用語、以降は本文です。

ᛝTerm 1ᛝ List item 1
ᛝᛝTerm 1-1ᛝ List item 1-1
ᛝᛝᛝTerm 1-1-1ᛝ List item 1-1-1
ᛝᛝᛝTerm 1-1-2ᛝ List item 1-1-2
ᛝᛝTerm 1-2ᛝ List item 1-2
ᛝᛝᛝTerm 1-2-1ᛝ List item 1-2-1
ᛝᛝᛝTerm 1-2-2ᛝ List item 1-2-2
ᛝTerm 2ᛝ List item 2
◃
ᛝTerm 1ᛝ List item new 1

用語と本文は通常横並びで出力されます。 用語の終端にを記入すると用語の後改行して本文を出力します。

ᛝTerm 1◃ᛝ List item 1
ᛝTerm 2◃ᛝ List item 2

Check List

1文字以上の[ ]と空白から始まるブロックは Check List (チェックリスト) となります。 の文字数がリストのレベルに相当します。 チェックボックスの状態は[ ], [x], [-]の3つを選択できます。

•[ ] List item 1
••[-] List item 1-1
•••[x] List item 1-1-1
•••[ ] List item 1-1-2
••[x] List item 1-2
•••[x] List item 1-2-1
•••[x] List item 1-2-2
•[ ] List item 2
◃
•[x] List item new 1

複合リスト

これまで説明したリストは別種のリストを入れ子にできます。 ただしリストのレベルは種類に関係なく設定する必要があります。

• List item 1
꓾꓾ List item 1-1
ᛝᛝᛝAᛝ List item 1-1-1
ᛝᛝᛝBᛝ List item 1-1-2
꓾꓾ List item 1-2
•••[x] List item 1-2-1
•••[ ] List item 1-2-2
• List item 2

リストの汎用的な字下げ

行の先頭で同じシンボルを続ける代わりに、``𐬹 ``(記号のあと空白が含まれる)でもリストのレベルを下げられます。

先の複合リストは次のようにも書けます。

• List item 1
𐬹 ꓾ List item 1-1
𐬹 𐬹 ᛝAᛝ List item 1-1-1
𐬹 𐬹 ᛝBᛝ List item 1-1-2
𐬹 ꓾ List item 1-2
𐬹 𐬹 •[x] List item 1-2-1
𐬹 𐬹 •[ ] List item 1-2-2
• List item 2

Scoped Blocks

ブロックのスコープ (開始位置と終了位置) をで指定できます。 このブロックは Scoped Blocks となります。

1行で複数段落を記述したり、リストのレベルを気にすることなく入れ子にできます。

⦃Paragraph 1.⦄⦃Paragraph 2.⦄

• ⦃List item 1
  ꓾ ⦃List item 1-1
    ᛝAᛝ List item 1-1-1
    ᛝBᛝ List item 1-1-2
    ⦄
  ꓾ ⦃List item 1-2
    •[x] List item 1-2-1
    •[ ] List item 1-2-2
    ⦄
  ⦄
• List item 2

Footnote List

1文字だけの[^ID]と空白から始まるブロックは Footnote List (脚注リスト) となります。 リストは入れ子にできません。 文中の脚注の書き方は Footnote 参照。

•[^1] This is footnote.
•[^2] This is footnote too.

Reference List

1文字だけの[#ID]と空白から始まるブロックは Reference List (参照リスト) となります。 リストは入れ子にできません。 文中の参照の書き方は Refenrence 参照。

•[#1] The Awesome Document, 1990, Anonymous.
•[#2] The theory of theory, 2000-01-01, Anonymous.

Basic Table

|で囲まれた行が連続するブロックは Basic Table となります。 基本的な構文は既存の軽量マークアップ言語のものと似ています。

| data11 | data12 | data13 |
| data21 | data22 | data23 |

:-:で構成された行はヘッダ部とデータ部を分割し、セル内のテキストアライメントを設定します。 ヘッダ部がない場合はテキストアライメントのみ設定します。 +-は左アライメントかつセル幅をページ幅に合うよう調節します。(latex, pdfのみ)

| head11 | head12 | head13 | head14 |
| head21 | head22 | head23 | head24 |
|:-------|:------:|-------:|+-------|
| data11 | data12 | data13 | data14 |
| data21 | data22 | data23 | data24 |
| a | b | c | d |

セルの内容をもしくはで開始することで、セルを結合できます。

| head11 | head12 | ⏴      | ⏴      |
|--------|--------|--------|--------|
| data11 | data12 | data13 | data14 |
| data21 | data22 | ⏴      | data24 |
| data31 | ⏶      | ⏴      | ⏶      |
| data41 | data42 | ⏴      | data44 |
| data51 | data52 | data53 |⏴data54 |
| data61 |⏶data62 |⏶data63 |⏴data64 |

先頭に ⟦⟧ で囲まれた行を挿入することでオプションを記述できます。

⟦type="long" w="100%" widths="1,2,3" fontsize="small"⟧
| data11 | data12 | data13 |
| data21 | data22 | data23 |

指定できるオプションは次の通りです。

type

表のタイプを指定します。long のみ指定できます。 long を指定すると PDF 形式の出力時にページをまたがる表を生成できます。

w

表の幅を指定します。単位として pt と % が指定できます。

widths

表の各列の幅の相対サイズを指定します。

align

表の各列のアライメントを指定します。l c r x xc xr から指定できます。 それぞれ左、中央、右、左(幅調整)、中央(幅調整)、右(幅調整)を表します。

colspec

widths と align を同時に指定できます。 5l,3c,1r のように指定します。

fontsize

表全体のフォントサイズを指定します。mediam small x-small から指定できます。

List Table

|¤¤¤という行から始まり¤¤¤という行で終わるブロックは List Table となります。

(v0.2.9 以降 |===という行から始まり===|という行で終わる書式は非推奨となりました。)

List Table 内はレベル2以上の Bullet List で構成されます。 レベル1の文は無視され、レベル2のリストアイテムが各セルの内容になります。 レベル3のリストは表内のレベル1のリストに置き換わります。

|¤¤¤
• •• data11
  •• data12
     ••• item1
     ••• item2
     ••• item3
  •• data13
• •• data21
  •• data22
  •• data23
¤¤¤

※見やすくするためにインデントしていますが、インデントは必須ではありません。

でリストを分割すると、第1リストがヘッダ、第2リストがデータになります。

|¤¤¤
• •• head1
  •• head2
  •• head3
◃
• •• data11
  •• data12
  •• data13
• •• data23
  •• data22
  •• data23
¤¤¤

Basic Tableと 同様にセルの内容をもしくはで開始することで、セルを結合できます。

|¤¤¤
• •• head1
  •• head2
  •• ⏴
◃
• •• data11
  •• data12
  •• data13
• •• data23
  •• ⏶data22
  •• data23
¤¤¤

開始行の|¤¤¤に続き⟦⟧でオプションを記述できます。

|¤¤¤⟦align="lcr"⟧
• •• data11
  •• data12
  •• data13
• •• A
  •• B
  •• C
¤¤¤

Figure

後述の Role という記法で図や表にキャプションを付けられます。 実際にキャプションが表示される位置は出力形式やテンプレートに依存します。

¤figure⸨caption⸩
¤image⸨./tglyph_64.png⸩
¤figure⸨caption⸩
| head11 | head12 | head13 |
| head21 | head22 | head23 |
|--------|--------|--------|
| data11 | data12 | data13 |
| data21 | data22 | data23 |
| data31 | data32 | data33 |
¤figure⸨caption⸩
[Not Image.]

Quote Block

>と空白で始まる行が連続したブロックは Quote Block (引用ブロック) となります。

> Quote text text text.
> new line text.
> > Nested quote text.
> return first quote.

> New quote text.

Code Block

⸌⸌⸌という行で囲まれたブロックは Code Block となります。 始めの⸌⸌⸌に続き言語名を記入することでシンタックスハイライトのヒントを与えます。

⸌⸌⸌c
#include <stdio.h>
# include <stdlib.h>
int main()
{
printf("Hello World!!\n");
exit(0);
}
⸌⸌⸌

後述の Include ロールで外部ファイルをインクルードできます。

⸌⸌⸌c
¤include⸨./example.c⸩
⸌⸌⸌

Custom Block

¤¤¤という行で囲まれたブロックは Custom Block となります。 始めの¤¤¤に続き拡張名を記入することで様々な拡張機能を実行します。 拡張名には math, graphviz , blockdiag , wavedrom を使用できます。

¤¤¤graphviz
digraph graph_name {
alpha;
beta;
alpha -> beta;
}
¤¤¤

後述の Include ロールで外部ファイルをインクルードできます。

¤¤¤graphviz
¤include⸨./graph1.dot⸩
¤¤¤

Horizontal Line

4文字以上の=もしくは-で始まる1行は Horizontal Line (水平線) となります。

paragraph

====

paragraph

Inline markup

ブロック内のいくつかのテキストにはインラインマークアップを適用できます。

Decoration

特定のシンボルでテキストを囲むことで、テキストを装飾できます。

装飾の種類は🙼強調🙼、⧫重要⧫、‗挿入‗、¬削除¬があります。
⧫🙼強調かつ重要🙼⧫のように入れ子にできます。
また⌃上付き文字⌃や⌄下付き文字⌄にもできます。
更に⁒変数⁒や⸌コード⸌も記入できます。

共通の終了シンボルを用いることもできます。

🙼強調⟠、⧫重要⟠、‗挿入⟠、¬削除⟠

Color Decoration

色を表すシンボルと終了シンボルでテキストを囲むことで、テキストの色を指定できます。 指定できる色は5種類です。

text 🔴color1⟠ 🟡color2⟠ 🟢color3⟠ 🔵color4⟠ 🟣color5⟠ text.

ネストした場合内側の色が反映されます。

🔵Color 🟣Decoration⟠ can⟠ be nested.

Linebreak

段落内の改行は多くの出力形式で無視されますが、を挿入すると改行を表す特殊文字に変換されます。 例えば HTML 出力の場合 <br > となります。

First line text.↲
Second line text.

Role

¤ロール名⟦オプション⟧⸨本文⸩という構文は Role となります。 ⟦オプション⟧は省略可能です。

Image Role

画像を挿入します。

Thothglyph のアイコンはこちら: ¤image⸨./tglyph_64.png⸩

オプションで画像の幅を設定できます。縦横比は固定です。

ピクセル数で指定: ¤image⟦w="150px"⟧⸨./tglyph_64.png⸩

ページ幅の割合で指定: ¤image⟦w="20%"⟧⸨./tglyph_64.png⸩

Include Role

外部のtglyphファイルを解釈して挿入します。 ファイルのパスは最初の入力ファイルを基点とした相対パスで指定します。

¤include⸨./sub1.tglyph⸩

Keyboard / Button / Menu Role

テキストの装飾の一種です。

Type ¤kbd⸨Ctrl A⸩ right now.

Click ¤btn⸨OK⸩ or ¤btn⸨Cancel⸩.

Select ¤menu⸨File > Quit⸩ to exit application.

Cross Reference

Hyper Link と同じ構文でURLの代わりに文書中のラベル名を指定すると Cross Reference となります。 テキストを指定しない場合、ラベルの参照先から取得します。

Cross refecence to section 1: ⸨sect1⸩!

⟦Here⟧⸨sect1⸩ is the same!

HTML や Markdown のような ファイル名#アンカー 形式もサポートしています。

A section in same file: ⸨#sect1⸩

A section in other file: ⸨other.tglyph#sect1⸩

First section in other file: ⸨other.tglyph⸩

Footnote

文中に[^ID]と記入すると Footnote となります。 別の場所で Footnote List ブロックに脚注の内容を記入します。 ID には数字も指定可能です。ただし本文中に出現した順に番号が割り振られるため数値に意味はありません。 ID は見出しレベル1以下で一意のものにする必要があります。 見出しレベル1が異なる Footnote List は参照できません。

The important text. [^1] And the important text too. [^2]

•[^1] This is footnote.
•[^2] This is footnote too.

Refenrence

文中に[#ID]と記入すると Reference となります。 別の場所で Reference List ブロックに参考文献の内容を記入します。 Reference List のリストには本文中で引用されていないものも含められます。 ID には数字も指定可能です。ただし Reference List のリスト順に番号が割り振られるため数値に意味はありません。

The important text. [#1] And the important text too. [#2]

•[#1] The Awesome Document, 1990, Anonymous.
•[#2] The theory of theory, 2000-01-01, Anonymous.
•[#3] Unreferenced bibliograpy I, 2XXX-XX-XX, Anonymous.
•[#4] Unreferenced bibliograpy II, 2XXX-XX-XX, Anonymous.

Replace

で囲まれた文字列は Config で attrs として定義した辞書をもとに置換できます。

Hello, I am ⁅author⁆.