mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-21 03:49:38 +00:00
Improved docs gen to not replace unchanged images.
This commit is contained in:
parent
ac620024e2
commit
b9470f1243
1 changed files with 33 additions and 4 deletions
|
@ -19,7 +19,11 @@ def get_header_link(name):
|
||||||
|
|
||||||
|
|
||||||
def toc_entry(name, indent, count=None):
|
def toc_entry(name, indent, count=None):
|
||||||
ref = get_header_link(name)
|
lname = "{0}{1}".format(
|
||||||
|
("%d. " % count) if count else "",
|
||||||
|
name
|
||||||
|
)
|
||||||
|
ref = get_header_link(lname)
|
||||||
if name.endswith( (")", "}", "]") ):
|
if name.endswith( (")", "}", "]") ):
|
||||||
name = "`" + name.replace("\\", "") + "`"
|
name = "`" + name.replace("\\", "") + "`"
|
||||||
return "{0}{1} [{2}](#{3})".format(
|
return "{0}{1} [{2}](#{3})".format(
|
||||||
|
@ -87,6 +91,7 @@ class ImageProcessing(object):
|
||||||
def gen_example_image(self, libfile, imgfile, code, extype):
|
def gen_example_image(self, libfile, imgfile, code, extype):
|
||||||
OPENSCAD = "/Applications/OpenSCAD.app/Contents/MacOS/OpenSCAD"
|
OPENSCAD = "/Applications/OpenSCAD.app/Contents/MacOS/OpenSCAD"
|
||||||
CONVERT = "/usr/local/bin/convert"
|
CONVERT = "/usr/local/bin/convert"
|
||||||
|
COMPARE = "/usr/local/bin/compare"
|
||||||
|
|
||||||
if extype == "NORENDER":
|
if extype == "NORENDER":
|
||||||
return
|
return
|
||||||
|
@ -177,9 +182,10 @@ class ImageProcessing(object):
|
||||||
|
|
||||||
if not self.keep_scripts:
|
if not self.keep_scripts:
|
||||||
os.unlink(scriptfile)
|
os.unlink(scriptfile)
|
||||||
outimgfile = self.imgroot + imgfile
|
targimgfile = self.imgroot + imgfile
|
||||||
|
newimgfile = self.imgroot + "_new_" + imgfile
|
||||||
if len(tmpimgs) == 1:
|
if len(tmpimgs) == 1:
|
||||||
cnvcmd = [CONVERT, tmpimgfile, "-resize", imgsizes[1], outimgfile]
|
cnvcmd = [CONVERT, tmpimgfile, "-resize", imgsizes[1], newimgfile]
|
||||||
print(" ".join(cnvcmd))
|
print(" ".join(cnvcmd))
|
||||||
res = subprocess.call(cnvcmd)
|
res = subprocess.call(cnvcmd)
|
||||||
if res != 0:
|
if res != 0:
|
||||||
|
@ -198,7 +204,7 @@ class ImageProcessing(object):
|
||||||
"+map"
|
"+map"
|
||||||
]
|
]
|
||||||
cnvcmd.extend(tmpimgs)
|
cnvcmd.extend(tmpimgs)
|
||||||
cnvcmd.append(outimgfile)
|
cnvcmd.append(newimgfile)
|
||||||
print(" ".join(cnvcmd))
|
print(" ".join(cnvcmd))
|
||||||
res = subprocess.call(cnvcmd)
|
res = subprocess.call(cnvcmd)
|
||||||
if res != 0:
|
if res != 0:
|
||||||
|
@ -206,6 +212,29 @@ class ImageProcessing(object):
|
||||||
for tmpimg in tmpimgs:
|
for tmpimg in tmpimgs:
|
||||||
os.unlink(tmpimg)
|
os.unlink(tmpimg)
|
||||||
|
|
||||||
|
# Time to compare image.
|
||||||
|
if not os.path.isfile(targimgfile):
|
||||||
|
print("NEW IMAGE installed.")
|
||||||
|
os.rename(newimgfile, targimgfile)
|
||||||
|
else:
|
||||||
|
if targimgfile.endswith(".gif"):
|
||||||
|
cmpcmd = ["cmp", newimgfile, targimgfile]
|
||||||
|
print(" ".join(cmpcmd))
|
||||||
|
res = subprocess.call(cmpcmd)
|
||||||
|
issame = res == 0
|
||||||
|
else:
|
||||||
|
cmpcmd = [COMPARE, "-metric", "MAE", newimgfile, targimgfile, "null:"]
|
||||||
|
print(" ".join(cmpcmd))
|
||||||
|
p = subprocess.Popen(cmpcmd, shell=False, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.STDOUT, close_fds=True)
|
||||||
|
issame = p.stdout.read().strip() == "0 (0)"
|
||||||
|
if issame:
|
||||||
|
print("Image unchanged.")
|
||||||
|
os.unlink(newimgfile)
|
||||||
|
else:
|
||||||
|
print("Image UPDATED.")
|
||||||
|
os.unlink(targimgfile)
|
||||||
|
os.rename(newimgfile, targimgfile)
|
||||||
|
|
||||||
|
|
||||||
imgprc = ImageProcessing()
|
imgprc = ImageProcessing()
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue