Added a buildout to the package itself, for both Plone 3.x and 4.x.
svn path=/plone.app.discussion/trunk/; revision=33809
This commit is contained in:
		
							parent
							
								
									fde7f2f828
								
							
						
					
					
						commit
						7049413ec8
					
				
							
								
								
									
										121
									
								
								bootstrap.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										121
									
								
								bootstrap.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,121 @@
 | 
				
			|||||||
 | 
					##############################################################################
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# Copyright (c) 2006 Zope Corporation and Contributors.
 | 
				
			||||||
 | 
					# All Rights Reserved.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# This software is subject to the provisions of the Zope Public License,
 | 
				
			||||||
 | 
					# Version 2.1 (ZPL).  A copy of the ZPL should accompany this distribution.
 | 
				
			||||||
 | 
					# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
 | 
				
			||||||
 | 
					# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 | 
				
			||||||
 | 
					# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
 | 
				
			||||||
 | 
					# FOR A PARTICULAR PURPOSE.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					##############################################################################
 | 
				
			||||||
 | 
					"""Bootstrap a buildout-based project
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Simply run this script in a directory containing a buildout.cfg.
 | 
				
			||||||
 | 
					The script accepts buildout command-line options, so you can
 | 
				
			||||||
 | 
					use the -c option to specify an alternate configuration file.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$Id$
 | 
				
			||||||
 | 
					"""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import os, shutil, sys, tempfile, urllib2
 | 
				
			||||||
 | 
					from optparse import OptionParser
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					tmpeggs = tempfile.mkdtemp()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					is_jython = sys.platform.startswith('java')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# parsing arguments
 | 
				
			||||||
 | 
					parser = OptionParser()
 | 
				
			||||||
 | 
					parser.add_option("-v", "--version", dest="version",
 | 
				
			||||||
 | 
					                          help="use a specific zc.buildout version")
 | 
				
			||||||
 | 
					parser.add_option("-d", "--distribute",
 | 
				
			||||||
 | 
					                   action="store_true", dest="distribute", default=False,
 | 
				
			||||||
 | 
					                   help="Use Disribute rather than Setuptools.")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					parser.add_option("-c", None, action="store", dest="config_file",
 | 
				
			||||||
 | 
					                   help=("Specify the path to the buildout configuration "
 | 
				
			||||||
 | 
					                         "file to be used."))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					options, args = parser.parse_args()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# if -c was provided, we push it back into args for buildout' main function
 | 
				
			||||||
 | 
					if options.config_file is not None:
 | 
				
			||||||
 | 
					    args += ['-c', options.config_file]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if options.version is not None:
 | 
				
			||||||
 | 
					    VERSION = '==%s' % options.version
 | 
				
			||||||
 | 
					else:
 | 
				
			||||||
 | 
					    VERSION = ''
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					USE_DISTRIBUTE = options.distribute
 | 
				
			||||||
 | 
					args = args + ['bootstrap']
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					to_reload = False
 | 
				
			||||||
 | 
					try:
 | 
				
			||||||
 | 
					    import pkg_resources
 | 
				
			||||||
 | 
					    if not hasattr(pkg_resources, '_distribute'):
 | 
				
			||||||
 | 
					        to_reload = True
 | 
				
			||||||
 | 
					        raise ImportError
 | 
				
			||||||
 | 
					except ImportError:
 | 
				
			||||||
 | 
					    ez = {}
 | 
				
			||||||
 | 
					    if USE_DISTRIBUTE:
 | 
				
			||||||
 | 
					        exec urllib2.urlopen('http://python-distribute.org/distribute_setup.py'
 | 
				
			||||||
 | 
					                         ).read() in ez
 | 
				
			||||||
 | 
					        ez['use_setuptools'](to_dir=tmpeggs, download_delay=0, no_fake=True)
 | 
				
			||||||
 | 
					    else:
 | 
				
			||||||
 | 
					        exec urllib2.urlopen('http://peak.telecommunity.com/dist/ez_setup.py'
 | 
				
			||||||
 | 
					                             ).read() in ez
 | 
				
			||||||
 | 
					        ez['use_setuptools'](to_dir=tmpeggs, download_delay=0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if to_reload:
 | 
				
			||||||
 | 
					        reload(pkg_resources)
 | 
				
			||||||
 | 
					    else:
 | 
				
			||||||
 | 
					        import pkg_resources
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if sys.platform == 'win32':
 | 
				
			||||||
 | 
					    def quote(c):
 | 
				
			||||||
 | 
					        if ' ' in c:
 | 
				
			||||||
 | 
					            return '"%s"' % c # work around spawn lamosity on windows
 | 
				
			||||||
 | 
					        else:
 | 
				
			||||||
 | 
					            return c
 | 
				
			||||||
 | 
					else:
 | 
				
			||||||
 | 
					    def quote (c):
 | 
				
			||||||
 | 
					        return c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					cmd = 'from setuptools.command.easy_install import main; main()'
 | 
				
			||||||
 | 
					ws  = pkg_resources.working_set
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if USE_DISTRIBUTE:
 | 
				
			||||||
 | 
					    requirement = 'distribute'
 | 
				
			||||||
 | 
					else:
 | 
				
			||||||
 | 
					    requirement = 'setuptools'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if is_jython:
 | 
				
			||||||
 | 
					    import subprocess
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    assert subprocess.Popen([sys.executable] + ['-c', quote(cmd), '-mqNxd',
 | 
				
			||||||
 | 
					           quote(tmpeggs), 'zc.buildout' + VERSION],
 | 
				
			||||||
 | 
					           env=dict(os.environ,
 | 
				
			||||||
 | 
					               PYTHONPATH=
 | 
				
			||||||
 | 
					               ws.find(pkg_resources.Requirement.parse(requirement)).location
 | 
				
			||||||
 | 
					               ),
 | 
				
			||||||
 | 
					           ).wait() == 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					else:
 | 
				
			||||||
 | 
					    assert os.spawnle(
 | 
				
			||||||
 | 
					        os.P_WAIT, sys.executable, quote (sys.executable),
 | 
				
			||||||
 | 
					        '-c', quote (cmd), '-mqNxd', quote (tmpeggs), 'zc.buildout' + VERSION,
 | 
				
			||||||
 | 
					        dict(os.environ,
 | 
				
			||||||
 | 
					            PYTHONPATH=
 | 
				
			||||||
 | 
					            ws.find(pkg_resources.Requirement.parse(requirement)).location
 | 
				
			||||||
 | 
					            ),
 | 
				
			||||||
 | 
					        ) == 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ws.add_entry(tmpeggs)
 | 
				
			||||||
 | 
					ws.require('zc.buildout' + VERSION)
 | 
				
			||||||
 | 
					import zc.buildout.buildout
 | 
				
			||||||
 | 
					zc.buildout.buildout.main(args)
 | 
				
			||||||
 | 
					shutil.rmtree(tmpeggs)
 | 
				
			||||||
							
								
								
									
										2
									
								
								buildout.cfg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								buildout.cfg
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,2 @@
 | 
				
			|||||||
 | 
					[buildout]
 | 
				
			||||||
 | 
					extends = test-plone-3.3.x.cfg
 | 
				
			||||||
							
								
								
									
										25
									
								
								test-plone-3.3.x.cfg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								test-plone-3.3.x.cfg
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,25 @@
 | 
				
			|||||||
 | 
					[buildout]
 | 
				
			||||||
 | 
					extends =
 | 
				
			||||||
 | 
					    http://svn.plone.org/svn/collective/buildout/plonetest/plone-3.3.x.cfg
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					package-name = plone.app.discussion
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[versions]
 | 
				
			||||||
 | 
					collective.autopermission = 1.0b1
 | 
				
			||||||
 | 
					collective.monkeypatcher = 1.0b2
 | 
				
			||||||
 | 
					collective.z3cform.datetimewidget = 0.1a9
 | 
				
			||||||
 | 
					plone.app.registry = 1.0b1
 | 
				
			||||||
 | 
					plone.app.z3cform = 0.4.9
 | 
				
			||||||
 | 
					plone.autoform = 1.0b2
 | 
				
			||||||
 | 
					plone.registry = 1.0b1
 | 
				
			||||||
 | 
					plone.supermodel = 1.0b4
 | 
				
			||||||
 | 
					plone.z3cform = 0.5.6
 | 
				
			||||||
 | 
					z3c.batching = 1.1.0
 | 
				
			||||||
 | 
					z3c.form = 1.9.0
 | 
				
			||||||
 | 
					z3c.formwidget.query = 0.3
 | 
				
			||||||
 | 
					zope.app.broken = 3.4.0
 | 
				
			||||||
 | 
					zope.component = 3.5.1
 | 
				
			||||||
 | 
					zope.container = 3.7.0
 | 
				
			||||||
 | 
					zope.location = 3.4.0
 | 
				
			||||||
 | 
					zope.security = 3.4.3
 | 
				
			||||||
 | 
					zope.site = 3.5.1
 | 
				
			||||||
							
								
								
									
										20
									
								
								test-plone-4.0.x.cfg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								test-plone-4.0.x.cfg
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,20 @@
 | 
				
			|||||||
 | 
					[buildout]
 | 
				
			||||||
 | 
					extends =
 | 
				
			||||||
 | 
					    http://svn.plone.org/svn/collective/buildout/plonetest/plone-4.0.x.cfg
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					package-name = plone.app.discussion
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[versions]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					collective.autopermission = 1.0b1
 | 
				
			||||||
 | 
					collective.monkeypatcher = 1.0b2
 | 
				
			||||||
 | 
					collective.z3cform.datetimewidget = 0.1a9
 | 
				
			||||||
 | 
					plone.app.registry = 1.0b1
 | 
				
			||||||
 | 
					plone.app.z3cform = 0.4.9
 | 
				
			||||||
 | 
					plone.autoform = 1.0b2
 | 
				
			||||||
 | 
					plone.registry = 1.0b1
 | 
				
			||||||
 | 
					plone.supermodel = 1.0b4
 | 
				
			||||||
 | 
					plone.z3cform = 0.5.6
 | 
				
			||||||
 | 
					z3c.batching = 1.1.0
 | 
				
			||||||
 | 
					z3c.form = 2.2.0
 | 
				
			||||||
 | 
					z3c.formwidget.query = 0.5
 | 
				
			||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user