Path: blob/master/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/JavadocClassFinder.java
41161 views
/*1* Copyright (c) 2001, 2019, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation. Oracle designates this7* particular file as subject to the "Classpath" exception as provided8* by Oracle in the LICENSE file that accompanied this code.9*10* This code is distributed in the hope that it will be useful, but WITHOUT11* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or12* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License13* version 2 for more details (a copy is included in the LICENSE file that14* accompanied this code).15*16* You should have received a copy of the GNU General Public License version17* 2 along with this work; if not, write to the Free Software Foundation,18* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.19*20* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA21* or visit www.oracle.com if you need additional information or have any22* questions.23*/2425package jdk.javadoc.internal.tool;2627import java.util.EnumSet;2829import javax.tools.JavaFileObject;3031import com.sun.tools.javac.api.JavacTrees;32import com.sun.tools.javac.code.Symbol.PackageSymbol;33import com.sun.tools.javac.code.ClassFinder;34import com.sun.tools.javac.util.Context;35import com.sun.tools.javac.util.Context.Factory;3637/** Javadoc uses an extended class finder that records package.html entries38*39* <p><b>This is NOT part of any supported API.40* If you write code that depends on this, you do so at your own risk.41* This code and its internal interfaces are subject to change or42* deletion without notice.</b>43*/44public class JavadocClassFinder extends ClassFinder {4546public static JavadocClassFinder instance(Context context) {47ClassFinder instance = context.get(classFinderKey);48if (instance == null)49instance = new JavadocClassFinder(context);50return (JavadocClassFinder)instance;51}5253public static void preRegister(Context context) {54context.put(classFinderKey, (Factory<ClassFinder>)JavadocClassFinder::new);55}5657private ToolEnvironment toolEnv;58private EnumSet<JavaFileObject.Kind> all = EnumSet.of(JavaFileObject.Kind.CLASS,59JavaFileObject.Kind.SOURCE,60JavaFileObject.Kind.HTML);61private EnumSet<JavaFileObject.Kind> noSource = EnumSet.of(JavaFileObject.Kind.CLASS,62JavaFileObject.Kind.HTML);63private JavacTrees jctrees;6465private final JavacTrees trees;6667public JavadocClassFinder(Context context) {68super(context);69toolEnv = ToolEnvironment.instance(context);70preferSource = true;71trees = JavacTrees.instance(context);72}7374/**75* Override getPackageFileKinds to include search for package.html76*/77@Override78protected EnumSet<JavaFileObject.Kind> getPackageFileKinds() {79return toolEnv.docClasses ? noSource : all;80}8182/**83* Override extraFileActions to check for package documentation84*/85@Override86protected void extraFileActions(PackageSymbol pack, JavaFileObject fo) {87if (fo.isNameCompatible("package", JavaFileObject.Kind.HTML)) {88pack.sourcefile = fo;89}90}91}929394