Makrdown compiler for music grids and structures
Project description
# Music Grid Markdown
Write formatted music grids (chords and structures), with live preview.
The output are well formatted music grids, that you can view or print. Here is an example:
![](agrid.jpg)
The input is a text file written in a special *markdown* syntax called "music grid markdown". Here is the script that produced the grid above:
```
# The Tune title
## A super cool subtitle
Author: The Author // the composer's name
Copyright: Relevant Copyright
// this is a line comment
- [INTRO]x2 "Drums play 8 bars".
- [A]x2 Play in a certain way.
4/4 [: (Tacet first) Dm | (1.) Dm A7 :](2.) Dm D7 |
| G | % | % | A7 Dm |
%vspace%
- [B]x2 Play in a certain way.
| Gm | (Break!) Dm - - - | === |
| (solo trumpet) -7- .l | A7 Dm |
- [A]x2 -> [B]x2 -> [CODA]
```
## Install and use
MusicMarkdown is an executable python module.
1. Download and install [Python3](https://www.python.org/downloads/) (if it is not installed already in your system)
2. Install the module with this command in a terminal window
pip3 install musicmarkdown
3. Create your music markdown script (or download [the example one](script.txt)).
4. Use a terminal window to goto the folder that contains your script and run this command:
python3 -m musicmd script.txt
This will generate an html file that you can open with your web browser. Then you can print it or save it as PDF etc.
If you want to open a **live preview** that changes as you edit the script, you have two options:
Maybe the easiest is to run this command in a terminal:
python3 -m musicmd script.txt serve
It will start a built-in web server and give you a link to open in a web browser. This will display the preview of the grid and show live modifications as you change (and save) your script. This option needs javascript enabled in your browser (which is usually the case, unless you disabled it on purpose)
Another option is to use an external preview, for example [Atom](https://atom.io)'s "Preview HTML" extension. This allows to have the script and the preview in the same editor. In this case run this command in a terminal:
python -m musicmd script.txt watch
and then open both your script and the generated html file and start a preview.
## Music grid markdown syntax
### Title
Title and subtitle are specified with leading `#` as in standard markdown syntax.
* `Author:` and `Copyright:` specify the corresponding field.
The title section is not compulsory.
### Comments
Comments start with `\\`
### Sections
sections are specified with a `-` at the beginning of the line.
Sections may contain:
* section names `[NAME]`
* repetitions `[NAME]x2`
* right arrows `->`
* normal text
### bars
Bars start with one of
* `|` normal
* `[` double open
* `]`double close
* A bar can be preceded by a tempo sign e.g. `3/4`
* A bar can be preceeded or followed by a repetition sign `:`
* modifiers `.l` (long) and `.s` (short) can be added in a bar to try to modify its size (works better for pauses and pentagrams).
Bars may contain a *case* text in brackets. values `1.` and `2.` are special and generate repetition cases.
### vertical space
Extra vertical space can be added with one of these:
* `%vspace%`
* `%vspace-big%`
* `%vspace-small%`
A bar may contain:
* `===` a pentagram
* `-4-` a pause
* `-` an empty space
* any other text will be interpreted as chord
* evry object in a bar must be separated by `whitespace`
Write formatted music grids (chords and structures), with live preview.
The output are well formatted music grids, that you can view or print. Here is an example:
![](agrid.jpg)
The input is a text file written in a special *markdown* syntax called "music grid markdown". Here is the script that produced the grid above:
```
# The Tune title
## A super cool subtitle
Author: The Author // the composer's name
Copyright: Relevant Copyright
// this is a line comment
- [INTRO]x2 "Drums play 8 bars".
- [A]x2 Play in a certain way.
4/4 [: (Tacet first) Dm | (1.) Dm A7 :](2.) Dm D7 |
| G | % | % | A7 Dm |
%vspace%
- [B]x2 Play in a certain way.
| Gm | (Break!) Dm - - - | === |
| (solo trumpet) -7- .l | A7 Dm |
- [A]x2 -> [B]x2 -> [CODA]
```
## Install and use
MusicMarkdown is an executable python module.
1. Download and install [Python3](https://www.python.org/downloads/) (if it is not installed already in your system)
2. Install the module with this command in a terminal window
pip3 install musicmarkdown
3. Create your music markdown script (or download [the example one](script.txt)).
4. Use a terminal window to goto the folder that contains your script and run this command:
python3 -m musicmd script.txt
This will generate an html file that you can open with your web browser. Then you can print it or save it as PDF etc.
If you want to open a **live preview** that changes as you edit the script, you have two options:
Maybe the easiest is to run this command in a terminal:
python3 -m musicmd script.txt serve
It will start a built-in web server and give you a link to open in a web browser. This will display the preview of the grid and show live modifications as you change (and save) your script. This option needs javascript enabled in your browser (which is usually the case, unless you disabled it on purpose)
Another option is to use an external preview, for example [Atom](https://atom.io)'s "Preview HTML" extension. This allows to have the script and the preview in the same editor. In this case run this command in a terminal:
python -m musicmd script.txt watch
and then open both your script and the generated html file and start a preview.
## Music grid markdown syntax
### Title
Title and subtitle are specified with leading `#` as in standard markdown syntax.
* `Author:` and `Copyright:` specify the corresponding field.
The title section is not compulsory.
### Comments
Comments start with `\\`
### Sections
sections are specified with a `-` at the beginning of the line.
Sections may contain:
* section names `[NAME]`
* repetitions `[NAME]x2`
* right arrows `->`
* normal text
### bars
Bars start with one of
* `|` normal
* `[` double open
* `]`double close
* A bar can be preceded by a tempo sign e.g. `3/4`
* A bar can be preceeded or followed by a repetition sign `:`
* modifiers `.l` (long) and `.s` (short) can be added in a bar to try to modify its size (works better for pauses and pentagrams).
Bars may contain a *case* text in brackets. values `1.` and `2.` are special and generate repetition cases.
### vertical space
Extra vertical space can be added with one of these:
* `%vspace%`
* `%vspace-big%`
* `%vspace-small%`
A bar may contain:
* `===` a pentagram
* `-4-` a pause
* `-` an empty space
* any other text will be interpreted as chord
* evry object in a bar must be separated by `whitespace`
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
musicmarkdown-0.3.tar.gz
(7.9 kB
view hashes)
Built Distribution
Close
Hashes for musicmarkdown-0.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4712999ce21478c43ab054d7fac8e1676b472daf7e171a1baeb4d8258ad8f0bf |
|
MD5 | 94ff9419d30ac74ba1ef28b2188dc8de |
|
BLAKE2b-256 | 49c6ca5614a466698d0b024e22e53de60638e313037aa19a03a220edb69c0450 |