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
|
#!/usr/bin/env python3
# pip3 install bible-passage-reference-parser
from bible import parse_string
import usfm2gmi.usfm2gmi as usfm2gmi
import os
import sys
import subprocess
def printf(line):
if line.strip():
print(usfm2gmi.convert(line), end=' ')
else:
print()
def eprint(*args, **kwargs):
print(*args, file=sys.stderr, **kwargs)
def main(qs):
if not qs:
print("10 Enter a scripture reference\r\n")
return
passages = parse_string(qs)
# TODO: Also handle "john 3, tomato 2" errors?
if type(passages[0]) == tuple:
print("51 " + str(passages[0][0]) + "'\r\n")
return
print("20 text/gemini\r\n")
print('=>https://ebible.org/find/details.php?id=engwebp&all=1 This content from World English Bible (public domain)')
print('=> gemini://gemini.zachdecook.com/usfm2gmi/ and rendered with usfm2gmi')
for passage in passages:
print("# " + passage.format())
printing = 0
inendc = False
bookabbrev=passage.start.format('a').upper()
fname = subprocess.check_output([f"find", "webp/", "-name", f'*-{bookabbrev}*']).strip()
eprint(fname)
f = open(fname)
startc = passage.start.chapter
startv= passage.start.verse
endc = passage.end.chapter
endv= passage.end.verse
for line in f:
if f'\\c {startc} ' in line:
printing = 1
if printing == 1 and (f'\\v {startv} ') in line:
printing =2
if (f'\\c {endc} ') in line:
inendc = True
if inendc and (f'\\v {endv+1} ') in line:
printing =0
if (f'\\c {endc+1} ') in line:
printing =0
if printing>=2:
printf(line)
print('(WEB)') #end in newline
if __name__ == '__main__':
qs = os.getenv("QUERY_STRING") or (sys.argv[1] if len(sys.argv) >= 2 else '')
main(qs)
|