[Python-checkins] python/dist/src/Mac/OSX/Doc setup.py,NONE,1.1

jackjansen@users.sourceforge.net jackjansen@users.sourceforge.net
Fri, 14 Feb 2003 15:46:24 -0800


Update of /cvsroot/python/python/dist/src/Mac/OSX/Doc
In directory sc8-pr-cvs1:/tmp/cvs-serv7170/Doc

Added Files:
	setup.py 
Log Message:
Moved setupDocs.py to Doc/setup.py and did some cleanup. It now at least
allows bdist, but it's still one big hack:-(


--- NEW FILE: setup.py ---
# Build and install an Apple Help Viewer compatible version of the Python
# documentation into the framework.
# Code by Bill Fancher, with some modifications by Jack Jansen.
#
# You must run this as a two-step process
# 1. python setupDocs.py build
# 2. Wait for Apple Help Indexing Tool to finish
# 3. python setupDocs.py install
#
# To do:
# - test whether the docs are available locally before downloading
# - fix buildDocsFromSource
# - Get documentation version from sys.version, fallback to 2.2.1
# - See if we can somehow detect that Apple Help Indexing Tool is finished
# - data_files to setup() doesn't seem the right way to pass the arguments
#
import sys, os, re
from distutils.cmd import Command
from distutils.command.build import build
from distutils.core import setup
from distutils.file_util import copy_file
from distutils.dir_util import copy_tree
from distutils.log import log
from distutils.spawn import spawn
from distutils import sysconfig, dep_util
from distutils.util import change_root

		
class DocBuild(build):
	def initialize_options(self):
		build.initialize_options(self)
		self.build_html = None
		self.build_dest = None
		self.download = 1
		self.doc_version = '2.2.1'
		
	def finalize_options(self):
		build.finalize_options(self)
		if self.build_html is None:
			self.build_html = os.path.join(self.build_base, 'html')
		if self.build_dest is None:
			self.build_dest = os.path.join(self.build_base, 'processed-html')
	
	def spawn(self, *args):
		spawn(args, 1,  self.verbose, self.dry_run)
	
	def downloadDocs(self):
		workdir = os.getcwd()
		self.mkpath(self.build_html)
		os.chdir(self.build_base)
		self.spawn('curl','-O', 'http://www.python.org/ftp/python/doc/%s/html-%s.tgz' % (self.doc_version,self.doc_version))
		os.chdir(workdir)
		os.chdir(self.build_html)
		self.spawn('tar', '-xzf', '../html-%s.tgz' % self.doc_version)
		os.chdir(workdir)
		
	def buildDocsFromSource(self):
		srcdir = '../../..'
		docdir = os.path.join(srcdir, 'Doc')
		htmldir = os.path.join(docdir, 'html')
		spawn(('make','--directory', docdir, 'html'), 1, self.verbose, self.dry_run)
		self.mkpath(self.build_html)
		copy_tree(htmldir, self.build_html)
		
	def ensureHtml(self):
		if not os.path.exists(self.build_html):
			if self.download:
				self.downloadDocs()
			else:
				self.buildDocsFromSource()
				
	def hackIndex(self):
		ind_html = 'index.html'
		#print 'self.build_dest =', self.build_dest
		hackedIndex = file(os.path.join(self.build_dest, ind_html),'w')
		origIndex = file(os.path.join(self.build_html,ind_html))
		r = re.compile('<style type="text/css">.*</style>', re.DOTALL)
		hackedIndex.write(r.sub('<META NAME="AppleTitle" CONTENT="Python Help">',origIndex.read()))
	
	def hackFile(self,d,f):
		origPath = os.path.join(d,f)
		assert(origPath[:len(self.build_html)] == self.build_html)
		outPath = os.path.join(self.build_dest, d[len(self.build_html)+1:], f)
		(name, ext) = os.path.splitext(f)
		if os.path.isdir(origPath):
			self.mkpath(outPath)
		elif ext == '.html':
			if self.verbose: print 'hacking %s to %s' % (origPath,outPath)
			hackedFile = file(outPath, 'w')
			origFile = file(origPath,'r')
			hackedFile.write(self.r.sub('<dl><dt><dd>', origFile.read()))
		else:
			copy_file(origPath, outPath)
			
	def hackHtml(self):
		self.r = re.compile('<dl><dd>')
		os.path.walk(self.build_html, self.visit, None)

	def visit(self, dummy, dirname, filenames):
		for f in filenames:
			self.hackFile(dirname, f)
			
	def makeHelpIndex(self):
		app = '/Developer/Applications/Apple Help Indexing Tool.app'
		self.spawn('open', '-a', app , self.build_dest)
		print "Please wait until Apple Help Indexing Tool finishes before installing"
		
	def run(self):
		self.ensure_finalized()
		self.ensureHtml()
		if not os.path.isdir(self.build_html):
			raise RuntimeError, \
  			"Can't find source folder for documentation."
  		self.mkpath(self.build_dest)
		if dep_util.newer(os.path.join(self.build_html,'index.html'), os.path.join(self.build_dest,'index.html')):
			self.mkpath(self.build_dest)
			self.hackHtml()
			self.hackIndex()
			self.makeHelpIndex()

class AHVDocInstall(Command):
	description = "install Apple Help Viewer html files"
	user_options = [('install-doc=', 'd',
		'directory to install HTML tree'),
		 ('root=', None,
		 "install everything relative to this alternate root directory"),
		]
		
	def initialize_options(self):
		self.build_dest = None
		self.install_doc = None
		self.prefix = None
		self.root = None
			
	def finalize_options(self):
		self.set_undefined_options('install',
			('prefix', 'prefix'),
			('root', 'root'))
#		import pdb ; pdb.set_trace()
		build_cmd = self.get_finalized_command('build')
		if self.build_dest == None:
			build_cmd = self.get_finalized_command('build')
			self.build_dest = build_cmd.build_dest
		if self.install_doc == None:
			self.install_doc = os.path.join(self.prefix, 'Resources/English.lproj/Documentation')
		print 'INSTALL', self.build_dest, '->', self.install_doc
		
	def run(self):
		self.finalize_options()
		self.ensure_finalized()
		print "Running Installer"
		instloc = self.install_doc
		if self.root:
			instloc = change_root(self.root, instloc)
		self.mkpath(instloc)
		copy_tree(self.build_dest, instloc)
		print "Installation complete"
		
def mungeVersion(infile, outfile):
	i = file(infile,'r')
	o = file(outfile,'w')
	o.write(re.sub('\$\(VERSION\)',sysconfig.get_config_var('VERSION'),i.read()))
	i.close()
	o.close()
		
def main():
	# turn off warnings when deprecated modules are imported
##	import warnings
##	warnings.filterwarnings("ignore",category=DeprecationWarning)
	setup(name = 'Documentation',
  		version = '%d.%d' % sys.version_info[:2],
  		cmdclass = {'install_data':AHVDocInstall, 'build':DocBuild},
  		data_files = ['dummy'],
 		)

if __name__ == '__main__':
	main()