[Dctrl-tools-devel] CVS dctrl-tools

CVS User ajk ajk@haydn.debian.org
Wed, 08 Jun 2005 21:33:55 +0000


Update of /cvsroot/dctrl-tools/dctrl-tools
In directory haydn:/tmp/cvs-serv17981

Modified Files:
	Makefile sorter.c 
Added Files:
	sort-dctrl.1.cp 
Log Message:
manpage sort-dctrl(1)

--- /cvsroot/dctrl-tools/dctrl-tools/Makefile	2005/06/08 20:52:18	1.24
+++ /cvsroot/dctrl-tools/dctrl-tools/Makefile	2005/06/08 21:33:54	1.25
@@ -27,7 +27,7 @@
 # List of translated languages is given in langs.mk
 include langs.mk
 
-all : grep-dctrl sort-dctrl sync-available grep-dctrl.1 mo
+all : grep-dctrl sort-dctrl sync-available grep-dctrl.1 sort-dctrl.1 mo
 
 pot : po/dctrl-tools.pot
 
--- /cvsroot/dctrl-tools/dctrl-tools/sorter.c	2005/06/08 20:52:19	1.5
+++ /cvsroot/dctrl-tools/dctrl-tools/sorter.c	2005/06/08 21:33:55	1.6
@@ -47,13 +47,14 @@
 		case FT_VERSION:
 			;
 			struct versionrevision ar, br;
-			if (!parse_version(&ar, af, strlen(af)) ||
-			    !parse_version(&br, bf, strlen(bf))) {
+			bool aok = parse_version(&ar, af, strlen(af));
+			bool bok = parse_version(&br, bf, strlen(bf));
+			if (!aok || !bok) {
 				message(L_IMPORTANT,
 					_("Parse error in field."), 0);
 				free(af);
 				free(bf);
-				return 0;
+				return aok ? (bok ? 0 : 1) : (bok ? -1 : 0);
 			}
 			r = versioncompare(&ar, &br);
 			break;

--- /cvsroot/dctrl-tools/dctrl-tools/sort-dctrl.1.cp	2005/06/08 21:33:55	NONE
+++ /cvsroot/dctrl-tools/dctrl-tools/sort-dctrl.1.cp	2005/06/08 21:33:55	1.1
.TH SORT-DCTRL 1 2005-06-08 "Debian Project" "Debian user's manual"
\" Copyright (C) 2005 Antti-Juhani Kaijanaho <gaia@iki.fi>
\"      This program is free software; you can redistribute it and/or modify
\"      it under the terms of the GNU General Public License as published by
\"      the Free Software Foundation; either version 2 of the License, or
\"      (at your option) any later version.
\" 
\"      This program is distributed in the hope that it will be useful,
\"      but WITHOUT ANY WARRANTY; without even the implied warranty of
\"      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
\"      GNU General Public License for more details. 
\"  
\"      You should have received a copy of the GNU General Public License
\"      along with this program; see the file COPYING.  If not, write to
\"      the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
\"      Boston, MA 02111-1307, USA.
.SH NAME
sort\-dctrl \- sort Debian control files
.SH SYNOPSIS
.B sort\-dctrl
[options]
[
.IR file " ..."
]
.sp
.B sort\-dctrl
\-\-copying | \-\-help | \-\-version | \-ChV
.SH DESCRIPTION
The
.B sort\-dctrl
program sorts Debian control files according to specified criteria.
.PP
A Debian control (dctrl) file is a semistructured single-table
database stored in a machine-parseable text file.  Such a database
consists of a set of records; each record is a mapping from field
names to field content.  Textually, records are separated by empty
lines, while each field is encoded as one or more nonempty lines
inside a record.  A field starts with its name, followed by a colon,
followed by the field content.  The colon must reside on the first
line of the field, and the first line must start with no whitespace.
Subsequent lines, in contrast, always start with linear whitespace
(one or more space or tab characters).
.PP
The
.B sort\-dctrl
program recognizes two field types: string fields and version fields.
Version fields act also as numeric fields.  String fields are compared
according to strict lexicographical octet-by-octet comparison, after
ignoring any initial whitespace after the colon.  Version fields are
parsed and compared as Debian version numbers.  When comparing version
numbers, if a field content does not in fact conform to the version
number syntax, it compares less than any field content that does
conform, and equal to any other nonconforming field content.  The
.B sort\-dctrl
program assumes all fields are string fields unless told otherwise.
.PP
You can specify arbitrary number of keys for sorting, using the \-k
option.  The keys are interpreted in a descending order of priority:
the first key specified is primary, the second key specified is
secondary, and so on.  If two records compare equal under the primary
key, then they are compared under the secondary key, and so on.  If no
keys are specified, a default key is assumed (the "Package" field with
no modifiers).
.SH OPTIONS
.IP "-k KEYSPEC, --key-spec=KEYSPEC"
Specify one or more keys for sorting.  You may specify this option any
number of times.  The KEYSPEC argument consists of a comma-separated
list of key specifications.  Each key specification consists of the
name of the field that serves as the key, optionally followed by a
colon and key modifiers.  The following key modifiers are supported:
.RS
.TP
.B r
Invert the comparison for this key, reversing the sorting order.
.TP
.B v
Treat this field as a version number field.
.TP
.B n
Treat this field as numeric, which currently is synonymous with 
.BR v .
.RE
.IP "\-q, \-\-quiet, \-\-silent"
Output nothing to the standard output stream.  Instead, exit
immediately after finding the first match.
.IP "\-l LEVEL, \-\-errorlevel=LEVEL"
Set debugging level to LEVEL.  LEVEL is one of "fatal", "important",
"informational" and "debug", but the last may not be available,
depending on the compile-time options.  These categories are given
here in order; every message that is emitted when "fatal" is in
effect, will be emitted in the "important" error level, and so on.
The default is "important".
.IP "\-V, \-\-version"
Print out version information.
.IP "\-C, \-\-copying"
Print out the copyright license.  This produces much output; be sure
to redirect or pipe it somewhere (such as your favourite pager).
.IP "\-h, \-\-help"
Print out a help summary.
.SH EXAMPLES
Here are some sample invocations of the program:
.IP "sort\-dctrl /var/lib/dpkg/available"
Output the dpkg available file sorted by the package name.
.IP "sort\-dctrl -k Version:v /var/lib/dpkg/available"
Output the dpkg available file sorted in ascending order of
version numbers.
.IP "sort\-dctrl -k Version:vr /var/lib/dpkg/available"
Output the dpkg available file sorted in descending order of
version numbers.
.IP "sort\-dctrl -k Package,Version:v /var/lib/dpkg/available"
Output the dpkg available file sorted primarily in ascending order of
package names and secondarily in descending order of version numbers.
.IP "sort\-dctrl -k Installed-Size:n,Size:nr /var/lib/dpkg/available"
Output the dpkg available file sorted primarily in ascending order of
installation sizes and secondarily in descending order of package
sizes.
.SH AUTHOR
The program and this manual page were written by Antti-Juhani
Kaijanaho <ajk@debian.org>.
.SH "SEE ALSO"
Ian Jackson et al.: Debian Policy Manual.  Published as the Debian
package debian\-policy.  Also available in the Debian website.  The
Debian project, 2004.
.PP
.BR grep-dctrl (1)
\" Local variables:
\" mode: nroff
\" End: