forked from zeromq/gitdown
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathREADME.txt
212 lines (164 loc) · 9.55 KB
/
README.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
.set GIT=http://github.com/imatix/gitdown
[diagram]
/----------------------------------------------------------\+\
|/---------------------------------------------------------/||
|| /--+ +------+ +------\ /----\/+ +\ +\ +\ /------\ ||
|| \-\| \--\/--/ |+----\| |/---/|| || || || |/----\| ||
|| || || || || || || || || || || || ||
|| +---\ || || || || || || || || || || || ||
|| \--\| || || \/ || || || || || || || || ||
|| || || || /-----/| |\----/| |\--/\--/| || || ||
|| || \/ \/ +------/ \------/ \--------/ +/ \+ ||
|\-----/|+--------------------------------------------------/|
\-------/+---------------------------------------------------/
[/diagram]
Welcome To Gitdown
==================
Gitdown is a simple tool for writing documentation hosted on a github repository. It uses [ditaa][] to convert ascii diagrams into images, and produces [markdown][] documents that can be uploaded to your repository along with code. I made Gitdown so that we could write technical white papers and user guides as plain text (including diagrams) and publish them with a single "git push" command. Gitdown is a simpler version of the tool we use to maintain the [ØMQ][zeromq] [Guide][zguide].
Gitdown is written and maintained by Pieter Hintjens. Please use the issue [tracker][] for all comments and errata. This document was published on &date("dddd mmmm, yyyy") at &time(), and generated by the magic of Gitdown from $(INPUT).
This is version 2010.10.11 of Gitdown. Changelog:
* 2010.10.11: don't do symbol substitution in code blocks.
* 2010.10.09: added .toc token to generate table of contents.
Contents
--------
.toc 1
License
-------
Copyright (c) 2010 Pieter Hintjens
Copyright (c) 1996-2010 iMatix Corporation
This is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version.
Installation and Use
--------------------
The code is in the bin subdirectory. Here is how I install it on a new box:
sudo cp bin/* /usr/local/bin
export PERLLIB=$PATH # goes into .bash_profile
Gitdown includes Ditaa/0.9 and assumes that Ditaa goes into /usr/local/bin/ditaa0_9.jar. Feel free to propose a better design.
Gitdown assumes that these tools are already installed on your box, which is easy if you're running Linux:
* *ImageMagick*, specifically `mogrify`.
* *Perl*.
To use Gitdown, edit a text document much like this README.txt. Then:
gitdown myfile.txt
git add myfile.md images/
git commit -m "Hey, Gitdown is totally crazy!"
git push origin master
The images directory holds images for all documents in the current directory. You can write documents anywhere on the git tree but if they are not at the root you must tell Gitdown how to create a full image path by setting the SUBDIR symbol (see below).
How it Works
------------
Gitdown exploits github.com's willingness to serve image blobs and Markdown documents that refer to them. This means you can publish a document with correctly-formatted links, together with images, in a single Git operation. It is a neat and comfortable way to work. Kudos to Stathis Sideris for making Ditaa. Gitdown also adds a preprocessing layer for symbolic insertion and simple macros like 'table of contents'. This code was recycled from [htmlpp](http://legacy.imatix.com/html/htmlpp/), a HTML preprocessor that looked a lot like Markdown.
The Gitdown workflow is:
[diagram]
+-------------------+
| me.txt |
+-------------------+
| Text file in +---> Saved in git as source
| Gitdown format |
+---------+---------+
|
|
+----------------------------+
| |
v v
+---------+---------+ +---------+---------+
| me.md | | images.html |
+-------------------+ +-------------------+
| Markdown output | | Temporary HTML |
| cFDA| | to feed Ditaa |
+---------+---------+ +---------+---------+
| |
| |
| v
| +---------+---------+
: | |
References | Ditaa |
| | {o}|
| +---------+---------+
| |
| |
| v
| +---------+---------+
| | images/me_nnn.png |
+----------------->+-------------------+
| Image files |
| cFDA|
+-------------------+
Figure # - Gitdown workflow
[/diagram]
1. You edit a text file that contains text and diagrams in a single document.
2. You process this document with Gitdown to give a Markdown document plus a number of images in an images subdirectory.
3. You add the output (Markdown and images) to your commit set and push that to the repository.
4. The Markdown document is now readable, with images, via the github.com user interface.
This README acts as an example.
Gitdown Syntax Summary
---------------------
Gitdown is a pre-processor that adds these syntax elements on top of Markdown:
[diagram] Defines a ditaa diagram block
[/diagram] # represents diagram number 1..n
.- comment Comment line
.set name=value Sets Gitdown symbol
.sub oldval=newval Replaces oldval by newval in every line
.toc [top] Insert table of contents
.end Everything past this is ignored
$\(xxx) Value of variable, anywhere in text
$\(xxx?zzz) Value of variable, or zzz if undefined
%\(text?zzz) Value of environment variable, or zzz if undef
&abc\(text) Intrinsic function with arguments
time() Format current time as hh:mm:ss
date() Return current date value
date("picture") Format current date using picture
date("picture", date, lc) Format specified date using picture & language
week_day([date]) Get day of week, 0=Sunday to 6=Saturday
year_week([date]) Get week of year, 1 is first full week
julian_date([date]) Get Julian date for date
lillian_date([date]) Get Lillian date for date
date_to_days(date) Convert yyyymmdd to Lillian date
days_to_date(days) Convert Lillian date to yyyymmdd
future_date(days[,date]) Calculate a future date
past_date(days[,date]) Calculate a past date
date_diff(date1[,date2]) Calculate date1 - date2
image_height("image.ext") Get image height (GIF, JPEG)
image_width("image.ext") Get image width (GIF, JPEG)
file_size("filename",arg) Get size of file: optional arg K or M
file_date("filename") Get date of file
file_time("filename") Get time of file as hh:mm:ss
normalise("filename") Normalise filename to UNIX format
system("command") Call a system utility
lower("string") Convert string to lower case
upper("string") Convert string to upper case
The top argument for .toc tells it the top header level in the text. Lower levels are shown horizontally. E.g. this file has level 2 headers in the text and uses `.toc 1` to get these laid-out on a single row.
These symbols have special meaning:
* GIT defines the root HTTP URL of the git repository
* BRANCH defines the respository branch, defaults to 'master'
* SUBDIR defines the /sub/dir to the current file, if not empty
These symbols are predefined by gitdown for you:
* INPUT specifies the original input file name.
* SELF specifies the input file name without extension.
* OUTPUT specifies the current output file name,
Markdown Syntax Summary
-----------------------
This is an extract of the most useful Markdown syntax.
# Header 1 or follow by ===== on next line
## Header 2 or follow by ----- on next line
### Header 3
#### Header 4
> Blockquote can continue over multiple lines
* List item can continue over multiple lines
1. List item can continue over multiple lines
code block indented 4 spaces
<url> automatic link, e.g. <ph@imatix.com>
![alt](url) image link
[text](url) inline link
[text][] implicit reference link
[text]: url defined later in document
*emphasis* usually, italics
**strong** usually, bold
`Code` fixed-space font
* You can put HTML anywhere in your text.
* Blank lines separate paragraphs.
* For more details see the [markdown][] syntax page.
.- Reference
.-
[zeromq]: http://www.zeromq.com
[zguide]: http://zguide.zeromq.org
[tracker]: $(GIT)/issues
[markdown]: http://daringfireball.net/projects/markdown/syntax
[ditaa]: http://ditaa.org