no-Shell patch three: fig2pstex/pdftex.sh -> fig2pstex/pdftex.py

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/branches/BRANCH_1_4_X@14464 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Bo Peng 2006-07-15 19:41:30 +00:00
parent d8fb4444fb
commit 1603f20819
7 changed files with 168 additions and 191 deletions

View File

@ -849,8 +849,8 @@ dist_scripts_DATA = \
scripts/clean_dvi.py \ scripts/clean_dvi.py \
scripts/convertDefault.py \ scripts/convertDefault.py \
scripts/fen2ascii.py \ scripts/fen2ascii.py \
scripts/fig2pdftex.sh \ scripts/fig2pdftex.py \
scripts/fig2pstex.sh \ scripts/fig2pstex.py \
scripts/fig_copy.py \ scripts/fig_copy.py \
scripts/layout2layout.py \ scripts/layout2layout.py \
scripts/legacy_lyxpreview2ppm.py \ scripts/legacy_lyxpreview2ppm.py \

View File

@ -169,7 +169,7 @@ def checkLatex():
checkProg('DTL to DVI converter', ['dt2dv']) != ['', '']): checkProg('DTL to DVI converter', ['dt2dv']) != ['', '']):
# Windows only: DraftDVI # Windows only: DraftDVI
converter_entry = r'''\converter latex dvi2 "%%" "latex" converter_entry = r'''\converter latex dvi2 "%%" "latex"
\converter dvi2 dvi "python $$s/scripts/clean_dvi.py $$i $$o" ""''' \converter dvi2 dvi "python -tt $$s/scripts/clean_dvi.py $$i $$o" ""'''
else: else:
converter_entry = r'\converter latex dvi "%%" "latex"' converter_entry = r'\converter latex dvi "%%" "latex"'
path, LATEX = checkProg('a Latex2e program', ['pplatex $$i', 'latex $$i', 'latex2e $$i'], path, LATEX = checkProg('a Latex2e program', ['pplatex $$i', 'latex $$i', 'latex2e $$i'],
@ -329,7 +329,7 @@ def checkConverterEntries():
# #
path, dvipng = checkProg('dvipng', ['dvipng']) path, dvipng = checkProg('dvipng', ['dvipng'])
if dvipng == "dvipng": if dvipng == "dvipng":
addToRC(r'\converter lyxpreview png "python $$s/scripts/lyxpreview2bitmap.py" ""') addToRC(r'\converter lyxpreview png "python -tt $$s/scripts/lyxpreview2bitmap.py" ""')
else: else:
addToRC(r'\converter lyxpreview png "" ""') addToRC(r'\converter lyxpreview png "" ""')
# #
@ -373,13 +373,13 @@ def checkConverterEntries():
# checkProg('Image converter', ['convert $$i $$o']) # checkProg('Image converter', ['convert $$i $$o'])
# #
# Entried that do not need checkProg # Entried that do not need checkProg
addToRC(r'''\converter lyxpreview ppm "python $$s/scripts/lyxpreview2bitmap.py" "" addToRC(r'''\converter lyxpreview ppm "python -tt $$s/scripts/lyxpreview2bitmap.py" ""
\converter date dateout "date +%d-%m-%Y > $$o" "" \converter date dateout "date +%d-%m-%Y > $$o" ""
\converter docbook docbook-xml "cp $$i $$o" "xml" \converter docbook docbook-xml "cp $$i $$o" "xml"
\converter fen asciichess "python $$s/scripts/fen2ascii.py $$i $$o" "" \converter fen asciichess "python -tt $$s/scripts/fen2ascii.py $$i $$o" ""
\converter fig pdftex "sh $$s/scripts/fig2pdftex.sh $$i $$o" "" \converter fig pdftex "python -tt $$s/scripts/fig2pdftex.py $$i $$o" ""
\converter fig pstex "sh $$s/scripts/fig2pstex.sh $$i $$o" "" \converter fig pstex "python -tt $$s/scripts/fig2pstex.py $$i $$o" ""
\converter lyx lyx13x "python $$s/lyx2lyx/lyx2lyx -t 221 $$i > $$o" "" \converter lyx lyx13x "python -tt $$s/lyx2lyx/lyx2lyx -t 221 $$i > $$o" ""
''') ''')
@ -442,9 +442,9 @@ def checkOtherEntries():
\print_spool_command "lpr"''', \print_spool_command "lpr"''',
'']) ''])
# Add the rest of the entries (no checkProg is required) # Add the rest of the entries (no checkProg is required)
addToRC(r'''\copier fig "python $$s/scripts/fig_copy.py $$i $$o" addToRC(r'''\copier fig "python -tt $$s/scripts/fig_copy.py $$i $$o"
\copier pstex "python $$s/scripts/tex_copy.py $$i $$o $$l" \copier pstex "python -tt $$s/scripts/tex_copy.py $$i $$o $$l"
\copier pdftex "python $$s/scripts/tex_copy.py $$i $$o $$l" \copier pdftex "python -tt $$s/scripts/tex_copy.py $$i $$o $$l"
''') ''')

View File

@ -1,4 +1,4 @@
#!/usr/bin/env python -tt #!/usr/bin/env python
# -*- coding: iso-8859-15 -*- # -*- coding: iso-8859-15 -*-
# file convertDefault.py # file convertDefault.py

105
lib/scripts/fig2pdftex.py Normal file
View File

@ -0,0 +1,105 @@
#!/usr/bin/env python
# -*- coding: iso-8859-15 -*-
# file fig2pdf.py
# This file is part of LyX, the document processor.
# Licence details can be found in the file COPYING.
#
# \author Angus Leeming
# \author Bo Peng
#
# Full author contact details are available in file CREDITS
# This script converts an XFIG image to something that pdflatex can process
# into high quality PDF.
# Usage:
# python fig2pdftex.py ${base}.fig ${base}.pdft
# This command generates
# ${base}.pdf the converted pdf file
# ${base}.pdft a tex file that can be included in your latex document
# using '\input{${base}.pdft}'
#
# Note:
# Do not use this command as
# python fig2pdftex.py file.fig file.pdf
# the real pdf file will be overwritten by a tex file named file.pdf.
#
import os, sys, re
def runCommand(cmd):
''' Utility function:
run a command, quit if fails
'''
if os.system(cmd) != 0:
print "Command '%s' fails." % cmd
sys.exit(1)
# We expect two args, the names of the input and output files.
if len(sys.argv) != 3:
sys.exit(1)
input, output = sys.argv[1:]
# Fail silently if the file doesn't exist
if not os.path.isfile(input):
sys.exit(0)
# Strip the extension from ${output}
outbase = os.path.splitext(output)[0]
# Ascertain whether fig2dev is "modern enough".
# If it is, then the help info will mention "pdftex_t" as one of the
# available outputs.
fout = os.popen('fig2dev -h')
help_msg = fout.read()
fout.close()
if 'pdftex_t' in help_msg:
# Modern versions of xfig can output the image without "special" text as
# a PDF file ${base}.pdf and place the text in a LaTeX file
# ${base}.pdftex_t for typesetting by pdflatex itself.
runCommand('fig2dev -Lpdftex -p1 %s %s.pdf' % (input, outbase))
runCommand('fig2dev -Lpdftex_t -p%s %s %s' % (outbase, input, output))
else:
# Older versions of xfig cannot do this, so we emulate the behaviour using
# pstex and pstex_t output.
runCommand('fig2dev -Lpstex %s %s.pstex' % (input, outbase))
runCommand('fig2dev -Lpstex_t -p %s %s %s' % (outbase, input, output))
# manipulates the Bounding Box info to enable gs to produce
# the appropriate PDF file from an EPS one.
# The generated PostScript commands are extracted from epstopdf, distributed
# with tetex.
epsfile = outbase + '.pstex'
tmp = open(epsfile + '.??', 'w')
boundingboxline = re.compile('%%BoundingBox:\s+(\d*)\s+(\d*)\s+(\d*)\s+(\d*)')
for line in open(epsfile).xreadlines():
if line[:13] == '%%BoundingBox':
(llx, lly, urx, ury) = map(int, boundingboxline.search(line).groups())
width = urx - llx
height = ury - lly
xoffset = - llx
yoffset = - lly
tmp.write('''%%%%BoundingBox: 0 0 %d %d
<< /PageSize [%d %d] >> setpagedevice
gsave %d %d translate
''' % (width, height, width, height, xoffset, yoffset))
else:
tmp.write(line)
tmp.close()
# direct move(rename) may fail under windows
os.unlink(epsfile)
os.rename(epsfile + '.??', epsfile)
# Convert the ${pstex} EPS file (free of "special" text) to PDF format
# using gs
runCommand('gs -q -dNOPAUSE -dBATCH -dSAFER -sDEVICE=pdfwrite -sOutputFile=%s.pdf %s.pstex'\
% (outbase, outbase))
os.unlink(epsfile)

View File

@ -1,134 +0,0 @@
#! /bin/sh
# file fig2pdf.sh
# This file is part of LyX, the document processor.
# Licence details can be found in the file COPYING.
#
# author Angus Leeming
#
# Full author contact details are available in file CREDITS
# This script converts an XFIG image to something that pdflatex can process
# into high quality PDF.
# Usage: sh fig2pdf.sh ${base}.xfig
# to generate ${base}.pdftex_t
# Thereafter, you need only '\input{${base}.pdftex_t}' in your latex document.
# The external programs
FIG2DEV=fig2dev
# Used only by legacy_xfig
GS=gs
find_exe() {
test $# -eq 1 || exit 1
type $1 > /dev/null || {
echo "Unable to find \"$1\". Please install."
exit 1
}
}
# modern_xfig() and legacy_xfig() are the functions that do all the work.
# Modern versions of xfig can output the image without "special" text as
# a PDF file ${base}.pdf and place the text in a LaTeX file
# ${base}.pdftex_t for typesetting by pdflatex itself.
modern_xfig() {
# Can we find fig2dev?
find_exe ${FIG2DEV}
input=$1
pdftex_t=$2
pdftex=$3.pdf
${FIG2DEV} -Lpdftex -p1 ${input} ${pdftex}
${FIG2DEV} -Lpdftex_t -p${outbase} ${input} ${pdftex_t}
exit 0;
}
# This function is used only by legacy_xfig.
# It manipulates the Bounding Box info to enable gs to produce
# the appropriate PDF file from an EPS one.
# The generated PostScript commands are extracted from epstopdf, distributed
# with tetex.
clean_epsfile() {
test $# -eq 1 || exit 1
# No bounding box info
grep '%%BoundingBox' $1 > /dev/null || return 1;
bbox=`sed -n '/^%%BoundingBox/p' $1`
llx=`echo ${bbox} | cut -d' ' -f2`
lly=`echo ${bbox} | cut -d' ' -f3`
urx=`echo ${bbox} | cut -d' ' -f4`
ury=`echo ${bbox} | cut -d' ' -f5`
width=`expr $urx - $llx`
height=`expr $ury - $lly`
xoffset=`expr 0 - $llx`
yoffset=`expr 0 - $lly`
temp=$1.??
sed "/^%%BoundingBox/{
s/^\(%%BoundingBox:\).*/\1 0 0 ${width} ${height}\\
<< \/PageSize [${width} ${height}] >> setpagedevice\\
gsave ${xoffset} ${yoffset} translate/
}" $1 > $temp
mv -f $temp $1
}
# Older versions of xfig cannot do this, so we emulate the behaviour using
# pstex and pstex_t output.
legacy_xfig() {
# Can we find fig2dev and epstopdf?
find_exe ${FIG2DEV}
find_exe ${GS}
input=$1
pdftex_t=$2
pdf=$3.pdf
pstex=$3.pstex
${FIG2DEV} -Lpstex ${input} ${pstex}
${FIG2DEV} -Lpstex_t -p${outbase} ${input} ${pdftex_t}
# Convert the ${pstex} EPS file (free of "special" text) to PDF format
# using gs
clean_epsfile ${pstex}
${GS} -q -dNOPAUSE -dBATCH -dSAFER \
-sDEVICE=pdfwrite -sOutputFile=${pdf} ${pstex}
rm -f ${pstex}
exit 0;
}
# The main logic of the script is below.
# All it does is ascertain which of the two functions above to call.
# We expect two args, the names of the input and output files.
test $# -eq 2 || exit 1
input=$1
output=$2
# Fail silently if the file doesn't exist
test -r $input || exit 0
# Strip the extension from ${output}
outbase=`echo ${output} | sed 's/[.][^.]*$//'`
# Ascertain whether fig2dev is "modern enough".
# If it is, then the help info will mention "pdftex_t" as one of the
# available outputs.
CONVERT_IT=modern_xfig
${FIG2DEV} -h | grep 'pdftex_t' > /dev/null || CONVERT_IT=legacy_xfig
${CONVERT_IT} ${input} ${output} ${outbase}
# The end

50
lib/scripts/fig2pstex.py Normal file
View File

@ -0,0 +1,50 @@
#!/usr/bin/env python
# -*- coding: iso-8859-15 -*-
# file fig2pstex.py
# This file is part of LyX, the document processor.
# Licence details can be found in the file COPYING.
#
# \author Angus Leeming
# \author Bo Peng
#
# Full author contact details are available in file CREDITS
# This script converts an XFIG image to something that latex can process
# into high quality PostScript.
# Usage:
# python fig2pstex.py ${base}.fig ${base}.pstex
# This command generates
# ${base}.eps the converted eps file
# ${base}.pstex a tex file that can be included in your latex document
# using '\input{${output}}'.
#
# Note:
# Do not use this command as
# python fig2pstex.py file.fig file.eps
# the real eps file will be overwritten by a tex file named file.eps.
#
import os, sys
# We expect two args, the names of the input and output files.
if len(sys.argv) != 3:
sys.exit(1)
input, output = sys.argv[1:]
# Fail silently if the file doesn't exist
if not os.path.isfile(input):
sys.exit(0)
# Strip the extension from ${output}
outbase = os.path.splitext(output)[0]
# Generate the EPS file
# Generate the PSTEX_T file
if os.system('fig2dev -Lpstex %s %s.eps' % (input, outbase)) != 0 or \
os.system('fig2dev -Lpstex_t -p%s %s %s' % (outbase, input, output)) != 0:
print 'fig2dev fails'
sys.exit(1)

View File

@ -1,44 +0,0 @@
#! /bin/sh
# file fig2pstex.sh
# This file is part of LyX, the document processor.
# Licence details can be found in the file COPYING.
#
# author Angus Leeming
#
# Full author contact details are available in file CREDITS
# This script converts an XFIG image to something that latex can process
# into high quality PostScript.
# Usage: sh fig2pstex.sh ${input} ${output}
# to generate the pstex_t file ${output}.
# In turn this file will \includegraphics{${output_base}}.
# The necessary ${output_base}.eps is also generated by this script.
#
# Thereafter, you need only '\input{${output}}' in your latex document.
# We expect two args, the names of the input and output files.
test $# -eq 2 || exit 1
# Can we find fig2dev?
type fig2dev > /dev/null || exit 1
input=$1
output=$2
# Fail silently if the file doesn't exist
test -r $input || exit 0
# Strip the extension from ${output}
outbase=`echo ${output} | sed 's/[.][^.]*$//'`
# Generate the EPS file
outeps=${outbase}.eps
fig2dev -Lpstex ${input} ${outeps}
# Generate the PSTEX_T file
fig2dev -Lpstex_t -p${outbase} ${input} ${output}
# The end