-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.txt
81 lines (60 loc) · 2.21 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
====================================
Nano LP -- Literate Programming tool
====================================
`Project HOME <http://code.google.com/p/nano-lp/>`_
`Presentation <http://nano-lp.googlecode.com/files/present.pdf>`_
`Documentation <http://code.google.com/p/nano-lp/w/list>`_
`Discussion <http://groups.google.com/group/nano-lp-discuss>`_
`ChangeLog <http://code.google.com/p/nano-lp/wiki/Changes>`_
Introduction
============
It's new literate programming (LP) tool. Main idea is too avoid processing
document (LP source) format, so input document format is supported by it's
traditional external tool. So it's possible to have favourite workflow: WYSIWYG
editing/text processing/converting with you favourite tool/suite
(OpenOffice/Markdown tool/TeX/etc.).
At the moment, supported input formats are:
* Markdown/MultiMarkdown
* OpenOffice/LibreOffice
* Creole
* reStructuredText
* TeX/LaTeX
* Txt2Tags
* Asciidoc
* HTML/XML
* ... and any compatible
Supported schemes are:
* FSfile - <path>
* FSURLfile - file:///<path>
* HTTPfile - http://<url><:port?>/<path>
* FTPfile - ftp://<url><:port?>/<path>
* SHELLfile - shell:<path-to-exec>#<options>
* ZIPfile - zip:<path-to-zip>#<path-in-zip>
with crypting (ZIP), authorizing (FTP, HTTP).
Main features
=============
* definition of command (macros) with placeholders in the body (code chunk)
* variables dictionaries (for substitution of placeholders)
* pasting command code chunk with substitution of placeholders
* definition of multiple parts code-chunks (for wrapping, etc.)
* joining, 'ending', etc. several code chunks
* 'globbing' commands when paste
* including one file to another (library)
* custom surround symbols (different for doc and code)
* custom event handlers (filters in chain/pipe manner)
* supporting URLs in file names (read via HTTP)
* prepare of HTML files (with LP commands) for Web publishing
* generating cross-references file
* auto-detecting of cycles
* configurable via simple .INI like file
* works with Python 2.7 - Python 3+
* works with Unicode (UTF8)
* highly extendible
Installation
============
Install Python (2.7 or 3+) first, then run::
$ python setup.py install
Then run::
$ nlp.py -h
or::
$ python path-to-scripts/nlp.py -h