summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorHans Hagen <pragma@wxs.nl>2004-12-17 00:00:00 +0100
committerHans Hagen <pragma@wxs.nl>2004-12-17 00:00:00 +0100
commit5604cb0a875f6114b67391fd279060678a9b7937 (patch)
tree443afcf61e75ccfc0f68d851be02dfd50714a803 /scripts
parentaade518a7e81df4cdf6b89559c5afc5192954a5e (diff)
downloadcontext-5604cb0a875f6114b67391fd279060678a9b7937.tar.gz
stable 2004.12.17
Diffstat (limited to 'scripts')
-rw-r--r--scripts/context/ruby/texmfstart.rb47
1 files changed, 41 insertions, 6 deletions
diff --git a/scripts/context/ruby/texmfstart.rb b/scripts/context/ruby/texmfstart.rb
index 74d9e3d24..bfa50eb37 100644
--- a/scripts/context/ruby/texmfstart.rb
+++ b/scripts/context/ruby/texmfstart.rb
@@ -28,7 +28,7 @@ require "rbconfig"
$mswindows = Config::CONFIG['host_os'] =~ /mswin/
$separator = File::PATH_SEPARATOR
-$version = "1.05"
+$version = "1.5.2"
if $mswindows then
@@ -88,7 +88,6 @@ else
end
-
class File
def File.needsupdate(oldname,newname)
@@ -102,7 +101,7 @@ class File
def File.syncmtimes(oldname,newname)
begin
t = File.mtime(oldname) # i'm not sure if the time is frozen, so we do it here
- File.utime(0,t,newname)
+ File.utime(0,t,oldname,newname)
rescue
end
end
@@ -172,14 +171,28 @@ def launch(filename)
end
end
-def expanded(arg)
+def expanded(arg) # no "other text files", too restricted
arg.gsub(/kpse\:(\S+)/o) do
original, resolved = $1, ''
+ if $program && ! $program.empty? then
+ pstr = "-progname=#{$program}"
+ else
+ pstr = ''
+ end
+ # auto suffix with texinputs as fall back
begin
- resolved = `kpsewhich -progname=#{program} -format=\"other text files\" #{file}`.chomp
+ resolved = `kpsewhich #{pstr} #{original}`.chomp
rescue
resolved = ''
end
+ # elsewhere in the tree
+ if resolved.empty? then
+ begin
+ resolved = `kpsewhich #{pstr} -format="other text files" #{original}`.chomp
+ rescue
+ resolved = ''
+ end
+ end
if resolved.empty? then
report("#{original} is not resolved") unless $report
original
@@ -194,9 +207,10 @@ def runcommand(command)
if $locate then
print(command)
elsif $execute then
- report("using 'exec' instead of 'system' call") if $verbose
+ report("using 'exec' instead of 'system' call: #{command}") if $verbose
exec(command)
else
+ report("using 'system' call: #{command}") if $verbose
system(command)
end
end
@@ -260,6 +274,7 @@ def usage
print(" texmfstart --program=yourtex yourscript.pl arg-1 arg-2\n")
print(" texmfstart --direct xsltproc kpse:somefile.xsl somefile.xml\n")
print(" texmfstart bin:xsltproc kpse:somefile.xsl somefile.xml\n")
+ print(" texmfstart --iftouched=normal,lowres downsample.rb normal lowres\n")
end
# somehow registration does not work out (at least not under windows)
@@ -538,12 +553,32 @@ $indirect = $directives['indirect'] || false
$iftouched = $directives['iftouched'] || false
+$openoffice = $directives['oo'] || false
+
$applications['unknown'] = ''
$applications['perl'] = $applications['pl'] = 'perl'
$applications['ruby'] = $applications['rb'] = 'ruby'
$applications['python'] = $applications['py'] = 'python'
$applications['java'] = $applications['jar'] = 'java'
+if $openoffice then
+ if ENV['OOPATH'] then
+ if FileTest.directory?(ENV['OOPATH']) then
+ report("using open office python") if $verbose
+ if $mswindows then
+ $applications['python'] = $applications['py'] = "\"#{File.join(ENV['OOPATH'],'program','python.bat')}\""
+ else
+ $applications['python'] = $applications['py'] = File.join(ENV['OOPATH'],'python')
+ end
+ report("python path #{$applications['python']}") if $verbose
+ else
+ report("environment variable 'OOPATH' does not exist") if $verbose
+ end
+ else
+ report("environment variable 'OOPATH' is not set") if $verbose
+ end
+end
+
if $mswindows then
$applications['pdf'] = ['',"pdfopen --page #{$page} --file",'acroread']
$applications['html'] = ['','netscape','mozilla','opera','iexplore']