DESCRIPTION
The Debbugs::Versions module provides generic support functions for the implementation of version tracking in debbugs.Complex organizations, such as Debian, require the tracking of bugs in multiple versions of packages. The versioning scheme is frequently branched: for example, a security update announced by an upstream developer will be packaged as-is for the unstable distribution while a minimal backport is made to the stable distribution. In order to report properly on the bugs open in each distribution, debbugs must be aware of the structure of the version tree for each package.
Gathering the version data is beyond the scope of this module: in the case of Debian it is carried out by mechanical analysis of package changelogs. Debbugs::Versions takes version data for a package generated by this or any other means, merges it into a tree structure, and allows the user to perform queries based on supplied data about the versions in which bugs have been found and the versions in which they have been fixed.
DATA FORMAT
The data format looks like this (backslashes are not actually there, and indicate continuation lines):
1.5.4 1.5.0 1.5-iwj.0.4 1.5-iwj.0.3 1.5-iwj.0.2 1.5-iwj.0.1 1.4.0 1.3.14 \ 1.3.13 1.3.12 1.3.11 1.3.10 ... 1.4.1.6 1.4.1.5 1.4.1.4 1.4.1.3 1.4.1.2 1.4.1.1 1.4.1 1.4.0.31 1.4.0.30 \ 1.4.0.29 1.4.0.28 1.4.0.27 1.4.0.26.0.1 1.4.0.26 1.4.0.25 1.4.0.24 \ 1.4.0.23.2 1.4.0.23.1 1.4.0.23 1.4.0.22 1.4.0.21 1.4.0.20 1.4.0.19 \ 1.4.0.18 1.4.0.17 1.4.0.16 1.4.0.15 1.4.0.14 1.4.0.13 1.4.0.12 \ 1.4.0.11 1.4.0.10 1.4.0.9 1.4.0.8 1.4.0.7 1.4.0.6 1.4.0.5 1.4.0.4 \ 1.4.0.3 1.4.0.2 1.4.0.1 1.4.0 \ 1.4.0.35 1.4.0.34 1.4.0.33 1.4.0.32 1.4.0.31
METHODS
- new
- Constructs a Debbugs::Versions object. The argument is a reference to a version comparison function, which must be usable by Perl's built-in "sort" function.
- isancestor
-
Takes two arguments, "ancestor" and "descendant". Returns true if and only
if "ancestor" is a version on which "descendant" is based according to the
version data supplied to this object. (As a degenerate case, this relation
is reflexive: a version is considered to be an ancestor of itself.)
This method is expected mainly to be used internally by the "merge" method.
- leaves
-
Find the leaves of the version tree, i.e. those versions with no
descendants.
This method is mainly for internal use.
- merge
- Merges one branch of version data into this object. This branch takes the form of a list of versions, each of which is to be considered as based on the next in the list.
- load
- Loads version data from the filehandle passed as the argument. Each line of input is expected to represent one branch, with versions separated by whitespace.
- save
- Outputs the version tree represented by this object to the filehandle passed as the argument. The format is the same as that expected by the "load" method.
- buggy
-
Takes three arguments, "version", "found", and "fixed". Returns true if
and only if "version" is based on or equal to a version in the list
referenced by "found", and not based on or equal to one referenced by
"fixed".
"buggy" attempts to cope with found and fixed versions not in the version tree by simply checking whether any fixed versions are recorded in the event that nothing is known about any of the found versions.
- allstates
-
Takes two arguments, "found" and "fixed", which are interpreted as in
``buggy''. Efficiently returns the state of the bug at every known version,
in the form of a hash from versions to states (as returned by ``buggy''). If
you pass a third argument, "interested", this method will stop after
determining the state of the bug at all the versions listed therein.
Whether this is faster than calling ``buggy'' for each version you're interested in is not altogether clear, and depends rather strongly on the number of known and interested versions.