⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 htmlwriter.java

📁 Mobile 应用程序使用 Java Micro Edition (Java ME) 平台
💻 JAVA
📖 第 1 页 / 共 3 页
字号:
/* * @(#)HTMLWriter.java	1.40 06/04/07 * * Copyright 2006 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. */package javax.swing.text.html;import javax.swing.text.*;import java.io.Writer;import java.util.Stack;import java.util.Enumeration;import java.util.Vector;import java.io.IOException;import java.util.StringTokenizer;import java.util.NoSuchElementException;import java.net.URL;/** * This is a writer for HTMLDocuments. * * @author  Sunita Mani * @version 1.26, 02/02/00 */public class HTMLWriter extends AbstractWriter {    /*     * Stores all elements for which end tags have to     * be emitted.     */    private Stack blockElementStack = new Stack();    private boolean inContent = false;    private boolean inPre = false;    /** When inPre is true, this will indicate the end offset of the pre     * element. */    private int preEndOffset;    private boolean inTextArea = false;    private boolean newlineOutputed = false;    private boolean completeDoc;    /*     * Stores all embedded tags. Embedded tags are tags that are     * stored as attributes in other tags. Generally they're     * character level attributes.  Examples include     * &lt;b&gt;, &lt;i&gt;, &lt;font&gt;, and &lt;a&gt;.      */    private Vector tags = new Vector(10);    /**     * Values for the tags.     */    private Vector tagValues = new Vector(10);    /**     * Used when writing out content.     */    private Segment segment;    /*     * This is used in closeOutUnwantedEmbeddedTags.     */    private Vector tagsToRemove = new Vector(10);    /**     * Set to true after the head has been output.     */    private boolean wroteHead;    /**     * Set to true when entities (such as &lt;) should be replaced.     */    private boolean replaceEntities;    /**     * Temporary buffer.     */    private char[] tempChars;    /**     * Creates a new HTMLWriter.     *     * @param w   a Writer     * @param doc  an HTMLDocument     *     */    public HTMLWriter(Writer w, HTMLDocument doc) {	this(w, doc, 0, doc.getLength());    }    /**     * Creates a new HTMLWriter.     *     * @param w  a Writer     * @param doc an HTMLDocument     * @param pos the document location from which to fetch the content     * @param len the amount to write out     */    public HTMLWriter(Writer w, HTMLDocument doc, int pos, int len) {	super(w, doc, pos, len);	completeDoc = (pos == 0 && len == doc.getLength());	setLineLength(80);    }    /**     * Iterates over the      * Element tree and controls the writing out of     * all the tags and its attributes.     *     * @exception IOException on any I/O error     * @exception BadLocationException if pos represents an invalid     *            location within the document.     *     */    public void write() throws IOException, BadLocationException {	ElementIterator it = getElementIterator();	Element current = null;	Element next = null;	wroteHead = false;	setCurrentLineLength(0);	replaceEntities = false;	setCanWrapLines(false);	if (segment == null) {	    segment = new Segment();	}	inPre = false;        boolean forcedBody = false;	while ((next = it.next()) != null) {	    if (!inRange(next)) {                if (completeDoc && next.getAttributes().getAttribute(                        StyleConstants.NameAttribute) == HTML.Tag.BODY) {                    forcedBody = true;                }                else {                    continue;                }	    }	    if (current != null) {				/*		  if next is child of current increment indent		*/		if (indentNeedsIncrementing(current, next)) {                    incrIndent();		} else if (current.getParentElement() != next.getParentElement()) {		    /*		       next and current are not siblings		       so emit end tags for items on the stack until the		       item on top of the stack, is the parent of the		       next.		    */		    Element top = (Element)blockElementStack.peek();		    while (top != next.getParentElement()) {			/*			   pop() will return top.			*/			blockElementStack.pop();			if (!synthesizedElement(top)) {                            AttributeSet attrs = top.getAttributes();			    if (!matchNameAttribute(attrs, HTML.Tag.PRE) &&                                !isFormElementWithContent(attrs)) {				decrIndent();			    }			    endTag(top);			}			top = (Element)blockElementStack.peek();		    }		} else if (current.getParentElement() == next.getParentElement()) {		    /*		       if next and current are siblings the indent level		       is correct.  But, we need to make sure that if current is		       on the stack, we pop it off, and put out its end tag.		    */		    Element top = (Element)blockElementStack.peek();		    if (top == current) {			blockElementStack.pop();			endTag(top);		    }		}	    }	    if (!next.isLeaf() || isFormElementWithContent(next.getAttributes())) {		blockElementStack.push(next);		startTag(next);	    } else {		emptyTag(next);	    }	    current = next;	}	/* Emit all remaining end tags */	/* A null parameter ensures that all embedded tags	   currently in the tags vector have their	   corresponding end tags written out.	*/	closeOutUnwantedEmbeddedTags(null);        if (forcedBody) {            blockElementStack.pop();            endTag(current);        }	while (!blockElementStack.empty()) {	    current = (Element)blockElementStack.pop();	    if (!synthesizedElement(current)) {                AttributeSet attrs = current.getAttributes();		if (!matchNameAttribute(attrs, HTML.Tag.PRE) &&                              !isFormElementWithContent(attrs)) {		    decrIndent();		}		endTag(current);	    }	}	if (completeDoc) {	    writeAdditionalComments();	}	segment.array = null;    }    /**     * Writes out the attribute set.  Ignores all     * attributes with a key of type HTML.Tag,     * attributes with a key of type StyleConstants,     * and attributes with a key of type     * HTML.Attribute.ENDTAG.     *     * @param attr   an AttributeSet     * @exception IOException on any I/O error     *     */    protected void writeAttributes(AttributeSet attr) throws IOException {	// translate css attributes to html	convAttr.removeAttributes(convAttr);	convertToHTML32(attr, convAttr);	Enumeration names = convAttr.getAttributeNames();	while (names.hasMoreElements()) {	    Object name = names.nextElement();	    if (name instanceof HTML.Tag || 		name instanceof StyleConstants || 		name == HTML.Attribute.ENDTAG) {		continue;	    }	    write(" " + name + "=\"" + convAttr.getAttribute(name) + "\"");	}    }    /**     * Writes out all empty elements (all tags that have no     * corresponding end tag).     *     * @param elem   an Element     * @exception IOException on any I/O error     * @exception BadLocationException if pos represents an invalid     *            location within the document.     */    protected void emptyTag(Element elem) throws BadLocationException, IOException {	if (!inContent && !inPre) {	    indentSmart();	}	AttributeSet attr = elem.getAttributes();	closeOutUnwantedEmbeddedTags(attr);	writeEmbeddedTags(attr);	if (matchNameAttribute(attr, HTML.Tag.CONTENT)) {	    inContent = true;	    text(elem);	} else if (matchNameAttribute(attr, HTML.Tag.COMMENT)) {	    comment(elem);	}  else {	    boolean isBlock = isBlockTag(elem.getAttributes());	    if (inContent && isBlock ) {		writeLineSeparator();		indentSmart();	    }	    Object nameTag = (attr != null) ? attr.getAttribute		              (StyleConstants.NameAttribute) : null;	    Object endTag = (attr != null) ? attr.getAttribute		              (HTML.Attribute.ENDTAG) : null;	    boolean outputEndTag = false;	    // If an instance of an UNKNOWN Tag, or an instance of a 	    // tag that is only visible during editing	    //	    if (nameTag != null && endTag != null &&		(endTag instanceof String) &&		((String)endTag).equals("true")) {		outputEndTag = true;	    }	    if (completeDoc && matchNameAttribute(attr, HTML.Tag.HEAD)) {		if (outputEndTag) {		    // Write out any styles.		    writeStyles(((HTMLDocument)getDocument()).getStyleSheet());		}		wroteHead = true;	    }	    write('<');	    if (outputEndTag) {		write('/');	    }	    write(elem.getName());	    writeAttributes(attr);	    write('>');	    if (matchNameAttribute(attr, HTML.Tag.TITLE) && !outputEndTag) {		Document doc = elem.getDocument();		String title = (String)doc.getProperty(Document.TitleProperty);		write(title);	    } else if (!inContent || isBlock) {		writeLineSeparator();		if (isBlock && inContent) {		    indentSmart();		}	    }	}    }    /**     * Determines if the HTML.Tag associated with the     * element is a block tag.     *     * @param attr  an AttributeSet     * @return  true if tag is block tag, false otherwise.     */    protected boolean isBlockTag(AttributeSet attr) {	Object o = attr.getAttribute(StyleConstants.NameAttribute);	if (o instanceof HTML.Tag) {	    HTML.Tag name = (HTML.Tag) o;	    return name.isBlock();	}	return false;    }    /**     * Writes out a start tag for the element.     * Ignores all synthesized elements.     *     * @param elem   an Element     * @exception IOException on any I/O error     */    protected void startTag(Element elem) throws IOException, BadLocationException {		if (synthesizedElement(elem)) {	    return;	}	// Determine the name, as an HTML.Tag.	AttributeSet attr = elem.getAttributes();	Object nameAttribute = attr.getAttribute(StyleConstants.NameAttribute);	HTML.Tag name;	if (nameAttribute instanceof HTML.Tag) {	    name = (HTML.Tag)nameAttribute;	}	else {	    name = null;	}	if (name == HTML.Tag.PRE) {	    inPre = true;	    preEndOffset = elem.getEndOffset();	}	// write out end tags for item on stack	closeOutUnwantedEmbeddedTags(attr);	if (inContent) { 	    writeLineSeparator();	    inContent = false;	    newlineOutputed = false;	}	if (completeDoc && name == HTML.Tag.BODY && !wroteHead) {	    // If the head has not been output, output it and the styles.	    wroteHead = true;	    indentSmart();	    write("<head>");	    writeLineSeparator();	    incrIndent();	    writeStyles(((HTMLDocument)getDocument()).getStyleSheet());	    decrIndent();	    writeLineSeparator();	    indentSmart();	    write("</head>");	    writeLineSeparator();	}	indentSmart();	write('<');	write(elem.getName());	writeAttributes(attr);	write('>');	if (name != HTML.Tag.PRE) {	    writeLineSeparator();	}	if (name == HTML.Tag.TEXTAREA) {	    textAreaContent(elem.getAttributes());	} else if (name == HTML.Tag.SELECT) {	    selectContent(elem.getAttributes());	} else if (completeDoc && name == HTML.Tag.BODY) {	    // Write out the maps, which is not stored as Elements in	    // the Document.	    writeMaps(((HTMLDocument)getDocument()).getMaps());	}	else if (name == HTML.Tag.HEAD) {            HTMLDocument document = (HTMLDocument)getDocument();	    wroteHead = true;            incrIndent();            writeStyles(document.getStyleSheet());            if (document.hasBaseTag()) {                indentSmart();

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -