a slide generator - intended to be used for sunday services with OBS
|  | 2 лет назад | |
|---|---|---|
| config | 2 лет назад | |
| slides | 2 лет назад | |
| utils | 2 лет назад | |
| .gitignore | 2 лет назад | |
| LICENSE | 3 лет назад | |
| README.md | 2 лет назад | |
| slidegen.py | 2 лет назад | |
| template.txt | 3 лет назад | 
As the name may partially imply, slidegen generates song slides as images - out of a plain text input file - intended for use with [OBS]() to livestream a typical (contemporary) Sunday church service.
This program is also intended to be used in conjunction with ssync, which is basically a wrapper script that automatically syncs a local copy with the remote slide repository, removes the old obs slides and lets the user interactively choose the new slides with a smart fuzzy finder.
Standalone use of slidegen is possible and can sure fit other use cases.
To add song slides to OBS or similar software as input sources, there exist the following obvious options:
Both of these processes have major downsides: They are hard to automate, take a long time to create the slides, have very limited to support for bulk operations on the song repository (like wanting to change the theme and layout of all slides or changing the metadata shared by a lot of songs) and maintaining is a lot harder because of bad portability and complex source files.
The only upside they have is that can be more intuitive for inexperienced computer users, but changing a text file template and uploading to a remote storage should not be too hard to manage and worth it as it has none of the above mentioned downsides.
As mentioned above, this program is not made to be executed directly. Therefore the commandline interface is not yet fully stable. Generally, the syntax is as follows
./slidegen.py SRC_PATH DEST_DIR PROMPT_INPUT
with SRC_PATH being the path to the song plain text file, DEST_DIR the output directory where the slide image file output is placed and PROMPT_INPUT
Here a short example:
./slidegen.py "../songrepo/Stille Nacht.txt" "~/Documents/Song Slides 1"
The file is divided into two what we will here call parts that are divided with at least one \n character and an arbitrary amount of lines that are either empty or only contain whitespace:
As the top of the file are these five metadata entries. We call them metadata strings:
As for the syntax, each line starts with the metadata string, followed by ": ", and ends with a non-empty string that acts as the value of the metadata string, which we call metadata value.  The structure is allowed only R and non-negative integers values separated by one comma each, which represents the structure or order in which to song is to be played by dividing the song into refrain and verses. The values in between the commas are called structure elements.
Hence to check if a line in the header has the correct syntax use the following regular expression: ^(?!structure)\S+: .+|^structure: ([0-9]+|R)(,([0-9]+|R))+$. What is not captured syntactically by this regex is that each metadata string and value pair must appear exactly once in the header.
The semantics of the other metadata values can be pretty much whatever you want, as long as they adhere to the syntax. Note also that the arrangement of lines doesn't have to match the list above, e.g. the line with the book metadata string can be above the line containing the title metadata, but note that it is probably better to not mix this up anyway for quicker manual editing's sake.
Example of a metadata header:
title: Amazing Grace
book: Pretty much every protestant songbook
text: John Newton (1779)
melody: American folk tune
structure: 1,2,3
To start off with the syntax, every unique structure element, will be placed on a separate line between an opening square bracket directly to the left and an closing square bracket directly to the right, e.g. [R] or [3]. We call these lines structure element identifiers. After each of those lines must follow a finite amount of lines that semantically carry the song text of the corresponding refrain or verse indicated by the structure element. The lines which are empty or only contain whitespace after the last line that doesn't meet these two requirements before either the next structure element identifier or the end of the file are ignored, while the lines that are empty or only contain whitespace before that last line who doesn't meet these two requirements are not ignored, as they semantically could act as separators intended by the user. Note that such ignored lines are not syntactically necessary, but are heavily encouraged for their clearer separation they provide semantically.
Here is a example of a text body using the first three verses of 'Amazing Grace' written by John Newton found on Hymnary.org:
[1]
Amazing grace (how sweet the sound)
that saved a wretch like me!
I once was lost, but now am found,
was blind, but now I see.
[2]
'Twas grace that taught my heart to fear,
and grace my fears relieved;
how precious did that grace appear
the hour I first believed!
[3]
Through many dangers, toils and snares
I have already come:
'tis grace has brought me safe thus far,
and grace will lead me home.
The configuration of slidegen is handled via constants in *.py files. The default configuration is stored in config/default_config.py, and in the same form a custom user-defined configuration can optionally be placed in config/config.py. You don't have to specify all the constants present in the default config, only the one's you want to change.
For example, if you want to change the text color to green and the file extension the jpeg, your config/config.py could look like this:
TEXT_COLOR = "green"
FILE_EXTENSION = "jpeg"
These are some issues and possible changes that will be addressed or at least considered by our future development efforts:
PROMPT_INPUT parsingPROMPT_INPUTslidegen is free (as in “free speech” and also as in “free beer”) Software. It is distributed under the GNU General Public License v3 (or any later version) - see the accompanying LICENSE file for more details.