diff options
author | Michael Koch <konqueror@gmx.de> | 2003-07-13 14:39:41 +0000 |
---|---|---|
committer | Michael Koch <mkoch@gcc.gnu.org> | 2003-07-13 14:39:41 +0000 |
commit | 754a9012a41d64efa3e848e3e9464925d1d09cb4 (patch) | |
tree | 63f4b1624c05106ebba600af0a1a3cf7d1f3156b /libjava | |
parent | 75e74c719018b6ba19d6130457ad75c439842101 (diff) | |
download | gcc-754a9012a41d64efa3e848e3e9464925d1d09cb4.zip gcc-754a9012a41d64efa3e848e3e9464925d1d09cb4.tar.gz gcc-754a9012a41d64efa3e848e3e9464925d1d09cb4.tar.bz2 |
EmbeddedWindow.java, [...]: New files.
2003-07-13 Michael Koch <konqueror@gmx.de>
* gnu/java/awt/EmbeddedWindow.java,
gnu/java/awt/EmbeddedWindowSupport.java,
gnu/java/awt/natEmbeddedWindow.cc:
New files.
* java/awt/Window.java
(Window): New constructor to support embedded windows.
* Makefile.am
(awt_java_source_files): Added gnu/java/awt/EmbeddedWindow.java and
gnu/java/awt/EmbeddedWindowSupport.java.
(nat_source_files): Added gnu/java/awt/natEmbeddedWindow.cc.
* Makefile.in: Regenerated.
From-SVN: r69288
Diffstat (limited to 'libjava')
-rw-r--r-- | libjava/ChangeLog | 14 | ||||
-rw-r--r-- | libjava/Makefile.am | 3 | ||||
-rw-r--r-- | libjava/Makefile.in | 23 | ||||
-rw-r--r-- | libjava/gnu/java/awt/EmbeddedWindow.java | 62 | ||||
-rw-r--r-- | libjava/gnu/java/awt/EmbeddedWindowSupport.java | 67 | ||||
-rw-r--r-- | libjava/gnu/java/awt/natEmbeddedWindow.cc | 16 | ||||
-rw-r--r-- | libjava/java/awt/Window.java | 14 |
7 files changed, 191 insertions, 8 deletions
diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 969ce1a..8e09cd1 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,17 @@ +2003-07-13 Michael Koch <konqueror@gmx.de> + + * gnu/java/awt/EmbeddedWindow.java, + gnu/java/awt/EmbeddedWindowSupport.java, + gnu/java/awt/natEmbeddedWindow.cc: + New files. + * java/awt/Window.java + (Window): New constructor to support embedded windows. + * Makefile.am + (awt_java_source_files): Added gnu/java/awt/EmbeddedWindow.java and + gnu/java/awt/EmbeddedWindowSupport.java. + (nat_source_files): Added gnu/java/awt/natEmbeddedWindow.cc. + * Makefile.in: Regenerated. + 2003-07-11 Matt Kraai <kraii@alumni.cmu.edu> * gnu/gcj/runtime/SharedLibLoader.java: Fix misspelling. diff --git a/libjava/Makefile.am b/libjava/Makefile.am index cf0b7bd..a7388a7 100644 --- a/libjava/Makefile.am +++ b/libjava/Makefile.am @@ -751,6 +751,8 @@ gnu/awt/j2d/MappedRaster.java \ gnu/java/awt/BitMaskExtent.java \ gnu/java/awt/Buffers.java \ gnu/java/awt/ComponentDataBlitOp.java \ +gnu/java/awt/EmbeddedWindow.java \ +gnu/java/awt/EmbeddedWindowSupport.java \ gnu/java/awt/EventModifier.java \ gnu/java/awt/GLightweightPeer.java \ gnu/java/awt/image/ImageDecoder.java \ @@ -2573,6 +2575,7 @@ gnu/gcj/runtime/natSharedLibLoader.cc \ gnu/gcj/runtime/natStackTrace.cc \ gnu/gcj/runtime/natStringBuffer.cc \ gnu/gcj/runtime/natVMClassLoader.cc \ +gnu/java/awt/natEmbeddedWindow.cc \ gnu/java/nio/natFileChannelImpl.cc \ gnu/java/nio/natFileLockImpl.cc \ gnu/java/nio/natSelectorImpl.cc \ diff --git a/libjava/Makefile.in b/libjava/Makefile.in index d660d86..563e516 100644 --- a/libjava/Makefile.in +++ b/libjava/Makefile.in @@ -522,6 +522,8 @@ gnu/awt/j2d/MappedRaster.java \ gnu/java/awt/BitMaskExtent.java \ gnu/java/awt/Buffers.java \ gnu/java/awt/ComponentDataBlitOp.java \ +gnu/java/awt/EmbeddedWindow.java \ +gnu/java/awt/EmbeddedWindowSupport.java \ gnu/java/awt/EventModifier.java \ gnu/java/awt/GLightweightPeer.java \ gnu/java/awt/image/ImageDecoder.java \ @@ -2336,6 +2338,7 @@ gnu/gcj/runtime/natSharedLibLoader.cc \ gnu/gcj/runtime/natStackTrace.cc \ gnu/gcj/runtime/natStringBuffer.cc \ gnu/gcj/runtime/natVMClassLoader.cc \ +gnu/java/awt/natEmbeddedWindow.cc \ gnu/java/nio/natFileChannelImpl.cc \ gnu/java/nio/natFileLockImpl.cc \ gnu/java/nio/natSelectorImpl.cc \ @@ -2511,14 +2514,15 @@ gnu/gcj/io/shs.lo gnu/gcj/protocol/core/natCoreInputStream.lo \ gnu/gcj/runtime/natFinalizerThread.lo gnu/gcj/runtime/natFirstThread.lo \ gnu/gcj/runtime/natNameFinder.lo gnu/gcj/runtime/natSharedLibLoader.lo \ gnu/gcj/runtime/natStackTrace.lo gnu/gcj/runtime/natStringBuffer.lo \ -gnu/gcj/runtime/natVMClassLoader.lo gnu/java/nio/natFileChannelImpl.lo \ -gnu/java/nio/natFileLockImpl.lo gnu/java/nio/natSelectorImpl.lo \ -java/io/natFile.lo java/io/natFileDescriptor.lo \ -java/io/natObjectInputStream.lo java/io/natVMObjectStreamClass.lo \ -java/lang/natCharacter.lo java/lang/natClass.lo \ -java/lang/natClassLoader.lo java/lang/natConcreteProcess.lo \ -java/lang/natDouble.lo java/lang/natFloat.lo java/lang/natMath.lo \ -java/lang/natObject.lo java/lang/natRuntime.lo java/lang/natString.lo \ +gnu/gcj/runtime/natVMClassLoader.lo gnu/java/awt/natEmbeddedWindow.lo \ +gnu/java/nio/natFileChannelImpl.lo gnu/java/nio/natFileLockImpl.lo \ +gnu/java/nio/natSelectorImpl.lo java/io/natFile.lo \ +java/io/natFileDescriptor.lo java/io/natObjectInputStream.lo \ +java/io/natVMObjectStreamClass.lo java/lang/natCharacter.lo \ +java/lang/natClass.lo java/lang/natClassLoader.lo \ +java/lang/natConcreteProcess.lo java/lang/natDouble.lo \ +java/lang/natFloat.lo java/lang/natMath.lo java/lang/natObject.lo \ +java/lang/natRuntime.lo java/lang/natString.lo \ java/lang/natStringBuffer.lo java/lang/natSystem.lo \ java/lang/natThread.lo java/lang/natVMSecurityManager.lo \ java/lang/ref/natReference.lo java/lang/reflect/natArray.lo \ @@ -2772,10 +2776,13 @@ DEP_FILES = .deps/$(srcdir)/$(CONVERT_DIR)/gen-from-JIS.P \ .deps/gnu/gcj/xlib/natXImage.P .deps/gnu/gcj/xlib/natXUnmapEvent.P \ .deps/gnu/java/awt/BitMaskExtent.P .deps/gnu/java/awt/Buffers.P \ .deps/gnu/java/awt/ComponentDataBlitOp.P \ +.deps/gnu/java/awt/EmbeddedWindow.P \ +.deps/gnu/java/awt/EmbeddedWindowSupport.P \ .deps/gnu/java/awt/EventModifier.P \ .deps/gnu/java/awt/GLightweightPeer.P \ .deps/gnu/java/awt/image/ImageDecoder.P \ .deps/gnu/java/awt/image/XBMDecoder.P \ +.deps/gnu/java/awt/natEmbeddedWindow.P \ .deps/gnu/java/awt/peer/gtk/GdkFontMetrics.P \ .deps/gnu/java/awt/peer/gtk/GdkGraphics.P \ .deps/gnu/java/awt/peer/gtk/GtkArg.P \ diff --git a/libjava/gnu/java/awt/EmbeddedWindow.java b/libjava/gnu/java/awt/EmbeddedWindow.java new file mode 100644 index 0000000..607cc38 --- /dev/null +++ b/libjava/gnu/java/awt/EmbeddedWindow.java @@ -0,0 +1,62 @@ +/* EmbeddedWindow.java -- + Copyright (C) 2003 Free Software Foundation, Inc. + +This file is part of GNU Classpath. + +GNU Classpath is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Classpath 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 for more details. + +You should have received a copy of the GNU General Public License +along with GNU Classpath; see the file COPYING. If not, write to the +Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +02111-1307 USA. + +Linking this library statically or dynamically with other modules is +making a combined work based on this library. Thus, the terms and +conditions of the GNU General Public License cover the whole +combination. + +As a special exception, the copyright holders of this library give you +permission to link this library with independent modules to produce an +executable, regardless of the license terms of these independent +modules, and to copy and distribute the resulting executable under +terms of your choice, provided that you also meet, for each linked +independent module, the terms and conditions of the license of that +module. An independent module is a module which is not derived from +or based on this library. If you modify this library, you may extend +this exception to your version of the library, but you are not +obligated to do so. If you do not wish to do so, delete this +exception statement from your version. */ + + +package gnu.java.awt; + +import java.awt.Window; + +/** + * This class represents an AWT window embedded into another graphical + * toolkit or anther application. + * + * @author Michael Koch <konqueror@gmx.de> + */ +public class EmbeddedWindow extends Window +{ + /** + * Creates an window embedded into another application of graphical toolkit. + * + * @param window_id The native handle to the screen area where the AWT window + * should be embedded. + * @param width The width of the screen area. + * @param height The height of the screen area. + */ + // This method is only made native to circumvent the package-privateness of + // an internal java.awt.Window constructor. + public static native Window create (int window_id, int width, int height); +} diff --git a/libjava/gnu/java/awt/EmbeddedWindowSupport.java b/libjava/gnu/java/awt/EmbeddedWindowSupport.java new file mode 100644 index 0000000..b29db27 --- /dev/null +++ b/libjava/gnu/java/awt/EmbeddedWindowSupport.java @@ -0,0 +1,67 @@ +/* EmbeddedWindowSupport.java -- + Copyright (C) 2003 Free Software Foundation, Inc. + +This file is part of GNU Classpath. + +GNU Classpath is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Classpath 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 for more details. + +You should have received a copy of the GNU General Public License +along with GNU Classpath; see the file COPYING. If not, write to the +Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA +02111-1307 USA. + +Linking this library statically or dynamically with other modules is +making a combined work based on this library. Thus, the terms and +conditions of the GNU General Public License cover the whole +combination. + +As a special exception, the copyright holders of this library give you +permission to link this library with independent modules to produce an +executable, regardless of the license terms of these independent +modules, and to copy and distribute the resulting executable under +terms of your choice, provided that you also meet, for each linked +independent module, the terms and conditions of the license of that +module. An independent module is a module which is not derived from +or based on this library. If you modify this library, you may extend +this exception to your version of the library, but you are not +obligated to do so. If you do not wish to do so, delete this +exception statement from your version. */ + + +package gnu.java.awt; + +import java.awt.peer.WindowPeer; + +/** + * This interface defines a method for creating embedded windows. + * + * All classes inherited from java.awt.Toolkit that implement this interface + * are assumed to support embedded windows. To embed the real embedded window + * you need to use gnu.java.awt.EmbeddedWindow. + * + * @see gnu.java.awt.EmbeddedWindow + * @see java.awt.Toolkit + * + * @author Michael Koch <konqueror@gmx.de> + */ +public interface EmbeddedWindowSupport +{ + /** + * This method creates an embedded window in an application. + * + * @param window_id The native handle of a screen area to display an + * AWT window in it. + * @param width The width of the screen area. + * @param height The height of the screen area. + */ + public WindowPeer createEmbeddedWindow (int window_id, + int width, int height); +} diff --git a/libjava/gnu/java/awt/natEmbeddedWindow.cc b/libjava/gnu/java/awt/natEmbeddedWindow.cc new file mode 100644 index 0000000..0811d41 --- /dev/null +++ b/libjava/gnu/java/awt/natEmbeddedWindow.cc @@ -0,0 +1,16 @@ +/* Copyright (C) 2003 Free Software Foundation + + This file is part of libgcj. + +This software is copyrighted work licensed under the terms of the +Libgcj License. Please consult the file "LIBGCJ_LICENSE" for +details. */ + +#include <gnu/java/awt/EmbeddedWindow.h> +#include <java/awt/Window.h> + +::java::awt::Window* +gnu::java::awt::EmbeddedWindow::create (jint window_id, jint width, jint height) +{ + return new ::java::awt::Window (window_id, width, height); +} diff --git a/libjava/java/awt/Window.java b/libjava/java/awt/Window.java index 13ae133..c286381 100644 --- a/libjava/java/awt/Window.java +++ b/libjava/java/awt/Window.java @@ -38,6 +38,7 @@ exception statement from your version. */ package java.awt; +import gnu.java.awt.EmbeddedWindowSupport; import java.awt.event.WindowEvent; import java.awt.event.WindowFocusListener; import java.awt.event.WindowListener; @@ -93,6 +94,19 @@ public class Window extends Container implements Accessible graphicsConfiguration = gc; } + Window(int window_id, int width, int height) + { + this(); + + Toolkit tk = getToolkit(); + if (!(tk instanceof EmbeddedWindowSupport)) + throw new UnsupportedOperationException + ("Embedded windows not supported by the current peers: " + tk.getClass()); + + peer = ((EmbeddedWindowSupport) getToolkit()) + .createEmbeddedWindow (window_id, width, height); + } + /** * Initializes a new instance of <code>Window</code> with the specified * parent. The window will initially be invisible. |