compilation séquentielle par défaut
Cette révision appartient à :
@@ -4,17 +4,22 @@ import subprocess
|
|||||||
import sys
|
import sys
|
||||||
import os
|
import os
|
||||||
|
|
||||||
def compiler(nf, lsuff) :
|
def compiler(nf, lsuff, parallel = False) :
|
||||||
basedir = os.path.dirname(nf)
|
basedir = os.path.dirname(nf)
|
||||||
builddir = os.path.join(basedir, "_build")
|
builddir = os.path.join(basedir, "_build")
|
||||||
basejobname = os.path.splitext(os.path.basename(nf))[0]
|
basejobname = os.path.splitext(os.path.basename(nf))[0]
|
||||||
|
if parallel :
|
||||||
|
call = subprocess.Popen
|
||||||
|
else :
|
||||||
|
call = subprocess.call
|
||||||
# https://stackoverflow.com/a/9745864
|
# https://stackoverflow.com/a/9745864
|
||||||
processes = []
|
processes = []
|
||||||
for suff in lsuff :
|
for suff in lsuff :
|
||||||
options = suff[1]
|
options = suff[1]
|
||||||
processes.append(subprocess.Popen('''latexmk -pdflua -shell-escape -bibtex-cond -cd -interaction=batchmode -dvi- -jobname=''' +basejobname+suff[0] +''' -outdir=''' + builddir + ''' -latexoption="--output-directory='''+builddir+''' --synctex=0 ''' + options + '''" ''' + nf, shell=True, stdout=subprocess.PIPE,
|
processes.append(call('''latexmk -pdflua -shell-escape -bibtex-cond -cd -interaction=batchmode -dvi- -jobname=''' +basejobname+suff[0] +''' -outdir=''' + builddir + ''' -latexoption="--output-directory='''+builddir+''' --synctex=0 ''' + options + '''" ''' + nf, shell=True, stdout=subprocess.PIPE,
|
||||||
bufsize=1, close_fds=True,
|
bufsize=1, close_fds=True,
|
||||||
universal_newlines=True))
|
universal_newlines=True))
|
||||||
|
if parallel :
|
||||||
while len(processes) > 0 :
|
while len(processes) > 0 :
|
||||||
for p in processes:
|
for p in processes:
|
||||||
if p.poll() is not None: # process ended
|
if p.poll() is not None: # process ended
|
||||||
@@ -33,7 +38,6 @@ if sys.argv[1].endswith(".tex") :
|
|||||||
else :
|
else :
|
||||||
nf = sys.argv[1]+".tex"
|
nf = sys.argv[1]+".tex"
|
||||||
|
|
||||||
|
|
||||||
with open(nf) as f :
|
with open(nf) as f :
|
||||||
for l in f.readlines() :
|
for l in f.readlines() :
|
||||||
if l.strip() == "" or l.strip().startswith("%") :
|
if l.strip() == "" or l.strip().startswith("%") :
|
||||||
@@ -47,5 +51,5 @@ with open(nf) as f :
|
|||||||
break
|
break
|
||||||
|
|
||||||
|
|
||||||
compiler(nf, modes)
|
compiler(nf, modes, len(sys.argv)>2 and sys.argv[2]=="--parallel")
|
||||||
|
|
||||||
|
|||||||
Référencer dans un nouveau ticket
Bloquer un utilisateur