From 59533342dfd9968173cf1bf7500550444c9aa80d Mon Sep 17 00:00:00 2001 From: Ronald Brill Date: Sat, 24 Feb 2024 14:00:25 +0100 Subject: [PATCH] add @Override and some try-with-resource s --- .../benchmarks/BuiltinBenchmark.java | 3 ++ examples/DynamicScopes.java | 1 + src/org/mozilla/javascript/Hashtable.java | 1 + .../mozilla/javascript/NativeJavaList.java | 1 + .../tests/scriptengine/BuiltinsTest.java | 34 ++++++++++--------- .../javascript/tools/ToolErrorReporter.java | 3 ++ .../javascript/tools/debugger/Dim.java | 10 ++++++ .../javascript/tools/debugger/Main.java | 2 ++ .../treetable/AbstractCellEditor.java | 7 ++++ .../tools/debugger/treetable/JTreeTable.java | 3 ++ .../treetable/TreeTableModelAdapter.java | 10 ++++++ .../tools/shell/ConsoleTextArea.java | 7 ++++ .../javascript/tools/shell/Global.java | 20 ++++++----- .../javascript/tools/shell/JSConsole.java | 1 + .../tools/shell/JavaPolicySecurity.java | 7 ++++ .../mozilla/javascript/xmlimpl/XMLList.java | 2 ++ .../mozilla/javascript/xmlimpl/XmlNode.java | 1 + .../javascript/xmlimpl/XmlProcessor.java | 3 ++ 18 files changed, 91 insertions(+), 25 deletions(-) diff --git a/benchmarks/org/mozilla/javascript/benchmarks/BuiltinBenchmark.java b/benchmarks/org/mozilla/javascript/benchmarks/BuiltinBenchmark.java index f1e81d25e4..cd866dc2a1 100644 --- a/benchmarks/org/mozilla/javascript/benchmarks/BuiltinBenchmark.java +++ b/benchmarks/org/mozilla/javascript/benchmarks/BuiltinBenchmark.java @@ -59,6 +59,7 @@ public void close() { @State(Scope.Thread) public static class AnnotatedClassState extends AbstractClassState { + @Override @Setup(Level.Trial) public void init() throws IllegalAccessException, InvocationTargetException, InstantiationException { @@ -122,6 +123,7 @@ public int getValue() { @State(Scope.Thread) public static class IdClassState extends AbstractClassState { + @Override @Setup(Level.Trial) public void init() throws IllegalAccessException, InvocationTargetException, InstantiationException { @@ -314,6 +316,7 @@ protected int findPrototypeId(String s) { @State(Scope.Thread) public static class DumbLambdaState extends AbstractClassState { + @Override @Setup(Level.Trial) public void init() throws IllegalAccessException, InvocationTargetException, InstantiationException { diff --git a/examples/DynamicScopes.java b/examples/DynamicScopes.java index ac80a74a7f..0ba24ac888 100644 --- a/examples/DynamicScopes.java +++ b/examples/DynamicScopes.java @@ -139,6 +139,7 @@ static class PerThread implements Runnable { this.x = x; } + @Override public void run() { // We need a new Context for this thread. Context cx = Context.enter(); diff --git a/src/org/mozilla/javascript/Hashtable.java b/src/org/mozilla/javascript/Hashtable.java index 25cffc83b9..53052d6c91 100644 --- a/src/org/mozilla/javascript/Hashtable.java +++ b/src/org/mozilla/javascript/Hashtable.java @@ -273,6 +273,7 @@ public void clear() { map.clear(); } + @Override public Iterator iterator() { return new Iter(first); } diff --git a/src/org/mozilla/javascript/NativeJavaList.java b/src/org/mozilla/javascript/NativeJavaList.java index 0fb3b69968..f292a6f8d7 100644 --- a/src/org/mozilla/javascript/NativeJavaList.java +++ b/src/org/mozilla/javascript/NativeJavaList.java @@ -77,6 +77,7 @@ public boolean has(int index, Scriptable start) { return super.has(index, start); } + @Override public void delete(int index) { if (isWithValidIndex(index)) { list.set(index, null); diff --git a/testsrc/org/mozilla/javascript/tests/scriptengine/BuiltinsTest.java b/testsrc/org/mozilla/javascript/tests/scriptengine/BuiltinsTest.java index a2bc1a0706..8fa671fff8 100644 --- a/testsrc/org/mozilla/javascript/tests/scriptengine/BuiltinsTest.java +++ b/testsrc/org/mozilla/javascript/tests/scriptengine/BuiltinsTest.java @@ -37,22 +37,24 @@ public void printStdout() throws ScriptException { @Test public void printStdoutAndCheckItPrints() throws Exception { - ByteArrayOutputStream bos = new ByteArrayOutputStream(); - PrintStream original = System.out; - PrintStream modified = new PrintStream(bos, false); - System.setOut(modified); - // Now Get A SimpleContext - ScriptContext sc = new SimpleScriptContext(); - try { - // this was a broken test - engine.eval("print('Hello, World!');", sc); - // this has been hard work https://github.com/mozilla/rhino/issues/1356 - Assert.assertEquals("Hello, World!\n", bos.toString()); - } finally { - // revert the sys out - System.setOut(original); - modified.close(); - bos.close(); + try (ByteArrayOutputStream bos = new ByteArrayOutputStream()) { + PrintStream original = System.out; + try (PrintStream modified = new PrintStream(bos, false)) { + System.setOut(modified); + try { + // Now Get A SimpleContext + ScriptContext sc = new SimpleScriptContext(); + + // this was a broken test + engine.eval("print('Hello, World!');", sc); + + // this has been hard work https://github.com/mozilla/rhino/issues/1356 + Assert.assertEquals("Hello, World!\n", bos.toString()); + } finally { + // revert the sys out + System.setOut(original); + } + } } } diff --git a/toolsrc/org/mozilla/javascript/tools/ToolErrorReporter.java b/toolsrc/org/mozilla/javascript/tools/ToolErrorReporter.java index 7cdd108805..2c9fa75544 100644 --- a/toolsrc/org/mozilla/javascript/tools/ToolErrorReporter.java +++ b/toolsrc/org/mozilla/javascript/tools/ToolErrorReporter.java @@ -92,18 +92,21 @@ private static String getExceptionMessage(RhinoException ex) { return msg; } + @Override public void warning( String message, String sourceName, int line, String lineSource, int lineOffset) { if (!reportWarnings) return; reportErrorMessage(message, sourceName, line, lineSource, lineOffset, true); } + @Override public void error( String message, String sourceName, int line, String lineSource, int lineOffset) { hasReportedErrorFlag = true; reportErrorMessage(message, sourceName, line, lineSource, lineOffset, false); } + @Override public EvaluatorException runtimeError( String message, String sourceName, int line, String lineSource, int lineOffset) { return new EvaluatorException(message, sourceName, line, lineSource, lineOffset); diff --git a/toolsrc/org/mozilla/javascript/tools/debugger/Dim.java b/toolsrc/org/mozilla/javascript/tools/debugger/Dim.java index 433797ac59..c4385c77f1 100644 --- a/toolsrc/org/mozilla/javascript/tools/debugger/Dim.java +++ b/toolsrc/org/mozilla/javascript/tools/debugger/Dim.java @@ -805,6 +805,7 @@ private DimIProxy(Dim dim, int type) { // ContextAction /** Performs the action given by {@link #type}. */ + @Override public Object run(Context cx) { switch (type) { case IPROXY_COMPILE_SCRIPT: @@ -863,6 +864,7 @@ private void withContext() { // ContextFactory.Listener /** Called when a Context is created. */ + @Override public void contextCreated(Context cx) { if (type != IPROXY_LISTEN) Kit.codeBug(); ContextData contextData = new ContextData(); @@ -873,6 +875,7 @@ public void contextCreated(Context cx) { } /** Called when a Context is destroyed. */ + @Override public void contextReleased(Context cx) { if (type != IPROXY_LISTEN) Kit.codeBug(); } @@ -880,6 +883,7 @@ public void contextReleased(Context cx) { // Debugger /** Returns a StackFrame for the given function or script. */ + @Override public DebugFrame getFrame(Context cx, DebuggableScript fnOrScript) { if (type != IPROXY_DEBUG) Kit.codeBug(); @@ -892,6 +896,7 @@ public DebugFrame getFrame(Context cx, DebuggableScript fnOrScript) { } /** Called when compilation is finished. */ + @Override public void handleCompilationDone(Context cx, DebuggableScript fnOrScript, String source) { if (type != IPROXY_DEBUG) Kit.codeBug(); @@ -984,6 +989,7 @@ private StackFrame(Context cx, Dim dim, FunctionSource fsource) { } /** Called when the stack frame is entered. */ + @Override public void onEnter(Context cx, Scriptable scope, Scriptable thisObj, Object[] args) { contextData.pushFrame(this); this.scope = scope; @@ -994,6 +1000,7 @@ public void onEnter(Context cx, Scriptable scope, Scriptable thisObj, Object[] a } /** Called when the current position has changed. */ + @Override public void onLineChange(Context cx, int lineno) { this.lineNumber = lineno; @@ -1013,11 +1020,13 @@ public void onLineChange(Context cx, int lineno) { } /** Called when an exception has been thrown. */ + @Override public void onExceptionThrown(Context cx, Throwable exception) { dim.handleExceptionThrown(cx, exception, this); } /** Called when the stack frame has been left. */ + @Override public void onExit(Context cx, boolean byThrow, Object resultOrException) { if (dim.breakOnReturn && !byThrow) { dim.handleBreakpointHit(this, cx); @@ -1026,6 +1035,7 @@ public void onExit(Context cx, boolean byThrow, Object resultOrException) { } /** Called when a 'debugger' statement is executed. */ + @Override public void onDebuggerStatement(Context cx) { dim.handleBreakpointHit(this, cx); } diff --git a/toolsrc/org/mozilla/javascript/tools/debugger/Main.java b/toolsrc/org/mozilla/javascript/tools/debugger/Main.java index 85f3315e19..3b57add10b 100644 --- a/toolsrc/org/mozilla/javascript/tools/debugger/Main.java +++ b/toolsrc/org/mozilla/javascript/tools/debugger/Main.java @@ -307,6 +307,7 @@ public static ScopeProvider newScopeProvider(Scriptable scope) { // ContextAction /** Exit action. */ + @Override public void run() { if (type != EXIT_ACTION) Kit.codeBug(); System.exit(0); @@ -315,6 +316,7 @@ public void run() { // ScopeProvider /** Returns the scope for script evaluations. */ + @Override public Scriptable getScope() { if (type != SCOPE_PROVIDER) Kit.codeBug(); if (scope == null) Kit.codeBug(); diff --git a/toolsrc/org/mozilla/javascript/tools/debugger/treetable/AbstractCellEditor.java b/toolsrc/org/mozilla/javascript/tools/debugger/treetable/AbstractCellEditor.java index 1612208420..7db9e8cae2 100644 --- a/toolsrc/org/mozilla/javascript/tools/debugger/treetable/AbstractCellEditor.java +++ b/toolsrc/org/mozilla/javascript/tools/debugger/treetable/AbstractCellEditor.java @@ -41,28 +41,35 @@ public class AbstractCellEditor implements CellEditor { protected EventListenerList listenerList = new EventListenerList(); + @Override public Object getCellEditorValue() { return null; } + @Override public boolean isCellEditable(EventObject e) { return true; } + @Override public boolean shouldSelectCell(EventObject anEvent) { return false; } + @Override public boolean stopCellEditing() { return true; } + @Override public void cancelCellEditing() {} + @Override public void addCellEditorListener(CellEditorListener l) { listenerList.add(CellEditorListener.class, l); } + @Override public void removeCellEditorListener(CellEditorListener l) { listenerList.remove(CellEditorListener.class, l); } diff --git a/toolsrc/org/mozilla/javascript/tools/debugger/treetable/JTreeTable.java b/toolsrc/org/mozilla/javascript/tools/debugger/treetable/JTreeTable.java index 52a735fce7..4a285d9267 100644 --- a/toolsrc/org/mozilla/javascript/tools/debugger/treetable/JTreeTable.java +++ b/toolsrc/org/mozilla/javascript/tools/debugger/treetable/JTreeTable.java @@ -201,6 +201,7 @@ public void paint(Graphics g) { } /** TreeCellRenderer method. Overridden to update the visible row. */ + @Override public Component getTableCellRendererComponent( JTable table, Object value, @@ -218,6 +219,7 @@ public Component getTableCellRendererComponent( /** TreeTableCellEditor implementation. Component returned is the JTree. */ public class TreeTableCellEditor extends AbstractCellEditor implements TableCellEditor { + @Override public Component getTableCellEditorComponent( JTable table, Object value, boolean isSelected, int r, int c) { return tree; @@ -351,6 +353,7 @@ protected void updateSelectedPathsFromSelectedRows() { * the list changse. */ class ListSelectionHandler implements ListSelectionListener { + @Override public void valueChanged(ListSelectionEvent e) { updateSelectedPathsFromSelectedRows(); } diff --git a/toolsrc/org/mozilla/javascript/tools/debugger/treetable/TreeTableModelAdapter.java b/toolsrc/org/mozilla/javascript/tools/debugger/treetable/TreeTableModelAdapter.java index ba38b6819a..422be21fbe 100644 --- a/toolsrc/org/mozilla/javascript/tools/debugger/treetable/TreeTableModelAdapter.java +++ b/toolsrc/org/mozilla/javascript/tools/debugger/treetable/TreeTableModelAdapter.java @@ -64,10 +64,12 @@ public TreeTableModelAdapter(TreeTableModel treeTableModel, JTree tree) { new TreeExpansionListener() { // Don't use fireTableRowsInserted() here; the selection model // would get updated twice. + @Override public void treeExpanded(TreeExpansionEvent event) { fireTableDataChanged(); } + @Override public void treeCollapsed(TreeExpansionEvent event) { fireTableDataChanged(); } @@ -79,18 +81,22 @@ public void treeCollapsed(TreeExpansionEvent event) { // the event before us. treeTableModel.addTreeModelListener( new TreeModelListener() { + @Override public void treeNodesChanged(TreeModelEvent e) { delayedFireTableDataChanged(); } + @Override public void treeNodesInserted(TreeModelEvent e) { delayedFireTableDataChanged(); } + @Override public void treeNodesRemoved(TreeModelEvent e) { delayedFireTableDataChanged(); } + @Override public void treeStructureChanged(TreeModelEvent e) { delayedFireTableDataChanged(); } @@ -99,6 +105,7 @@ public void treeStructureChanged(TreeModelEvent e) { // Wrappers, implementing TableModel interface. + @Override public int getColumnCount() { return treeTableModel.getColumnCount(); } @@ -113,6 +120,7 @@ public Class getColumnClass(int column) { return treeTableModel.getColumnClass(column); } + @Override public int getRowCount() { return tree.getRowCount(); } @@ -122,6 +130,7 @@ protected Object nodeForRow(int row) { return treePath.getLastPathComponent(); } + @Override public Object getValueAt(int row, int column) { return treeTableModel.getValueAt(nodeForRow(row), column); } @@ -143,6 +152,7 @@ public void setValueAt(Object value, int row, int column) { protected void delayedFireTableDataChanged() { SwingUtilities.invokeLater( new Runnable() { + @Override public void run() { fireTableDataChanged(); } diff --git a/toolsrc/org/mozilla/javascript/tools/shell/ConsoleTextArea.java b/toolsrc/org/mozilla/javascript/tools/shell/ConsoleTextArea.java index 6f726bcf69..0ef70bdf72 100644 --- a/toolsrc/org/mozilla/javascript/tools/shell/ConsoleTextArea.java +++ b/toolsrc/org/mozilla/javascript/tools/shell/ConsoleTextArea.java @@ -30,6 +30,7 @@ public ConsoleWrite(ConsoleTextArea textArea, String str) { this.str = str; } + @Override public void run() { textArea.write(str); } @@ -149,6 +150,7 @@ public void eval(String str) { console1.flush(); } + @Override public void keyPressed(KeyEvent e) { int code = e.getKeyCode(); if (code == KeyEvent.VK_BACK_SPACE || code == KeyEvent.VK_LEFT) { @@ -213,6 +215,7 @@ public void keyPressed(KeyEvent e) { } } + @Override public void keyTyped(KeyEvent e) { int keyChar = e.getKeyChar(); if (keyChar == 0x8 /* KeyEvent.VK_BACK_SPACE */) { @@ -224,6 +227,7 @@ public void keyTyped(KeyEvent e) { } } + @Override public synchronized void keyReleased(KeyEvent e) {} public synchronized void write(String str) { @@ -233,6 +237,7 @@ public synchronized void write(String str) { select(outputMark, outputMark); } + @Override public synchronized void insertUpdate(DocumentEvent e) { int len = e.getLength(); int off = e.getOffset(); @@ -241,6 +246,7 @@ public synchronized void insertUpdate(DocumentEvent e) { } } + @Override public synchronized void removeUpdate(DocumentEvent e) { int len = e.getLength(); int off = e.getOffset(); @@ -260,6 +266,7 @@ public synchronized void postUpdateUI() { select(outputMark, outputMark); } + @Override public synchronized void changedUpdate(DocumentEvent e) {} public InputStream getIn() { diff --git a/toolsrc/org/mozilla/javascript/tools/shell/Global.java b/toolsrc/org/mozilla/javascript/tools/shell/Global.java index d61b791853..6e80e5fd9e 100644 --- a/toolsrc/org/mozilla/javascript/tools/shell/Global.java +++ b/toolsrc/org/mozilla/javascript/tools/shell/Global.java @@ -340,9 +340,9 @@ public static void serialize(Context cx, Scriptable thisObj, Object[] args, Func String filename = Context.toString(args[1]); FileOutputStream fos = new FileOutputStream(filename); Scriptable scope = ScriptableObject.getTopLevelScope(thisObj); - ScriptableOutputStream out = new ScriptableOutputStream(fos, scope); - out.writeObject(obj); - out.close(); + try (ScriptableOutputStream out = new ScriptableOutputStream(fos, scope)) { + out.writeObject(obj); + } } public static Object deserialize(Context cx, Scriptable thisObj, Object[] args, Function funObj) @@ -351,12 +351,12 @@ public static Object deserialize(Context cx, Scriptable thisObj, Object[] args, throw Context.reportRuntimeError("Expected a filename to read the serialization from"); } String filename = Context.toString(args[0]); - FileInputStream fis = new FileInputStream(filename); - Scriptable scope = ScriptableObject.getTopLevelScope(thisObj); - ObjectInputStream in = new ScriptableInputStream(fis, scope); - Object deserialized = in.readObject(); - in.close(); - return Context.toObject(deserialized, scope); + try (FileInputStream fis = new FileInputStream(filename)) { + Scriptable scope = ScriptableObject.getTopLevelScope(thisObj); + ObjectInputStream in = new ScriptableInputStream(fis, scope); + Object deserialized = in.readObject(); + return Context.toObject(deserialized, scope); + } } public String[] getPrompts(Context cx) { @@ -1144,10 +1144,12 @@ class Runner implements Runnable, ContextAction { s = script; } + @Override public void run() { factory.call(this); } + @Override public Object run(Context cx) { if (f != null) return f.call(cx, scope, scope, args); else return s.exec(cx, scope); diff --git a/toolsrc/org/mozilla/javascript/tools/shell/JSConsole.java b/toolsrc/org/mozilla/javascript/tools/shell/JSConsole.java index 7db6557627..e4c4a9f98b 100644 --- a/toolsrc/org/mozilla/javascript/tools/shell/JSConsole.java +++ b/toolsrc/org/mozilla/javascript/tools/shell/JSConsole.java @@ -144,6 +144,7 @@ public void windowClosing(WindowEvent e) { Main.main(args); } + @Override public void actionPerformed(ActionEvent e) { String cmd = e.getActionCommand(); String plaf_name = null; diff --git a/toolsrc/org/mozilla/javascript/tools/shell/JavaPolicySecurity.java b/toolsrc/org/mozilla/javascript/tools/shell/JavaPolicySecurity.java index 1e027d2cbc..98bc6e452a 100644 --- a/toolsrc/org/mozilla/javascript/tools/shell/JavaPolicySecurity.java +++ b/toolsrc/org/mozilla/javascript/tools/shell/JavaPolicySecurity.java @@ -39,10 +39,12 @@ private static class Loader extends ClassLoader implements GeneratedClassLoader this.domain = domain; } + @Override public Class defineClass(String name, byte[] data) { return super.defineClass(name, data, 0, data.length, domain); } + @Override public void linkClass(Class cl) { resolveClass(cl); } @@ -85,10 +87,12 @@ public boolean implies(Permission permission) { @Override public Enumeration elements() { return new Enumeration() { + @Override public boolean hasMoreElements() { return false; } + @Override public Permission nextElement() { return null; } @@ -123,6 +127,7 @@ protected void callProcessFileSecure( final Context cx, final Scriptable scope, final String filename) { AccessController.doPrivileged( new PrivilegedAction() { + @Override public Object run() { URL url = getUrlObj(filename); ProtectionDomain staticDomain = getUrlDomain(url); @@ -172,6 +177,7 @@ public GeneratedClassLoader createClassLoader( final ProtectionDomain domain = (ProtectionDomain) securityDomain; return AccessController.doPrivileged( new PrivilegedAction() { + @Override public Loader run() { return new Loader(parentLoader, domain); } @@ -220,6 +226,7 @@ public Object callWithDomain( PrivilegedAction action = new PrivilegedAction() { + @Override public Object run() { return callable.call(cx, scope, thisObj, args); } diff --git a/xmlimplsrc/org/mozilla/javascript/xmlimpl/XMLList.java b/xmlimplsrc/org/mozilla/javascript/xmlimpl/XMLList.java index 0a32207295..0470a0cd6e 100644 --- a/xmlimplsrc/org/mozilla/javascript/xmlimpl/XMLList.java +++ b/xmlimplsrc/org/mozilla/javascript/xmlimpl/XMLList.java @@ -744,6 +744,7 @@ public Scriptable getExtraMethodSource(Context cx) { return null; } + @Override public Object call(Context cx, Scriptable scope, Scriptable thisObj, Object[] args) { // This XMLList is being called as a Function. // Let's find the real Function object. @@ -782,6 +783,7 @@ public Object call(Context cx, Scriptable scope, Scriptable thisObj, Object[] ar return ((Callable) func).call(cx, scope, thisObj, args); } + @Override public Scriptable construct(Context cx, Scriptable scope, Object[] args) { throw ScriptRuntime.typeErrorById("msg.not.ctor", "XMLList"); } diff --git a/xmlimplsrc/org/mozilla/javascript/xmlimpl/XmlNode.java b/xmlimplsrc/org/mozilla/javascript/xmlimpl/XmlNode.java index 551343491f..fb2b24eafc 100644 --- a/xmlimplsrc/org/mozilla/javascript/xmlimpl/XmlNode.java +++ b/xmlimplsrc/org/mozilla/javascript/xmlimpl/XmlNode.java @@ -312,6 +312,7 @@ Namespace getNamespaceDeclaration() { static class XmlNodeUserDataHandler implements UserDataHandler, Serializable { private static final long serialVersionUID = 4666895518900769588L; + @Override public void handle(short operation, String key, Object data, Node src, Node dest) {} } diff --git a/xmlimplsrc/org/mozilla/javascript/xmlimpl/XmlProcessor.java b/xmlimplsrc/org/mozilla/javascript/xmlimpl/XmlProcessor.java index d899bcecab..0d0bf2d66c 100644 --- a/xmlimplsrc/org/mozilla/javascript/xmlimpl/XmlProcessor.java +++ b/xmlimplsrc/org/mozilla/javascript/xmlimpl/XmlProcessor.java @@ -133,14 +133,17 @@ private void throwError(SAXParseException e) { throw ScriptRuntime.constructError("TypeError", e.getMessage(), e.getLineNumber() - 1); } + @Override public void error(SAXParseException e) { throwError(e); } + @Override public void fatalError(SAXParseException e) { throwError(e); } + @Override public void warning(SAXParseException e) { Context.reportWarning(e.getMessage()); }