Add file commit histories
This commit is contained in:
parent
b6978bad9e
commit
65e36de48c
30
notes2web.py
30
notes2web.py
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
|
|
||||||
from bs4 import BeautifulSoup as bs
|
from bs4 import BeautifulSoup as bs
|
||||||
|
import subprocess
|
||||||
import frontmatter
|
import frontmatter
|
||||||
import magic
|
import magic
|
||||||
import sys
|
import sys
|
||||||
@ -40,6 +41,29 @@ def get_files(folder):
|
|||||||
|
|
||||||
return markdown, plaintext, other
|
return markdown, plaintext, other
|
||||||
|
|
||||||
|
def git_filehistory(working_dir, filename):
|
||||||
|
print(f"{pathlib.Path(filename).relative_to(working_dir)=}")
|
||||||
|
git_response = subprocess.run(
|
||||||
|
[
|
||||||
|
'git',
|
||||||
|
f"--git-dir={os.path.join(working_dir, '.git')}",
|
||||||
|
"log",
|
||||||
|
"-p",
|
||||||
|
"--",
|
||||||
|
pathlib.Path(filename).relative_to(working_dir)
|
||||||
|
],
|
||||||
|
stdout=subprocess.PIPE
|
||||||
|
)
|
||||||
|
|
||||||
|
filehistory = f"File history not available: git log returned code {git_response.returncode}."
|
||||||
|
"\nIf this is not a git repository, this is not a problem."
|
||||||
|
if git_response.returncode == 0:
|
||||||
|
filehistory = git_response.stdout.decode('utf-8')
|
||||||
|
if filehistory == "":
|
||||||
|
filehistory = "This file has no history (it may not be part of the git repository)."
|
||||||
|
|
||||||
|
return filehistory
|
||||||
|
|
||||||
|
|
||||||
def get_dirs(folder):
|
def get_dirs(folder):
|
||||||
r = []
|
r = []
|
||||||
@ -151,8 +175,10 @@ def main(args):
|
|||||||
'headers': header_lines
|
'headers': header_lines
|
||||||
})
|
})
|
||||||
|
|
||||||
|
filehistory = git_filehistory(args.notes, filename)
|
||||||
|
|
||||||
if update_required(filename, output_filename) or args.force:
|
if update_required(filename, output_filename) or args.force:
|
||||||
html = pypandoc.convert_file(filename, 'html', extra_args=[f'--template={args.template}'])
|
html = pypandoc.convert_file(filename, 'html', extra_args=[f'--template={args.template}', '-V', f'filehistory={filehistory}'])
|
||||||
os.makedirs(os.path.dirname(output_filename), exist_ok=True)
|
os.makedirs(os.path.dirname(output_filename), exist_ok=True)
|
||||||
|
|
||||||
with open(output_filename, 'w+') as fp:
|
with open(output_filename, 'w+') as fp:
|
||||||
@ -160,6 +186,7 @@ def main(args):
|
|||||||
|
|
||||||
print(f"{plaintext_files=}")
|
print(f"{plaintext_files=}")
|
||||||
for filename in plaintext_files:
|
for filename in plaintext_files:
|
||||||
|
filehistory = git_filehistory(args.notes, filename)
|
||||||
title = os.path.basename(re.sub(f"^{args.notes.name}", args.output_dir.name, filename))
|
title = os.path.basename(re.sub(f"^{args.notes.name}", args.output_dir.name, filename))
|
||||||
output_filename = re.sub(f"^{args.notes.name}", os.path.join(args.output_dir.name, 'notes'), filename) + '.html'
|
output_filename = re.sub(f"^{args.notes.name}", os.path.join(args.output_dir.name, 'notes'), filename) + '.html'
|
||||||
os.makedirs(os.path.dirname(output_filename), exist_ok=True)
|
os.makedirs(os.path.dirname(output_filename), exist_ok=True)
|
||||||
@ -169,6 +196,7 @@ def main(args):
|
|||||||
with open(filename) as fp:
|
with open(filename) as fp:
|
||||||
html += fp.read()
|
html += fp.read()
|
||||||
html += TEXT_ARTICLE_TEMPLATE_FOOT
|
html += TEXT_ARTICLE_TEMPLATE_FOOT
|
||||||
|
html = html.replace(r'$filehistory$', filehistory)
|
||||||
|
|
||||||
with open(output_filename, 'w+') as fp:
|
with open(output_filename, 'w+') as fp:
|
||||||
fp.write(html)
|
fp.write(html)
|
||||||
|
@ -15,6 +15,12 @@
|
|||||||
$endfor$
|
$endfor$
|
||||||
</p>
|
</p>
|
||||||
$body$
|
$body$
|
||||||
|
<details>
|
||||||
|
<summary>
|
||||||
|
Commit log (file history)
|
||||||
|
</summary>
|
||||||
|
<pre>$filehistory$</pre>
|
||||||
|
</details>
|
||||||
|
|
||||||
<p style="font-size: 0.7em;"> page generated by <a href="https://github.com/alvierahman90/notes2web">notes2web</a></p>
|
<p style="font-size: 0.7em;"> page generated by <a href="https://github.com/alvierahman90/notes2web">notes2web</a></p>
|
||||||
</body>
|
</body>
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
</pre>
|
</pre>
|
||||||
|
<details>
|
||||||
|
<summary>
|
||||||
|
Commit log (file history)
|
||||||
|
</summary>
|
||||||
|
<pre>$filehistory$</pre>
|
||||||
|
</details>
|
||||||
<p style="font-size: 0.7em;"> page generated by <a href="https://github.com/alvierahman90/notes2web">notes2web</a></p>
|
<p style="font-size: 0.7em;"> page generated by <a href="https://github.com/alvierahman90/notes2web">notes2web</a></p>
|
||||||
</body>
|
</body>
|
||||||
|
Reference in New Issue
Block a user