Skip to content

Commit

Permalink
Merge pull request protocolbuffers#481 from haberman/wrapping-upb-doc
Browse files Browse the repository at this point in the history
First version of a doc describing how to wrap upb
  • Loading branch information
haberman authored Jan 7, 2022
2 parents 107032d + f067371 commit b13fc03
Show file tree
Hide file tree
Showing 8 changed files with 970 additions and 1 deletion.
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
*.s??
*.sw?
obj/
lib/
bazel-*
43 changes: 43 additions & 0 deletions doc/render.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
#!/usr/bin/env python3

import subprocess
import sys
import shutil
import os

if len(sys.argv) < 2:
print("Must pass a filename argument")
sys.exit(1)

in_filename = sys.argv[1]
out_filename = in_filename.replace(".in.md", ".md")
out_dir = in_filename.replace(".in.md", "")

if in_filename == out_filename:
print("File must end in .in.md")
sys.exit(1)

if os.path.isdir(out_dir):
shutil.rmtree(out_dir)

os.mkdir(out_dir)
file_num = 1

with open(out_filename, "wb") as out_file, open(in_filename, "rb") as in_file:
for line in in_file:
if line.startswith(b"```dot"):
dot_lines = []
while True:
dot_line = next(in_file)
if dot_line == b"```\n":
break
dot_lines.append(dot_line)
dot_input = b"".join(dot_lines)
svg_filename = out_dir + "/" + str(file_num) + ".svg"
svg = subprocess.check_output(['dot', '-Tsvg', '-o', svg_filename], input=dot_input)
out_file.write(b"<div align=center>\n")
out_file.write(b"<img src='%s'/>\n" % (svg_filename.encode('utf-8')))
out_file.write(b"</div>\n")
file_num += 1
else:
out_file.write(line)
Loading

0 comments on commit b13fc03

Please sign in to comment.