8334509: Cancelling PageDialog does not return the same PageFormat object
Reviewed-by: aivanov, prr
This commit is contained in:
parent
8e1d2b091c
commit
689cee3d09
@ -522,6 +522,7 @@ Java_sun_awt_windows_WPageDialogPeer__1show(JNIEnv *env, jobject peer)
|
|||||||
AwtComponent *awtParent = (parent != NULL) ? (AwtComponent *)JNI_GET_PDATA(parent) : NULL;
|
AwtComponent *awtParent = (parent != NULL) ? (AwtComponent *)JNI_GET_PDATA(parent) : NULL;
|
||||||
HWND hwndOwner = awtParent ? awtParent->GetHWnd() : NULL;
|
HWND hwndOwner = awtParent ? awtParent->GetHWnd() : NULL;
|
||||||
|
|
||||||
|
jboolean doIt = JNI_FALSE;
|
||||||
PAGESETUPDLG setup;
|
PAGESETUPDLG setup;
|
||||||
memset(&setup, 0, sizeof(setup));
|
memset(&setup, 0, sizeof(setup));
|
||||||
|
|
||||||
@ -577,7 +578,7 @@ Java_sun_awt_windows_WPageDialogPeer__1show(JNIEnv *env, jobject peer)
|
|||||||
*/
|
*/
|
||||||
if ((setup.hDevMode == NULL) && (setup.hDevNames == NULL)) {
|
if ((setup.hDevMode == NULL) && (setup.hDevNames == NULL)) {
|
||||||
CLEANUP_SHOW;
|
CLEANUP_SHOW;
|
||||||
return JNI_FALSE;
|
return doIt;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
int measure = PSD_INTHOUSANDTHSOFINCHES;
|
int measure = PSD_INTHOUSANDTHSOFINCHES;
|
||||||
@ -605,7 +606,7 @@ Java_sun_awt_windows_WPageDialogPeer__1show(JNIEnv *env, jobject peer)
|
|||||||
pageFormatToSetup(env, self, page, &setup, AwtPrintControl::getPrintDC(env, self));
|
pageFormatToSetup(env, self, page, &setup, AwtPrintControl::getPrintDC(env, self));
|
||||||
if (env->ExceptionCheck()) {
|
if (env->ExceptionCheck()) {
|
||||||
CLEANUP_SHOW;
|
CLEANUP_SHOW;
|
||||||
return JNI_FALSE;
|
return doIt;
|
||||||
}
|
}
|
||||||
|
|
||||||
setup.lpfnPageSetupHook = reinterpret_cast<LPPAGESETUPHOOK>(pageDlgHook);
|
setup.lpfnPageSetupHook = reinterpret_cast<LPPAGESETUPHOOK>(pageDlgHook);
|
||||||
@ -619,7 +620,7 @@ Java_sun_awt_windows_WPageDialogPeer__1show(JNIEnv *env, jobject peer)
|
|||||||
jobject paper = getPaper(env, page);
|
jobject paper = getPaper(env, page);
|
||||||
if (paper == NULL) {
|
if (paper == NULL) {
|
||||||
CLEANUP_SHOW;
|
CLEANUP_SHOW;
|
||||||
return JNI_FALSE;
|
return doIt;
|
||||||
}
|
}
|
||||||
int units = setup.Flags & PSD_INTHOUSANDTHSOFINCHES ?
|
int units = setup.Flags & PSD_INTHOUSANDTHSOFINCHES ?
|
||||||
MM_HIENGLISH :
|
MM_HIENGLISH :
|
||||||
@ -661,7 +662,7 @@ Java_sun_awt_windows_WPageDialogPeer__1show(JNIEnv *env, jobject peer)
|
|||||||
setPaperValues(env, paper, &paperSize, &margins, units);
|
setPaperValues(env, paper, &paperSize, &margins, units);
|
||||||
if (env->ExceptionCheck()) {
|
if (env->ExceptionCheck()) {
|
||||||
CLEANUP_SHOW;
|
CLEANUP_SHOW;
|
||||||
return JNI_FALSE;
|
return doIt;
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
* Put the updated Paper instance and the orientation into
|
* Put the updated Paper instance and the orientation into
|
||||||
@ -670,7 +671,7 @@ Java_sun_awt_windows_WPageDialogPeer__1show(JNIEnv *env, jobject peer)
|
|||||||
setPaper(env, page, paper);
|
setPaper(env, page, paper);
|
||||||
if (env->ExceptionCheck()) {
|
if (env->ExceptionCheck()) {
|
||||||
CLEANUP_SHOW;
|
CLEANUP_SHOW;
|
||||||
return JNI_FALSE;
|
return doIt;
|
||||||
}
|
}
|
||||||
setPageFormatOrientation(env, page, orientation);
|
setPageFormatOrientation(env, page, orientation);
|
||||||
if (env->ExceptionCheck()) {
|
if (env->ExceptionCheck()) {
|
||||||
@ -684,12 +685,13 @@ Java_sun_awt_windows_WPageDialogPeer__1show(JNIEnv *env, jobject peer)
|
|||||||
jboolean err = setPrintPaperSize(env, self, devmode->dmPaperSize);
|
jboolean err = setPrintPaperSize(env, self, devmode->dmPaperSize);
|
||||||
if (err) {
|
if (err) {
|
||||||
CLEANUP_SHOW;
|
CLEANUP_SHOW;
|
||||||
return JNI_FALSE;
|
return doIt;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
::GlobalUnlock(setup.hDevMode);
|
::GlobalUnlock(setup.hDevMode);
|
||||||
}
|
}
|
||||||
|
doIt = JNI_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
AwtDialog::CheckUninstallModalHook();
|
AwtDialog::CheckUninstallModalHook();
|
||||||
@ -708,7 +710,7 @@ Java_sun_awt_windows_WPageDialogPeer__1show(JNIEnv *env, jobject peer)
|
|||||||
|
|
||||||
CLEANUP_SHOW;
|
CLEANUP_SHOW;
|
||||||
|
|
||||||
return JNI_TRUE;
|
return doIt;
|
||||||
|
|
||||||
CATCH_BAD_ALLOC_RET(0);
|
CATCH_BAD_ALLOC_RET(0);
|
||||||
}
|
}
|
||||||
|
58
test/jdk/java/awt/print/PrinterJob/PageDialogCancelTest.java
Normal file
58
test/jdk/java/awt/print/PrinterJob/PageDialogCancelTest.java
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2024, 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.
|
||||||
|
*
|
||||||
|
* 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 8334366
|
||||||
|
* @key headful printer
|
||||||
|
* @summary Verifies original pageobject is returned unmodified
|
||||||
|
* on cancelling pagedialog
|
||||||
|
* @requires (os.family == "windows")
|
||||||
|
* @run main PageDialogCancelTest
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.awt.Robot;
|
||||||
|
import java.awt.event.KeyEvent;
|
||||||
|
import java.awt.print.PageFormat;
|
||||||
|
import java.awt.print.PrinterJob;
|
||||||
|
|
||||||
|
public class PageDialogCancelTest {
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
PrinterJob pj = PrinterJob.getPrinterJob();
|
||||||
|
PageFormat oldFormat = new PageFormat();
|
||||||
|
Robot robot = new Robot();
|
||||||
|
Thread t1 = new Thread(() -> {
|
||||||
|
robot.delay(2000);
|
||||||
|
robot.keyPress(KeyEvent.VK_ESCAPE);
|
||||||
|
robot.keyRelease(KeyEvent.VK_ESCAPE);
|
||||||
|
robot.waitForIdle();
|
||||||
|
});
|
||||||
|
t1.start();
|
||||||
|
PageFormat newFormat = pj.pageDialog(oldFormat);
|
||||||
|
if (!newFormat.equals(oldFormat)) {
|
||||||
|
throw new RuntimeException("Original PageFormat not returned on cancelling PageDialog");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user