mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-12-25 05:55:34 +00:00
Some clean up of the lyxpreview code.
Move some common variables to lyxpreview_tools. Otherwise, add a few variable names, making it easier to track things. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@39656 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
2dfa11904f
commit
675f233f34
@ -74,15 +74,11 @@
|
|||||||
|
|
||||||
import glob, os, pipes, re, string, sys
|
import glob, os, pipes, re, string, sys
|
||||||
|
|
||||||
from lyxpreview_tools import copyfileobj, error, find_exe, \
|
from lyxpreview_tools import copyfileobj, error, filter_pages, find_exe, \
|
||||||
find_exe_or_terminate, make_texcolor, mkstemp, run_command, warning, \
|
find_exe_or_terminate, join_metrics_and_rename, latex_commands, \
|
||||||
write_metrics_info, filter_pages, join_metrics_and_rename
|
latex_file_re, make_texcolor, mkstemp, run_command, warning, \
|
||||||
|
write_metrics_info
|
||||||
|
|
||||||
# Pre-compiled regular expression.
|
|
||||||
latex_file_re = re.compile("\.tex$")
|
|
||||||
|
|
||||||
# PATH environment variable
|
|
||||||
path = string.split(os.environ["PATH"], os.pathsep)
|
|
||||||
|
|
||||||
def usage(prog_name):
|
def usage(prog_name):
|
||||||
return "Usage: %s <latex file> <dpi> ppm <fg color> <bg color>\n" \
|
return "Usage: %s <latex file> <dpi> ppm <fg color> <bg color>\n" \
|
||||||
@ -250,12 +246,13 @@ def crop_files(pnmcrop, basename):
|
|||||||
|
|
||||||
|
|
||||||
def legacy_conversion(argv, skipMetrics = False):
|
def legacy_conversion(argv, skipMetrics = False):
|
||||||
latex_commands = ["latex", "pplatex", "platex", "latex2e"]
|
|
||||||
# Parse and manipulate the command line arguments.
|
# Parse and manipulate the command line arguments.
|
||||||
if len(argv) == 7:
|
if len(argv) == 7:
|
||||||
latex_commands = [argv[6]]
|
latex = [argv[6]]
|
||||||
elif len(argv) != 6:
|
elif len(argv) != 6:
|
||||||
error(usage(argv[0]))
|
error(usage(argv[0]))
|
||||||
|
else:
|
||||||
|
latex = None
|
||||||
|
|
||||||
dir, latex_file = os.path.split(argv[1])
|
dir, latex_file = os.path.split(argv[1])
|
||||||
if len(dir) != 0:
|
if len(dir) != 0:
|
||||||
@ -270,7 +267,7 @@ def legacy_conversion(argv, skipMetrics = False):
|
|||||||
bg_color_gr = make_texcolor(argv[5], True)
|
bg_color_gr = make_texcolor(argv[5], True)
|
||||||
|
|
||||||
# External programs used by the script.
|
# External programs used by the script.
|
||||||
latex = find_exe_or_terminate(latex_commands, path)
|
latex = find_exe_or_terminate(latex or latex_commands)
|
||||||
|
|
||||||
# Move color information into the latex file.
|
# Move color information into the latex file.
|
||||||
if not legacy_latex_file(latex_file, fg_color, bg_color, bg_color_gr):
|
if not legacy_latex_file(latex_file, fg_color, bg_color, bg_color_gr):
|
||||||
@ -293,7 +290,7 @@ def legacy_conversion_pdflatex(latex_file, failed_pages, legacy_metrics, gs,
|
|||||||
gs_device, gs_ext, alpha, resolution, output_format):
|
gs_device, gs_ext, alpha, resolution, output_format):
|
||||||
|
|
||||||
# Search for pdflatex executable
|
# Search for pdflatex executable
|
||||||
pdflatex = find_exe(["pdflatex"], path)
|
pdflatex = find_exe(["pdflatex"])
|
||||||
if pdflatex == None:
|
if pdflatex == None:
|
||||||
warning("Can't find pdflatex. Some pages failed with all the possible routes.")
|
warning("Can't find pdflatex. Some pages failed with all the possible routes.")
|
||||||
else:
|
else:
|
||||||
@ -333,9 +330,9 @@ def legacy_conversion_pdflatex(latex_file, failed_pages, legacy_metrics, gs,
|
|||||||
|
|
||||||
def legacy_conversion_step2(latex_file, dpi, output_format, skipMetrics = False):
|
def legacy_conversion_step2(latex_file, dpi, output_format, skipMetrics = False):
|
||||||
# External programs used by the script.
|
# External programs used by the script.
|
||||||
dvips = find_exe_or_terminate(["dvips"], path)
|
dvips = find_exe_or_terminate(["dvips"])
|
||||||
gs = find_exe_or_terminate(["gswin32c", "gs"], path)
|
gs = find_exe_or_terminate(["gswin32c", "gs"])
|
||||||
pnmcrop = find_exe(["pnmcrop"], path)
|
pnmcrop = find_exe(["pnmcrop"])
|
||||||
|
|
||||||
# Run the dvi file through dvips.
|
# Run the dvi file through dvips.
|
||||||
dvi_file = latex_file_re.sub(".dvi", latex_file)
|
dvi_file = latex_file_re.sub(".dvi", latex_file)
|
||||||
|
@ -66,19 +66,14 @@
|
|||||||
import glob, os, re, string, sys
|
import glob, os, re, string, sys
|
||||||
|
|
||||||
from legacy_lyxpreview2ppm import legacy_conversion, \
|
from legacy_lyxpreview2ppm import legacy_conversion, \
|
||||||
legacy_conversion_step2, legacy_extract_metrics_info, filter_pages
|
legacy_conversion_step2, legacy_extract_metrics_info
|
||||||
|
|
||||||
from lyxpreview_tools import copyfileobj, error, find_exe, \
|
from lyxpreview_tools import copyfileobj, error, filter_pages, find_exe, \
|
||||||
find_exe_or_terminate, make_texcolor, mkstemp, run_command, warning, \
|
find_exe_or_terminate, join_metrics_and_rename, latex_commands, \
|
||||||
write_metrics_info, join_metrics_and_rename
|
latex_file_re, make_texcolor, mkstemp, run_command, warning, \
|
||||||
|
write_metrics_info
|
||||||
|
|
||||||
|
|
||||||
# Pre-compiled regular expressions.
|
|
||||||
latex_file_re = re.compile("\.tex$")
|
|
||||||
|
|
||||||
# PATH environment variable
|
|
||||||
path = string.split(os.environ["PATH"], os.pathsep)
|
|
||||||
|
|
||||||
def usage(prog_name):
|
def usage(prog_name):
|
||||||
return "Usage: %s <format> <latex file> <dpi> <fg color> <bg color>\n" \
|
return "Usage: %s <format> <latex file> <dpi> <fg color> <bg color>\n" \
|
||||||
"\twhere the colors are hexadecimal strings, eg 'faf0e6'" \
|
"\twhere the colors are hexadecimal strings, eg 'faf0e6'" \
|
||||||
@ -215,7 +210,7 @@ def find_ps_pages(dvi_file):
|
|||||||
|
|
||||||
# Check for PostScript specials in the dvi, badly supported by dvipng
|
# Check for PostScript specials in the dvi, badly supported by dvipng
|
||||||
# This is required for correct rendering of PSTricks and TikZ
|
# This is required for correct rendering of PSTricks and TikZ
|
||||||
dv2dt = find_exe_or_terminate(["dv2dt"], path)
|
dv2dt = find_exe_or_terminate(["dv2dt"])
|
||||||
dv2dt_call = '%s "%s"' % (dv2dt, dvi_file)
|
dv2dt_call = '%s "%s"' % (dv2dt, dvi_file)
|
||||||
|
|
||||||
# The output from dv2dt goes to stdout
|
# The output from dv2dt goes to stdout
|
||||||
@ -290,40 +285,47 @@ def main(argv):
|
|||||||
if len(argv) != 6 and len(argv) != 7:
|
if len(argv) != 6 and len(argv) != 7:
|
||||||
error(usage(argv[0]))
|
error(usage(argv[0]))
|
||||||
|
|
||||||
|
script_name = argv[0]
|
||||||
|
|
||||||
output_format = string.lower(argv[1])
|
output_format = string.lower(argv[1])
|
||||||
|
|
||||||
dir, latex_file = os.path.split(argv[2])
|
input_path = argv[2]
|
||||||
|
dir, latex_file = os.path.split(input_path)
|
||||||
if len(dir) != 0:
|
if len(dir) != 0:
|
||||||
os.chdir(dir)
|
os.chdir(dir)
|
||||||
|
|
||||||
dpi = string.atoi(argv[3])
|
dpi = string.atoi(argv[3])
|
||||||
fg_color = make_texcolor(argv[4], False)
|
fg_color = argv[4]
|
||||||
bg_color = make_texcolor(argv[5], False)
|
bg_color = argv[5]
|
||||||
|
|
||||||
fg_color_gr = make_texcolor(argv[4], True)
|
fg_color_dvipng = make_texcolor(fg_color, False)
|
||||||
bg_color_gr = make_texcolor(argv[5], True)
|
bg_color_dvipng = make_texcolor(bg_color, False)
|
||||||
|
|
||||||
|
fg_color_gr = make_texcolor(fg_color, True)
|
||||||
|
bg_color_gr = make_texcolor(bg_color, True)
|
||||||
|
|
||||||
# External programs used by the script.
|
# External programs used by the script.
|
||||||
if len(argv) == 7:
|
if len(argv) == 7:
|
||||||
latex = argv[6]
|
latex = [argv[6]]
|
||||||
else:
|
else:
|
||||||
latex = find_exe_or_terminate(["latex", "pplatex", "platex", "latex2e"], path)
|
latex = None
|
||||||
|
latex = find_exe_or_terminate(latex or latex_commands)
|
||||||
|
|
||||||
# Omit font size specification in latex file.
|
# Omit font size specification in latex file.
|
||||||
fix_latex_file(latex_file)
|
fix_latex_file(latex_file)
|
||||||
|
|
||||||
# This can go once dvipng becomes widespread.
|
# This can go once dvipng becomes widespread.
|
||||||
dvipng = find_exe(["dvipng"], path)
|
dvipng = find_exe(["dvipng"])
|
||||||
if dvipng == None:
|
if dvipng == None:
|
||||||
# The data is input to legacy_conversion in as similar
|
# The data is input to legacy_conversion in as similar
|
||||||
# as possible a manner to that input to the code used in
|
# as possible a manner to that input to the code used in
|
||||||
# LyX 1.3.x.
|
# LyX 1.3.x.
|
||||||
vec = [ argv[0], argv[2], argv[3], argv[1], argv[4], argv[5], latex ]
|
vec = [ script_name, input_path, str(dpi), output_format, fg_color, bg_color, latex ]
|
||||||
return legacy_conversion(vec)
|
return legacy_conversion(vec)
|
||||||
|
|
||||||
pngtopnm = ""
|
pngtopnm = ""
|
||||||
if output_format == "ppm":
|
if output_format == "ppm":
|
||||||
pngtopnm = find_exe_or_terminate(["pngtopnm"], path)
|
pngtopnm = find_exe_or_terminate(["pngtopnm"])
|
||||||
|
|
||||||
# Move color information for PDF into the latex file.
|
# Move color information for PDF into the latex file.
|
||||||
if not color_pdf(latex_file, bg_color_gr, fg_color_gr):
|
if not color_pdf(latex_file, bg_color_gr, fg_color_gr):
|
||||||
@ -365,12 +367,12 @@ def main(argv):
|
|||||||
|
|
||||||
# If all pages need PostScript, directly use the legacy method.
|
# If all pages need PostScript, directly use the legacy method.
|
||||||
if len(ps_pages) == page_count:
|
if len(ps_pages) == page_count:
|
||||||
vec = [argv[0], argv[2], argv[3], argv[1], argv[4], argv[5], latex]
|
vec = [ script_name, input_path, str(dpi), output_format, fg_color, bg_color, latex ]
|
||||||
return legacy_conversion(vec)
|
return legacy_conversion(vec)
|
||||||
|
|
||||||
# Run the dvi file through dvipng.
|
# Run the dvi file through dvipng.
|
||||||
dvipng_call = '%s -Ttight -depth -height -D %d -fg "%s" -bg "%s" %s "%s"' \
|
dvipng_call = '%s -Ttight -depth -height -D %d -fg "%s" -bg "%s" %s "%s"' \
|
||||||
% (dvipng, dpi, fg_color, bg_color, pages_parameter, dvi_file)
|
% (dvipng, dpi, fg_color_dvipng, bg_color_dvipng, pages_parameter, dvi_file)
|
||||||
dvipng_status, dvipng_stdout = run_command(dvipng_call)
|
dvipng_status, dvipng_stdout = run_command(dvipng_call)
|
||||||
|
|
||||||
if dvipng_status != None:
|
if dvipng_status != None:
|
||||||
@ -391,8 +393,8 @@ def main(argv):
|
|||||||
filter_pages(latex_file, legacy_latex_file, ps_pages)
|
filter_pages(latex_file, legacy_latex_file, ps_pages)
|
||||||
|
|
||||||
# Pass the new LaTeX file to the legacy method
|
# Pass the new LaTeX file to the legacy method
|
||||||
vec = [ argv[0], latex_file_re.sub("_legacy.tex", argv[2]),
|
vec = [ script_name, latex_file_re.sub("_legacy.tex", input_path),
|
||||||
argv[3], argv[1], argv[4], argv[5], latex ]
|
str(dpi), output_format, fg_color, bg_color, latex ]
|
||||||
legacy_metrics = legacy_conversion(vec, True)[1]
|
legacy_metrics = legacy_conversion(vec, True)[1]
|
||||||
|
|
||||||
# Now we need to mix metrics data from dvipng and the legacy method
|
# Now we need to mix metrics data from dvipng and the legacy method
|
||||||
|
@ -16,6 +16,20 @@
|
|||||||
|
|
||||||
import os, re, string, sys, tempfile
|
import os, re, string, sys, tempfile
|
||||||
|
|
||||||
|
|
||||||
|
# Known flavors of latex
|
||||||
|
latex_commands = ("latex", "pplatex", "platex", "latex2e")
|
||||||
|
pdflatex_commands = ("pdflatex", "xelatex", "lualatex")
|
||||||
|
|
||||||
|
# Pre-compiled regular expressions
|
||||||
|
latex_file_re = re.compile(r"\.tex$")
|
||||||
|
|
||||||
|
# PATH and PATHEXT environment variables
|
||||||
|
path = os.environ["PATH"].split(os.pathsep)
|
||||||
|
extlist = ['']
|
||||||
|
if "PATHEXT" in os.environ:
|
||||||
|
extlist += os.environ["PATHEXT"].split(os.pathsep)
|
||||||
|
|
||||||
use_win32_modules = 0
|
use_win32_modules = 0
|
||||||
if os.name == "nt":
|
if os.name == "nt":
|
||||||
use_win32_modules = 1
|
use_win32_modules = 1
|
||||||
@ -59,10 +73,8 @@ def make_texcolor(hexcolor, graphics):
|
|||||||
return "rgb %f %f %f" % (red, green, blue)
|
return "rgb %f %f %f" % (red, green, blue)
|
||||||
|
|
||||||
|
|
||||||
def find_exe(candidates, path):
|
def find_exe(candidates):
|
||||||
extlist = ['']
|
global extlist, path
|
||||||
if "PATHEXT" in os.environ:
|
|
||||||
extlist = extlist + os.environ["PATHEXT"].split(os.pathsep)
|
|
||||||
|
|
||||||
for prog in candidates:
|
for prog in candidates:
|
||||||
for directory in path:
|
for directory in path:
|
||||||
@ -78,8 +90,8 @@ def find_exe(candidates, path):
|
|||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
def find_exe_or_terminate(candidates, path):
|
def find_exe_or_terminate(candidates):
|
||||||
exe = find_exe(candidates, path)
|
exe = find_exe(candidates)
|
||||||
if exe == None:
|
if exe == None:
|
||||||
error("Unable to find executable from '%s'" % string.join(candidates))
|
error("Unable to find executable from '%s'" % string.join(candidates))
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user