summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xtoolkit/test/accessibility/AccessibilityWorkBench.java120
1 files changed, 119 insertions, 1 deletions
diff --git a/toolkit/test/accessibility/AccessibilityWorkBench.java b/toolkit/test/accessibility/AccessibilityWorkBench.java
index f29f2aae68de..60ef39204202 100755
--- a/toolkit/test/accessibility/AccessibilityWorkBench.java
+++ b/toolkit/test/accessibility/AccessibilityWorkBench.java
@@ -32,7 +32,7 @@ import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
import javax.swing.tree.*;
-
+import java.io.*;
public class AccessibilityWorkBench
extends JFrame
@@ -46,6 +46,8 @@ public class AccessibilityWorkBench
{
public static final String msVersion = "v1.1";
public String msFileName;
+ public String msOptionsFileName = ".AWBrc";
+
/*WinFilename
// = "file:///d|/tmp/impress-test-document.sxi";
= "file:///d|/tmp/writer-test-document.sxw";
@@ -219,6 +221,21 @@ public class AccessibilityWorkBench
aTextButton = createButton("Text", "text");
aQuitButton = createButton ("Quit", "quit");
+ LoadOptions();
+
+ // Menu bar.
+ maMenuBar = new MenuBar ();
+ setMenuBar (maMenuBar);
+ Menu aOptionsMenu = new Menu ("Options");
+ maMenuBar.add (aOptionsMenu);
+ CheckboxMenuItem aItem;
+ aItem = new CheckboxMenuItem ("Show Descriptions", maCanvas.getShowDescriptions());
+ aOptionsMenu.add (aItem);
+ aItem.addActionListener (this);
+ aItem = new CheckboxMenuItem ("Show Names", maCanvas.getShowNames());
+ aOptionsMenu.add (aItem);
+ aItem.addActionListener (this);
+
maMainPanel.setLayout (aLayout);
getContentPane().add ("Center", maMainPanel);
maMainPanel.setVisible (true);
@@ -227,6 +244,95 @@ public class AccessibilityWorkBench
}
+ protected void LoadOptions ()
+ {
+ try
+ {
+ File aOptionsFile = new File (
+ System.getProperty ("user.home"),
+ msOptionsFileName);
+ StreamTokenizer aTokenizer = new StreamTokenizer (new FileReader (aOptionsFile));
+ aTokenizer.eolIsSignificant (true);
+ while (true)
+ {
+ if (aTokenizer.nextToken() != StreamTokenizer.TT_WORD)
+ {
+ if (aTokenizer.ttype != StreamTokenizer.TT_EOF)
+ System.out.println ("unexpected token in options file: " + aTokenizer.toString()
+ + " instead of option name");
+ break;
+ }
+ String sOptionName = aTokenizer.sval;
+
+ if (aTokenizer.nextToken() != '=')
+ {
+ System.out.println ("unexpected token in options file: " + aTokenizer.toString()
+ + " instead of =");
+ break;
+ }
+
+ String sValue = null;
+ Number nValue = null;
+ switch (aTokenizer.nextToken())
+ {
+ case StreamTokenizer.TT_WORD:
+ sValue = aTokenizer.sval;
+ break;
+ case StreamTokenizer.TT_NUMBER:
+ nValue = new Double (aTokenizer.nval);
+ break;
+ }
+
+ System.out.print ("option value " + sOptionName + " is set to ");
+ if (sValue != null)
+ System.out.println ("string " + sValue);
+ else if (nValue != null)
+ System.out.println ("number " + nValue);
+ else
+ System.out.println ("nothing");
+
+ if (aTokenizer.nextToken() == StreamTokenizer.TT_EOF)
+ break;
+ if (aTokenizer.ttype != StreamTokenizer.TT_EOL)
+ {
+ System.out.println ("unexpected token in options file: " + aTokenizer.toString()
+ + " instead of newline");
+ break;
+ }
+
+ if (sOptionName.compareTo ("ShowDescriptions") == 0)
+ maCanvas.setShowDescriptions (sValue.compareTo ("true")==0);
+ else if (sOptionName.compareTo ("ShowNames") == 0)
+ maCanvas.setShowNames (sValue.compareTo ("true")==0);
+ else
+ System.out.println ("option " + sOptionName + " unknown");
+
+ }
+ }
+ catch (Exception e)
+ {
+ System.out.println ("caught exception while loading options file : " + e);
+ }
+ }
+
+ protected void SaveOptions ()
+ {
+ try
+ {
+ File aOptionsFile = new File (
+ System.getProperty ("user.home"),
+ msOptionsFileName);
+ PrintWriter aOut = new PrintWriter (new FileWriter (aOptionsFile));
+ aOut.println ("ShowDescriptions = " + maCanvas.getShowDescriptions());
+ aOut.println ("ShowNames = " + maCanvas.getShowNames());
+ aOut.close();
+ }
+ catch (Exception e)
+ {
+ System.out.println ("caught exception while writing options file : " + e);
+ }
+ }
+
/** Create a new button and place at the right most position into the
button bar.
@@ -321,6 +427,16 @@ public class AccessibilityWorkBench
Canvas.bPaintText = ! Canvas.bPaintText;
maCanvas.repaint ();
}
+ else if (e.getActionCommand().equals ("Show Descriptions"))
+ {
+ maCanvas.setShowDescriptions ( ! maCanvas.getShowDescriptions());
+ SaveOptions ();
+ }
+ else if (e.getActionCommand().equals ("Show Names"))
+ {
+ maCanvas.setShowNames ( ! maCanvas.getShowNames());
+ SaveOptions ();
+ }
else
{
System.err.println("unknown command " + e.getActionCommand());
@@ -573,4 +689,6 @@ public class AccessibilityWorkBench
aExpandButton,
aShapesButton,
aTextButton;
+ private MenuBar
+ maMenuBar;
}