2011-05-22 12:44:39 -04:00
|
|
|
/** Called automatically by JsDoc Toolkit. */
|
2011-06-02 06:56:24 -04:00
|
|
|
load(JSDOC.opt.t + 'src/Symbol.js');
|
|
|
|
load(JSDOC.opt.t + 'src/Utils.js');
|
|
|
|
load(JSDOC.opt.t + 'src/Operator.js');
|
|
|
|
load(JSDOC.opt.t + 'src/Render.js');
|
2011-06-01 13:49:50 -04:00
|
|
|
|
2011-05-22 12:44:39 -04:00
|
|
|
function publish(symbolSet) {
|
2011-06-01 06:19:15 -04:00
|
|
|
var renderMode = JSDOC.opt.D.renderMode;
|
2011-06-07 05:33:39 -04:00
|
|
|
var templatedocs = renderMode == 'templatedocs';
|
|
|
|
var extension = templatedocs ? '.jstl' : '.html';
|
2011-06-07 05:34:53 -04:00
|
|
|
var templateDir = JSDOC.opt.t || SYS.pwd + '../templates/jsdoc/';
|
|
|
|
var outDir = JSDOC.opt.d || SYS.pwd + '../out/jsdoc/';
|
|
|
|
|
2011-05-22 12:44:39 -04:00
|
|
|
publish.conf = { // trailing slash expected for dirs
|
2011-06-07 05:33:39 -04:00
|
|
|
// Use no extensions in links for templatedocs
|
|
|
|
ext: templatedocs ? '' : extension,
|
2011-06-07 05:34:53 -04:00
|
|
|
outDir: outDir,
|
|
|
|
templateDir: templateDir,
|
|
|
|
staticDir: templateDir + 'static/',
|
|
|
|
classesDir: outDir + 'classes/',
|
2011-06-07 05:35:26 -04:00
|
|
|
symbolsDir: templatedocs ? 'reference/' : 'classes/',
|
2011-06-01 06:19:15 -04:00
|
|
|
srcDir: 'symbols/src/',
|
2011-06-07 05:21:51 -04:00
|
|
|
renderMode: renderMode,
|
|
|
|
globalName: 'Global Scope'
|
2011-05-26 14:13:07 -04:00
|
|
|
};
|
2011-06-07 05:35:26 -04:00
|
|
|
|
|
|
|
Link.base = templatedocs ? '/' : '../';
|
2011-05-28 09:43:26 -04:00
|
|
|
|
2011-06-01 06:19:15 -04:00
|
|
|
if (renderMode == 'docs') {
|
|
|
|
// Copy over the static files
|
|
|
|
Utils.copyDirectory(
|
|
|
|
new java.io.File(publish.conf.staticDir),
|
|
|
|
new java.io.File(publish.conf.outDir)
|
|
|
|
);
|
2011-06-08 07:21:17 -04:00
|
|
|
|
|
|
|
// Create the classes directory
|
|
|
|
new java.io.File(publish.conf.classesDir).mkdir();
|
2011-06-01 06:19:15 -04:00
|
|
|
} else {
|
|
|
|
Utils.deleteFiles(new File(publish.conf.outDir));
|
2011-06-07 05:34:53 -04:00
|
|
|
new java.io.File(publish.conf.classesDir).mkdirs();
|
2011-06-01 06:19:15 -04:00
|
|
|
}
|
2011-05-28 09:43:26 -04:00
|
|
|
|
2011-05-22 12:44:39 -04:00
|
|
|
// used to allow Link to check the details of things being linked to
|
|
|
|
Link.symbolSet = symbolSet;
|
|
|
|
|
|
|
|
// get an array version of the symbolset, useful for filtering
|
2011-05-28 09:43:26 -04:00
|
|
|
var symbols = symbolSet.toArray(),
|
|
|
|
files = JSDOC.opt.srcFiles,
|
2011-05-30 14:07:45 -04:00
|
|
|
aliasSort = Utils.makeSortby('alias'),
|
|
|
|
classes = symbols.filter(Utils.isaClass).sort(aliasSort);
|
2011-05-22 12:44:39 -04:00
|
|
|
|
|
|
|
// create a filemap in which outfiles must be to be named uniquely, ignoring case
|
2011-06-07 05:23:14 -04:00
|
|
|
// Since we want lowercase links in templatedocs, we always use this
|
|
|
|
if (JSDOC.opt.u || templatedocs) {
|
2011-05-22 12:44:39 -04:00
|
|
|
var filemapCounts = {};
|
|
|
|
Link.filemap = {};
|
|
|
|
for (var i = 0, l = classes.length; i < l; i++) {
|
2011-06-07 05:23:14 -04:00
|
|
|
var alias = classes[i].alias,
|
|
|
|
lcAlias = alias.toLowerCase();
|
2011-05-22 12:44:39 -04:00
|
|
|
|
2011-05-28 09:43:26 -04:00
|
|
|
if (!filemapCounts[lcAlias]) {
|
|
|
|
filemapCounts[lcAlias] = 1;
|
|
|
|
} else {
|
|
|
|
filemapCounts[lcAlias]++;
|
|
|
|
}
|
2011-06-07 05:23:14 -04:00
|
|
|
// Use lowercase links for templatedocs
|
|
|
|
var linkAlias = templatedocs ? lcAlias : alias;
|
|
|
|
Link.filemap[alias] = filemapCounts[lcAlias] > 1
|
|
|
|
? linkAlias + '_' + filemapCounts[lcAlias] : linkAlias;
|
2011-05-22 12:44:39 -04:00
|
|
|
}
|
|
|
|
}
|
2011-05-29 08:00:56 -04:00
|
|
|
|
2011-05-22 12:44:39 -04:00
|
|
|
// create each of the class pages
|
|
|
|
for (var i = 0, l = classes.length; i < l; i++) {
|
|
|
|
var symbol = classes[i];
|
|
|
|
|
|
|
|
symbol.events = symbol.getEvents(); // 1 order matters
|
|
|
|
symbol.methods = symbol.getMethods(); // 2
|
2011-05-26 14:13:07 -04:00
|
|
|
for (var j = 0; j < symbol.methods.length; j++) {
|
|
|
|
var method = symbol.methods[j];
|
|
|
|
method.isOperator = Operator.isOperator(method);
|
|
|
|
}
|
2011-05-22 12:44:39 -04:00
|
|
|
|
|
|
|
Link.currentSymbol= symbol;
|
2011-06-01 13:49:50 -04:00
|
|
|
var html = Render._class(symbol);
|
2011-05-28 09:43:26 -04:00
|
|
|
var name = ((JSDOC.opt.u)? Link.filemap[symbol.alias] : symbol.alias)
|
2011-06-07 05:33:39 -04:00
|
|
|
+ extension;
|
2011-06-01 06:19:15 -04:00
|
|
|
if (renderMode == 'docs') {
|
2011-06-01 13:49:50 -04:00
|
|
|
html = Render.html({
|
2011-06-01 06:19:15 -04:00
|
|
|
content: html,
|
|
|
|
title: symbol.alias
|
|
|
|
});
|
|
|
|
}
|
2011-06-07 05:34:53 -04:00
|
|
|
IO.saveFile(publish.conf.classesDir, name, html);
|
2011-05-22 12:44:39 -04:00
|
|
|
}
|
2011-06-07 05:28:18 -04:00
|
|
|
if (templatedocs) {
|
|
|
|
IO.saveFile(publish.conf.outDir, 'packages.js', Render.indexjs());
|
|
|
|
} else {
|
|
|
|
IO.saveFile(publish.conf.classesDir, 'index.html', Render.index());
|
2011-05-26 14:13:07 -04:00
|
|
|
}
|
2011-06-01 13:49:50 -04:00
|
|
|
}
|