summaryrefslogtreecommitdiff
path: root/odk/docs/idl/wikilinks.py
blob: 51490879ad7dc63527c7a3175dbbb89f7ab4bd09 (plain)
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
# -*- tab-width: 4; indent-tabs-mode: nil; py-indent-offset: 4 -*-
#
# This file is part of the LibreOffice project.
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
#

# wikilinks.py:
# This throwaway prgram can be used to convert idl_chapter_refs.txt to a
# "fake" IDL file that can be fed to doxygen to get the DevGuide Wiki links.

import sys

devguidewww = "http://wiki.openoffice.org/wiki/"
in_topic = False
link = None
description = None
allthings = {}
allkinds = {}

# unfortunately we need to know what kind of entity to declare...
# generate this file like so:
# solver/unxlngx6/bin/regview solver/unxlngx6/bin/types.rdb | grep -A1 "type class:" | awk '/type class:/ { class = $NF } /type name:/ { gsub("/", ".", $NF); gsub("\"", "", $NF); print class, $NF }' > /tmp/kinds
for line in open("/tmp/kinds") :
    (kind,_,name) = line.strip().partition(" ")
    allkinds[name] = kind

for line in sys.stdin :
    sline = line.strip()
    if sline.startswith("LINK:") :
        link = sline.partition('LINK:')[2]
    elif sline.startswith("DESCR:") :
        description = sline.partition('DESCR:')[2]
    elif sline == "TOPIC:" :
        in_topic = True
    elif in_topic :
        if sline == "" :
            in_topic = False
        elif sline in allthings :
            allthings[sline].append((link, description))
        else:
            allthings[sline] = [(link, description)]

print("/* this file was generated from idl_chapter_refs.txt by wikilinks.py */")

for key in allthings:
    kind = allkinds[key]
    parts = key.split(".")
    print("\n")
    for p in parts[0:-1] :
        print("module", p, "{")
    # for enums the "{}" trick results in broken/duplicate output
    if kind == "enum" :
        print("/// @" + kind, parts[-1])
    print("/// @par Developers Guide")
    for item in allthings[key] :
        print("///      <a href=\"" + devguidewww + item[0] + "\">"
                + item[1] + "</a><br>")
    # doxygen does not have tags for e.g. @service but empty definition works
    if kind != "enum" :
        print(kind, parts[-1], "{}")
    for p in parts[0:-1] :
        print("};")

# vim:set shiftwidth=4 softtabstop=4 expandtab: