ltabb 8ed5afe62c Free the lizard
git-svn-id: svn://10.0.0.236/trunk@10 18797224-902f-48f8-a5cc-f745e15eee43
1998-03-28 02:44:41 +00:00

97 lines
3.5 KiB
Java

/* -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
*
* The contents of this file are subject to the Netscape Public License
* Version 1.0 (the "NPL"); you may not use this file except in
* compliance with the NPL. You may obtain a copy of the NPL at
* http://www.mozilla.org/NPL/
*
* Software distributed under the NPL is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
* for the specific language governing rights and limitations under the
* NPL.
*
* The Initial Developer of this code under the NPL is Netscape
* Communications Corporation. Portions created by Netscape are
* Copyright (C) 1998 Netscape Communications Corporation. All Rights
* Reserved.
*/
package netscape.test.plugin.composer;
import java.io.*;
import netscape.plugin.composer.*;
import netscape.plugin.composer.io.*;
import java.awt.Color;
/** Sample Plugin that wraps selected text into a table.
* Shows how to do low-level parsing of html.
*/
public class Tableize 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 Tableize());
}
/** 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 "Tableize";
}
/** 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 "Character Tools";
}
/** 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 "Puts the selected text into a table.";
}
/** Perform the action of the plugin. This plugin wraps selected text into a table.
*
* @param document the current document.
*/
public boolean perform(Document document) throws IOException{
// 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(document.getInput());
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(token);
out.print("<TABLE BGCOLOR=#30c030><TR><TD>");
continue;
}
else if (comment.isSelectionEnd() ){
out.print("</TD></TR></TABLE>");
out.print(token);
continue;
}
}
out.print(token);
}
out.close();
return true;
}
}