File: make_html_refs.c

package info (click to toggle)
allegro5 2%3A5.0.10-3
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 14,856 kB
  • ctags: 15,948
  • sloc: ansic: 87,540; cpp: 9,693; objc: 3,491; python: 2,057; sh: 829; makefile: 93; perl: 37; pascal: 24
file content (51 lines) | stat: -rw-r--r-- 1,153 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
/*
 * make_html_refs DOC-FILE...
 *
 * Generate a file containing (HTML-specific) link definitions for each API
 * entry found.  e.g. if foo.txt contains "# API: bar" then we generate:
 *
 *   [bar]: foo.html#bar
 *
 * OPTIONS
 *
 * --strip-underscores
 *    Pandoc 1.2 and 1.2.1 strip underscores when generating HTML identifiers
 *    so we must do the same.
 */

#include <string.h>
#include "dawk.h"

int main(int argc, char *argv[])
{
   int strip_underscores = false;
   dstr line;
   dstr file;
   const char *name;
   dstr sec_id;

   if (argc >= 2 && 0 == strcmp(argv[1], "--strip-underscores")) {
      strip_underscores = true;
      argc--;
      argv++;
   }

   d_init(argc, argv);

   while (d_getline(line)) {
      if (d_match(line, "^#+ API: *")) {
         d_basename(d_filename, ".html", file);
         name = d_after_match;
         d_tolower(name, sec_id);
         if (strip_underscores) {
            d_delchr(sec_id, '_');
         }
         /* The extra blank lines are to work around Pandoc issue #182. */
         d_printf("[%s]: %s#%s\n\n", name, file, sec_id);
      }
   }

   return 0;
}

/* vim: set sts=3 sw=3 et: */