1 //<script type="text/javascript">
9 @requires JSDOC.DocComment
15 conf: { loaded: false },
17 walker : false, // will be JSDOC.Walker()
18 symbols : false, //will be JSDOC.SymbolSet()
27 if (this.conf.loaded) {
30 println("init parser conf!?");
33 ignoreCode: JSDOC.opt.n,
34 ignoreAnonymous: true, // factory: true
35 treatUnderscoredAsPrivate: true, // factory: true
36 explain: false // factory: false
39 this.symbols = new JSDOC.SymbolSet();
40 //this.walker = new JSDOC.Walker();
41 //JSDOC.Parser.filesSymbols = {};
47 * Parse a token stream.
48 * @param {JSDOC.TokenStream} token stream
49 * @param {String} filename
54 parse : function(ts, srcFile)
59 // not a nice way to set stuff...
61 JSDOC.Symbol.srcFile = (srcFile || "");
62 JSDOC.DocComment.shared = ""; // shared comments don't cross file boundaries
68 this.filesSymbols[JSDOC.Symbol.srcFile] = new JSDOC.SymbolSet();
70 this.walker = new JSDOC.Walker2(ts);
71 this.walker.buildSymbolTree()
72 //this.walker.walk(ts); // adds to our symbols
73 // throw "done sym tree";
75 // filter symbols by option
76 for (p in this.symbols._index) {
77 var symbol = this.symbols.getSymbol(p);
79 if (!symbol) continue;
81 if (symbol.is("FILE") || symbol.is("GLOBAL")) {
84 else if (!JSDOC.opt.a && !symbol.comment.isUserComment) {
85 //println("Deleting Symbols (no a / user comment): " + symbol.alias);
86 //this.symbols.deleteSymbol(symbol.alias);
87 //this.filesSymbols[JSDOC.Symbol.srcFile].deleteSymbol(symbol.alias);
90 if (/#$/.test(symbol.alias)) { // we don't document prototypes - this should not happen..
91 // rename the symbol ??
92 /*if (!this.symbols.getSymbol(symbol.alias.substring(0,symbol.alias.length-1))) {
94 println("Renaming Symbol (got a #): " + symbol.alias);
95 var n = '' + symbol.alias;
96 this.symbols.renameSymbol( n ,n.substring(0,n-1));
97 this.filesSymbols[JSDOC.Symbol.srcFile].renameSymbol( n ,n.substring(0,n-1));
101 println("Deleting Symbols (got a #): " + symbol.alias);
103 this.symbols.deleteSymbol(symbol.alias);
104 this.filesSymbols[JSDOC.Symbol.srcFile].deleteSymbol(symbol.alias);
108 //println(JSDOC.prettyDump(JSDOC.toQDump(this.filesSymbols[JSDOC.Symbol.srcFile]._index,'{','}')));
109 //println("AfterParse: " + this.symbols.keys().toSource().split(",").join(",\n "));
110 return this.symbols.toArray();
114 addSymbol: function(symbol)
116 println("PARSER addSYMBOL : " + symbol.alias);
118 // if a symbol alias is documented more than once the last one with the user docs wins
119 if (this.symbols.hasSymbol(symbol.alias)) {
120 var oldSymbol = this.symbols.getSymbol(symbol.alias);
122 if (oldSymbol.comment.isUserComment && !oldSymbol.comment.hasTags) {
123 if (symbol.comment.isUserComment) { // old and new are both documented
124 JSDOC.opt.LOG.warn("The symbol '"+symbol.alias+"' is documented more than once.");
126 else { // old is documented but new isn't
132 // we don't document anonymous things
133 if (this.conf.ignoreAnonymous && symbol.name.match(/\$anonymous\b/)) return;
135 // uderscored things may be treated as if they were marked private, this cascades
136 if (this.conf.treatUnderscoredAsPrivate && symbol.name.match(/[.#-]_[^.#-]+$/)) {
137 symbol.isPrivate = true;
140 // -p flag is required to document private things
141 if ((symbol.isInner || symbol.isPrivate) && !JSDOC.opt.p) return;
143 // ignored things are not documented, this doesn't cascade
144 if (symbol.isIgnored) return;
145 // add it to the file's list... (for dumping later..)
146 if (JSDOC.Symbol.srcFile) {
147 this.filesSymbols[JSDOC.Symbol.srcFile].addSymbol(symbol);
150 this.symbols.addSymbol(symbol);
153 addBuiltin: function(name) {
155 var builtin = new JSDOC.Symbol(name, [], "CONSTRUCTOR", new JSDOC.DocComment(""));
156 builtin.isNamespace = false;
157 builtin.srcFile = "";
158 builtin.isPrivate = false;
159 this.addSymbol(builtin);
165 this.symbols.relate();
167 // make a litle report about what was found
168 if (this.conf.explain) {
169 var symbols = this.symbols.toArray();
171 for (var i = 0, l = symbols.length; i < l; i++) {
172 var symbol = symbols[i];
173 if (srcFile != symbol.srcFile) {
174 srcFile = symbol.srcFile;
175 print("\n"+srcFile+"\n-------------------");
177 print(i+":\n alias => "+symbol.alias + "\n name => "+symbol.name+ "\n isa => "+symbol.isa + "\n memberOf => " + symbol.memberOf + "\n isStatic => " + symbol.isStatic + ", isInner => " + symbol.isInner);
179 print("-------------------\n");