gerv%gerv.net 8b69962ee3 Bug 236613: change to MPL/LGPL/GPL tri-license.
git-svn-id: svn://10.0.0.236/trunk@155500 18797224-902f-48f8-a5cc-f745e15eee43
2004-04-25 21:07:34 +00:00

189 lines
6.6 KiB
Java

/* -*- 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.test.plugin.composer;
import java.io.*;
import java.awt.*;
import netscape.plugin.composer.*;
import netscape.plugin.composer.io.*;
/** Sample Plugin that edits layers.
*/
public class AddLayer extends Plugin {
/** Test the plugin. Not required for normal operation of the plugin.
* You can use this to run the plugin from the command line:
* java -classpath <your-class-path> <your-plugin-name> args...
* where args... are passed on to the Test class.
* You can remove this code before shipping your plugin.
*/
static public void main(String[] args) {
Test.perform(args, new AddLayer());
}
/** Get the human readable name of the plugin. Defaults to the name of the plugin class.
* @return the human readable name of the plugin.
*/
public String getName()
{
return "Create Layer...";
}
/** Get the human readable category of the plugin. Defaults to the name of the plugin class.
* @return the human readable category of the plugin.
*/
public String getCategory()
{
return "Layers";
}
/** Get the human readable hint for the plugin. This is a one-sentence description of
* what the plugin does. Defaults to the name of the plugin class.
* @return the human readable hint for the plugin.
*/
public String getHint()
{
return "Turns the selection into a layer.";
}
/** Perform the action of the plugin.
*
* @param document the current document.
*/
public boolean perform(Document document) throws IOException{
// Interact with the user to get the layer tag/
Tag layerTag = getLayerTagFromUser(document);
if ( layerTag == null ) return false; // User cancled.
Tag endTag = new Tag(layerTag.getName(), false);
// Get the output stream to hold the new document text.
PrintWriter out = new PrintWriter(document.getOutput());
// Create a lexical stream to tokenize the old document text.
LexicalStream in = new LexicalStream(new SelectedHTMLReader(document.getInput(), out));
for(;;){
// Get the next token of the document.
Token token = in.next();
if ( token == null ) break; // Null means we've finished the document.
else if ( token instanceof Comment ) {
Comment comment = (Comment) token;
if ( comment.isSelectionStart() ) {
out.print(layerTag);
}
else if ( comment.isSelectionEnd() ) {
out.print(comment);
out.print(endTag);
continue; // So comment isn't printed twice.
}
}
out.print(token);
}
out.close();
return true;
}
private Tag getLayerTagFromUser(Document document){
AddLayerDialog dialog = new AddLayerDialog("Add Layer", document);
dialog.reshape(50,50,300,300);
dialog.show();
dialog.requestFocus();
/* Wait for the user to exit the dialog. */
boolean result = dialog.waitForExit();
dialog.dispose(); // Cleans up the native OS window associated with the dialog.
if ( result ) {
Tag layer = new Tag("LAYER");
return layer;
}
else return null;
}
}
/** An awt dialog for interacting with the user. This is like
* the java.awt.Dialog class, except that it doesn't require a
* parent Frame.
*/
class AddLayerDialog extends Frame {
public AddLayerDialog(String title, Document document) {
super(title);
this.document = document;
Panel buttons = new Panel();
buttons.add("East", ok = new Button("OK"));
buttons.add("West", cancel = new Button("Cancel"));
// add("Center", text = new TextArea());
add("South", buttons);
}
/** Handle window close event.
*/
public boolean handleEvent(Event event) {
if (event.id == Event.WINDOW_DESTROY) {
hide();
signalExit();
return true;
} else {
return super.handleEvent(event);
}
}
public boolean action(Event evt, Object what){
if ( evt.target == ok || evt.target == cancel) {
success = evt.target == ok;
hide();
signalExit();
return true;
}
return false;
}
synchronized public boolean waitForExit() {
while ( ! bExited ) {
try {
wait();
} catch ( InterruptedException e){
}
}
return success;
}
synchronized public void signalExit() {
bExited = true;
notifyAll();
}
private Button ok;
private Button cancel;
private boolean bExited = false;
private boolean success = false;
private Document document;
}