X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Fdoc_extract.c;h=3495c0c6b6b44a943436fbcc4bb287e4dc8f327e;hp=5a48b79f50d048c706a5145392450fecfc936c99;hb=77354575335e5ee900a4ba126d4d76e34b9273e8;hpb=100444225380d3f5ca29424ea54703d308c7c651 diff --git a/tools/doc_extract.c b/tools/doc_extract.c index 5a48b79f..3495c0c6 100644 --- a/tools/doc_extract.c +++ b/tools/doc_extract.c @@ -1,13 +1,28 @@ /* This merely extracts, doesn't do XML or anything. */ -#include +#include +#include +#include "tools.h" #include #include -#include -#include -#include -#include #include "doc_extract.h" +/* We regard non-alphanumerics as equiv. */ +static bool typematch(const char *a, const char *b) +{ + size_t i; + + for (i = 0; a[i]; i++) { + if (cisalnum(a[i])) { + if (a[i] != b[i]) + return false; + } else { + if (cisalnum(b[i])) + return false; + } + } + return b[i] == '\0'; +} + int main(int argc, char *argv[]) { unsigned int i; @@ -16,7 +31,7 @@ int main(int argc, char *argv[]) if (argc < 3) errx(1, "Usage: doc_extract [--function=] TYPE ...\n" - "Where TYPE is functions|author|license|maintainer|summary|description|example|all"); + "Where TYPE is functions|author|license|maintainer|summary|description|example|see_also|all"); if (strstarts(argv[1], "--function=")) { function = argv[1] + strlen("--function="); @@ -30,15 +45,15 @@ int main(int argc, char *argv[]) struct list_head *list; struct doc_section *d; - file = grab_file(NULL, argv[i], NULL); + file = tal_grab_file(NULL, argv[i], NULL); if (!file) err(1, "Reading file %s", argv[i]); - lines = strsplit(file, file, "\n"); + lines = tal_strsplit(file, file, "\n", STR_EMPTY_OK); - list = extract_doc_sections(lines); + list = extract_doc_sections(lines, argv[i]); if (list_empty(list)) errx(1, "No documentation in file %s", argv[i]); - talloc_free(file); + tal_free(file); if (streq(type, "functions")) { const char *last = NULL; @@ -60,14 +75,14 @@ int main(int argc, char *argv[]) } if (streq(type, "all")) printf("%s:\n", d->type); - else if (!streq(d->type, type)) + else if (!typematch(d->type, type)) continue; for (j = 0; j < d->num_lines; j++) printf("%s\n", d->lines[j]); } } - talloc_free(list); + tal_free(list); } return 0; }