/* * Copyright 2008-2009 Sun Microsystems, Inc. All Rights Reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, * CA 95054 USA or visit www.sun.com if you need additional information or * have any questions. */ package org.visage.tools.visagedoc; import com.sun.tools.mjavac.util.Context; import com.sun.tools.mjavac.util.JCDiagnostic.DiagnosticPosition; import com.sun.tools.mjavac.util.List; import com.sun.tools.mjavac.code.Kinds; import com.sun.tools.mjavac.code.Symbol.*; import com.sun.tools.mjavac.tree.JCTree; import org.visage.tools.comp.VisageEnter; import org.visage.tools.tree.*; import java.util.HashMap; import javax.tools.JavaFileObject; /** * Javadoc's own enter phase does a few things above and beyond that * done by javac. * @author Neal Gafter */ public class VisagedocEnter extends VisageEnter { public static VisagedocEnter instance0(Context context) { VisageEnter instance = context.get(visageEnterKey); if (instance == null) instance = new VisagedocEnter(context); return (VisagedocEnter)instance; } public static void preRegister(final Context context) { context.put(visageEnterKey, new Context.Factory<VisageEnter>() { public VisageEnter make() { return new VisagedocEnter(context); } }); } protected VisagedocEnter(Context context) { super(context); messager = Messager.instance0(context); docenv = DocEnv.instance(context); } final Messager messager; final DocEnv docenv; @Override public void main(List<VisageScript> trees) { // count all Enter errors as warnings. int nerrors = messager.nerrors; super.main(trees); messager.nwarnings += (messager.nerrors - nerrors); messager.nerrors = nerrors; } @Override public void visitScript(VisageScript tree) { if (tree.docComments == null) tree.docComments = new HashMap<JCTree, String>(); super.visitScript(tree); if (tree.sourcefile.isNameCompatible("package-info", JavaFileObject.Kind.SOURCE)) { String comment = tree.docComments.get(tree); docenv.makePackageDoc(tree.packge, comment, tree); } } @Override public void visitClassDeclaration(VisageClassDeclaration tree) { super.visitClassDeclaration(tree); if (tree.sym != null && tree.sym.kind == Kinds.TYP) { if (tree.sym == null) return; String comment = env.toplevel.docComments.get(tree); ClassSymbol c = tree.sym; docenv.makeClassDoc(c, comment, tree, env.toplevel.lineMap); } } /** Don't complain about a duplicate class. */ @Override protected void duplicateClass(DiagnosticPosition pos, ClassSymbol c) {} }