Twisted's automated release system.

This module is only for use within Twisted's release system. If you are anyone else, do not use it. The interface and behaviour will change without notice.

Only Linux is supported by this code. It should not be used by any tools which must run on multiple platforms (eg the setup.py script).

Function runCommand Execute a vector of arguments.
Interface IVCSCommand An interface for VCS commands.
Class GitCommand Subset of Git commands to release Twisted from a Git repository.
Function getRepositoryCommand Detect the VCS used in the specified directory and return a GitCommand if the directory is a Git repository. If the directory is not git, it raises a NotWorkingDirectory exception.
Function getNextVersion Calculate the version number for a new release of Twisted based on the previous version number.
Function changeAllProjectVersions Change the version of the project.
Class Project A representation of a project that has a version.
Function findTwistedProjects Find all Twisted-style projects beneath a base directory.
Function generateVersionFileData Generate the data to be placed into a _version.py file.
Function replaceProjectVersion Write version specification code into the given filename, which sets the version to the given version number.
Function replaceInFile I replace the text `oldstr' with `newstr' in `filename' using science.
Class NoDocumentsFound Raised when no input documents are found.
Class APIBuilder Generate API documentation from source files using pydoctor. This requires pydoctor to be installed and usable.
Class NewsBuilder Generate the new section of a NEWS file.
Class SphinxBuilder Generate HTML documentation using Sphinx.
Function filePathDelta Return a list of strings that represent destination as a path relative to origin.
Class NotWorkingDirectory Raised when a directory does not appear to be a repository directory of a supported VCS.
Class ChangeVersionsScriptOptions Options for ChangeVersionsScript.
Class ChangeVersionsScript A thing for changing version numbers. See main.
Class BuildAPIDocsScript A thing for building API documentation. See main.
Class CheckTopfileScript A thing for checking whether a checkout has a topfile.
Function _changeVersionInFile Replace the old version number with the new one in the given filename.
def runCommand(args, **kwargs): (source)

Execute a vector of arguments.

This is a wrapper around subprocess.check_output, so it takes the same arguments as subprocess.Popen with one difference: all arguments after the vector must be keyword arguments.

def getRepositoryCommand(directory): (source)

Detect the VCS used in the specified directory and return a GitCommand if the directory is a Git repository. If the directory is not git, it raises a NotWorkingDirectory exception.

ParametersdirectoryThe directory to detect the VCS used from. (type: FilePath)
Returns (type: GitCommand)
RaisesNotWorkingDirectoryif no supported VCS can be found from the specified directory.
def _changeVersionInFile(old, new, filename): (source)

Replace the old version number with the new one in the given filename.

def getNextVersion(version, prerelease, patch, today): (source)

Calculate the version number for a new release of Twisted based on the previous version number.

ParametersversionThe previous version number.
prereleaseIf True, make the next version a pre-release one. If version is a pre-release, it increments the pre-release counter, otherwise create a new version with prerelease set to 1. (type: bool)
patchIf True, make the next version a patch release. It increments the micro counter. (type: bool)
todayThe current date. (type: datetime)
def changeAllProjectVersions(root, prerelease, patch, today=None): (source)

Change the version of the project.

ParametersrootThe root of the Twisted source tree. (type: FilePath)
prerelease (type: bool)
patch (type: bool)
todayDefaults to the current day, according to the system clock. (type: datetime)
def findTwistedProjects(baseDirectory): (source)

Find all Twisted-style projects beneath a base directory.

ParametersbaseDirectoryA twisted.python.filepath.FilePath to look inside.
ReturnsA list of Project.
def generateVersionFileData(version): (source)

Generate the data to be placed into a _version.py file.

ParametersversionA version object.
def replaceProjectVersion(filename, newversion): (source)

Write version specification code into the given filename, which sets the version to the given version number.

ParametersfilenameA filename which is most likely a "_version.py" under some Twisted project.
newversionA version object.
def replaceInFile(filename, oldToNew): (source)

I replace the text `oldstr' with `newstr' in `filename' using science.

def filePathDelta(origin, destination): (source)

Return a list of strings that represent destination as a path relative to origin.

It is assumed that both paths represent directories, not files. That is to say, the delta of twisted.python.filepath.FilePath /foo/bar to twisted.python.filepath.FilePath /foo/baz will be ../baz, not baz.

ParametersoriginThe origin of the relative path. (type: twisted.python.filepath.FilePath)
destinationThe destination of the relative path. (type: twisted.python.filepath.FilePath)
API Documentation for Twisted, generated by pydoctor at 2016-09-15 00:53:01.