aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/dba.c
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2016-07-29 15:29:32 +0000
committerIngo Schwarze <schwarze@openbsd.org>2016-07-29 15:29:32 +0000
commit7f6377086cfbc884dfcb75e0a4075d0f0cf8b73d (patch)
tree54b2cd9ca087c1032cb10a510ef9d833949f3f24 /dba.c
parentf4e272dbf8fef6a69684f04aee7d6c022d22f869 (diff)
downloadmandoc-7f6377086cfbc884dfcb75e0a4075d0f0cf8b73d.tar.gz
mandoc-7f6377086cfbc884dfcb75e0a4075d0f0cf8b73d.tar.zst
mandoc-7f6377086cfbc884dfcb75e0a4075d0f0cf8b73d.zip
Sort sections and architectures in the pages table.
Diffstat (limited to 'dba.c')
-rw-r--r--dba.c26
1 files changed, 19 insertions, 7 deletions
diff --git a/dba.c b/dba.c
index 2fb2ab64..ce84c016 100644
--- a/dba.c
+++ b/dba.c
@@ -1,4 +1,4 @@
-/* $Id: dba.c,v 1.2 2016/07/29 15:23:57 schwarze Exp $ */
+/* $Id: dba.c,v 1.3 2016/07/29 15:29:32 schwarze Exp $ */
/*
* Copyright (c) 2016 Ingo Schwarze <schwarze@openbsd.org>
*
@@ -33,6 +33,7 @@
static void *prepend(const char *, char);
static void dba_pages_write(struct dba_array *);
static int compare_names(const void *, const void *);
+static int compare_strings(const void *, const void *);
static void dba_macros_write(struct dba_array *);
static void dba_macro_write(struct dba_array *);
@@ -243,24 +244,26 @@ prepend(const char *instr, char inbyte)
static void
dba_pages_write(struct dba_array *pages)
{
- struct dba_array *page, *names;
- void *entry;
+ struct dba_array *page, *entry;
int32_t pos_pages, pos_end;
pos_pages = dba_array_writelen(pages, 5);
dba_array_FOREACH(pages, page) {
dba_array_setpos(page, DBP_NAME, dba_tell());
- names = dba_array_get(page, DBP_NAME);
- dba_array_sort(names, compare_names);
- dba_array_writelst(names);
+ entry = dba_array_get(page, DBP_NAME);
+ dba_array_sort(entry, compare_names);
+ dba_array_writelst(entry);
}
dba_array_FOREACH(pages, page) {
dba_array_setpos(page, DBP_SECT, dba_tell());
- dba_array_writelst(dba_array_get(page, DBP_SECT));
+ entry = dba_array_get(page, DBP_SECT);
+ dba_array_sort(entry, compare_strings);
+ dba_array_writelst(entry);
}
dba_array_FOREACH(pages, page) {
if ((entry = dba_array_get(page, DBP_ARCH)) != NULL) {
dba_array_setpos(page, DBP_ARCH, dba_tell());
+ dba_array_sort(entry, compare_strings);
dba_array_writelst(entry);
} else
dba_array_setpos(page, DBP_ARCH, 0);
@@ -292,6 +295,15 @@ compare_names(const void *vp1, const void *vp2)
strcasecmp(cp1 + 1, cp2 + 1);
}
+static int
+compare_strings(const void *vp1, const void *vp2)
+{
+ const char *cp1, *cp2;
+
+ cp1 = *(char **)vp1;
+ cp2 = *(char **)vp2;
+ return strcmp(cp1, cp2);
+}
/*** functions for handling macros ************************************/