8151015: JTextArea.insert() does not behave as expected with invalid position
Reviewed-by: prr
This commit is contained in:
parent
e6dcf30b2a
commit
d0668c07b4
jdk
src/java.desktop/share/classes/javax/swing/text
test/javax/swing/text
AbstractDocument/DocumentInsert
GapContent/4496801
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
@ -702,6 +702,9 @@ public abstract class AbstractDocument implements Document, Serializable {
|
||||
if ((str == null) || (str.length() == 0)) {
|
||||
return;
|
||||
}
|
||||
if (offs > getLength()) {
|
||||
throw new BadLocationException("Invalid insert", getLength());
|
||||
}
|
||||
DocumentFilter filter = getDocumentFilter();
|
||||
|
||||
writeLock();
|
||||
|
61
jdk/test/javax/swing/text/AbstractDocument/DocumentInsert/DocumentInsertAtWrongPositionTest.java
Normal file
61
jdk/test/javax/swing/text/AbstractDocument/DocumentInsert/DocumentInsertAtWrongPositionTest.java
Normal file
@ -0,0 +1,61 @@
|
||||
/*
|
||||
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation. Oracle designates this
|
||||
* particular file as subject to the "Classpath" exception as provided
|
||||
* by Oracle in the LICENSE file that accompanied this code.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
import javax.swing.*;
|
||||
import javax.swing.text.*;
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @bug 8151015
|
||||
* @summary JTextArea.insert() does not behave as expected with invalid position
|
||||
* @run main DocumentInsertAtWrongPositionTest
|
||||
*/
|
||||
public class DocumentInsertAtWrongPositionTest {
|
||||
public static void main(String[] args) throws Exception {
|
||||
JTextField te = new JTextField("1234567890");
|
||||
JTextPane tp = new JTextPane();
|
||||
tp.setText("1234567890");
|
||||
JTextArea ta = new JTextArea("1234567890");
|
||||
|
||||
try {
|
||||
ta.insert("abc", 11);
|
||||
|
||||
throw new RuntimeException("failed");
|
||||
} catch (IllegalArgumentException e) {
|
||||
}
|
||||
try {
|
||||
|
||||
te.getDocument().insertString(11, "abc", new SimpleAttributeSet());
|
||||
|
||||
throw new RuntimeException("failed");
|
||||
} catch (BadLocationException e) {
|
||||
}
|
||||
try {
|
||||
tp.getDocument().insertString(11, "abc", new SimpleAttributeSet());
|
||||
throw new RuntimeException("failed");
|
||||
} catch (BadLocationException e) {
|
||||
}
|
||||
}
|
||||
}
|
53
jdk/test/javax/swing/text/GapContent/4496801/bug4496801.java
Normal file
53
jdk/test/javax/swing/text/GapContent/4496801/bug4496801.java
Normal file
@ -0,0 +1,53 @@
|
||||
/*
|
||||
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation. Oracle designates this
|
||||
* particular file as subject to the "Classpath" exception as provided
|
||||
* by Oracle in the LICENSE file that accompanied this code.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
/* @test
|
||||
@bug 4496801 8151015
|
||||
@summary Tests HTMLDocument.insertBeforeEnd() method
|
||||
@author Peter Zhelezniakov
|
||||
@run main bug4496801
|
||||
*/
|
||||
|
||||
import javax.swing.text.html.parser.ParserDelegator;
|
||||
import javax.swing.text.html.*;
|
||||
import javax.swing.text.*;
|
||||
import java.io.IOException;
|
||||
|
||||
public class bug4496801 {
|
||||
public static void main(String[] args) {
|
||||
HTMLDocument doc = new HTMLDocument();
|
||||
doc.setParser(new ParserDelegator());
|
||||
|
||||
Element html = doc.getRootElements()[0];
|
||||
Element body = html.getElement(0);
|
||||
|
||||
try {
|
||||
doc.insertBeforeEnd(body, "<h2>foo</h2>");
|
||||
} catch (IOException e) {
|
||||
} catch (BadLocationException e) {
|
||||
throw new RuntimeException("Insertion failed");
|
||||
}
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user