Welcome, guest | Sign In | My Account | Store | Cart

Notice! PyPM is being replaced with the ActiveState Platform, which enhances PyPM’s build and deploy capabilities. Create your free Platform account to download ActivePython or customize Python with the packages you require and get automatic updates.

Download
ActivePython
INSTALL>
pypm install buildout-script

How to install buildout_script

  1. Download and install ActivePython
  2. Open Command Prompt
  3. Type pypm install buildout-script
 Python 2.7Python 3.2Python 3.3
Windows (32-bit)
0.2a1 Available View build log
Windows (64-bit)
0.2a1 Available View build log
Mac OS X (10.5+)
0.2a1 Available View build log
Linux (32-bit)
0.2a1 Available View build log
Linux (64-bit)
0.2a1 Available View build log
 
License
MIT License
Dependencies
Imports
Lastest release
version 0.2a1 on Jan 5th, 2011

System Message: WARNING/2 (<string>, line 10)

Field list ends without a blank line; unexpected unindent.

2006, Nathan R. Yergler, Creative Commons; licensed to the public under the MIT license.

Overview

buildout_script is a zc.buildout recipe for generating scripts from a template. Unlike scripts specified in by the console_scripts entry point, those generated by buildout_script are not restricted to Python code.

Scripts are generated from templates and can include settings from the buildout substituted at runtime.

One example usage is the generation of a wrapper script for Paste Script to check the status of a daemonized server process (see paster-check below).

Usage

To use the buildout_script recipe, specify it as the recipe for a zc.buildout part along with the template part. For example:

[sample_part]

System Message: ERROR/3 (<string>, line 36)

Inconsistent literal block quoting.

recipe = buildout_script template = paster-check.sh.in

The script will be created in the bin-directory. You may also specify the following parameters:

target The filename for the generated script; if omitted, the script will have the template filename without the extension.

template_dir An optional directory to look for templates in. Default: templates Templates included with the recipe may also be used without specifying a template_dir.

Templates

Templates should be formatted using Python string formatting syntax. The dictionary used for the formatting operation is a flattened dictionary of the buildout settings and part settings.

For example, a trivial script template to list the files in the buildout installation directory would look like this:

#!/bin/bash

# Sample buildout_script script template ls %(directory)

buildout_script ships with one script template, paster-check.sh.in, described below. Additional template contributions are welcome.

paster-check.sh.in

At Creative Commons we use Paste Script as the server for simple web applications. We run them using the --daemon flag, but occassionally something goes awry and the process dies. This template generates a script which can be called periodically from cron to ensure the process is still running. Note that this script can also be used to start the server if it is not already running.

Configuration Parameters

Configuration parameters used by this script, which should be specified as settings in the zc.buildout part:

server_cfg The Paste Deploy configuration file to serve.

pid_file The PID file to use when starting the server (and to subsequently check).

log_file The log file to use.

Change History

0.2a1 (2007-03-14)
  • Implemented template recipe for creating a non-executable file.
0.1 (2006-12-12)
  • Initial public release

Download

Subscribe to package updates

Last updated Jan 5th, 2011

Download Stats

Last month:6

What does the lock icon mean?

Builds marked with a lock icon are only available via PyPM to users with a current ActivePython Business Edition subscription.

Need custom builds or support?

ActivePython Enterprise Edition guarantees priority access to technical support, indemnification, expert consulting and quality-assured language builds.

Plan on re-distributing ActivePython?

Get re-distribution rights and eliminate legal risks with ActivePython OEM Edition.