/* -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- * * ***** BEGIN LICENSE BLOCK ***** * Version: MPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla Public License Version * 1.1 (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is mozilla.org code. * * The Initial Developer of the Original Code is * Netscape Communications Corporation. * Portions created by the Initial Developer are Copyright (C) 1998 * the Initial Developer. All Rights Reserved. * * Contributor(s): * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 2 or later (the "GPL"), or * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the MPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the MPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */ package netscape.plugin.composer; import java.io.*; import java.util.*; import java.net.URL; import netscape.javascript.JSObject; /** An abstract HTML document. * Contains html text. Also contains * a work directory. The work directory is where * you place images (or other embedded files) that you * are inserting into the document. * */ public abstract class Document { /** Get the base URL of the document. This is the url that the * relative URLs are relative to. * @return the base URL of the document. */ public abstract URL getBase(); /** Get the work directory of the document. You need this * to be able to add files to the document. * @return the work directory for the document. */ public abstract File getWorkDirectory(); /** Get the work directory of the document as a URL. You need this * to be able to add files to the document. * @return the work directory for the document as a URL. */ public abstract URL getWorkDirectoryURL(); /** Get an input stream for a document. Use this to read * information out of the document. * @return an input stream for the document. The caller must call the close() * method when finished with the stream. The caller must * finish with the stream before creating another input stream * for the same document. * @throw IOException if there is an existing unclosed input stream for this document. */ public abstract Reader getInput() throws IOException; /** Get an output stream for a document. Use this to write * information into a document. * @return an output stream for the document.The caller must call the close() * method when finished with the stream. The caller must * finish with the stream before creating another output stream * for the same part. * @throw IOException if there is an existing unclosed output stream for this document. */ public abstract Writer getOutput() throws IOException; /** Get the entire text of the document as a String. Use this to read information * out of the document. This is more convenient than getInput if your intent is * to perform string-based operations on the document's raw HTML code. * getInput is more convenient if you intend to tokenize the HTML. * @return the entire raw html text of the document, as a String. * @throw IOException if there is a problem reading the document. */ public abstract String getText() throws IOException; /** Set the entire text of the document. Use this to write information * into the document. This is more convenient than getOutput if you have * performed string-based operations on the document's raw HTML text. * getOutput is more convenient if you process tokenized HTML. * @param text the new entire raw HTML text of the document. * @throw IOException if there is a problem writing the document, or if * there is an existing getOutput stream that has not been closed. */ public abstract void setText(String text) throws IOException; /** Get the event that triggered this plug-in invocation. * This method returns null if this is a normal invocation. *
     * The standard events are:
     *     edit - called when an existing document is about to be edited.
     *     open - called when a document (new or old) is opened for editing.
     *     close - called when a document is about to be closed.
     *     publish - called before a document is published.
     *     publishComplete - called after a document is published.
     *     save - called before a document is saved.
     *     send - called before a document is sent (mailed).
     * 
* @return the event that triggered the plug-in invocation, * or null if this is a normal invocation. */ public String getEventName(){ return null; } /** Get the document URL (if it is known) for this document. * This method returns null if there is no document URL available. * During a publish or a save event, the URL will be the URL of * the destination to which the document is being published or saved. * @return the URL of the document, or null if * the document URL is unknown. */ public URL getDocumentURL(){ return null; } /** Redirect the open to a new document URL. This method only has an * effect when the event is "edit". Useful for situations where the * publishing URL is different from the editing URL. This could happen * when you use an FTP server to access the backing store of an HTTP server. * @param newURL The URL, expressed as a string, that should be used to * edit the document. */ public void redirectDocumentOpen(String newURL){ } /** Open a URL for editing. This call is asynchronous. No errors are returned. * @param URL The URL, expressed as a string, that is to be edited. */ static public void editDocument(String url){ try { Composer.editDocument(url); } catch (Throwable t){ t.printStackTrace(); } } /** get the jsobject from the document. If no javascript in the * runtime, this will return null */ public JSObject getJSObject(){return null;} }