-
Notifications
You must be signed in to change notification settings - Fork 94
/
Copy pathindex.js
156 lines (139 loc) · 4.96 KB
/
index.js
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
/**
* Original work Copyright (c) 2016 Philippe FERDINAND
* Modified work Copyright (c) 2016 Kam Low
*
* @license MIT
**/
'use strict';
var path = require('path');
var doxyparser = require('./src/parser');
var templates = require('./src/templates');
var helpers = require('./src/helpers');
module.exports = {
/**
* Default options values.
**/
defaultOptions: {
directory: null, /** Location of the doxygen files **/
output: 'api.md', /** Output file **/
groups: false, /** Output doxygen groups separately **/
noindex: false, /** Disable generation of the index. Does not work with `groups` option **/
anchors: true, /** Generate anchors for internal links **/
language: 'cpp', /** Programming language **/
templates: 'templates', /** Templates directory **/
pages: false, /** Output doxygen pages separately **/
classes: false, /** Output doxygen classes separately **/
output_s: 'api_%s.md', /** Output file for groups and classes **/
logfile: 'moxygen.log', /** Log file **/
filters: {
members: [
'define',
'enum',
// 'enumvalue',
'func',
// 'variable',
'property',
'public-attrib',
'public-func',
'protected-attrib',
'protected-func',
'signal',
'public-slot',
'protected-slot',
'public-type',
'private-attrib',
'private-func',
'private-slot',
'public-static-func',
'private-static-func',
],
compounds: [
'namespace',
'class',
'struct',
'union',
'typedef',
'interface',
// 'file',
]
},
},
/**
* Parse files and render the output.
**/
run: function (options) {
// Sanitize options
if (typeof options.output == "undefined") {
if (options.classes || options.groups) {
options.output = this.defaultOptions.output_s;
}
else {
options.output = this.defaultOptions.output;
}
}
if ((options.classes || options.groups) && options.output.indexOf('%s') === -1) {
throw "The `output` file parameter must contain an '%s' for group or class name " +
"substitution when `groups` or `classes` are enabled."
}
if (typeof options.templates == "undefined") {
options.templates = path.join(__dirname, this.defaultOptions.templates, options.language);
}
// Load templates
templates.registerHelpers(options);
templates.load(options.templates);
// Parse files
doxyparser.loadIndex(options, function (err, root) {
if (err)
throw err;
// Output groups
if (options.groups) {
var groups = root.toArray('compounds', 'group');
if (!groups.length)
throw "You have enabled `groups` output, but no groups were " +
"located in your doxygen XML files."
groups.forEach(function (group) {
group.filterChildren(options.filters, group.id);
var compounds = group.toFilteredArray('compounds');
compounds.unshift(group); // insert group at top
helpers.writeCompound(group, templates.renderArray(compounds), doxyparser.references, options);
});
}
else if (options.classes) {
var rootCompounds = root.toArray('compounds', 'namespace');
if (!rootCompounds.length)
throw "You have enabled `classes` output, but no classes were " +
"located in your doxygen XML files."
rootCompounds.forEach(function (comp) {
comp.filterChildren(options.filters);
var compounds = comp.toFilteredArray();
helpers.writeCompound(comp, [templates.render(comp)], doxyparser.references, options);
compounds.forEach(function (e) {
e.filterChildren(options.filters)
helpers.writeCompound(e, [templates.render(e)], doxyparser.references, options);
});
});
}
// Output single file
else {
root.filterChildren(options.filters);
var compounds = root.toFilteredArray('compounds');
if (!options.noindex)
compounds.unshift(root); // insert root at top if index is enabled
var contents = templates.renderArray(compounds);
contents.push('Generated by [Moxygen](https://sourcey.com/moxygen)')
helpers.writeCompound(root, contents, doxyparser.references, options);
}
if(options.pages){
var pages = root.toArray('compounds', 'page');
if(!pages.length)
throw "You have enabled `pages` output, but no pages were " +
"located in your doxygen XML files."
pages.forEach(function(page){
var compounds = page.toFilteredArray('compounds');
compounds.unshift(page);
helpers.writeCompound(page, templates.renderArray(compounds), doxyparser.references, options);
})
}
});
},
}