diff options
author | Joris | 2023-12-27 18:21:58 +0100 |
---|---|---|
committer | Joris | 2023-12-27 18:21:58 +0100 |
commit | 0761cb1942e7230fa173df6a3b890e6bc5d3d8e6 (patch) | |
tree | 0a50a4cdd238aa1db38fe5e4296c7d5d42cc169c /main.py | |
parent | 98eca7d594960aa616786cbd491b937d50f55499 (diff) |
Remove main.py
Diffstat (limited to 'main.py')
-rw-r--r-- | main.py | 147 |
1 files changed, 0 insertions, 147 deletions
diff --git a/main.py b/main.py deleted file mode 100644 index a4494ff..0000000 --- a/main.py +++ /dev/null @@ -1,147 +0,0 @@ -import string - -atom_end = set('()"\'') | set(string.whitespace) - -def parse(sexp): - stack, i, length = [[]], 0, len(sexp) - while i < length: - c = sexp[i] - - reading = type(stack[-1]) - if reading == list: - match c: - case '(': - stack.append([]) - case ')': - stack[-2].append(stack.pop()) - if stack[-1][0] == ('quote',): stack[-2].append(stack.pop()) - case '"': - stack.append('') - case "'": - stack.append([('quote',)]) - case _: - if c in string.whitespace: - pass - else: - stack.append((c,)) - elif reading == str: - if c == '"': - stack[-2].append(stack.pop()) - if stack[-1][0] == ('quote',): stack[-2].append(stack.pop()) - elif c == '\\': - i += 1 - stack[-1] += sexp[i] - else: - stack[-1] += c - elif reading == tuple: - if c in atom_end: - atom = stack.pop() - if atom[0][0].isdigit(): - stack[-1].append(eval(atom[0])) - else: - stack[-1].append(atom) - if stack[-1][0] == ('quote',): - stack[-2].append(stack.pop()) - continue - else: - stack[-1] = ((stack[-1][0] + c),) - i += 1 - return stack.pop() - -def h(node, attributes, *children): - res_attrs = '' - if type(attributes) == dict: - for key in attributes: - res_attrs += f' {key}={attributes[key]}' - else: - children = [attributes] + list(children) - - res = f'<{node} {res_attrs}>' - if type(children) in [tuple, list]: - res += ''.join(children) - elif type(children) == str: - res += children - - res += f'</{node}>' - return res - -def lines(s: str): - return [h('div', x) for x in s.split('\n')] - -def chord_line(sexp): - res = '' - for x in sexp: - res += h('td', { 'class': 'g-Chord' }, x[0]) - return res - -def chords(sexp): - return h('section', - { 'class': 'g-Section' }, - h('h2', { 'class': 'g-Subtitle' }, 'Accords'), - h('table', { 'class': 'g-Chords' }, *[h('tr', {}, chord_line(x)) for x in sexp])) - -part_names = { - 'intro': 'Intro', - 'verse': 'Couplet', - 'chorus': 'Refrain', - 'interlude': 'Interlude' -} - -def lyrics(sexp): - ys = [] - for x in sexp: - match x: - case [(name)]: - ys.append(h('section', - { 'class': 'g-Section' }, - h('div', - { 'class': 'g-Lyrics__Part' }, - h('h3', part_names[name[0]])))) - case [(name), s]: - ys.append(h('section', - { 'class': 'g-Section' }, - h('div', - { 'class': 'g-Lyrics__Part' }, - h('h3', part_names[name[0]]), - h('div', { 'class': 'g-Lyrics__Paragraph' }, *lines(s))))) - return h('section', - { 'class': 'g-Section' }, - h('h2', { 'class': 'g-Subtitle' }, 'Paroles'), - h('div', { 'class': 'g-Lyrics' }, *ys)) - -def sexp_prop(sexp, name): - return [x[1:] for x in sexp if x[0][0] == name][0] - -# ----------------- - -with open('ben-e-king-stand-by-me.lisp', 'r') as f: - content = f.read() - -sexp = parse(content) - -title = sexp_prop(sexp, 'title')[0] -subtitle = sexp_prop(sexp, 'from')[0] - -html = f''' - <!doctype html> - <html lang="fr"> - <meta charset="utf-8"> - <meta name="viewport" content="width=device-width"> - <title>{title} – {subtitle}</title> - <link rel="stylesheet" href="main.css"> - <link rel="icon" href="/icon.png"> - <script src="/main.js"></script> -''' - -html += h('body', - h('section', - { 'class': 'g-Section' }, - h('h1', { 'class': 'g-Title' }, title), - h('div', { 'class': 'g-Author' }, subtitle)), - chords(sexp_prop(sexp, 'chords')), - lyrics(sexp_prop(sexp, 'lyrics'))) - -with open('ben-e-king-stand-by-me.html', 'w') as f: - f.write(html) - -print('OK') |