mizdebsk / rpms / xerces-j2

Forked from rpms/xerces-j2 5 years ago
Clone
mbooth c43feda
/*
mbooth c43feda
 * Licensed to the Apache Software Foundation (ASF) under one or more
mbooth c43feda
 * contributor license agreements.  See the NOTICE file distributed with
mbooth c43feda
 * this work for additional information regarding copyright ownership.
mbooth c43feda
 * The ASF licenses this file to You under the Apache License, Version 2.0
mbooth c43feda
 * (the "License"); you may not use this file except in compliance with
mbooth c43feda
 * the License.  You may obtain a copy of the License at
mbooth c43feda
 * 
mbooth c43feda
 *      http://www.apache.org/licenses/LICENSE-2.0
mbooth c43feda
 * 
mbooth c43feda
 * Unless required by applicable law or agreed to in writing, software
mbooth c43feda
 * distributed under the License is distributed on an "AS IS" BASIS,
mbooth c43feda
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
mbooth c43feda
 * See the License for the specific language governing permissions and
mbooth c43feda
 * limitations under the License.
mbooth c43feda
 */
mbooth c43feda
mbooth c43feda
package org.apache.xerces.util;
mbooth c43feda
mbooth c43feda
import java.util.Map;
mbooth c43feda
mbooth c43feda
import com.sun.javadoc.Tag;
mbooth c43feda
import com.sun.tools.doclets.Taglet;
mbooth c43feda
mbooth c43feda
/**
mbooth c43feda
 * This class provides support for a 'xerces.experimental' tag
mbooth c43feda
 * in javadoc comments. The tag creates a warning in the generated
mbooth c43feda
 * html for users.
mbooth c43feda
 * 
mbooth c43feda
 * @author Ankit Pasricha, IBM
mbooth c43feda
 */
mbooth c43feda
public class ExperimentalTaglet implements Taglet {
mbooth c43feda
    
mbooth c43feda
    private static final String NAME = "xerces.experimental";
mbooth c43feda
    private static final String HEADER = "EXPERIMENTAL:";
mbooth c43feda
    /* (non-Javadoc)
mbooth c43feda
     * @see com.sun.tools.doclets.Taglet#inConstructor()
mbooth c43feda
     */
mbooth c43feda
    public boolean inConstructor() {
mbooth c43feda
        return false;
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
    /* (non-Javadoc)
mbooth c43feda
     * @see com.sun.tools.doclets.Taglet#inField()
mbooth c43feda
     */
mbooth c43feda
    public boolean inField() {
mbooth c43feda
        return false;
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
    /* (non-Javadoc)
mbooth c43feda
     * @see com.sun.tools.doclets.Taglet#inMethod()
mbooth c43feda
     */
mbooth c43feda
    public boolean inMethod() {
mbooth c43feda
        return true;
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
    /* (non-Javadoc)
mbooth c43feda
     * @see com.sun.tools.doclets.Taglet#inOverview()
mbooth c43feda
     */
mbooth c43feda
    public boolean inOverview() {
mbooth c43feda
        return true;
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
    /* (non-Javadoc)
mbooth c43feda
     * @see com.sun.tools.doclets.Taglet#inPackage()
mbooth c43feda
     */
mbooth c43feda
    public boolean inPackage() {
mbooth c43feda
        return false;
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
    /* (non-Javadoc)
mbooth c43feda
     * @see com.sun.tools.doclets.Taglet#inType()
mbooth c43feda
     */
mbooth c43feda
    public boolean inType() {
mbooth c43feda
        return true;
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
    /* (non-Javadoc)
mbooth c43feda
     * @see com.sun.tools.doclets.Taglet#isInlineTag()
mbooth c43feda
     */
mbooth c43feda
    public boolean isInlineTag() {
mbooth c43feda
        return false;
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
    /* (non-Javadoc)
mbooth c43feda
     * @see com.sun.tools.doclets.Taglet#getName()
mbooth c43feda
     */
mbooth c43feda
    public String getName() {
mbooth c43feda
        return NAME;
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
    /* (non-Javadoc)
mbooth c43feda
     * @see com.sun.tools.doclets.Taglet#toString(com.sun.javadoc.Tag)
mbooth c43feda
     */
mbooth c43feda
    public String toString(Tag arg0) {
mbooth c43feda
        return "

" + HEADER + "

"
mbooth c43feda
        + "This class should not be considered stable. It is likely to be altered or replaced in the future.
"
mbooth c43feda
        + "" + arg0.text() + "\n";
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
    /* (non-Javadoc)
mbooth c43feda
     * @see com.sun.tools.doclets.Taglet#toString(com.sun.javadoc.Tag[])
mbooth c43feda
     */
mbooth c43feda
    public String toString(Tag[] tags) {
mbooth c43feda
        if (tags.length == 0) {
mbooth c43feda
            return null;
mbooth c43feda
        }
mbooth c43feda
        String result = "\n

" + HEADER + "

";
mbooth c43feda
        result += "This class should not be considered stable. It is likely to be altered or replaced in the future.";
mbooth c43feda
        result += "";
mbooth c43feda
        for (int i = 0; i < tags.length; i++) {
mbooth c43feda
            result += "
";
mbooth c43feda
            result += tags[i].text();
mbooth c43feda
        }
mbooth c43feda
        return result + "\n";
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
    /**
mbooth c43feda
     * Register this Taglet.
mbooth c43feda
     * @param tagletMap  the map to register this tag to.
mbooth c43feda
     */
mbooth c43feda
    public static void register(Map tagletMap) {
mbooth c43feda
        ExperimentalTaglet tag = new ExperimentalTaglet();
mbooth c43feda
        Taglet t = (Taglet) tagletMap.get(tag.getName());
mbooth c43feda
        if (t != null) {
mbooth c43feda
            tagletMap.remove(tag.getName());
mbooth c43feda
        }
mbooth c43feda
        tagletMap.put(tag.getName(), tag);
mbooth c43feda
    }
mbooth c43feda
    
mbooth c43feda
}