From bbf1f0e5cffb8c01696eb26e254857a61f017d70 Mon Sep 17 00:00:00 2001
From: =?utf8?q?Karsten=20Ball=C3=BCder?= <ballueder@usa.net>
Date: Wed, 20 May 1998 14:21:00 +0000
Subject: [PATCH] now MSW stuff is complete

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@10 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
---
 include/wx/msw/ctl3d/ctl3d.h                |  61 ++
 include/wx/msw/ole/droptgt.h                | 113 +++
 include/wx/msw/ole/oleutils.h               | 145 ++++
 include/wx/msw/ole/uuid.h                   |  91 +++
 samples/joytest/chart.ico                   | Bin 0 -> 766 bytes
 samples/joytest/gun.wav                     | Bin 0 -> 26838 bytes
 samples/joytest/joytest.cpp                 | 171 ++++
 samples/joytest/joytest.def                 |   8 +
 samples/joytest/joytest.h                   |  51 ++
 samples/joytest/joytest.ico                 | Bin 0 -> 766 bytes
 samples/joytest/joytest.rc                  |   5 +
 samples/joytest/makefile.b32                |  64 ++
 samples/joytest/makefile.bcc                |  75 ++
 samples/joytest/makefile.dos                |  63 ++
 samples/joytest/makefile.g95                |  35 +
 samples/joytest/makefile.nt                 |  63 ++
 samples/joytest/makefile.sc                 |  37 +
 samples/joytest/makefile.unx                |  55 ++
 samples/joytest/makefile.wat                |  43 +
 samples/joytest/mondrian.ico                | Bin 0 -> 766 bytes
 samples/mfc/makefile.b32                    |  71 ++
 samples/mfc/makefile.bcc                    |  76 ++
 samples/mfc/makefile.dos                    |  89 +++
 samples/mfc/makefile.nt                     |  66 ++
 samples/mfc/makefile.wat                    |  47 ++
 samples/mfc/mfctest.cpp                     | 408 ++++++++++
 samples/mfc/mfctest.def                     |  21 +
 samples/mfc/mfctest.h                       |  66 ++
 samples/mfc/mfctest.ico                     | Bin 0 -> 766 bytes
 samples/mfc/mfctest.rc                      | 108 +++
 samples/mfc/resource.h                      |  18 +
 samples/mfc/stdafx.h                        |  12 +
 samples/nativdlg/aiai.ico                   | Bin 0 -> 766 bytes
 samples/nativdlg/dialog1.rc                 | 142 ++++
 samples/nativdlg/makefile.b32               |  64 ++
 samples/nativdlg/makefile.bcc               |  74 ++
 samples/nativdlg/makefile.dos               |  86 ++
 samples/nativdlg/makefile.g95               |  36 +
 samples/nativdlg/makefile.nt                |  63 ++
 samples/nativdlg/makefile.sc                |  35 +
 samples/nativdlg/makefile.unx               |  76 ++
 samples/nativdlg/makefile.vms               |  38 +
 samples/nativdlg/makefile.wat               |  42 +
 samples/nativdlg/nativdlg.cpp               | 130 +++
 samples/nativdlg/nativdlg.def               |   9 +
 samples/nativdlg/nativdlg.h                 |  47 ++
 samples/nativdlg/nativdlg.rc                |   4 +
 samples/nativdlg/resource.h                 |  25 +
 samples/ownerdrw/bell.bmp                   | Bin 0 -> 370 bytes
 samples/ownerdrw/makefile.b32               |  64 ++
 samples/ownerdrw/makefile.dos               |  65 ++
 samples/ownerdrw/makefile.g95               |  37 +
 samples/ownerdrw/makefile.nt                |  64 ++
 samples/ownerdrw/mondrian.ico               | Bin 0 -> 766 bytes
 samples/ownerdrw/nosound.bmp                | Bin 0 -> 370 bytes
 samples/ownerdrw/ownerdrw.cpp               | 293 +++++++
 samples/ownerdrw/ownerdrw.def               |   8 +
 samples/ownerdrw/ownerdrw.rc                |   6 +
 samples/ownerdrw/sound.bmp                  | Bin 0 -> 370 bytes
 samples/regtest/key1.ico                    | Bin 0 -> 318 bytes
 samples/regtest/key2.ico                    | Bin 0 -> 318 bytes
 samples/regtest/key3.ico                    | Bin 0 -> 318 bytes
 samples/regtest/makefile.g95                |  37 +
 samples/regtest/makefile.nt                 |  64 ++
 samples/regtest/registry.ico                | Bin 0 -> 1078 bytes
 samples/regtest/regtest.cpp                 | 834 ++++++++++++++++++++
 samples/regtest/regtest.rc                  |   9 +
 samples/regtest/value1.ico                  | Bin 0 -> 318 bytes
 samples/regtest/value2.ico                  | Bin 0 -> 318 bytes
 samples/taskbar/makefile.b32                |  64 ++
 samples/taskbar/makefile.bcc                |  73 ++
 samples/taskbar/makefile.dos                |  65 ++
 samples/taskbar/makefile.g95                |  37 +
 samples/taskbar/makefile.nt                 |  64 ++
 samples/taskbar/mondrian.ico                | Bin 0 -> 766 bytes
 samples/taskbar/tbtest.cpp                  | 120 +++
 samples/taskbar/tbtest.def                  |   8 +
 samples/taskbar/tbtest.h                    |  50 ++
 samples/taskbar/tbtest.rc                   |   3 +
 src/msw/ctl3d/borland/makefile.b32          |  25 +
 src/msw/ctl3d/borland/makefile.bcc          |  25 +
 src/msw/ctl3d/ctl3d.dll                     | Bin 0 -> 20964 bytes
 src/msw/ctl3d/ctl3d32.dll                   | Bin 0 -> 26623 bytes
 src/msw/ctl3d/ctl3dv2.dll                   | Bin 0 -> 27620 bytes
 src/msw/ctl3d/msvc/ctl3d.h                  |  61 ++
 src/msw/ctl3d/msvc/ctl3d.lib                | Bin 0 -> 2560 bytes
 src/msw/ctl3d/msvc/ctl3dv2.lib              | Bin 0 -> 2560 bytes
 src/msw/ctl3d/readme.txt                    |  31 +
 src/msw/ctl3d/wat32/import32.zip            | Bin 0 -> 22993 bytes
 src/msw/ctl3d/wat386/ctl3d.h                |  61 ++
 src/msw/ctl3d/wat386/ctl3d32.c              | 285 +++++++
 src/msw/ctl3d/wat386/ctl3d32.lnk            |   1 +
 src/msw/ctl3d/wat386/ctl3d32.obj            | Bin 0 -> 6699 bytes
 src/msw/ctl3d/wat386/ctl3d32.txt            |  11 +
 src/msw/ctl3d/wat386/makefile.wat           |  23 +
 src/msw/ole/droptgt.cpp                     | 459 +++++++++++
 src/msw/ole/oleutils.cpp                    | 193 +++++
 src/msw/ole/uuid.cpp                        | 153 ++++
 utils/nplugin/docs/notes.txt                |  32 +
 utils/nplugin/lib/dummy                     |   1 +
 utils/nplugin/samples/gui/gui.cpp           | 186 +++++
 utils/nplugin/samples/gui/gui.h             |  59 ++
 utils/nplugin/samples/gui/makefile.nt       |  70 ++
 utils/nplugin/samples/gui/npgui32.def       |   9 +
 utils/nplugin/samples/gui/npgui32.rc        |  44 ++
 utils/nplugin/samples/simple/makefile.nt    |  70 ++
 utils/nplugin/samples/simple/npsimple32.def |   9 +
 utils/nplugin/samples/simple/npsimple32.rc  |  44 ++
 utils/nplugin/samples/simple/simple.cpp     | 174 ++++
 utils/nplugin/src/makefile.nt               |  78 ++
 utils/nplugin/src/npapi.h                   | 258 ++++++
 utils/nplugin/src/npapp.cpp                 | 277 +++++++
 utils/nplugin/src/npapp.h                   |  91 +++
 utils/nplugin/src/npframe.cpp               | 293 +++++++
 utils/nplugin/src/npframe.h                 |  81 ++
 utils/nplugin/src/npshell.cpp               | 278 +++++++
 utils/nplugin/src/npupp.h                   | 799 +++++++++++++++++++
 utils/nplugin/src/npwin.cpp                 | 186 +++++
 118 files changed, 9265 insertions(+)
 create mode 100644 include/wx/msw/ctl3d/ctl3d.h
 create mode 100644 include/wx/msw/ole/droptgt.h
 create mode 100644 include/wx/msw/ole/oleutils.h
 create mode 100644 include/wx/msw/ole/uuid.h
 create mode 100644 samples/joytest/chart.ico
 create mode 100644 samples/joytest/gun.wav
 create mode 100644 samples/joytest/joytest.cpp
 create mode 100644 samples/joytest/joytest.def
 create mode 100644 samples/joytest/joytest.h
 create mode 100644 samples/joytest/joytest.ico
 create mode 100644 samples/joytest/joytest.rc
 create mode 100644 samples/joytest/makefile.b32
 create mode 100644 samples/joytest/makefile.bcc
 create mode 100644 samples/joytest/makefile.dos
 create mode 100644 samples/joytest/makefile.g95
 create mode 100644 samples/joytest/makefile.nt
 create mode 100644 samples/joytest/makefile.sc
 create mode 100644 samples/joytest/makefile.unx
 create mode 100644 samples/joytest/makefile.wat
 create mode 100644 samples/joytest/mondrian.ico
 create mode 100644 samples/mfc/makefile.b32
 create mode 100644 samples/mfc/makefile.bcc
 create mode 100644 samples/mfc/makefile.dos
 create mode 100644 samples/mfc/makefile.nt
 create mode 100644 samples/mfc/makefile.wat
 create mode 100644 samples/mfc/mfctest.cpp
 create mode 100644 samples/mfc/mfctest.def
 create mode 100644 samples/mfc/mfctest.h
 create mode 100644 samples/mfc/mfctest.ico
 create mode 100644 samples/mfc/mfctest.rc
 create mode 100644 samples/mfc/resource.h
 create mode 100644 samples/mfc/stdafx.h
 create mode 100644 samples/nativdlg/aiai.ico
 create mode 100644 samples/nativdlg/dialog1.rc
 create mode 100644 samples/nativdlg/makefile.b32
 create mode 100644 samples/nativdlg/makefile.bcc
 create mode 100644 samples/nativdlg/makefile.dos
 create mode 100644 samples/nativdlg/makefile.g95
 create mode 100644 samples/nativdlg/makefile.nt
 create mode 100644 samples/nativdlg/makefile.sc
 create mode 100644 samples/nativdlg/makefile.unx
 create mode 100644 samples/nativdlg/makefile.vms
 create mode 100644 samples/nativdlg/makefile.wat
 create mode 100644 samples/nativdlg/nativdlg.cpp
 create mode 100644 samples/nativdlg/nativdlg.def
 create mode 100644 samples/nativdlg/nativdlg.h
 create mode 100644 samples/nativdlg/nativdlg.rc
 create mode 100644 samples/nativdlg/resource.h
 create mode 100644 samples/ownerdrw/bell.bmp
 create mode 100644 samples/ownerdrw/makefile.b32
 create mode 100644 samples/ownerdrw/makefile.dos
 create mode 100644 samples/ownerdrw/makefile.g95
 create mode 100644 samples/ownerdrw/makefile.nt
 create mode 100644 samples/ownerdrw/mondrian.ico
 create mode 100644 samples/ownerdrw/nosound.bmp
 create mode 100644 samples/ownerdrw/ownerdrw.cpp
 create mode 100644 samples/ownerdrw/ownerdrw.def
 create mode 100644 samples/ownerdrw/ownerdrw.rc
 create mode 100644 samples/ownerdrw/sound.bmp
 create mode 100644 samples/regtest/key1.ico
 create mode 100644 samples/regtest/key2.ico
 create mode 100644 samples/regtest/key3.ico
 create mode 100644 samples/regtest/makefile.g95
 create mode 100644 samples/regtest/makefile.nt
 create mode 100644 samples/regtest/registry.ico
 create mode 100644 samples/regtest/regtest.cpp
 create mode 100644 samples/regtest/regtest.rc
 create mode 100644 samples/regtest/value1.ico
 create mode 100644 samples/regtest/value2.ico
 create mode 100644 samples/taskbar/makefile.b32
 create mode 100644 samples/taskbar/makefile.bcc
 create mode 100644 samples/taskbar/makefile.dos
 create mode 100644 samples/taskbar/makefile.g95
 create mode 100644 samples/taskbar/makefile.nt
 create mode 100644 samples/taskbar/mondrian.ico
 create mode 100644 samples/taskbar/tbtest.cpp
 create mode 100644 samples/taskbar/tbtest.def
 create mode 100644 samples/taskbar/tbtest.h
 create mode 100644 samples/taskbar/tbtest.rc
 create mode 100644 src/msw/ctl3d/borland/makefile.b32
 create mode 100644 src/msw/ctl3d/borland/makefile.bcc
 create mode 100644 src/msw/ctl3d/ctl3d.dll
 create mode 100644 src/msw/ctl3d/ctl3d32.dll
 create mode 100644 src/msw/ctl3d/ctl3dv2.dll
 create mode 100644 src/msw/ctl3d/msvc/ctl3d.h
 create mode 100644 src/msw/ctl3d/msvc/ctl3d.lib
 create mode 100644 src/msw/ctl3d/msvc/ctl3dv2.lib
 create mode 100644 src/msw/ctl3d/readme.txt
 create mode 100644 src/msw/ctl3d/wat32/import32.zip
 create mode 100644 src/msw/ctl3d/wat386/ctl3d.h
 create mode 100644 src/msw/ctl3d/wat386/ctl3d32.c
 create mode 100644 src/msw/ctl3d/wat386/ctl3d32.lnk
 create mode 100644 src/msw/ctl3d/wat386/ctl3d32.obj
 create mode 100644 src/msw/ctl3d/wat386/ctl3d32.txt
 create mode 100644 src/msw/ctl3d/wat386/makefile.wat
 create mode 100644 src/msw/ole/droptgt.cpp
 create mode 100644 src/msw/ole/oleutils.cpp
 create mode 100644 src/msw/ole/uuid.cpp
 create mode 100644 utils/nplugin/docs/notes.txt
 create mode 100644 utils/nplugin/lib/dummy
 create mode 100644 utils/nplugin/samples/gui/gui.cpp
 create mode 100644 utils/nplugin/samples/gui/gui.h
 create mode 100644 utils/nplugin/samples/gui/makefile.nt
 create mode 100644 utils/nplugin/samples/gui/npgui32.def
 create mode 100644 utils/nplugin/samples/gui/npgui32.rc
 create mode 100644 utils/nplugin/samples/simple/makefile.nt
 create mode 100644 utils/nplugin/samples/simple/npsimple32.def
 create mode 100644 utils/nplugin/samples/simple/npsimple32.rc
 create mode 100644 utils/nplugin/samples/simple/simple.cpp
 create mode 100644 utils/nplugin/src/makefile.nt
 create mode 100644 utils/nplugin/src/npapi.h
 create mode 100644 utils/nplugin/src/npapp.cpp
 create mode 100644 utils/nplugin/src/npapp.h
 create mode 100644 utils/nplugin/src/npframe.cpp
 create mode 100644 utils/nplugin/src/npframe.h
 create mode 100644 utils/nplugin/src/npshell.cpp
 create mode 100644 utils/nplugin/src/npupp.h
 create mode 100644 utils/nplugin/src/npwin.cpp

diff --git a/include/wx/msw/ctl3d/ctl3d.h b/include/wx/msw/ctl3d/ctl3d.h
new file mode 100644
index 0000000000..de7e67aa50
--- /dev/null
+++ b/include/wx/msw/ctl3d/ctl3d.h
@@ -0,0 +1,61 @@
+/*-----------------------------------------------------------------------
+|	CTL3D.DLL
+|	
+|	Adds 3d effects to Windows controls
+|
+|	See ctl3d.doc for info
+|		
+-----------------------------------------------------------------------*/
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+BOOL WINAPI Ctl3dSubclassDlg(HWND, WORD);
+BOOL WINAPI Ctl3dSubclassDlgEx(HWND, DWORD);
+WORD WINAPI Ctl3dGetVer(void);
+BOOL WINAPI Ctl3dEnabled(void);
+HBRUSH WINAPI Ctl3dCtlColor(HDC, LONG);	// ARCHAIC, use Ctl3dCtlColorEx
+HBRUSH WINAPI Ctl3dCtlColorEx(UINT wm, WPARAM wParam, LPARAM lParam);
+BOOL WINAPI Ctl3dColorChange(void);
+BOOL WINAPI Ctl3dSubclassCtl(HWND);
+LONG WINAPI Ctl3dDlgFramePaint(HWND, UINT, WPARAM, LPARAM);
+
+BOOL WINAPI Ctl3dAutoSubclass(HANDLE);
+
+BOOL WINAPI Ctl3dRegister(HANDLE);
+BOOL WINAPI Ctl3dUnregister(HANDLE);
+
+//begin DBCS: far east short cut key support
+VOID WINAPI Ctl3dWinIniChange(void);
+//end DBCS
+
+
+/* Ctl3dSubclassDlg3d flags */
+#define CTL3D_BUTTONS		0x0001
+#define CTL3D_LISTBOXES		0x0002		
+#define CTL3D_EDITS			0x0004	
+#define CTL3D_COMBOS			0x0008		
+#define CTL3D_STATICTEXTS	0x0010		
+#define CTL3D_STATICFRAMES	0x0020
+
+#define CTL3D_NODLGWINDOW       0x00010000
+#define CTL3D_ALL				0xffff
+
+#define WM_DLGBORDER (WM_USER+3567)
+/* WM_DLGBORDER *(int FAR *)lParam return codes */
+#define CTL3D_NOBORDER		0
+#define CTL3D_BORDER			1
+
+#define WM_DLGSUBCLASS (WM_USER+3568)
+/* WM_DLGSUBCLASS *(int FAR *)lParam return codes */
+#define CTL3D_NOSUBCLASS	0
+#define CTL3D_SUBCLASS		1
+
+/* Resource ID for 3dcheck.bmp (for .lib version of ctl3d) */
+#define CTL3D_3DCHECK 26567
+
+
+#ifdef __cplusplus
+}
+#endif
diff --git a/include/wx/msw/ole/droptgt.h b/include/wx/msw/ole/droptgt.h
new file mode 100644
index 0000000000..518a39cd5c
--- /dev/null
+++ b/include/wx/msw/ole/droptgt.h
@@ -0,0 +1,113 @@
+///////////////////////////////////////////////////////////////////////////////
+// Name:        ole/droptgt.h
+// Purpose:     declaration of the wxDropTarget class
+// Author:      Vadim Zeitlin
+// Modified by: 
+// Created:     06.03.98
+// RCS-ID:      $Id$
+// Copyright:   (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
+// Licence:     wxWindows license
+///////////////////////////////////////////////////////////////////////////////
+
+// ============================================================================
+// prolog
+// ============================================================================
+#ifndef   _OLEDROPTGT_H
+#define   _OLEDROPTGT_H
+
+#ifdef __GNUG__
+#pragma interface "droptgt.h"
+#endif
+
+#if !USE_DRAG_AND_DROP
+  #error  "You should #define USE_DRAG_AND_DROP to 1 to compile this file!"
+#endif  //WX_DRAG_DROP
+
+// ----------------------------------------------------------------------------
+// forward declarations
+// ----------------------------------------------------------------------------
+class  wxIDropTarget;
+struct IDataObject;
+
+typedef unsigned short wxDataFormat;
+
+// ----------------------------------------------------------------------------
+// An instance of the class wxDropTarget may be associated with any wxWindow
+// derived object via SetDropTarget() function. If this is done, the virtual
+// methods of wxDropTarget are called when something is dropped on the window.
+// 
+// Note that wxDropTarget is an abstract base class (ABC) and you should derive
+// your own class from it implementing pure virtual function in order to use it
+// (all of them, including protected ones which are called by the class itself)
+// ----------------------------------------------------------------------------
+class WXDLLEXPORT wxDropTarget
+{
+public:
+  // ctor & dtor
+  wxDropTarget();
+  virtual ~wxDropTarget();
+
+  // normally called by wxWindow on window creation/destruction, but might be
+  // called `manually' as well. Register() returns true on success.
+  bool Register(WXHWND hwnd);
+  void Revoke(WXHWND hwnd);
+
+  // do we accept this kind of data?
+  virtual bool IsAcceptedData(IDataObject *pIDataSource) const;
+
+  // called when mouse enters/leaves the window: might be used to give
+  // some visual feedback to the user
+  virtual void OnEnter() { }
+  virtual void OnLeave() { }
+
+  // this function is called when data is dropped.
+  // (x, y) are the coordinates of the drop
+  virtual bool OnDrop(long x, long y, const void *pData) = 0;
+
+protected:
+  // Override these to indicate what kind of data you support: the first
+  // format to which data can be converted is used. The classes below show
+  // how it can be done in the simplest cases.
+    // how many different (clipboard) formats do you support?
+  virtual size_t GetFormatCount() const = 0;
+    // return the n-th supported format
+  virtual wxDataFormat GetFormat(size_t n) const = 0;
+
+private:
+  wxIDropTarget    *m_pIDropTarget; // the pointer to COM interface
+};
+
+// ----------------------------------------------------------------------------
+// A simple wxDropTarget derived class for text data: you only need to
+// override OnDropText() to get something working
+// ----------------------------------------------------------------------------
+class WXDLLEXPORT wxTextDropTarget : public wxDropTarget
+{
+public:
+  virtual bool OnDrop(long x, long y, const void *pData);
+  virtual bool OnDropText(long x, long y, const char *psz) = 0;
+
+protected:
+  virtual size_t GetFormatCount() const;
+  virtual wxDataFormat GetFormat(size_t n) const;
+};
+
+// ----------------------------------------------------------------------------
+// A drop target which accepts files (dragged from File Manager or Explorer)
+// ----------------------------------------------------------------------------
+class WXDLLEXPORT wxFileDropTarget : public wxDropTarget
+{
+public:
+  virtual bool OnDrop(long x, long y, const void *pData);
+
+  // params: the number of files and the array of file names
+  virtual bool OnDropFiles(long x, long y, 
+                           size_t nFiles, const char * const aszFiles[]) = 0;
+
+protected:
+  virtual size_t GetFormatCount() const;
+  virtual wxDataFormat GetFormat(size_t n) const;
+};
+
+// ============================================================================
+#endif  //_OLEDROPTGT_H
\ No newline at end of file
diff --git a/include/wx/msw/ole/oleutils.h b/include/wx/msw/ole/oleutils.h
new file mode 100644
index 0000000000..1430abbbe2
--- /dev/null
+++ b/include/wx/msw/ole/oleutils.h
@@ -0,0 +1,145 @@
+///////////////////////////////////////////////////////////////////////////////
+// Name:        oleutils.h
+// Purpose:     OLE helper routines, OLE debugging support &c
+// Author:      Vadim Zeitlin
+// Modified by: 
+// Created:     19.02.1998
+// RCS-ID:      $Id$
+// Copyright:   (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
+// Licence:     wxWindows license
+///////////////////////////////////////////////////////////////////////////////
+
+#ifndef   _OLEUTILS_H
+#define   _OLEUTILS_H
+
+#ifdef __GNUG__
+#pragma interface "oleutils.h"
+#endif
+
+// ============================================================================
+// General purpose functions and macros
+// ============================================================================
+
+// ----------------------------------------------------------------------------
+// misc helper functions/macros
+// ----------------------------------------------------------------------------
+
+// release the interface pointer (if !NULL)
+inline void ReleaseInterface(IUnknown *pIUnk)
+{
+  if ( pIUnk != NULL )
+    pIUnk->Release();
+}
+
+// release the interface pointer (if !NULL) and make it NULL
+#define   RELEASE_AND_NULL(p)   if ( (p) != NULL ) { p->Release(); p = NULL; };
+
+// return TRUE if the iid is in the array
+bool IsIidFromList(REFIID riid, const IID *aIids[], size_t nCount);
+
+// ============================================================================
+// IUnknown implementation helpers
+// ============================================================================
+
+/*
+   The most dumb implementation of IUnknown methods. We don't support 
+   aggregation nor containment, but for 99% of cases this simple
+   implementation is quite enough.
+
+   Usage is trivial: here is all you should have
+   1) DECLARE_IUNKNOWN_METHOS in your (IUnknown derived!) class declaration
+   2) BEGIN/END_IID_TABLE with ADD_IID in between for all interfaces you
+      support (at least all for which you intent to return 'this' from QI,
+      i.e. you should derive from IFoo if you have ADD_IID(Foo)) somewhere else
+   3) IMPLEMENT_IUNKNOWN_METHOS somewhere also
+
+   These macros are quite simple: AddRef and Release are trivial and QI does
+   lookup in a static member array of IIDs and returns 'this' if it founds
+   the requested interface in it or E_NOINTERFACE if not.
+ */
+
+// declare the methods and the member variable containing reference count
+// you must also define the ms_aIids array somewhere with BEGIN_IID_TABLE
+// and friends (see below)
+#define   DECLARE_IUNKNOWN_METHODS                                            \
+  public:                                                                     \
+    STDMETHODIMP          QueryInterface(REFIID, void **);                    \
+    STDMETHODIMP_(ULONG)  AddRef();                                           \
+    STDMETHODIMP_(ULONG)  Release();                                          \
+  private:                                                                    \
+    static  const IID    *ms_aIids[];                                         \
+    ULONG                 m_cRef
+
+// macros for declaring supported interfaces
+// NB: you should write ADD_INTERFACE(Foo) and not ADD_INTERFACE(IID_IFoo)!
+#define BEGIN_IID_TABLE(cname)  const IID *cname::ms_aIids[] = {
+#define ADD_IID(iid)                                             &IID_I##iid,
+#define END_IID_TABLE                                          }
+
+// implementation is as straightforward as possible
+// Parameter:  classname - the name of the class
+#define   IMPLEMENT_IUNKNOWN_METHODS(classname)                               \
+  STDMETHODIMP classname::QueryInterface(REFIID riid, void **ppv)             \
+  {                                                                           \
+    wxLogQueryInterface(#classname, riid);                                    \
+                                                                              \
+    if ( IsIidFromList(riid, ms_aIids, WXSIZEOF(ms_aIids)) ) {                  \
+      *ppv = this;                                                            \
+      AddRef();                                                               \
+                                                                              \
+      return S_OK;                                                            \
+    }                                                                         \
+    else {                                                                    \
+      *ppv = NULL;                                                            \
+                                                                              \
+      return (HRESULT) E_NOINTERFACE;                                                   \
+    }                                                                         \
+  }                                                                           \
+                                                                              \
+  STDMETHODIMP_(ULONG) classname::AddRef()                                    \
+  {                                                                           \
+    wxLogAddRef(#classname, m_cRef);                                          \
+                                                                              \
+    return ++m_cRef;                                                          \
+  }                                                                           \
+                                                                              \
+  STDMETHODIMP_(ULONG) classname::Release()                                   \
+  {                                                                           \
+    wxLogRelease(#classname, m_cRef);                                         \
+                                                                              \
+    if ( --m_cRef == 0 ) {                                                    \
+      delete this;                                                            \
+      return 0;                                                               \
+    }                                                                         \
+    else                                                                      \
+      return m_cRef;                                                          \
+  }
+
+// ============================================================================
+// Debugging support
+// ============================================================================
+
+#ifdef  __DEBUG__
+
+// ----------------------------------------------------------------------------
+// 
+// ----------------------------------------------------------------------------
+
+// ----------------------------------------------------------------------------
+// All OLE specific log functions have DebugTrace level (as LogTrace)
+// ----------------------------------------------------------------------------
+
+// tries to translate riid into a symbolic name, if possible
+void wxLogQueryInterface(const char *szInterface, REFIID riid);
+
+// these functions print out the new value of reference counter
+void wxLogAddRef (const char *szInterface, ULONG cRef);
+void wxLogRelease(const char *szInterface, ULONG cRef);
+
+#else   //!DEBUG
+  #define   wxLogQueryInterface(szInterface, riid)
+  #define   wxLogAddRef(szInterface, cRef)
+  #define   wxLogRelease(szInterface, cRef)
+#endif  //DEBUG
+
+#endif  //_OLEUTILS_H
\ No newline at end of file
diff --git a/include/wx/msw/ole/uuid.h b/include/wx/msw/ole/uuid.h
new file mode 100644
index 0000000000..a970267997
--- /dev/null
+++ b/include/wx/msw/ole/uuid.h
@@ -0,0 +1,91 @@
+///////////////////////////////////////////////////////////////////////////////
+// Name:        ole/uuid.h
+// Purpose:     encapsulates an UUID with some added helper functions
+// Author:      Vadim Zeitlin
+// Modified by: 
+// Created:     11.07.97
+// RCS-ID:      $Id$
+// Copyright:   (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
+// Licence:     wxWindows license
+//
+// Notes:       you should link your project with RPCRT4.LIB!
+///////////////////////////////////////////////////////////////////////////////
+
+#ifndef   _OLEUUID_H
+#define   _OLEUUID_H
+
+#ifdef __GNUG__
+#pragma interface "uuid.h"
+#endif
+
+// ------------------------------------------------------------------
+// UUID (Universally Unique IDentifier) definition
+// ------------------------------------------------------------------
+
+// ----- taken from RPC.H
+#ifndef UUID_DEFINED            // in some cases RPC.H will be already
+  #ifdef  __WIN32__             // included, so avoid redefinition
+    typedef struct                
+    {
+      unsigned long   Data1;
+      unsigned short  Data2;
+      unsigned short  Data3;
+      unsigned char   Data4[8];
+    } UUID;                     // UUID = GUID = CLSID = LIBID = IID
+  #else   // WIN16
+    #error "Don't know about UUIDs on this platform"
+  #endif  // WIN32
+#endif  // UUID_DEFINED
+
+#ifndef GUID_DEFINED
+  typedef UUID GUID;
+  #define UUID_DEFINED          // prevent redefinition
+#endif  // GUID_DEFINED
+
+typedef unsigned char uchar;
+
+// ------------------------------------------------------------------
+// a class to store UUID and it's string representation
+// ------------------------------------------------------------------
+
+// uses RPC functions to create/convert Universally Unique Identifiers
+class Uuid
+{
+private:
+  UUID  m_uuid;
+  uchar *m_pszUuid;   // this string is alloc'd and freed by RPC 
+  char  *m_pszCForm;  // this string is allocated in Set/Create
+
+  void  UuidToCForm();
+
+  // function used to set initial state by all ctors
+  void  Init() { m_pszUuid = NULL; m_pszCForm = NULL; }
+
+public:
+  // ctors & dtor
+  Uuid()                 { Init();            }
+  Uuid(const char *pc)   { Init(); Set(pc);   }
+  Uuid(const UUID &uuid) { Init(); Set(uuid); }
+ ~Uuid();
+
+  // copy ctor and assignment operator needed for this class
+  Uuid(const Uuid& uuid);
+  Uuid& operator=(const Uuid& uuid);
+
+  // create a brand new UUID
+  void Create();
+
+  // set value of UUID 
+  bool Set(const char *pc);   // from a string, returns true if ok
+  void Set(const UUID& uuid); // from another UUID (never fails)
+
+  // accessors
+  operator const UUID*() const { return &m_uuid;             }
+  operator const char*() const { return (char *)(m_pszUuid); }
+
+  // return string representation of the UUID in the C form
+  // (as in DEFINE_GUID macro)
+  const char *CForm() const    { return m_pszCForm;          }
+};
+
+#endif    // _OLEUUID_H
\ No newline at end of file
diff --git a/samples/joytest/chart.ico b/samples/joytest/chart.ico
new file mode 100644
index 0000000000000000000000000000000000000000..16d4a585fd3246e7a8dc43c45e010c006e643dd6
GIT binary patch
literal 766
zcmc&wF%H5o40I7AQkYn&nArFNzsi_=qf@@p2UOx4jHOFdsgk)%D>cxHj+|r1*R$Ou
zA_c50k3u|mA}8!ucnQD53)v%zcxdbJ5TSTKZiq<XUh2ArplOLJGdPT&$QOt<gJWF=
zaFcbkE1dI<Xe+InHGQkUIKN=yPv-tkZ&>7qFu*Pe;O)q})Br9M@2fs2xG_OluNwM{
zcSECEB^`=VZ-!Clq`-NP$D|`q^P8EoNK<|GI(*Wt>lv#s7a1^aS#Q-v=NLJDsYfc-
TMvJ?z=wHXdA%Ehd{14;}SbUVL

literal 0
HcmV?d00001

diff --git a/samples/joytest/gun.wav b/samples/joytest/gun.wav
new file mode 100644
index 0000000000000000000000000000000000000000..8cb037d78d14fec09784deb03d1c225c5bf96f12
GIT binary patch
literal 26838
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

literal 0
HcmV?d00001

diff --git a/samples/joytest/joytest.cpp b/samples/joytest/joytest.cpp
new file mode 100644
index 0000000000..6ec7c6fa53
--- /dev/null
+++ b/samples/joytest/joytest.cpp
@@ -0,0 +1,171 @@
+/////////////////////////////////////////////////////////////////////////////
+// Name:        joytest.cpp
+// Purpose:     Joystick sample
+// Author:      Julian Smart
+// Modified by:
+// Created:     04/01/98
+// RCS-ID:      $Id$
+// Copyright:   (c) Julian Smart and Markus Holzem
+// Licence:   	wxWindows license
+/////////////////////////////////////////////////////////////////////////////
+
+// For compilers that support precompilation, includes "wx/wx.h".
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+#pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+#include "wx/wx.h"
+#endif
+
+#include <wx/msw/wave.h>
+#include <wx/msw/joystick.h>
+
+#include "joytest.h"
+
+MyFrame *frame = NULL;
+
+IMPLEMENT_APP(MyApp)
+
+// For drawing lines in a canvas
+long xpos = -1;
+long ypos = -1;
+
+int winNumber = 1;
+
+// Initialise this in OnInit, not statically
+bool MyApp::OnInit(void)
+{
+  wxJoystick stick(wxJOYSTICK1);
+  if (!stick.IsOk())
+  {
+    wxMessageBox("No joystick detected!");
+    return FALSE;
+  }
+  m_fire.Create("gun.wav");
+
+  m_maxX = stick.GetXMax();
+  m_maxY = stick.GetYMax();
+
+  // Create the main frame window
+
+  frame = new MyFrame(NULL, "Joystick Demo", wxPoint(0, 0), wxSize(500, 400),
+   wxDEFAULT_FRAME | wxHSCROLL | wxVSCROLL);
+
+  // Give it an icon (this is ignored in MDI mode: uses resources)
+#ifdef __WINDOWS__
+  frame->SetIcon(wxIcon("joyicon"));
+#endif
+#ifdef __X__
+  frame->SetIcon(wxIcon("joyicon.xbm"));
+#endif
+
+  // Make a menubar
+  wxMenu *file_menu = new wxMenu;
+
+  file_menu->Append(JOYTEST_QUIT, "&Exit");
+
+  wxMenu *help_menu = new wxMenu;
+  help_menu->Append(JOYTEST_ABOUT, "&About");
+
+  wxMenuBar *menu_bar = new wxMenuBar;
+
+  menu_bar->Append(file_menu, "&File");
+  menu_bar->Append(help_menu, "&Help");
+
+  // Associate the menu bar with the frame
+  frame->SetMenuBar(menu_bar);
+
+  frame->CreateStatusBar();
+
+  frame->Show(TRUE);
+
+  SetTopWindow(frame);
+
+  return TRUE;
+}
+
+BEGIN_EVENT_TABLE(MyCanvas, wxScrolledWindow)
+	EVT_JOYSTICK_EVENTS(MyCanvas::OnJoystickEvent)
+END_EVENT_TABLE()
+
+// Define a constructor for my canvas
+MyCanvas::MyCanvas(wxWindow *parent, const wxPoint& pos, const wxSize& size):
+ wxScrolledWindow(parent, -1, pos, size, wxSUNKEN_BORDER)
+{
+    wxJoystick joystick(wxJOYSTICK1);
+    joystick.SetCapture(this);
+}
+
+MyCanvas::~MyCanvas(void)
+{
+    wxJoystick joystick(wxJOYSTICK1);
+    joystick.ReleaseCapture();
+}
+
+void MyCanvas::OnJoystickEvent(wxJoystickEvent& event)
+{
+  wxClientDC dc(this);
+
+  wxPoint pt(event.GetPosition());
+
+  // Scale to canvas size
+  int cw, ch;
+  GetSize(&cw, &ch);
+
+  pt.x = (long) (((double)pt.x/(double)wxGetApp().m_maxX) * cw);
+  pt.y = (long) (((double)pt.y/(double)wxGetApp().m_maxY) * ch);
+
+  if (xpos > -1 && ypos > -1 && event.IsMove() && event.ButtonIsDown())
+  {
+    dc.SetPen(*wxBLACK_PEN);
+    dc.DrawLine(xpos, ypos, pt.x, pt.y);
+  }
+  xpos = pt.x;
+  ypos = pt.y;
+
+  char buf[100];
+  if (event.ButtonDown())
+    sprintf(buf, "Joystick (%ld, %ld) Fire!", pt.x, pt.y);
+  else
+    sprintf(buf, "Joystick (%ld, %ld)", pt.x, pt.y);
+  frame->SetStatusText(buf);
+
+  if (event.ButtonDown() && wxGetApp().m_fire.IsOk())
+  {
+    wxGetApp().m_fire.Play();
+  }
+}
+
+BEGIN_EVENT_TABLE(MyFrame, wxFrame)
+  EVT_MENU(JOYTEST_QUIT, MyFrame::OnQuit)
+END_EVENT_TABLE()
+
+MyFrame::MyFrame(wxFrame *parent, const wxString& title, const wxPoint& pos, const wxSize& size,
+const long style):
+  wxFrame(parent, -1, title, pos, size, style)
+{
+  canvas = new MyCanvas(this);
+}
+
+MyFrame::~MyFrame(void)
+{
+}
+
+void MyFrame::OnQuit(wxCommandEvent& event)
+{
+      Close(TRUE);
+}
+
+void MyFrame::OnActivate(wxActivateEvent& event)
+{
+  if (event.GetActive() && canvas)
+    canvas->SetFocus();
+}
+
+bool MyFrame::OnClose(void)
+{
+  return TRUE;
+}
\ No newline at end of file
diff --git a/samples/joytest/joytest.def b/samples/joytest/joytest.def
new file mode 100644
index 0000000000..501f2b229a
--- /dev/null
+++ b/samples/joytest/joytest.def
@@ -0,0 +1,8 @@
+NAME         Joytest
+DESCRIPTION  'Joystick Test Program'
+EXETYPE      WINDOWS
+STUB         'WINSTUB.EXE'
+CODE         PRELOAD MOVEABLE DISCARDABLE
+DATA         PRELOAD MOVEABLE MULTIPLE
+HEAPSIZE     6000
+STACKSIZE    48000
diff --git a/samples/joytest/joytest.h b/samples/joytest/joytest.h
new file mode 100644
index 0000000000..68c4f68075
--- /dev/null
+++ b/samples/joytest/joytest.h
@@ -0,0 +1,51 @@
+/////////////////////////////////////////////////////////////////////////////
+// Name:        joytest.cpp
+// Purpose:     Joystick sample
+// Author:      Julian Smart
+// Modified by:
+// Created:     04/01/98
+// RCS-ID:      $Id$
+// Copyright:   (c) Julian Smart and Markus Holzem
+// Licence:   	wxWindows license
+/////////////////////////////////////////////////////////////////////////////
+
+// Define a new application
+class MyApp: public wxApp
+{
+  public:
+    bool OnInit(void);
+
+    // Joystick max values
+    int     m_maxX;
+    int     m_maxY;
+
+    wxWave  m_fire;
+};
+
+DECLARE_APP(MyApp)
+
+class MyCanvas: public wxScrolledWindow
+{
+  public:
+    MyCanvas(wxWindow *parent, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize);
+    ~MyCanvas(void);
+    void OnJoystickEvent(wxJoystickEvent& event);
+
+    DECLARE_EVENT_TABLE()
+};
+
+class MyFrame: public wxFrame
+{
+  public:
+    MyCanvas *canvas;
+    MyFrame(wxFrame *parent, const wxString& title, const wxPoint& pos, const wxSize& size, const long style);
+    ~MyFrame(void);
+    bool OnClose(void);
+    void OnActivate(wxActivateEvent& event);
+    void OnQuit(wxCommandEvent& event);
+
+DECLARE_EVENT_TABLE()
+};
+
+#define JOYTEST_QUIT        1
+#define JOYTEST_ABOUT       2
diff --git a/samples/joytest/joytest.ico b/samples/joytest/joytest.ico
new file mode 100644
index 0000000000000000000000000000000000000000..2dc1bde40cf921731fb2f7c6534054c6fb8d96d1
GIT binary patch
literal 766
zcmah{IgY|W5G*e%tq=i3o32BCvHXmAf>Zy(`6TlchZ{QF05Mc`&y2+((WbBJ>H`DN
z@#*^mB!3^kH~o>?Q%}?mpR_<=?X?6JSqZ@%EkkNRN{NMRALOiv%14mQONo@Vuu~f2
zR1r@bqoxHgHqbgO7{>y8VLOh4a849H4Zzj{FAJP(g5{I-n)O_*F$%SIE3<<+Nj^dZ
zMrsmnqFCH}{&VhK#xlN*^s!HQyVC2cT_ZcBoK?PWy+p6H9A{2%_%Scn3ie-MC5TR`
zfM>p<u^XdS?|okOIfpJ^f%66U{Re&)U_S$23D`&j|AJNVMk-G}mHwHtG*h#+L%Xz7
FyKkN>7Bv6>

literal 0
HcmV?d00001

diff --git a/samples/joytest/joytest.rc b/samples/joytest/joytest.rc
new file mode 100644
index 0000000000..8138605789
--- /dev/null
+++ b/samples/joytest/joytest.rc
@@ -0,0 +1,5 @@
+aaaa                    ICON    "mondrian.ico"
+joyicon                 ICON    "mondrian.ico"
+
+#include "wx/msw/wx.rc"
+
diff --git a/samples/joytest/makefile.b32 b/samples/joytest/makefile.b32
new file mode 100644
index 0000000000..d889d44cee
--- /dev/null
+++ b/samples/joytest/makefile.b32
@@ -0,0 +1,64 @@
+#
+# File:		makefile.b32
+# Author:	Patrick Halke
+# Created:	1995
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds 32bit MDI example.
+
+# WXWIN and BCCDIR are set by parent make
+
+WXDIR = $(WXWIN)
+!include $(WXDIR)\src\makeb32.env
+
+WXLIBDIR = $(WXDIR)\lib
+WXLIB = $(WXLIBDIR)\wx32.lib
+LIBS=$(WXLIB) cw32 import32
+
+TARGET=joytest
+
+!if "$(FINAL)" == "0"
+LINKFLAGS=/v /Tpe /L$(WXLIBDIR);$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS= -v
+!else
+LINKFLAGS=/Tpe /L$(WXLIBDIR);$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS =
+!endif
+CPPFLAGS=$(DEBUG_FLAGS) $(OPT) @$(CFG)
+
+OBJECTS = joytest.obj
+
+$(TARGET).exe:	$(OBJECTS) $(TARGET).def $(TARGET).res
+  tlink32 $(LINKFLAGS) @&&!
+c0w32.obj $(OBJECTS)
+$(TARGET)
+nul
+$(LIBS)
+$(TARGET).def
+!
+        brc32 -K $(TARGET).res
+
+.$(SRCSUFF).obj:
+	bcc32 $(CPPFLAGS) -c {$< }
+
+.c.obj:
+	bcc32 $(CPPFLAGS) -P- -c {$< }
+
+joytest.obj:      joytest.$(SRCSUFF) joytest.h
+
+$(TARGET).res :      $(TARGET).rc $(WXDIR)\include\wx\msw\wx.rc
+    brc32 -r /i$(BCCDIR)\include /i$(WXDIR)\include $(TARGET)
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.rws
+
+
diff --git a/samples/joytest/makefile.bcc b/samples/joytest/makefile.bcc
new file mode 100644
index 0000000000..230ea4abbe
--- /dev/null
+++ b/samples/joytest/makefile.bcc
@@ -0,0 +1,75 @@
+#
+# File:		makefile.bcc
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds joytest example (DOS).
+
+!if "$(BCCDIR)" == ""
+!error You must define the BCCDIR variable in autoexec.bat, e.g. BCCDIR=d:\bc4
+!endif
+
+!if "$(WXWIN)" == ""
+!error You must define the WXWIN variable in autoexec.bat, e.g. WXWIN=c:\wx
+!endif
+
+!ifndef FINAL
+FINAL=0
+!endif
+
+WXDIR = $(WXWIN)
+!include $(WXDIR)\src\makebcc.env
+
+THISDIR = $(WXDIR)\samples\joytest
+WXLIB = $(WXDIR)\lib\wx.lib
+LIBS=$(WXLIB) mathwl cwl import
+INC=-I$(WXDIR)\include\base -I$(WXDIR)\include\msw
+CFG=$(WXDIR)\src\wxwin.cfg
+
+!if "$(FINAL)" == "0"
+LINKFLAGS=/v/Vt /Twe /L$(WXDIR)\lib;$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS= -v
+!else
+LINKFLAGS=/Twe /L$(WXDIR)\lib;$(BCCDIR)\lib
+OPT = -O2
+DEBUG_FLAGS =
+!endif
+CPPFLAGS=$(DEBUG_FLAGS) $(OPT) @$(CFG)
+
+HEADERS = joytest.h
+SOURCES = joytest.$(SRCSUFF)
+OBJECTS = joytest.obj
+
+joytest:    joytest.exe
+
+all:    joytest.exe
+
+joytest.exe:      $(WXLIB) joytest.obj joytest.def joytest.res
+        tlink $(LINKFLAGS) @&&!
+c0wl.obj joytest.obj
+joytest
+nul
+$(LIBS)
+joytest.def
+!
+        rc -30 -K joytest.res
+
+.$(SRCSUFF).obj:
+	bcc $(CPPFLAGS) -c {$< }
+
+joytest.obj:      joytest.$(SRCSUFF)
+
+joytest.res :      joytest.rc $(WXDIR)\include\msw\wx.rc
+    rc -r /i$(BCCDIR)\include /i$(WXDIR)\include\msw /i$(WXDIR)\contrib\fafa joytest
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.rws
diff --git a/samples/joytest/makefile.dos b/samples/joytest/makefile.dos
new file mode 100644
index 0000000000..b2ddbcf9f5
--- /dev/null
+++ b/samples/joytest/makefile.dos
@@ -0,0 +1,63 @@
+#
+# File:		makefile.dos
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds joytest example (DOS).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+WXDIR = $(WXWIN)
+
+!include $(WXDIR)\src\makemsc.env
+
+THISDIR = $(WXDIR)\samples\joytest
+INC=/I$(WXDIR)\include
+
+HEADERS = joytest.h
+SOURCES = joytest.$(SRCSUFF)
+OBJECTS = joytest.obj
+
+all:    joytest.exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.dos
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.dos clean
+        cd $(THISDIR)
+
+
+joytest.exe:      $(WXDIR)\src\msw\dummy.obj $(WXLIB) joytest.obj joytest.def joytest.res
+        link $(LINKFLAGS) @<<
+$(WXDIR)\src\msw\dummy.obj joytest.obj,
+joytest,
+NUL,
+$(LIBS),
+joytest.def
+;
+<<
+        rc -K joytest.res
+
+joytest.obj:      joytest.h joytest.$(SRCSUFF)
+        cl @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+joytest.res :      joytest.rc $(WXDIR)\include\wx\msw\wx.rc
+    rc -r /i$(WXDIR)\include joytest
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
diff --git a/samples/joytest/makefile.g95 b/samples/joytest/makefile.g95
new file mode 100644
index 0000000000..8eef77f7cf
--- /dev/null
+++ b/samples/joytest/makefile.g95
@@ -0,0 +1,35 @@
+#
+# File:		makefile.unx
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile for joytest example (UNIX).
+
+WXDIR = ../..
+
+# All common UNIX compiler flags and options are now in
+# this central makefile.
+include $(WXDIR)/src/makeg95.env
+
+OBJECTS = $(OBJDIR)/joytest.$(OBJSUFF) $(OBJDIR)/joytest_resources.$(OBJSUFF)
+
+all:    $(OBJDIR) joytest$(GUISUFFIX)
+
+$(OBJDIR):
+	mkdir $(OBJDIR)
+
+joytest$(GUISUFFIX): $(OBJECTS) $(WXLIB)
+	$(CC) $(LDFLAGS) -o joytest$(GUISUFFIX)$(EXESUFF) $(OBJECTS) $(LDLIBS)
+
+$(OBJDIR)/joytest.$(OBJSUFF):        joytest.$(SRCSUFF) joytest.h
+	$(CC) -c $(CPPFLAGS) -o $@ joytest.$(SRCSUFF)
+
+$(OBJDIR)/joytest_resources.o:  joytest.rc
+	$(RESCOMP) -i joytest.rc -o $(OBJDIR)/joytest_resources.o $(RESFLAGS)
+
+clean:
+	rm -f $(OBJECTS) joytest$(GUISUFFIX).exe core *.res *.rsc
diff --git a/samples/joytest/makefile.nt b/samples/joytest/makefile.nt
new file mode 100644
index 0000000000..ca7ec0c46a
--- /dev/null
+++ b/samples/joytest/makefile.nt
@@ -0,0 +1,63 @@
+#
+# File:		makefile.nt
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds joytest example (MS VC++).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+WXUSINGDLL=0
+
+!include $(WXDIR)\src\ntwxwin.mak
+
+THISDIR = $(WXDIR)\samples\joytest
+PROGRAM=joytest
+
+OBJECTS = $(PROGRAM).obj
+
+$(PROGRAM):    $(PROGRAM).exe
+
+all:    wx $(PROGRAM).exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt clean
+        cd $(THISDIR)
+
+$(PROGRAM).exe:      $(DUMMYOBJ) $(WXLIB) $(OBJECTS) $(PROGRAM).res
+	$(link) @<<
+-out:$(PROGRAM).exe
+$(LINKFLAGS)
+$(DUMMYOBJ) $(OBJECTS) $(PROGRAM).res
+$(LIBS)
+<<
+
+
+$(PROGRAM).obj:      $(PROGRAM).$(SRCSUFF) $(DUMMYOBJ)
+        $(cc) @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+$(PROGRAM).res :      $(PROGRAM).rc $(WXDIR)\include\wx\msw\wx.rc
+    $(rc) -r /i$(WXDIR)\include -fo$@ $(PROGRAM).rc
+
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
diff --git a/samples/joytest/makefile.sc b/samples/joytest/makefile.sc
new file mode 100644
index 0000000000..bcdcb11d54
--- /dev/null
+++ b/samples/joytest/makefile.sc
@@ -0,0 +1,37 @@
+;    Last change:  JS   12 Apr 98   10:45 am
+# Symantec C++ makefile for joytest example
+# NOTE that peripheral libraries are now dealt in main wxWindows makefile.
+
+WXDIR = $(WXWIN)
+!include $(WXDIR)\src\makesc.env
+
+WXLIB = $(WXDIR)\lib\wx.lib
+INCDIR = $(WXDIR)\include
+MSWINC = $(INCDIR)\msw
+BASEINC = $(INCDIR)\base
+
+CC=sc
+RC=rc
+CFLAGS = -o -ml -W -Dwx_msw
+LDFLAGS = -ml -W
+
+INCLUDE=$(BASEINC);$(MSWINC)
+
+LIBS=$(WXLIB) libw.lib commdlg.lib shell.lib
+
+.$(SRCSUFF).obj:
+	*$(CC) -c $(CFLAGS) -I$(INCLUDE) $<
+
+.rc.res:
+	*$(RC) -r -I$(INCLUDE) $<
+
+joytest.exe: joytest.obj joytest.def joytest.res
+	*$(CC) $(LDFLAGS) -o$@ joytest.obj joytest.def $(LIBS)
+	*$(RC) -k joytest.res
+
+clean:
+        -del *.obj
+	-del *.exe
+	-del *.res
+	-del *.map
+	-del *.rws
diff --git a/samples/joytest/makefile.unx b/samples/joytest/makefile.unx
new file mode 100644
index 0000000000..c4156423ac
--- /dev/null
+++ b/samples/joytest/makefile.unx
@@ -0,0 +1,55 @@
+#
+# File:		makefile.unx
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile for joytest example (UNIX).
+
+WXDIR = ../..
+
+# All common UNIX compiler flags and options are now in
+# this central makefile.
+include $(WXDIR)/src/make.env
+
+OBJECTS = $(OBJDIR)/joytest.$(OBJSUFF)
+
+.SUFFIXES:
+
+all:    $(OBJDIR) joytest$(GUISUFFIX)
+
+wx:
+#	cd $(WXDIR)/src/x; $(MAKE) -f makefile.unx
+motif:
+	$(MAKE) -f makefile.unx GUISUFFIX=_motif GUI=-Dwx_motif GUISUFFIX=_motif OPT='$(OPT)' LDLIBS='$(MOTIFLDLIBS)' OPTIONS='$(OPTIONS)' DEBUG='$(DEBUG)' WARN='$(WARN)' XLIB='$(XLIB)' XINCLUDE='$(XINCLUDE)' XVIEW_LINK=
+
+xview:
+	$(MAKE) -f makefile.unx GUI=-Dwx_xview GUISUFFIX=_ol CC=$(CC) OPTIONS='$(OPTIONS)' DEBUG='$(DEBUG)' WARN='$(WARN)' XLIB='$(XLIB)' XINCLUDE='$(XINCLUDE)'
+
+hp:
+	$(MAKE) -f makefile.unx GUI=-Dwx_motif GUISUFFIX=_hp CC=CC DEBUG='$(DEBUG)' WARN='-w' \
+         XINCLUDE='$(HPXINCLUDE)' XLIB='$(HPXLIB)' XVIEW_LINK='' LDLIBS='$(HPLDLIBS)'
+
+$(OBJDIR):
+	mkdir $(OBJDIR)
+
+joytest$(GUISUFFIX): $(OBJDIR)/joytest.$(OBJSUFF) $(WXLIB)
+	$(CC) $(LDFLAGS) -o joytest$(GUISUFFIX) $(OBJDIR)/joytest.$(OBJSUFF) $(XVIEW_LINK) $(LDLIBS)
+
+$(OBJDIR)/joytest.$(OBJSUFF):        joytest.$(SRCSUFF) joytest.h
+	$(CC) -c $(CPPFLAGS) -o $@ joytest.$(SRCSUFF)
+
+clean_motif:
+	$(MAKE) -f makefile.unx GUISUFFIX=_motif cleanany
+
+clean_ol:
+	$(MAKE) -f makefile.unx GUISUFFIX=_ol cleanany
+
+clean_hp:
+	$(MAKE) -f makefile.unx GUISUFFIX=_hp cleanany
+
+cleanany:
+	rm -f $(OBJECTS) joytest$(GUISUFFIX) core
diff --git a/samples/joytest/makefile.wat b/samples/joytest/makefile.wat
new file mode 100644
index 0000000000..d009dcb6a8
--- /dev/null
+++ b/samples/joytest/makefile.wat
@@ -0,0 +1,43 @@
+#
+# Makefile for WATCOM
+#
+# Created by D.Chubraev, chubraev@iem.ee.ethz.ch
+# 8 Nov 1994
+#
+
+WXDIR = ..\.. 
+
+!include $(WXDIR)\src\makewat.env
+
+WXLIB = $(WXDIR)\lib
+NAME = joytest
+LNK = $(name).lnk
+OBJS = $(name).obj
+
+all:    $(name).exe
+
+$(name).exe : $(OBJS) $(name).res $(LNK) $(WXLIB)\wx$(LEVEL).lib
+    wlink @$(LNK)
+    $(BINDCOMMAND) $(name).res
+
+$(name).res :      $(name).rc $(WXDIR)\include\msw\wx.rc
+     $(RC) $(RESFLAGS1) $(name).rc
+
+$(LNK) : makefile.wat
+    %create $(LNK)
+    @%append $(LNK) debug all
+    @%append $(LNK) system $(LINKOPTION)
+    @%append $(LNK) $(MINDATA)
+    @%append $(LNK) $(MAXDATA)
+    @%append $(LNK) $(STACK)
+    @%append $(LNK) name $(name)
+    @%append $(LNK) file $(WXLIB)\wx$(LEVEL).lib
+    @for %i in ($(EXTRALIBS)) do @%append $(LNK) file %i
+    @for %i in ($(OBJS)) do @%append $(LNK) file %i
+
+thing: .SYMBOLIC
+    echo $(WATLIBDIR)
+
+clean:   .SYMBOLIC
+    -erase *.obj *.bak *.err *.pch *.lib *.lnk *.res *.exe *.rex
+
diff --git a/samples/joytest/mondrian.ico b/samples/joytest/mondrian.ico
new file mode 100644
index 0000000000000000000000000000000000000000..2310c5d275a87af295d5ea8dc79ea417a5e74c53
GIT binary patch
literal 766
zcmZQzU<5)11px*Sc)`TLAO@s0fLH;D9e|jTfdxnc0Z<M**w4TKL=5})Lnt5#WHKB$
zaDbtqp#doIAB-6O{|B*v7zjZ^AOa2W|NsACHyAJ}De?dRKnp(HN~rljcR;{k;{zQE
i@;}UZ|9Q?Fpp*~yJCwmWbLIrN`9Qm9%}2L?p!oo$cZ4ed

literal 0
HcmV?d00001

diff --git a/samples/mfc/makefile.b32 b/samples/mfc/makefile.b32
new file mode 100644
index 0000000000..9f0993827d
--- /dev/null
+++ b/samples/mfc/makefile.b32
@@ -0,0 +1,71 @@
+#
+# File:		makefile.bcc
+# Author:       Andre Beltman
+# Created:      1995
+# Updated:	
+# Copyright:    (c) 1995, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds mfc example (DOS).
+
+# WXWIN and BCCDIR are set by parent make
+
+WXDIR = $(WXWIN)
+!include $(WXDIR)\src\makeb32.env
+
+WXLIBDIR = $(WXDIR)\lib
+WXINC = $(WXDIR)\include\msw
+WXBASESRC = $(WXDIR)\src\base
+WXBASEINC = $(WXDIR)\include\base
+WXLIB = $(WXLIBDIR)\wx32.lib
+FAFALIB = $(WXLIBDIR)\fafa.lib
+ITSYLIB = $(WXLIBDIR)\itsy.lib
+XPMLIB = $(WXLIBDIR)\xpm.lib
+DIBLIB = $(WXLIBDIR)\dib.lib
+GAUGELIB = $(WXLIBDIR)\gauge.lib
+WXTREELIB = $(WXLIBDIR)\wxtree.lib
+RCPARSERLIB = $(WXLIBDIR)\rcparser.lib
+PROLOGLIB = $(WXLIBDIR)\prologio.lib
+LIBS=$(WXLIB) cw32 import32 ctl3d32 $(FAFALIB) $(ITSYLIB) $(DIBLIB)\
+  $(XPMLIB) $(PROLOGLIB) $(RCPARSERLIB) $(GAUGELIB) $(WXTREELIB)
+
+TARGET=hello
+
+!if "$(FINAL)" == "0"
+LINKFLAGS=/v /Tpe /L$(WXLIBDIR);$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS= -v
+!else
+LINKFLAGS=/Tpe /L$(WXLIBDIR);$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS =
+!endif
+CPPFLAGS=$(DEBUG_FLAGS) $(OPT) @$(CFG)
+
+OBJECTS = hello.obj
+
+$(TARGET).exe:	$(OBJECTS) $(TARGET).def $(TARGET).res
+  tlink32 $(LINKFLAGS) @&&!
+c0w32.obj $(OBJECTS)
+$(TARGET)
+nul
+$(LIBS)
+$(TARGET).def
+!
+        brc32 -K $(TARGET).res
+
+.$(SRCSUFF).obj:
+	bcc32 $(CPPFLAGS) -c {$< }
+
+.c.obj:
+	bcc32 $(CPPFLAGS) -P- -c {$< }
+
+hello.obj:      hello.$(SRCSUFF)
+
+$(TARGET).res :      $(TARGET).rc $(WXDIR)\include\msw\wx.rc
+    brc32 -r /i$(BCCDIR)\include /i$(WXDIR)\include\msw /i$(WXDIR)\contrib\fafa $(TARGET)
+
+clean:
+        -erase *.obj *.exe *.res *.map *.rws
+
diff --git a/samples/mfc/makefile.bcc b/samples/mfc/makefile.bcc
new file mode 100644
index 0000000000..6e2059d571
--- /dev/null
+++ b/samples/mfc/makefile.bcc
@@ -0,0 +1,76 @@
+#
+# File:		makefile.bcc
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds mfc example (DOS).
+
+!if "$(BCCDIR)" == ""
+!error You must define the BCCDIR variable in autoexec.bat, e.g. BCCDIR=d:\bc4
+!endif
+
+!if "$(WXWIN)" == ""
+!error You must define the WXWIN variable in autoexec.bat, e.g. WXWIN=c:\wx
+!endif
+
+WXDIR = $(WXWIN)
+!include $(WXDIR)\src\makebcc.env
+
+THISDIR = $(WXDIR)\samples\mfc
+WXLIB = $(WXDIR)\lib\wx.lib
+
+LIBS=$(WXLIB) mathwl cwl import
+INC=-I$(WXDIR)\include\base -I$(WXDIR)\include\msw
+CFG=$(WXDIR)\src\wxwin.cfg
+
+!ifndef FINAL
+FINAL=0
+!endif
+
+!if "$(FINAL)" == "0"
+LINKFLAGS=/v/Vt /Twe /L$(WXDIR)\lib;$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS= -v
+!else
+LINKFLAGS=/Twe /L$(WXDIR)\lib;$(BCCDIR)\lib
+OPT = -O2
+DEBUG_FLAGS =
+!endif
+CPPFLAGS=$(DEBUG_FLAGS) $(OPT) @$(CFG)
+
+HEADERS = hello.h
+SOURCES = hello.$(SRCSUFF)
+OBJECTS = hello.obj
+
+hello:    hello.exe
+
+all:    hello.exe
+
+hello.exe:      $(WXLIB) hello.obj hello.def hello.res
+        tlink $(LINKFLAGS) @&&!
+c0wl.obj hello.obj
+hello
+nul
+$(LIBS)
+hello.def
+!
+        rc -30 -K hello.res
+
+.$(SRCSUFF).obj:
+	bcc $(CPPFLAGS) -c {$< }
+
+hello.obj:      hello.$(SRCSUFF)
+
+hello.res :      hello.rc $(WXDIR)\include\msw\wx.rc
+    rc -r /i$(BCCDIR)\include /i$(WXDIR)\include\msw /i$(WXDIR)\contrib\fafa hello
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.rws
diff --git a/samples/mfc/makefile.dos b/samples/mfc/makefile.dos
new file mode 100644
index 0000000000..93934fd12a
--- /dev/null
+++ b/samples/mfc/makefile.dos
@@ -0,0 +1,89 @@
+#
+# File:		makefile.dos
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds MFC compatibility example (DOS).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info.
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+
+!include $(WXDIR)\src\makemsc.env
+
+THISDIR = $(WXDIR)\samples\mfc
+WXLIB = $(WXDIR)\lib\wx.lib
+MFCINC = c:\msvc\mfc\include
+LIBS=lafxcwD $(WXLIB) oldnames libw llibcew commdlg ddeml shell mmsystem  # mfcoleui compobj storage ole2 ole2disp
+#LIBS=lafxcwD llibcew libw commdlg shell
+INC=-I$(MFCINC) -I$(WXDIR)\include\base -I$(WXDIR)\include\msw
+DUMMY=$(WXDIR)\src\msw\dummy.obj
+
+# Set this to nothing if using MS C++ 7
+ZOPTION=/Z7
+
+!ifndef FINAL
+FINAL=0
+!endif
+
+PRECOMP = # /YuWX_PREC.H /Fp$(WXDIR)\src\msw\wx.pch
+
+!if "$(FINAL)" == "0"
+CPPFLAGS=/D_DEBUG /AL /W3 /Zi $(ZOPTION) /G2sw /Od $(INC) $(PRECOMP) /Dwx_msw
+#CPPFLAGS=/AL /Zp /GA /G2 /Gyf /Od /W3 $(INC) /D_DEBUG
+LINKFLAGS=/NOD /CO /NOE /ONERROR:NOEXE /SEG:256 /STACK:12000
+!else
+CPPFLAGS=/AL /W3 /G2sw $(INC) /Ox $(PRECOMP) /Dwx_msw
+LINKFLAGS=/NOD /NOE /ONERROR:NOEXE /SEG:256
+!endif
+
+HEADERS = hello.h
+SOURCES = hello.$(SRCSUFF)
+OBJECTS = hello.obj
+
+hello:    hello.exe
+
+all:    wx hello.exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.dos FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.dos clean
+        cd $(THISDIR)
+
+
+hello.exe:      $(DUMMY) $(WXLIB) hello.obj hello.def hello.res
+        link $(LINKFLAGS) @<<
+$(DUMMY) hello.obj,
+hello,
+NUL,
+$(LIBS),
+hello.def
+;
+<<
+        rc -31 -K hello.res
+
+hello.obj:      hello.h hello.$(SRCSUFF) $(DUMMY)
+        cl @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+hello.res :      hello.rc $(WXDIR)\include\msw\wx.rc
+    rc -r /i$(MFCINC) /i$(WXDIR)\include\msw /i$(WXDIR)\contrib\fafa hello
+
+clean:
+        -erase *.obj
+        -erase *.sbr
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.pdb
diff --git a/samples/mfc/makefile.nt b/samples/mfc/makefile.nt
new file mode 100644
index 0000000000..3564096b50
--- /dev/null
+++ b/samples/mfc/makefile.nt
@@ -0,0 +1,66 @@
+#
+# File:		makefile.nt
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds MFC/wxWin example (MS VC++).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+
+EXTRALIBS=# mfc42.lib
+EXTRAINC=-Ig:\DevStudio\mfc\include
+EXTRAFLAGS=/D_AFXDLL
+
+!include $(WXDIR)\src\ntwxwin.mak
+
+THISDIR = $(WXDIR)\samples\mfc
+PROGRAM=mfctest
+
+OBJECTS = $(PROGRAM).obj
+
+$(PROGRAM):    $(PROGRAM).exe
+
+all:    wx $(PROGRAM).exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt clean
+        cd $(THISDIR)
+
+$(PROGRAM).exe:      $(DUMMYOBJ) $(WXLIB) $(OBJECTS) $(PROGRAM).res
+	$(link) @<<
+-out:$(PROGRAM).exe
+$(LINKFLAGS)
+$(DUMMYOBJ) $(OBJECTS) $(PROGRAM).res
+$(LIBS)
+<<
+
+
+$(PROGRAM).obj:      $(PROGRAM).h $(PROGRAM).$(SRCSUFF) $(DUMMYOBJ)
+        $(cc) @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+$(PROGRAM).res :      $(PROGRAM).rc $(WXDIR)\include\wx\msw\wx.rc
+    $(rc) -r /i$(WXDIR)\include -fo$@ $(PROGRAM).rc
+
+clean:
+        -erase *.obj
+        -erase *.sbr
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.pdb
+
diff --git a/samples/mfc/makefile.wat b/samples/mfc/makefile.wat
new file mode 100644
index 0000000000..0958ed9530
--- /dev/null
+++ b/samples/mfc/makefile.wat
@@ -0,0 +1,47 @@
+#
+# Makefile for WATCOM
+#
+# Created by D.Chubraev, chubraev@iem.ee.ethz.ch
+# 8 Nov 1994
+#
+
+WXDIR = ..\.. 
+
+!include $(WXDIR)\src\makewat.env
+
+WXLIB = $(WXDIR)\lib
+NAME = hello
+LNK = $(name).lnk
+OBJS = $(name).obj 
+
+# Required for multi-threaded MFC apps
+EXTRACPPFLAGS = -bm -oaxt-zp4-ei-xs-zo-w3-bm-bt=nt -d_WINDOWS -d_MBCS
+refmain = _wstart2_
+
+
+PRECOMP=
+
+all:    $(name).exe
+
+$(name).exe : $(OBJS) $(name).res $(LNK) $(WXLIB)\wx$(LEVEL).lib
+    wlink @$(LNK)
+    $(BINDCOMMAND) -d_MBCS $(name).res
+
+$(name).res :      $(name).rc $(WXDIR)\include\msw\wx.rc
+     $(RC) $(RESFLAGS1) $(name).rc
+
+$(LNK) : makefile.wat
+    %create $(LNK)
+    @%append $(LNK) debug all
+    @%append $(LNK) system $(LINKOPTION)
+    @%append $(LNK) $(MINDATA)
+    @%append $(LNK) $(MAXDATA)
+    @%append $(LNK) $(STACK)
+    @%append $(LNK) name $(name)
+    @%append $(LNK) file $(WXLIB)\wx$(LEVEL).lib
+    @for %i in ($(EXTRALIBS)) do @%append $(LNK) file %i
+    @for %i in ($(OBJS)) do @%append $(LNK) file %i
+
+clean:   .SYMBOLIC
+    -erase *.obj *.bak *.err *.pch *.lib *.lnk *.res *.exe *.rex
+
diff --git a/samples/mfc/mfctest.cpp b/samples/mfc/mfctest.cpp
new file mode 100644
index 0000000000..cbbcd343c2
--- /dev/null
+++ b/samples/mfc/mfctest.cpp
@@ -0,0 +1,408 @@
+// hello.cpp : Defines the class behaviors for the application.
+//           Hello is a simple program which consists of a main window
+//           and an "About" dialog which can be invoked by a menu choice.
+//           It is intended to serve as a starting-point for new
+//           applications.
+//
+// This is a part of the Microsoft Foundation Classes C++ library.
+// Copyright (C) 1992 Microsoft Corporation
+// All rights reserved.
+//
+// This source code is only intended as a supplement to the
+// Microsoft Foundation Classes Reference and Microsoft
+// WinHelp documentation provided with the library.
+// See these sources for detailed information regarding the
+// Microsoft Foundation Classes product.
+
+// *** MODIFIED BY JULIAN SMART TO DEMONSTRATE CO-EXISTANCE WITH wxWINDOWS ***
+//
+// This sample pops up an initial wxWindows frame, with a menu item
+// that allows a new MFC window to be created. Note that CDummyWindow
+// is a class that allows a wxWindows window to be seen as a CWnd
+// for the purposes of specifying a valid main window to the
+// MFC initialisation.
+//
+// You can easily modify this code so that an MFC window pops up
+// initially as the main frame, and allows wxWindows frames to be
+// created subsequently:
+//
+// (1) Make MyApp::OnInit return NULL, not create a window.
+// (2) Restore the MFC code to create a window in InitInstance, and remove
+//     creation of CDummyWindow.
+//
+// IMPORTANT NOTE: to compile this sample, you must first edit
+// wx/src/msw/wx_main.cc, set NOWINMAIN to 1, and remake wxWindows
+// (it only needs to recompile wx_main.cc).
+// This eliminates the duplicate WinMain function which MFC implements.
+
+// For compilers that support precompilation, includes "wx/wx.h".
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+#pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+#include "wx/wx.h"
+#endif
+
+#ifdef new
+#undef new
+#endif
+
+#include "stdafx.h"
+
+#ifdef DrawText
+#undef DrawText
+#endif
+
+#include "resource.h"
+
+#include "mfctest.h"
+
+#include "wx/wx.h"
+
+/////////////////////////////////////////////////////////////////////////////
+
+// theApp:
+// Just creating this application object runs the whole application.
+//
+CTheApp theApp;
+
+// wxWindows elements
+
+// Define a new application type
+class MyApp: public wxApp
+{ public:
+    bool OnInit(void);
+    wxFrame *CreateFrame(void);
+ };
+
+DECLARE_APP(MyApp)
+
+class MyCanvas: public wxScrolledWindow
+{
+  public:
+    MyCanvas(wxWindow *parent, const wxPoint& pos, const wxSize& size);
+    void OnPaint(wxPaintEvent& event);
+    void OnMouseEvent(wxMouseEvent& event);
+DECLARE_EVENT_TABLE()
+};
+
+class MyChild: public wxFrame
+{
+  public:
+    MyCanvas *canvas;
+    MyChild(wxFrame *frame, const wxString& title, const wxPoint& pos, const wxSize& size, const long style);
+    ~MyChild(void);
+    Bool OnClose(void);
+
+    void OnQuit(wxCommandEvent& event);
+    void OnNew(wxCommandEvent& event);
+    void OnActivate(wxActivateEvent& event);
+
+DECLARE_EVENT_TABLE()
+};
+
+// For drawing lines in a canvas
+long xpos = -1;
+long ypos = -1;
+
+// Initialise this in OnInit, not statically
+wxPen *red_pen;
+wxFont *small_font;
+
+// ID for the menu quit command
+#define HELLO_QUIT 1
+#define HELLO_NEW  2
+
+DECLARE_APP(MyApp)
+IMPLEMENT_APP(MyApp)
+
+/////////////////////////////////////////////////////////////////////////////
+
+// CMainWindow constructor:
+// Create the window with the appropriate style, size, menu, etc.
+//
+CMainWindow::CMainWindow()
+{
+	LoadAccelTable( "MainAccelTable" );
+	Create( NULL, "Hello Foundation Application",
+		WS_OVERLAPPEDWINDOW, rectDefault, NULL, "MainMenu" );
+}
+
+// OnPaint:
+// This routine draws the string "Hello, Windows!" in the center of the
+// client area.  It is called whenever Windows sends a WM_PAINT message.
+// Note that creating a CPaintDC automatically does a BeginPaint and
+// an EndPaint call is done when it is destroyed at the end of this
+// function.  CPaintDC's constructor needs the window (this).
+//
+void CMainWindow::OnPaint()
+{
+	CString s = "Hello, Windows!";
+	CPaintDC dc( this );
+	CRect rect;
+
+	GetClientRect( rect );
+	dc.SetTextAlign( TA_BASELINE | TA_CENTER );
+	dc.SetTextColor( ::GetSysColor( COLOR_WINDOWTEXT ) );
+	dc.SetBkMode(TRANSPARENT);
+	dc.TextOut( ( rect.right / 2 ), ( rect.bottom / 2 ),
+				s, s.GetLength() );
+}
+
+// OnAbout:
+// This member function is called when a WM_COMMAND message with an
+// IDM_ABOUT code is received by the CMainWindow class object.  The
+// message map below is responsible for this routing.
+//
+// We create a ClDialog object using the "AboutBox" resource (see
+// hello.rc), and invoke it.
+//
+void CMainWindow::OnAbout()
+{
+	CDialog about( "AboutBox", this );
+	about.DoModal();
+}
+
+void CMainWindow::OnTest()
+{
+  wxMessageBox("This is a wxWindows message box.\nWe're about to create a new wxWindows frame.", "wxWindows", wxOK);
+  wxGetApp().CreateFrame();
+}
+
+// CMainWindow message map:
+// Associate messages with member functions.
+//
+// It is implied that the ON_WM_PAINT macro expects a member function
+// "void OnPaint()".
+//
+// It is implied that members connected with the ON_COMMAND macro
+// receive no arguments and are void of return type, e.g., "void OnAbout()".
+//
+BEGIN_MESSAGE_MAP( CMainWindow, CFrameWnd )
+	//{{AFX_MSG_MAP( CMainWindow )
+	ON_WM_PAINT()
+	ON_COMMAND( IDM_ABOUT, OnAbout )
+	ON_COMMAND( IDM_TEST, OnTest )
+	//}}AFX_MSG_MAP
+END_MESSAGE_MAP()
+
+/////////////////////////////////////////////////////////////////////////////
+// CTheApp
+
+// InitInstance:
+// When any CTheApp object is created, this member function is automatically
+// called.  Any data may be set up at this point.
+//
+// Also, the main window of the application should be created and shown here.
+// Return TRUE if the initialization is successful.
+//
+BOOL CTheApp::InitInstance()
+{
+	TRACE( "HELLO WORLD\n" );
+
+	SetDialogBkColor();     // hook gray dialogs (was default in MFC V1)
+
+    wxEntry((WXHINSTANCE) m_hInstance, (WXHINSTANCE) m_hPrevInstance, m_lpCmdLine, m_nCmdShow, FALSE);
+
+/*
+	m_pMainWnd = new CMainWindow();
+	m_pMainWnd->ShowWindow( m_nCmdShow );
+	m_pMainWnd->UpdateWindow();
+*/
+
+    if (wxTheApp && wxTheApp->GetTopWindow())
+    {
+        m_pMainWnd = new CDummyWindow((HWND) wxTheApp->GetTopWindow()->GetHWND());
+    }
+
+	return TRUE;
+}
+
+int CTheApp::ExitInstance()
+{
+  wxApp::CleanUp();
+
+  return CWinApp::ExitInstance();
+}
+
+// Override this to provide wxWindows message loop
+// compatibility
+
+BOOL CTheApp::PreTranslateMessage(MSG *msg)
+{
+  if (wxTheApp && wxTheApp->ProcessMessage((WXMSG*) msg))
+    return TRUE;
+  else
+    return CWinApp::PreTranslateMessage(msg);
+}
+
+BOOL CTheApp::OnIdle(LONG lCount)
+{
+    if (wxTheApp)
+        return wxTheApp->ProcessIdle();
+    else
+        return FALSE;
+}
+
+/*********************************************************************
+ * wxWindows elements
+ ********************************************************************/
+ 
+bool MyApp::OnInit(void)
+{
+  // Don't exit app when the top level frame is deleted
+//  SetExitOnFrameDelete(FALSE);
+  
+  // Create a red pen
+  red_pen = new wxPen("RED", 3, wxSOLID);
+
+  // Create a small font
+  small_font = new wxFont(10, wxSWISS, wxNORMAL, wxNORMAL);
+
+  wxFrame* frame = CreateFrame();
+  return TRUE;
+}
+
+wxFrame *MyApp::CreateFrame(void)
+{
+      MyChild *subframe = new MyChild(NULL, "Canvas Frame", wxPoint(10, 10), wxSize(300, 300),
+                             wxDEFAULT_FRAME);
+
+      subframe->SetTitle("wxWindows canvas frame");
+
+      // Give it a status line
+      subframe->CreateStatusBar();
+
+      // Make a menubar
+      wxMenu *file_menu = new wxMenu;
+
+      file_menu->Append(HELLO_NEW, "&New MFC Window");
+      file_menu->Append(HELLO_QUIT, "&Close");
+
+      wxMenuBar *menu_bar = new wxMenuBar;
+
+      menu_bar->Append(file_menu, "&File");
+
+      // Associate the menu bar with the frame
+      subframe->SetMenuBar(menu_bar);
+
+      int width, height;
+      subframe->GetClientSize(&width, &height);
+
+      MyCanvas *canvas = new MyCanvas(subframe, wxPoint(0, 0), wxSize(width, height));
+      wxCursor *cursor = new wxCursor(wxCURSOR_PENCIL);
+      canvas->SetCursor(cursor);
+      subframe->canvas = canvas;
+
+      // Give it scrollbars
+//      canvas->SetScrollbars(20, 20, 50, 50, 4, 4);
+
+      subframe->Show(TRUE);
+      // Return the main frame window
+      return subframe;
+}
+
+BEGIN_EVENT_TABLE(MyCanvas, wxScrolledWindow)
+    EVT_PAINT(MyCanvas::OnPaint)
+    EVT_MOUSE_EVENTS(MyCanvas::OnMouseEvent)
+END_EVENT_TABLE()
+
+// Define a constructor for my canvas
+MyCanvas::MyCanvas(wxWindow *parent, const wxPoint& pos, const wxSize& size):
+ wxScrolledWindow(parent, -1, pos, size)
+{
+}
+
+// Define the repainting behaviour
+void MyCanvas::OnPaint(wxPaintEvent& event)
+{
+    wxPaintDC dc(this);
+
+    dc.SetFont(small_font);
+    dc.SetPen(wxGREEN_PEN);
+    dc.DrawLine(0, 0, 200, 200);
+    dc.DrawLine(200, 0, 0, 200);
+
+    dc.SetBrush(wxCYAN_BRUSH);
+    dc.SetPen(wxRED_PEN);
+    dc.DrawRectangle(100, 100, 100, 50);
+    dc.DrawRoundedRectangle(150, 150, 100, 50, 20);
+
+    dc.DrawEllipse(250, 250, 100, 50);
+    dc.DrawSpline(50, 200, 50, 100, 200, 10);
+    dc.DrawLine(50, 230, 200, 230);
+    dc.DrawText("This is a test string", 50, 230);
+}
+
+// This implements a tiny doodling program! Drag the mouse using
+// the left button.
+void MyCanvas::OnMouseEvent(wxMouseEvent& event)
+{
+    wxClientDC dc(this);
+    dc.SetPen(wxBLACK_PEN);
+    long x, y;
+    event.Position(&x, &y);
+    if (xpos > -1 && ypos > -1 && event.Dragging())
+    {
+        dc.DrawLine(xpos, ypos, x, y);
+    }
+    xpos = x;
+    ypos = y;
+}
+
+BEGIN_EVENT_TABLE(MyChild, wxFrame)
+    EVT_MENU(HELLO_QUIT, MyChild::OnQuit)
+    EVT_MENU(HELLO_NEW, MyChild::OnNew)
+    EVT_ACTIVATE(MyChild::OnActivate)
+END_EVENT_TABLE()
+
+MyChild::MyChild(wxFrame *frame, const wxString& title, const wxPoint& pos, const wxSize& size, const long style):
+  wxFrame(frame, -1, title, pos, size, style)
+{
+  canvas = NULL;
+}
+
+MyChild::~MyChild(void)
+{
+}
+
+void MyChild::OnQuit(wxCommandEvent& event)
+{
+    Close(TRUE);
+}
+
+void MyChild::OnNew(wxCommandEvent& event)
+{
+    CMainWindow *mainWin = new CMainWindow();
+    mainWin->ShowWindow( TRUE );
+    mainWin->UpdateWindow();
+}
+ 
+void MyChild::OnActivate(wxActivateEvent& event)
+{
+  if (event.GetActive() && canvas)
+    canvas->SetFocus();
+}
+
+Bool MyChild::OnClose(void)
+{
+  return TRUE;
+}
+
+
+// Dummy MFC window for specifying a valid main window to MFC, using
+// a wxWindows HWND.
+CDummyWindow::CDummyWindow(HWND hWnd):CWnd()
+{
+  Attach(hWnd);
+}
+
+// Don't let the CWnd destructor delete the HWND
+CDummyWindow::~CDummyWindow(void)
+{
+  Detach();
+}
+
diff --git a/samples/mfc/mfctest.def b/samples/mfc/mfctest.def
new file mode 100644
index 0000000000..7c741d1059
--- /dev/null
+++ b/samples/mfc/mfctest.def
@@ -0,0 +1,21 @@
+; hello.def : Declares the module parameters for the application.
+;
+; This is a part of the Microsoft Foundation Classes C++ library.
+; Copyright (C) 1992 Microsoft Corporation
+; All rights reserved.
+;
+; This source code is only intended as a supplement to the
+; Microsoft Foundation Classes Reference and Microsoft
+; WinHelp documentation provided with the library.
+; See these sources for detailed information regarding the
+; Microsoft Foundation Classes product.
+
+NAME         Hello
+DESCRIPTION  'Hello Microsoft Foundation Classes Windows Application'
+
+EXETYPE      WINDOWS
+
+CODE         PRELOAD MOVEABLE DISCARDABLE
+DATA         PRELOAD MOVEABLE MULTIPLE
+
+HEAPSIZE     1024
diff --git a/samples/mfc/mfctest.h b/samples/mfc/mfctest.h
new file mode 100644
index 0000000000..038a08cad2
--- /dev/null
+++ b/samples/mfc/mfctest.h
@@ -0,0 +1,66 @@
+// hello.h : Declares the class interfaces for the application.
+//         Hello is a simple program which consists of a main window
+//         and an "About" dialog which can be invoked by a menu choice.
+//         It is intended to serve as a starting-point for new
+//         applications.
+//
+// This is a part of the Microsoft Foundation Classes C++ library.
+// Copyright (C) 1992 Microsoft Corporation
+// All rights reserved.
+//
+// This source code is only intended as a supplement to the
+// Microsoft Foundation Classes Reference and Microsoft
+// WinHelp documentation provided with the library.
+// See these sources for detailed information regarding the
+// Microsoft Foundation Classes product.
+
+#ifndef __MFCTEST_H__
+#define __MFCTEST_H__
+
+/////////////////////////////////////////////////////////////////////////////
+
+// CMainWindow:
+// See hello.cpp for the code to the member functions and the message map.
+//
+class CMainWindow : public CFrameWnd
+{
+public:
+	CMainWindow();
+
+	//{{AFX_MSG( CMainWindow )
+	afx_msg void OnPaint();
+	afx_msg void OnAbout();
+	afx_msg void OnTest();
+	//}}AFX_MSG
+
+	DECLARE_MESSAGE_MAP()
+};
+
+// A dummy CWnd pointing to a wxWindow's HWND
+class CDummyWindow: public CWnd
+{
+  public:
+    CDummyWindow(HWND hWnd);
+    ~CDummyWindow(void);
+};
+
+/////////////////////////////////////////////////////////////////////////////
+
+// CTheApp:
+// See hello.cpp for the code to the InitInstance member function.
+//
+class CTheApp : public CWinApp
+{
+public:
+	BOOL InitInstance();
+    int ExitInstance();
+
+    // Override this to provide wxWindows message loop
+    // compatibility
+    BOOL PreTranslateMessage(MSG *msg);
+    BOOL OnIdle(LONG lCount);
+};
+
+/////////////////////////////////////////////////////////////////////////////
+
+#endif // __MFCTEST_H__
diff --git a/samples/mfc/mfctest.ico b/samples/mfc/mfctest.ico
new file mode 100644
index 0000000000000000000000000000000000000000..331b675b63ea5c7aebc8502a2b459568cedd7564
GIT binary patch
literal 766
zcmc(cF%H5o3`KttW2G`NcjOoxEl0}@dJV=Npi+6?4xs}hQk~jy`s~C`q=7NdH(6d6
z>CXH>XY`2<x?-gQ`z-|sDJ3T?E?QJ;1?=%@-|e9c|H5o3>$s)6q)1hh-NvO=qy5Co
z`COXnu|8>Zg}pwwJLvWQpL4=z|CL)s`uVx+ykXyP)c3_vA9z%I33Im=o8yxL-kcGw
dBql_1DBSqSBlEx`(MPoWeAkv98#(wac>^wsLdgIC

literal 0
HcmV?d00001

diff --git a/samples/mfc/mfctest.rc b/samples/mfc/mfctest.rc
new file mode 100644
index 0000000000..7c5da8b070
--- /dev/null
+++ b/samples/mfc/mfctest.rc
@@ -0,0 +1,108 @@
+//Microsoft App Studio generated resource script.
+//
+#include "wx/msw/wx.rc"
+#include "resource.h"
+
+#define APSTUDIO_READONLY_SYMBOLS
+/////////////////////////////////////////////////////////////////////////
+//
+// Generated from the TEXTINCLUDE 2 resource.
+//
+#include "afxres.h"
+
+
+/////////////////////////////////////////////////////////////////////////////////////
+#undef APSTUDIO_READONLY_SYMBOLS
+
+
+//////////////////////////////////////////////////////////////////////////////
+//
+// Icon
+//
+
+AFX_IDI_STD_FRAME       ICON    DISCARDABLE     "MFCTEST.ICO"
+
+//////////////////////////////////////////////////////////////////////////////
+//
+// Menu
+//
+
+MAINMENU MENU DISCARDABLE 
+BEGIN
+    POPUP "&File"
+    BEGIN
+        MENUITEM "&Test wxWindows",         IDM_TEST
+    END
+    POPUP "&Help"
+    BEGIN
+        MENUITEM "&About Hello...\tF1",         IDM_ABOUT
+    END
+END
+
+
+//////////////////////////////////////////////////////////////////////////////
+//
+// Accelerator
+//
+
+MAINACCELTABLE ACCELERATORS MOVEABLE PURE 
+BEGIN
+    VK_F1,          IDM_ABOUT,              VIRTKEY 
+END
+
+
+//////////////////////////////////////////////////////////////////////////////
+//
+// Dialog
+//
+
+ABOUTBOX DIALOG DISCARDABLE  34, 22, 144, 75
+STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
+CAPTION "About Hello"
+FONT 8, "Helv"
+BEGIN
+    CTEXT           "Microsoft Windows",IDC_STATIC,0,5,144,8
+    CTEXT           "Microsoft Foundation Classes",IDC_STATIC,0,14,144,8
+    CTEXT           "Hello, Windows!",IDC_STATIC,0,23,144,8
+    CTEXT           "Version 2.0",IDC_STATIC,0,36,144,8
+    DEFPUSHBUTTON   "OK",IDOK,56,53,32,14,WS_GROUP
+END
+
+#ifdef APSTUDIO_INVOKED
+//////////////////////////////////////////////////////////////////////////////
+//
+// TEXTINCLUDE
+//
+
+1 TEXTINCLUDE DISCARDABLE 
+BEGIN
+    "resource.h\0"
+END
+
+2 TEXTINCLUDE DISCARDABLE 
+BEGIN
+    "#include ""afxres.h""\r\n"
+    "\r\n"
+    "\0"
+END
+
+3 TEXTINCLUDE DISCARDABLE 
+BEGIN
+    "\r\n"
+    "\0"
+END
+
+/////////////////////////////////////////////////////////////////////////////////////
+#endif    // APSTUDIO_INVOKED
+
+
+#ifndef APSTUDIO_INVOKED
+////////////////////////////////////////////////////////////////////////////////
+//
+// Generated from the TEXTINCLUDE 3 resource.
+//
+
+
+/////////////////////////////////////////////////////////////////////////////////////
+#endif    // not APSTUDIO_INVOKED
+
diff --git a/samples/mfc/resource.h b/samples/mfc/resource.h
new file mode 100644
index 0000000000..e20ad76cbb
--- /dev/null
+++ b/samples/mfc/resource.h
@@ -0,0 +1,18 @@
+//{{NO_DEPENDENCIES}}
+// App Studio generated include file.
+// Used by HELLO.RC
+//
+#define IDM_ABOUT                       100
+#define IDM_TEST                        101
+
+// Next default values for new objects
+// 
+#ifdef APSTUDIO_INVOKED
+#ifndef APSTUDIO_READONLY_SYMBOLS
+
+#define _APS_NEXT_RESOURCE_VALUE        110
+#define _APS_NEXT_COMMAND_VALUE         32768
+#define _APS_NEXT_CONTROL_VALUE         1000
+#define _APS_NEXT_SYMED_VALUE           112
+#endif
+#endif
diff --git a/samples/mfc/stdafx.h b/samples/mfc/stdafx.h
new file mode 100644
index 0000000000..5b9f153634
--- /dev/null
+++ b/samples/mfc/stdafx.h
@@ -0,0 +1,12 @@
+// This is a part of the Microsoft Foundation Classes C++ library.
+// Copyright (C) 1992 Microsoft Corporation
+// All rights reserved.
+//
+// This source code is only intended as a supplement to the
+// Microsoft Foundation Classes Reference and Microsoft
+// WinHelp documentation provided with the library.
+// See these sources for detailed information regarding the
+// Microsoft Foundation Classes product.
+
+
+#include <afxwin.h>
diff --git a/samples/nativdlg/aiai.ico b/samples/nativdlg/aiai.ico
new file mode 100644
index 0000000000000000000000000000000000000000..a3db6563cc0b9f4588e1e994fe54b90a3cb1d6c1
GIT binary patch
literal 766
zcmc(bJ930T3`Bcft}@v=+L+MC@X_W5#I6lE$3$=(hlEfB<Ja@?LOIyb0!^!t)JP*;
zc>4Zbw(l3|27cf@{)u1o%88L{R;n8d60briz)7fio<S#4ewC6VoX4NcpV>a{V~VK)
z)$t4e1%j>c0*T7ZEBuvb0Ndch+2BCx7U^mZHa?iIh11ZPGV>8*oPzc{HmcjEM7U^(
z*rd)gSRm_`KJo;dxt={X3#3|q&kYE;ul$En1WJC3UOX%3ev8=<z}j41;VP{UzUs~U
s)wx~DuB_~?Y=Qe|v5`BV=<&%~$Nt1hCmx0~Ul2L;AGObMz1)9;A6NK_vj6}9

literal 0
HcmV?d00001

diff --git a/samples/nativdlg/dialog1.rc b/samples/nativdlg/dialog1.rc
new file mode 100644
index 0000000000..412338aaa1
--- /dev/null
+++ b/samples/nativdlg/dialog1.rc
@@ -0,0 +1,142 @@
+//Microsoft Developer Studio generated resource script.
+//
+
+#ifndef __WINDOWS__
+#define __WINDOWS__
+#endif
+
+#ifndef __WIN32__
+#define __WIN32__
+#endif
+
+#ifndef __WIN95__
+#define __WIN95__
+#endif
+
+#ifdef __MINGW32__
+#define wxID_OK                 5100
+#define wxID_CANCEL             5101
+#define wxID_APPLY              5102
+#define wxID_YES                5103
+#define wxID_NO                 5104
+/* #include <wx/msw/gnuwin32/winresrc.h> */
+#else
+#include <wx/defs.h>
+/* #include <windows.h> */
+#endif
+
+#include "resource.h"
+
+#ifndef __MINGW32__
+#include <commctrl.h>
+#endif
+
+#define APSTUDIO_READONLY_SYMBOLS
+/////////////////////////////////////////////////////////////////////////////
+//
+// Generated from the TEXTINCLUDE 2 resource.
+//
+// #include "afxres.h"
+
+/////////////////////////////////////////////////////////////////////////////
+#undef APSTUDIO_READONLY_SYMBOLS
+
+/////////////////////////////////////////////////////////////////////////////
+// English (U.K.) resources
+
+#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_ENG)
+#ifdef _WIN32
+LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_UK
+#pragma code_page(1252)
+#endif //_WIN32
+
+/////////////////////////////////////////////////////////////////////////////
+//
+// Dialog
+//
+
+dialog1 DIALOG DISCARDABLE  0, 0, 271, 172
+STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
+CAPTION "Test Dialog"
+FONT 8, "MS Sans Serif"
+BEGIN
+    DEFPUSHBUTTON   "OK",wxID_OK,214,7,50,14
+    PUSHBUTTON      "Cancel",wxID_CANCEL,214,24,50,14
+    GROUPBOX        "wxStaticBox",IDC_STATIC,7,7,198,158
+    EDITTEXT        IDC_EDIT1,64,23,125,14,ES_AUTOHSCROLL
+    LTEXT           "wxStaticText",IDC_STATIC,13,25,42,8
+    CONTROL         "wxCheckBox",IDC_CHECK1,"Button",BS_AUTOCHECKBOX | 
+                    WS_TABSTOP,14,47,57,10
+    COMBOBOX        IDC_COMBO1,83,46,48,30,CBS_DROPDOWN | CBS_SORT | 
+                    WS_VSCROLL | WS_TABSTOP
+    CONTROL         "wxRadioButton",IDC_RADIO1,"Button",BS_AUTORADIOBUTTON,
+                    141,47,64,10
+    LISTBOX         IDC_LIST1,14,69,86,40,LBS_SORT | LBS_NOINTEGRALHEIGHT | 
+                    WS_VSCROLL | WS_TABSTOP
+    SCROLLBAR       IDC_SCROLLBAR1,111,71,76,11
+    CONTROL         "Slider1",IDC_SLIDER1,"msctls_trackbar32",TBS_BOTH | 
+                    TBS_NOTICKS | WS_TABSTOP,10,116,100,15
+    CONTROL         "Spin1",IDC_SPIN1,"msctls_updown32",UDS_ARROWKEYS,111,90,
+                    10,14
+END
+
+
+/////////////////////////////////////////////////////////////////////////////
+//
+// DESIGNINFO
+//
+
+#ifdef APSTUDIO_INVOKED
+GUIDELINES DESIGNINFO DISCARDABLE 
+BEGIN
+    dialog1, DIALOG
+    BEGIN
+        LEFTMARGIN, 7
+        RIGHTMARGIN, 264
+        TOPMARGIN, 7
+        BOTTOMMARGIN, 165
+    END
+END
+#endif    // APSTUDIO_INVOKED
+
+
+#ifdef APSTUDIO_INVOKED
+/////////////////////////////////////////////////////////////////////////////
+//
+// TEXTINCLUDE
+//
+
+1 TEXTINCLUDE DISCARDABLE 
+BEGIN
+    "resource.h\0"
+END
+
+2 TEXTINCLUDE DISCARDABLE 
+BEGIN
+    "#include ""afxres.h""\r\n"
+    "\0"
+END
+
+3 TEXTINCLUDE DISCARDABLE 
+BEGIN
+    "\r\n"
+    "\0"
+END
+
+#endif    // APSTUDIO_INVOKED
+
+#endif    // English (U.K.) resources
+/////////////////////////////////////////////////////////////////////////////
+
+
+
+#ifndef APSTUDIO_INVOKED
+/////////////////////////////////////////////////////////////////////////////
+//
+// Generated from the TEXTINCLUDE 3 resource.
+//
+
+
+/////////////////////////////////////////////////////////////////////////////
+#endif    // not APSTUDIO_INVOKED
+
diff --git a/samples/nativdlg/makefile.b32 b/samples/nativdlg/makefile.b32
new file mode 100644
index 0000000000..7c55473a6a
--- /dev/null
+++ b/samples/nativdlg/makefile.b32
@@ -0,0 +1,64 @@
+#
+# File:		makefile.b32
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds 32bit nativdlg example.
+
+# WXWIN and BCCDIR are set by parent make
+
+WXDIR = $(WXWIN)
+!include $(WXDIR)\src\makeb32.env
+
+WXLIBDIR = $(WXDIR)\lib
+WXLIB = $(WXLIBDIR)\wx32.lib
+LIBS=$(WXLIB) cw32 import32
+
+TARGET=nativdlg
+
+!if "$(FINAL)" == "0"
+LINKFLAGS=/v /Tpe /L$(WXLIBDIR);$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS= -v
+!else
+LINKFLAGS=/Tpe /L$(WXLIBDIR);$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS =
+!endif
+CPPFLAGS=$(DEBUG_FLAGS) $(OPT) @$(CFG)
+
+OBJECTS = nativdlg.obj
+
+$(TARGET).exe:	$(OBJECTS) $(TARGET).def $(TARGET).res
+  tlink32 $(LINKFLAGS) @&&!
+c0w32.obj $(OBJECTS)
+$(TARGET)
+nul
+$(LIBS)
+$(TARGET).def
+!
+        brc32 -K $(TARGET).res
+
+.$(SRCSUFF).obj:
+	bcc32 $(CPPFLAGS) -c {$< }
+
+.c.obj:
+	bcc32 $(CPPFLAGS) -P- -c {$< }
+
+nativdlg.obj:	nativdlg.$(SRCSUFF) nativdlg.h # dialog1.wxr
+
+$(TARGET).res :      $(TARGET).rc $(WXDIR)\include\wx\msw\wx.rc
+    brc32 -r /D__WINDOWS__ /i$(BCCDIR)\include /i$(WXDIR)\include $(TARGET)
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.rws
+
+
diff --git a/samples/nativdlg/makefile.bcc b/samples/nativdlg/makefile.bcc
new file mode 100644
index 0000000000..19ad9c2a44
--- /dev/null
+++ b/samples/nativdlg/makefile.bcc
@@ -0,0 +1,74 @@
+#
+# File:		makefile.bcc
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds resource example (DOS).
+
+!if "$(BCCDIR)" == ""
+!error You must define the BCCDIR variable in autoexec.bat, e.g. BCCDIR=d:\bc4
+!endif
+
+!if "$(WXWIN)" == ""
+!error You must define the WXWIN variable in autoexec.bat, e.g. WXWIN=c:\wx
+!endif
+
+WXDIR = $(WXWIN)
+THISDIR = $(WXDIR)\samples\resource
+WXLIB = $(WXDIR)\lib\wx.lib
+
+LIBS=$(WXLIB) mathwl cwl import
+INC=-I$(WXDIR)\include\base -I$(WXDIR)\include\msw
+CFG=$(WXDIR)\src\wxwin.cfg
+
+!ifndef FINAL
+FINAL=0
+!endif
+
+!if "$(FINAL)" == "0"
+LINKFLAGS=/v/Vt /Twe /L$(WXDIR)\lib;$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS= -v
+!else
+LINKFLAGS=/Twe /L$(WXDIR)\lib;$(BCCDIR)\lib
+OPT = -O2
+DEBUG_FLAGS =
+!endif
+CPPFLAGS=$(DEBUG_FLAGS) $(OPT) @$(CFG)
+
+HEADERS = resource.h
+SOURCES = resource.cc
+OBJECTS = resource.obj
+
+resource:    resource.exe
+
+all:    resource.exe
+
+resource.exe:      $(WXLIB) resource.obj resource.def resource.res
+        tlink $(LINKFLAGS) @&&!
+c0wl.obj resource.obj
+resource
+nul
+$(LIBS)
+resource.def
+!
+        rc -30 -K resource.res
+
+.cc.obj:
+	bcc $(CPPFLAGS) -c {$< }
+
+resource.obj:      resource.cc
+
+resource.res :      resource.rc $(WXDIR)\include\msw\wx.rc
+    rc -r /i$(BCCDIR)\include /i$(WXDIR)\include\msw /i$(WXDIR)\contrib\fafa resource
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.rws
diff --git a/samples/nativdlg/makefile.dos b/samples/nativdlg/makefile.dos
new file mode 100644
index 0000000000..6096ca810c
--- /dev/null
+++ b/samples/nativdlg/makefile.dos
@@ -0,0 +1,86 @@
+#
+# File:		makefile.dos
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds resource example (DOS).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info.
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+
+!include $(WXDIR)\src\makemsc.env
+
+THISDIR = $(WXDIR)\samples\resource
+WXLIB = $(WXDIR)\lib\wx.lib
+LIBS=$(WXLIB) oldnames libw llibcew commdlg ddeml shell mmsystem
+INC=-I$(WXDIR)\include\base -I$(WXDIR)\include\msw
+DUMMY=$(WXDIR)\src\msw\dummy.obj
+
+# Set this to nothing if using MS C++ 7
+ZOPTION=/Z7
+
+!ifndef FINAL
+FINAL=0
+!endif
+
+PRECOMP = /YuWX_PREC.H /Fp$(WXDIR)\src\msw\wx.pch
+
+!if "$(FINAL)" == "0"
+CPPFLAGS=/AL /W3 /Zi $(ZOPTION) /G2sw /Od $(INC) $(PRECOMP) /Dwx_msw
+LINKFLAGS=/NOD /CO /ONERROR:NOEXE /SEG:256
+!else
+CPPFLAGS=/AL /W3 /G2sw $(INC) /Ox $(PRECOMP) /Dwx_msw
+LINKFLAGS=/NOD /ONERROR:NOEXE /SEG:256
+!endif
+
+HEADERS = resource.h
+SOURCES = resource.$(SRCSUFF)
+OBJECTS = resource.obj
+
+resource:    resource.exe
+
+all:    wx resource.exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.dos FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.dos clean
+        cd $(THISDIR)
+
+
+resource.exe:      $(DUMMY) $(WXLIB) resource.obj resource.def resource.res
+        link $(LINKFLAGS) @<<
+$(DUMMY) resource.obj,
+resource,
+NUL,
+$(LIBS),
+resource.def
+;
+<<
+        rc -31 -K resource.res
+
+resource.obj:      resource.h resource.$(SRCSUFF) dialog1.wxr $(DUMMY)
+        cl @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+resource.res :      resource.rc $(WXDIR)\include\msw\wx.rc
+    rc -r /i$(WXDIR)\include\msw /i$(WXDIR)\contrib\fafa resource
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
diff --git a/samples/nativdlg/makefile.g95 b/samples/nativdlg/makefile.g95
new file mode 100644
index 0000000000..018f915f18
--- /dev/null
+++ b/samples/nativdlg/makefile.g95
@@ -0,0 +1,36 @@
+#
+# File:		makefile.g95
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile for nativdlg example (UNIX).
+
+WXDIR = ../..
+
+# All common UNIX compiler flags and options are now in
+# this central makefile.
+include $(WXDIR)/src/makeg95.env
+
+OBJECTS=$(OBJDIR)/nativdlg.$(OBJSUFF) $(OBJDIR)/nativdlg_resources.$(OBJSUFF)
+
+all:	$(OBJDIR) nativdlg$(GUISUFFIX)
+
+$(OBJDIR):
+	mkdir $(OBJDIR)
+
+$(OBJDIR)/nativdlg.$(OBJSUFF):        nativdlg.$(SRCSUFF) nativdlg.h
+	$(CC) -c $(CPPFLAGS) -o $@ nativdlg.$(SRCSUFF)
+
+nativdlg$(GUISUFFIX): $(OBJECTS) $(WXLIB)
+	$(CC) $(LDFLAGS) -o nativdlg$(GUISUFFIX)$(EXESUFF) $(OBJECTS) $(LDLIBS)
+
+$(OBJDIR)/nativdlg_resources.o:  nativdlg.rc
+	$(RESCOMP) -i nativdlg.rc -o $(OBJDIR)/nativdlg_resources.o $(RESFLAGS)
+
+clean:
+	rm -f $(OBJECTS) nativdlg$(GUISUFFIX).exe core *.rsc *.res
+
diff --git a/samples/nativdlg/makefile.nt b/samples/nativdlg/makefile.nt
new file mode 100644
index 0000000000..08261497f8
--- /dev/null
+++ b/samples/nativdlg/makefile.nt
@@ -0,0 +1,63 @@
+#
+# File:		makefile.nt
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds nativdlg example (MS VC++).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+
+!include $(WXDIR)\src\ntwxwin.mak
+
+THISDIR = $(WXDIR)\samples\nativdlg
+PROGRAM=nativdlg
+
+OBJECTS = $(PROGRAM).obj
+
+$(PROGRAM):    $(PROGRAM).exe
+
+all:    wx $(PROGRAM).exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt clean
+        cd $(THISDIR)
+
+$(PROGRAM).exe:      $(DUMMYOBJ) $(WXLIB) $(OBJECTS) $(PROGRAM).res
+	$(link) @<<
+-out:$(PROGRAM).exe
+$(LINKFLAGS)
+$(DUMMYOBJ) $(OBJECTS) $(PROGRAM).res
+$(LIBS)
+<<
+
+
+$(PROGRAM).obj:      $(PROGRAM).h $(PROGRAM).$(SRCSUFF) $(DUMMYOBJ)
+        $(cc) @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+$(PROGRAM).res :      $(PROGRAM).rc $(WXDIR)\include\wx\msw\wx.rc dialog1.rc
+    $(rc) -r /i$(WXDIR)\include /D__WINDOWS__ -fo$@ $(PROGRAM).rc
+
+
+clean:
+        -erase *.obj
+        -erase *.sbr
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.pdb
+
diff --git a/samples/nativdlg/makefile.sc b/samples/nativdlg/makefile.sc
new file mode 100644
index 0000000000..235c8f8bc1
--- /dev/null
+++ b/samples/nativdlg/makefile.sc
@@ -0,0 +1,35 @@
+# Symantec C++ makefile for hello example
+# NOTE that peripheral libraries are now dealt in main wxWindows makefile.
+
+WXDIR = $(WXWIN)
+WXLIB = $(WXDIR)\lib\wx.lib
+INCDIR = $(WXDIR)\include
+MSWINC = $(INCDIR)\msw
+BASEINC = $(INCDIR)\base
+
+CC=sc
+RC=rc
+CFLAGS = -o -ml -W -Dwx_msw
+LDFLAGS = -ml -W
+
+INCLUDE=$(BASEINC);$(MSWINC)
+
+LIBS=$(WXLIB) libw.lib commdlg.lib shell.lib
+
+.cc.obj:
+	*$(CC) -c $(CFLAGS) -I$(INCLUDE) $<
+
+.rc.res:
+	*$(RC) -r -I$(INCLUDE) $<
+
+hello.exe: hello.obj hello.def hello.res
+	*$(CC) $(LDFLAGS) -o$@ hello.obj hello.def $(LIBS)
+        *$(RC) -k hello.res
+
+clean:
+        -del *.obj
+	-del *.exe
+	-del *.res
+	-del *.map
+	-del *.rws
+
diff --git a/samples/nativdlg/makefile.unx b/samples/nativdlg/makefile.unx
new file mode 100644
index 0000000000..1967b5e242
--- /dev/null
+++ b/samples/nativdlg/makefile.unx
@@ -0,0 +1,76 @@
+#
+# File:		makefile.unx
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile for resource example (UNIX).
+
+WXDIR = ../..
+
+# All common UNIX compiler flags and options are now in
+# this central makefile.
+include $(WXDIR)/src/make.env
+
+OBJECTS=$(OBJDIR)/resource.$(OBJSUFF)
+
+.SUFFIXES:
+
+all:	$(OBJDIR) resource$(GUISUFFIX)
+
+wxmotif:
+	cd $(WXDIR)/src/x; $(MAKE) -f makefile.unx motif
+
+wxxview:
+	cd $(WXDIR)/src/x; $(MAKE) -f makefile.unx xview
+
+wxhp:
+	cd $(WXDIR)/src/x; $(MAKE) -f makefile.unx hp
+
+# For SGI, include -lPW on your LDLIBS
+motif:	wxmotif
+	$(MAKE) -f makefile.unx all GUISUFFIX=_motif GUI=-Dwx_motif GUISUFFIX=_motif OPT='$(OPT)' LDLIBS='$(MOTIFLDLIBS)' WXLIB=$(WXDIR)/lib/libwx_motif.a OPTIONS='$(OPTIONS)' DEBUG='$(DEBUG)' WARN='$(WARN)' XLIB='$(XLIB)' XINCLUDE='$(XINCLUDE)' XVIEW_LINK=
+
+xview:	wxxview
+	$(MAKE) -f makefile.unx GUI=-Dwx_xview GUISUFFIX=_ol CC=$(CC) OPTIONS='$(OPTIONS)' DEBUG='$(DEBUG)' WARN='$(WARN)' XLIB='$(XLIB)' XINCLUDE='$(XINCLUDE)' LDLIBS='$(XVIEWLDLIBS)'
+
+hp:	wxhp
+	$(MAKE) -f makefile.unx GUI=-Dwx_motif GUISUFFIX=_hp CC=CC OPT='' DEBUG='$(DEBUG)' WARN='-w' \
+           XINCLUDE='$(HPXINCLUDE)' \
+           XLIB='$(HPXLIB)' \
+           XVIEW_LINK='' \
+           LDLIBS='$(HPLDLIBS)'
+
+$(OBJDIR):
+	mkdir $(OBJDIR)
+
+resource$(GUISUFFIX): $(OBJDIR)/resource.$(OBJSUFF) $(WXLIB)
+	$(CC) $(LDFLAGS) -o resource$(GUISUFFIX) $(OBJDIR)/resource.$(OBJSUFF) $(XVIEW_LINK) $(LDLIBS)
+
+$(OBJDIR)/resource.$(OBJSUFF):        resource.$(SRCSUFF) resource.h
+	$(CC) -c $(CPPFLAGS) -o $@ resource.$(SRCSUFF)
+
+clean_motif:
+	$(MAKE) -f makefile.unx GUISUFFIX=_motif cleanany
+
+clean_ol:
+	$(MAKE) -f makefile.unx GUISUFFIX=_ol cleanany
+
+clean_hp:
+	$(MAKE) -f makefile.unx GUISUFFIX=_hp cleanany
+
+cleanany:
+	rm -f $(OBJECTS) resource$(GUISUFFIX) core
+
+wxclean_ol:
+	cd $(WXDIR)/src/x; $(MAKE) -f makefile.unx clean_ol
+
+wxclean_motif:
+	cd $(WXDIR)/src/x; $(MAKE) -f makefile.unx clean_motif
+
+wxclean_hp:
+	cd $(WXDIR)/src/x; $(MAKE) -f makefile.unx clean_hp
+
diff --git a/samples/nativdlg/makefile.vms b/samples/nativdlg/makefile.vms
new file mode 100644
index 0000000000..1ef109fbeb
--- /dev/null
+++ b/samples/nativdlg/makefile.vms
@@ -0,0 +1,38 @@
+#************************************************************************
+# Makefile for HELLO under VMS
+# by Stefan Hammes
+# (incomplete) update history:
+# 11.04.95
+#************************************************************************
+
+#************************************************************************
+# Definition section
+# (cave: definitions and includes must begin with ',')
+#************************************************************************
+
+APPOPTS = 
+APPDEFS = 
+APPINCS = 
+
+#************************************************************************
+# Module section
+#************************************************************************
+
+# Name of main module
+MAIN = hello
+
+# Object modules of the application.
+OBJS = hello.obj
+
+.include [--.src]makevms.env
+
+# main dependency
+$(MAIN).exe : $(MAIN).$(OBJ)
+    $(LINK) $(LINKFLAGS) /exec=$(MAIN).exe $(MAIN).$(OBJ),$(WXLIB)/lib,$(OPTSFILE)/option
+    - purge *.exe
+
+#************************************************************************
+# Header file depedencies following
+#************************************************************************
+hello.obj : hello.cc hello.h
+
diff --git a/samples/nativdlg/makefile.wat b/samples/nativdlg/makefile.wat
new file mode 100644
index 0000000000..0ad7f98a89
--- /dev/null
+++ b/samples/nativdlg/makefile.wat
@@ -0,0 +1,42 @@
+#
+# Makefile for WATCOM
+#
+# Created by D.Chubraev, chubraev@iem.ee.ethz.ch
+# 8 Nov 1994
+#
+
+WXDIR = ..\.. 
+
+!include $(WXDIR)\src\makewat.env
+
+WXLIB = $(WXDIR)\lib
+NAME = hello
+LNK = $(name).lnk
+OBJS = $(name).obj 
+
+PRECOMP=
+
+all:    $(name).exe
+
+$(name).exe : $(OBJS) $(name).res $(LNK) $(WXLIB)\wx$(LEVEL).lib
+    wlink @$(LNK)
+    $(BINDCOMMAND) $(name).res
+
+$(name).res :      $(name).rc $(WXDIR)\include\msw\wx.rc
+     $(RC) $(RESFLAGS1) $(name).rc
+
+$(LNK) : makefile.wat
+    %create $(LNK)
+    @%append $(LNK) debug all
+    @%append $(LNK) system $(LINKOPTION)
+    @%append $(LNK) $(MINDATA)
+    @%append $(LNK) $(MAXDATA)
+    @%append $(LNK) $(STACK)
+    @%append $(LNK) name $(name)
+    @%append $(LNK) file $(WXLIB)\wx$(LEVEL).lib
+    @for %i in ($(EXTRALIBS)) do @%append $(LNK) file %i
+    @for %i in ($(OBJS)) do @%append $(LNK) file %i
+
+clean:   .SYMBOLIC
+    -erase *.obj *.bak *.err *.pch *.lib *.lnk *.res *.exe *.rex
+
diff --git a/samples/nativdlg/nativdlg.cpp b/samples/nativdlg/nativdlg.cpp
new file mode 100644
index 0000000000..32d24f893c
--- /dev/null
+++ b/samples/nativdlg/nativdlg.cpp
@@ -0,0 +1,130 @@
+/////////////////////////////////////////////////////////////////////////////
+// Name:        nativdlg.cpp
+// Purpose:     Native Windows dialog sample
+// Author:      Julian Smart
+// Modified by:
+// Created:     04/01/98
+// RCS-ID:      $Id$
+// Copyright:   (c) Julian Smart and Markus Holzem
+// Licence:   	wxWindows license
+/////////////////////////////////////////////////////////////////////////////
+
+#ifdef __GNUG__
+#pragma implementation
+#endif
+
+// For compilers that support precompilation, includes "wx/wx.h".
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+#pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+#include "wx/wx.h"
+#endif
+
+#include "wx/resource.h"
+
+#include <ctype.h>
+#include "nativdlg.h"
+#include "resource.h"
+
+// Declare two frames
+MyFrame   *frame = NULL;
+
+IMPLEMENT_APP(MyApp)
+
+// Testing of ressources
+MyApp::MyApp()
+{
+}
+
+bool MyApp::OnInit(void)
+{
+  // Create the main frame window
+  frame = new MyFrame(NULL, -1, "wxWindows Native Dialog Sample", wxPoint(0, 0), wxSize(300, 250));
+
+  // Give it a status line
+  frame->CreateStatusBar(2);
+
+  // Make a menubar
+  wxMenu *file_menu = new wxMenu;
+
+  file_menu->Append(RESOURCE_TEST1, "&Dialog box test",                "Test dialog box resource");
+  file_menu->Append(RESOURCE_QUIT, "E&xit",                "Quit program");
+
+  wxMenuBar *menu_bar = new wxMenuBar;
+
+  menu_bar->Append(file_menu, "&File");
+
+  // Associate the menu bar with the frame
+  frame->SetMenuBar(menu_bar);
+
+  // Make a panel
+  frame->panel = new wxWindow(frame, -1, wxPoint(0, 0), wxSize(400, 400), 0, "MyMainFrame");
+  frame->Show(TRUE);
+
+  // Return the main frame window
+  SetTopWindow(frame);
+
+  return TRUE;
+}
+
+BEGIN_EVENT_TABLE(MyFrame, wxFrame)
+	EVT_MENU(RESOURCE_QUIT, MyFrame::OnQuit)
+	EVT_MENU(RESOURCE_TEST1, MyFrame::OnTest1)
+END_EVENT_TABLE()
+
+// Define my frame constructor
+MyFrame::MyFrame(wxWindow *parent, const wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size):
+  wxFrame(parent, id, title, pos, size)
+{
+  panel = NULL;
+}
+
+void MyFrame::OnQuit(wxCommandEvent& event)
+{
+	Close(TRUE);
+}
+
+void MyFrame::OnTest1(wxCommandEvent& event)
+{
+      MyDialog *dialog = new MyDialog;
+      if (dialog->LoadNativeDialog(this, dialog1))
+      {
+/*
+        wxTextCtrl *text = (wxTextCtrl *)wxFindWindowByName("multitext3", dialog);
+        if (text)
+          text->SetValue("wxWindows resource demo");
+*/
+        dialog->SetModal(TRUE);
+        dialog->ShowModal();
+      }
+      dialog->Close(TRUE);
+}
+
+bool MyFrame::OnClose(void)
+{
+  Show(FALSE);
+
+  return TRUE;
+}
+
+BEGIN_EVENT_TABLE(MyDialog, wxDialog)
+	EVT_BUTTON(wxID_OK, MyDialog::OnOk)
+	EVT_BUTTON(wxID_CANCEL, MyDialog::OnCancel)
+END_EVENT_TABLE()
+
+
+void MyDialog::OnOk(wxCommandEvent& event)
+{
+  EndModal(wxID_OK);
+}
+
+void MyDialog::OnCancel(wxCommandEvent& event)
+{
+  EndModal(wxID_CANCEL);
+}
+
+
diff --git a/samples/nativdlg/nativdlg.def b/samples/nativdlg/nativdlg.def
new file mode 100644
index 0000000000..49791b5e6c
--- /dev/null
+++ b/samples/nativdlg/nativdlg.def
@@ -0,0 +1,9 @@
+NAME         Resource
+DESCRIPTION  'Resource'
+EXETYPE      WINDOWS
+STUB         'WINSTUB.EXE'
+CODE         PRELOAD MOVEABLE DISCARDABLE
+DATA         PRELOAD MOVEABLE MULTIPLE
+HEAPSIZE     1024
+STACKSIZE    16192
+
diff --git a/samples/nativdlg/nativdlg.h b/samples/nativdlg/nativdlg.h
new file mode 100644
index 0000000000..25688ea5fc
--- /dev/null
+++ b/samples/nativdlg/nativdlg.h
@@ -0,0 +1,47 @@
+/////////////////////////////////////////////////////////////////////////////
+// Name:        nativdlg.h
+// Purpose:     Native Windows dialog sample
+// Author:      Julian Smart
+// Modified by:
+// Created:     04/01/98
+// RCS-ID:      $Id$
+// Copyright:   (c) Julian Smart and Markus Holzem
+// Licence:   	wxWindows license
+/////////////////////////////////////////////////////////////////////////////
+
+#ifdef __GNUG__
+#pragma interface
+#endif
+
+// Define a new application
+class MyApp: public wxApp
+{
+  public:
+    MyApp(void) ;
+    bool OnInit(void);
+};
+
+class MyFrame: public wxFrame
+{
+  public:
+    wxWindow *panel;
+    MyFrame(wxWindow *parent, const wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size);
+    bool OnClose(void);
+    void OnQuit(wxCommandEvent& event);
+    void OnTest1(wxCommandEvent& event);
+
+ DECLARE_EVENT_TABLE()
+};
+
+class MyDialog : public wxDialog
+{
+  public:
+    void OnOk(wxCommandEvent& event);
+    void OnCancel(wxCommandEvent& event);
+
+ DECLARE_EVENT_TABLE()
+};
+
+#define RESOURCE_QUIT       4
+#define RESOURCE_TEST1      2
+
diff --git a/samples/nativdlg/nativdlg.rc b/samples/nativdlg/nativdlg.rc
new file mode 100644
index 0000000000..db18d163f2
--- /dev/null
+++ b/samples/nativdlg/nativdlg.rc
@@ -0,0 +1,4 @@
+#include "wx/msw/wx.rc"
+
+#include "dialog1.rc"
+
diff --git a/samples/nativdlg/resource.h b/samples/nativdlg/resource.h
new file mode 100644
index 0000000000..a71bf8475c
--- /dev/null
+++ b/samples/nativdlg/resource.h
@@ -0,0 +1,25 @@
+//{{NO_DEPENDENCIES}}
+// Microsoft Developer Studio generated include file.
+// Used by dialog1.rc
+//
+#define dialog1                         101
+#define IDC_EDIT1                       1000
+#define IDC_CHECK1                      1001
+#define IDC_COMBO1                      1003
+#define IDC_RADIO1                      1005
+#define IDC_LIST1                       1006
+#define IDC_SCROLLBAR1                  1007
+#define IDC_SLIDER1                     1008
+#define IDC_SPIN1                       1009
+#define IDC_STATIC                      -1
+
+// Next default values for new objects
+// 
+#ifdef APSTUDIO_INVOKED
+#ifndef APSTUDIO_READONLY_SYMBOLS
+#define _APS_NEXT_RESOURCE_VALUE        102
+#define _APS_NEXT_COMMAND_VALUE         40001
+#define _APS_NEXT_CONTROL_VALUE         1010
+#define _APS_NEXT_SYMED_VALUE           101
+#endif
+#endif
diff --git a/samples/ownerdrw/bell.bmp b/samples/ownerdrw/bell.bmp
new file mode 100644
index 0000000000000000000000000000000000000000..279b827162f2b745c005fc802938a84f0ce5890a
GIT binary patch
literal 370
zcmb7<F$%*l3`KvSkPEbT=sCLgE~Z0e=n!umbD#|Ntx`xq{gM+;p%7X6en>*HZ}&$B
zw<q<=I5RGc4ks$`b={K$(2-KTs6>=fcw0f;p=!k7u@ps`;V%cT)}F?J!_0&p#!2&%
vld<$VEqU&p<3Ns5`Nf_+KG?%$w#sLQx8`|ei8_4vBY&s8ZsYZro@o37zjK0f

literal 0
HcmV?d00001

diff --git a/samples/ownerdrw/makefile.b32 b/samples/ownerdrw/makefile.b32
new file mode 100644
index 0000000000..771353702f
--- /dev/null
+++ b/samples/ownerdrw/makefile.b32
@@ -0,0 +1,64 @@
+#
+# File:		makefile.bcc
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds ownerdrw example (DOS).
+
+# WXWIN and BCCDIR are set by parent make
+
+WXDIR = $(WXWIN)
+!include $(WXDIR)\src\makeb32.env
+
+WXLIBDIR = $(WXDIR)\lib
+WXINC = $(WXDIR)\include\msw
+WXLIB = $(WXLIBDIR)\wx32.lib
+LIBS=$(WXLIB) cw32 import32
+
+TARGET=ownerdrw
+
+!if "$(FINAL)" == "0"
+LINKFLAGS=/v /Tpe /L$(WXLIBDIR);$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS= -v
+!else
+LINKFLAGS=/Tpe /L$(WXLIBDIR);$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS =
+!endif
+CPPFLAGS=$(DEBUG_FLAGS) $(OPT) @$(CFG)
+
+OBJECTS = ownerdrw.obj
+
+$(TARGET).exe:	$(OBJECTS) $(TARGET).def $(TARGET).res
+  tlink32 $(LINKFLAGS) @&&!
+c0w32.obj $(OBJECTS)
+$(TARGET)
+nul
+$(LIBS)
+$(TARGET).def
+!
+        brc32 -K $(TARGET).res
+
+.$(SRCSUFF).obj:
+	bcc32 $(CPPFLAGS) -c {$< }
+
+.c.obj:
+	bcc32 $(CPPFLAGS) -P- -c {$< }
+
+ownerdrw.obj:      ownerdrw.$(SRCSUFF)
+
+$(TARGET).res :      $(TARGET).rc $(WXDIR)\include\wx\msw\wx.rc
+    brc32 -r /i$(BCCDIR)\include /i$(WXDIR)\include $(TARGET)
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.rws
+
diff --git a/samples/ownerdrw/makefile.dos b/samples/ownerdrw/makefile.dos
new file mode 100644
index 0000000000..71c72681ac
--- /dev/null
+++ b/samples/ownerdrw/makefile.dos
@@ -0,0 +1,65 @@
+#
+# File:		makefile.dos
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds ownerdrw example (DOS).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+WXDIR = $(WXWIN)
+
+!include $(WXDIR)\src\makemsc.env
+
+THISDIR = $(WXDIR)\samples\ownerdrw
+
+!ifndef FINAL
+FINAL=0
+!endif
+
+HEADERS =
+SOURCES = ownerdrw.$(SRCSUFF)
+OBJECTS = ownerdrw.obj
+
+all:    ownerdrw.exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.dos FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.dos clean
+        cd $(THISDIR)
+
+ownerdrw.exe:      $(WXDIR)\src\msw\dummy.obj $(WXLIB) ownerdrw.obj ownerdrw.def ownerdrw.res
+        link $(LINKFLAGS) @<<
+ownerdrw.obj $(WXDIR)\src\msw\dummy.obj,
+ownerdrw,
+NUL,
+$(LIBS),
+ownerdrw.def
+;
+<<
+        rc -K ownerdrw.res
+
+ownerdrw.obj:      ownerdrw.$(SRCSUFF)
+        cl @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+ownerdrw.res :      ownerdrw.rc $(WXDIR)\include\wx\msw\wx.rc
+    rc -r /i$(WXDIR)\include ownerdrw
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
diff --git a/samples/ownerdrw/makefile.g95 b/samples/ownerdrw/makefile.g95
new file mode 100644
index 0000000000..c821885cc3
--- /dev/null
+++ b/samples/ownerdrw/makefile.g95
@@ -0,0 +1,37 @@
+#
+# File:		makefile.unx
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile for ownerdrw example (UNIX).
+
+WXDIR = ../..
+
+# All common UNIX compiler flags and options are now in
+# this central makefile.
+include $(WXDIR)/src/makeg95.env
+
+OBJECTS = $(OBJDIR)/ownerdrw.$(OBJSUFF) $(OBJDIR)/ownerdrw_resources.$(OBJSUFF)
+
+all:    $(OBJDIR) ownerdrw$(GUISUFFIX)$(EXESUFF)
+
+wx:
+
+$(OBJDIR):
+	mkdir $(OBJDIR)
+
+ownerdrw$(GUISUFFIX)$(EXESUFF):	$(OBJECTS) $(WXLIB)
+	$(CC) $(LDFLAGS) -o ownerdrw$(GUISUFFIX)$(EXESUFF) $(OBJECTS) $(LDLIBS)
+
+$(OBJDIR)/ownerdrw.$(OBJSUFF):	ownerdrw.$(SRCSUFF)
+	$(CC) -c $(CPPFLAGS) -o $@ ownerdrw.$(SRCSUFF)
+
+$(OBJDIR)/ownerdrw_resources.o:  ownerdrw.rc
+	$(RESCOMP) -i ownerdrw.rc -o $(OBJDIR)/ownerdrw_resources.o $(RESFLAGS)
+
+clean:
+	rm -f $(OBJECTS) ownerdrw$(GUISUFFIX).exe core *.rsc *.res
diff --git a/samples/ownerdrw/makefile.nt b/samples/ownerdrw/makefile.nt
new file mode 100644
index 0000000000..5976dadeb2
--- /dev/null
+++ b/samples/ownerdrw/makefile.nt
@@ -0,0 +1,64 @@
+#
+# File:		makefile.nt
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds ownerdrw example (MS VC++).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+
+WXUSINGDLL=0
+
+!include $(WXDIR)\src\ntwxwin.mak
+
+THISDIR = $(WXDIR)\samples\ownerdrw
+PROGRAM=ownerdrw
+
+OBJECTS = $(PROGRAM).obj
+
+$(PROGRAM):    $(PROGRAM).exe
+
+all:    wx $(PROGRAM).exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt clean
+        cd $(THISDIR)
+
+$(PROGRAM).exe:      $(DUMMYOBJ) $(WXLIB) $(OBJECTS) $(PROGRAM).res
+	$(link) @<<
+-out:$(PROGRAM).exe
+$(LINKFLAGS)
+$(DUMMYOBJ) $(OBJECTS) $(PROGRAM).res
+$(LIBS)
+<<
+
+
+$(PROGRAM).obj:      $(PROGRAM).$(SRCSUFF) $(DUMMYOBJ)
+        $(cc) @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+$(PROGRAM).res :      $(PROGRAM).rc $(WXDIR)\include\wx\msw\wx.rc
+    $(rc) -r /i$(WXDIR)\include -fo$@ $(PROGRAM).rc
+
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
diff --git a/samples/ownerdrw/mondrian.ico b/samples/ownerdrw/mondrian.ico
new file mode 100644
index 0000000000000000000000000000000000000000..2310c5d275a87af295d5ea8dc79ea417a5e74c53
GIT binary patch
literal 766
zcmZQzU<5)11px*Sc)`TLAO@s0fLH;D9e|jTfdxnc0Z<M**w4TKL=5})Lnt5#WHKB$
zaDbtqp#doIAB-6O{|B*v7zjZ^AOa2W|NsACHyAJ}De?dRKnp(HN~rljcR;{k;{zQE
i@;}UZ|9Q?Fpp*~yJCwmWbLIrN`9Qm9%}2L?p!oo$cZ4ed

literal 0
HcmV?d00001

diff --git a/samples/ownerdrw/nosound.bmp b/samples/ownerdrw/nosound.bmp
new file mode 100644
index 0000000000000000000000000000000000000000..722e2e4ced920128980723aaab87529acc7f78dc
GIT binary patch
literal 370
zcmZvWF%H5o3`Kt>q|zPkz&Y5tOT>ViEgNe#Und7c3jaG4fmA29pB?wt*V}zU*n{yx
zKhe+h2?s{t6>%>VfET5V#7IPIjad&pE_xTydDLRCui=mL)_3-O6xqmmjX@V%1&+p1
z@j_)yir0!H1u@@~GX<No+BnyJ{+ZFY^Jm^IEziN!PN1kXnbJIV&@ZX(>a#7@&T5DG
I*kKgF8+G_}MF0Q*

literal 0
HcmV?d00001

diff --git a/samples/ownerdrw/ownerdrw.cpp b/samples/ownerdrw/ownerdrw.cpp
new file mode 100644
index 0000000000..2e039f2926
--- /dev/null
+++ b/samples/ownerdrw/ownerdrw.cpp
@@ -0,0 +1,293 @@
+///////////////////////////////////////////////////////////////////////////////
+// Name:        ownerdrw.cpp
+// Purpose:     Owner-draw sample, for Windows
+// Author:      Vadim Zeitlin
+// Modified by: 
+// Created:     13.11.97
+// RCS-ID:      $Id$
+// Copyright:   (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
+// Licence:     wxWindows license
+///////////////////////////////////////////////////////////////////////////////
+
+// ============================================================================
+// headers & declarations
+// ============================================================================
+
+// For compilers that support precompilation, includes "wx.h".
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+  #pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+  #include "wx/wx.h"
+#endif
+
+#include  "wx/ownerdrw.h"
+#include  "wx/menuitem.h"
+#include  "wx/msw/checklst.h"
+
+// Define a new application type
+class OwnerDrawnApp: public wxApp
+{
+public:
+  bool OnInit();
+};
+
+// Define a new frame type
+class OwnerDrawnFrame : public wxFrame
+{
+public:
+  // ctor & dtor
+  OwnerDrawnFrame(wxFrame *frame, char *title, int x, int y, int w, int h);
+  ~OwnerDrawnFrame();
+
+  // notifications
+  void OnQuit             (wxCommandEvent& event);
+  void OnAbout            (wxCommandEvent& event);
+  void OnListboxSelect    (wxCommandEvent& event);
+  void OnCheckboxToggle   (wxCommandEvent& event);
+  void OnListboxDblClick  (wxCommandEvent& event);
+  bool OnClose            ()                        { return TRUE; }
+
+  DECLARE_EVENT_TABLE()
+
+private:
+  void InitMenu();
+
+  wxCheckListBox *m_pListBox;
+};
+
+enum 
+{ 
+  Menu_Quit = 1, 
+  Menu_First = 100,
+  Menu_Test1, Menu_Test2, Menu_Test3, 
+  Menu_Bitmap, Menu_Bitmap2, 
+  Menu_Submenu, Menu_Sub1, Menu_Sub2, Menu_Sub3,
+  Control_First = 1000,
+  Control_Listbox, Control_Listbox2,
+};
+
+BEGIN_EVENT_TABLE(OwnerDrawnFrame, wxFrame)
+  EVT_MENU(Menu_Quit, OwnerDrawnFrame::OnQuit)
+  EVT_LISTBOX(Control_Listbox, OwnerDrawnFrame::OnListboxSelect)
+  EVT_CHECKLISTBOX(Control_Listbox, OwnerDrawnFrame::OnCheckboxToggle)
+  EVT_COMMAND(Control_Listbox, wxEVT_COMMAND_LISTBOX_DOUBLECLICKED, 
+              OwnerDrawnFrame::OnListboxDblClick)
+END_EVENT_TABLE()
+
+IMPLEMENT_APP(OwnerDrawnApp);
+
+// init our app: create windows
+bool OwnerDrawnApp::OnInit(void)
+{
+  OwnerDrawnFrame *pFrame = new OwnerDrawnFrame(NULL, "wxWindows Ownerdraw Sample",
+                                                50, 50, 450, 340);
+  SetTopWindow(pFrame);
+
+  return TRUE;
+}
+
+// create the menu bar for the main frame
+void OwnerDrawnFrame::InitMenu()
+{
+  // Make a menubar
+  wxMenu *file_menu = new wxMenu,
+         *sub_menu  = new wxMenu;
+
+  // vars used for menu construction
+  wxMenuItem *pItem;
+  wxFont fontLarge(18, wxROMAN, wxNORMAL, wxBOLD, FALSE),
+         fontUlined(12, wxDEFAULT, wxNORMAL, wxNORMAL, TRUE),
+         fontItalic(12, wxMODERN, wxITALIC, wxBOLD, FALSE),
+         // should be at least of the size of bitmaps
+         fontBmp(14, wxDEFAULT, wxNORMAL, wxNORMAL, FALSE);
+
+  // sorry for my artistic skills...
+  wxBitmap bmpBell("bell"), bmpSound("sound"), bmpNoSound("nosound");
+
+  // construct submenu
+  pItem = new wxMenuItem(sub_menu, Menu_Sub1, "Submenu &first", "large", TRUE);
+  pItem->SetFont(fontLarge);
+  sub_menu->Append(pItem);
+  
+  pItem = new wxMenuItem(sub_menu, Menu_Sub2, "Submenu &second", "italic", TRUE);
+  pItem->SetFont(fontItalic);
+  sub_menu->Append(pItem);
+  
+  pItem = new wxMenuItem(sub_menu, Menu_Sub3, "Submenu &third", "underlined", TRUE);
+  pItem->SetFont(fontUlined);
+  sub_menu->Append(pItem);
+  
+  // construct menu
+  pItem = new wxMenuItem(file_menu, Menu_Test1, "&Uncheckable", "red item");
+  pItem->SetFont(*wxITALIC_FONT);
+  pItem->SetTextColour(wxColor(255, 0, 0));
+  pItem->SetMarginWidth(23);
+  file_menu->Append(pItem);
+
+  pItem = new wxMenuItem(file_menu, Menu_Test2, "&Checkable", "checkable item", TRUE);
+  pItem->SetFont(*wxSMALL_FONT);
+  file_menu->Append(pItem);
+  file_menu->Check(Menu_Test2, TRUE);
+
+  pItem = new wxMenuItem(file_menu, Menu_Test3, "&Disabled", "disabled item");
+  pItem->SetFont(*wxNORMAL_FONT);
+  file_menu->Append(pItem);
+  file_menu->Enable(Menu_Test3, FALSE);
+
+  file_menu->AppendSeparator();
+
+  pItem = new wxMenuItem(file_menu, Menu_Bitmap, "&Bell", "check/uncheck me!", TRUE);
+  pItem->SetFont(fontBmp);
+  pItem->SetBitmaps(bmpBell);
+  file_menu->Append(pItem);
+
+  pItem = new wxMenuItem(file_menu, Menu_Bitmap2, "So&und", "icon changes!", TRUE);
+  pItem->SetFont(fontBmp);
+  pItem->SetBitmaps(bmpSound, bmpNoSound);
+  file_menu->Append(pItem);
+
+  file_menu->AppendSeparator();
+
+  pItem = new wxMenuItem(file_menu, Menu_Submenu, "&Sub menu", "", TRUE, sub_menu);
+  pItem->SetFont(*wxSWISS_FONT);
+  file_menu->Append(pItem);
+
+  file_menu->AppendSeparator();
+  file_menu->Append(Menu_Quit, "&Quit", "Normal item");
+
+  wxMenuBar *menu_bar = new wxMenuBar;
+
+  menu_bar->Append(file_menu, "&File");
+  SetMenuBar(menu_bar);
+}
+
+// main frame constructor
+OwnerDrawnFrame::OwnerDrawnFrame(wxFrame *frame, char *title, int x, int y, int w, int h)
+         : wxFrame(frame, -1, title, wxPoint(x, y), wxSize(w, h))
+{
+  // set the icon
+  SetIcon(wxIcon("mondrian"));
+
+  // create the menu
+  InitMenu();
+
+  // make a panel with some controls
+  wxPanel *pPanel = new wxPanel(this, -1, wxPoint(0, 0), 
+                                wxSize(400, 200), wxTAB_TRAVERSAL);
+
+  // check list box
+  static const char* aszChoices[] = { "Hello", "world", "and", 
+                                      "goodbye", "cruel", "world",
+                                      "-------", "owner-drawn", "listbox" };
+
+  wxString *astrChoices = new wxString[WXSIZEOF(aszChoices)];
+  uint ui;
+  for ( ui = 0; ui < WXSIZEOF(aszChoices); ui++ )
+    astrChoices[ui] = aszChoices[ui];
+
+  m_pListBox = new wxCheckListBox
+                   (                                             
+                     pPanel,             // parent               
+                     Control_Listbox,    // control id           
+                     wxPoint(10, 10),    // listbox poistion     
+                     wxSize(200, 200),   // listbox size         
+                     WXSIZEOF(aszChoices), // number of strings    
+                     astrChoices         // array of strings
+                   );                                            
+                                                                            
+  delete [] astrChoices;
+
+  for ( ui = 0; ui < WXSIZEOF(aszChoices); ui += 2 ) {
+    m_pListBox->GetItem(ui)->SetBackgroundColour(wxColor(200, 200, 200));
+  }
+
+  m_pListBox->Check(2);
+
+  // normal (but owner-drawn) listbox
+  static const char* aszColors[] = { "Red", "Blue", "Pink",
+                                     "Green", "Yellow", 
+                                     "Black", "Violet"  };
+  struct { uint r, g, b; } aColors[] = { {255,0,0}, {0,0,255}, {255,128,192},
+                                        {0,255,0}, {255,255,128}, 
+                                        {0,0,0}, {128,0,255} };
+  astrChoices = new wxString[WXSIZEOF(aszColors)];
+  for ( ui = 0; ui < WXSIZEOF(aszColors); ui++ )
+    astrChoices[ui] = aszColors[ui];
+
+  wxListBox *pListBox = new wxListBox
+                           (                                             
+                             pPanel,              // parent               
+                             Control_Listbox2,    // control id           
+                             wxPoint(220, 10),    // listbox poistion     
+                             wxDefaultSize,       // listbox size         
+                             WXSIZEOF(aszColors),   // number of strings    
+                             astrChoices,         // array of strings
+                             wxLB_OWNERDRAW,      // owner-drawn
+                             wxDefaultValidator,  // 
+                             wxListBoxNameStr
+                           );
+
+  for ( ui = 0; ui < WXSIZEOF(aszColors); ui++ ) {
+    pListBox->GetItem(ui)->SetTextColour(wxColor(aColors[ui].r,
+                                                aColors[ui].g, 
+                                                aColors[ui].b));
+    // yellow on white is horrible...
+    if ( ui == 4 )
+      pListBox->GetItem(ui)->SetBackgroundColour(wxColor(0, 0, 0));
+    
+  }
+
+  // create the status line
+  const int widths[] = { -1, 60 };
+  CreateStatusBar(2);
+  SetStatusWidths(2, widths);
+  SetStatusText("no selection", 0);
+
+  Show(TRUE);
+}
+
+OwnerDrawnFrame::~OwnerDrawnFrame()
+{
+}
+
+void OwnerDrawnFrame::OnQuit(wxCommandEvent& event)
+{
+  Close(TRUE);
+}
+
+void OwnerDrawnFrame::OnAbout(wxCommandEvent& event)
+{
+  wxMessageDialog dialog(this, "Demo of owner-drawn controls\n"
+                         "About wxOwnerDrawn", wxYES_NO | wxCANCEL);
+  dialog.ShowModal();
+}
+
+void OwnerDrawnFrame::OnListboxSelect(wxCommandEvent& event)
+{
+  wxString strSelection;
+  uint nSel = event.GetSelection();
+  strSelection.sprintf("item %d selected (%schecked)", nSel,
+                       m_pListBox->IsChecked(nSel) ? "" : "not ");
+  SetStatusText(strSelection);
+}
+
+void OwnerDrawnFrame::OnListboxDblClick(wxCommandEvent& event)
+{
+  wxString strSelection;
+  strSelection.sprintf("item %d double clicked", m_pListBox->GetSelection());
+  wxMessageDialog dialog(this, strSelection);
+  dialog.ShowModal();
+}
+
+void OwnerDrawnFrame::OnCheckboxToggle(wxCommandEvent& event)
+{
+  wxString strSelection;
+  uint nItem = event.GetInt();
+  strSelection.sprintf("item %d was %schecked", nItem,
+                       m_pListBox->IsChecked(nItem) ? "" : "un");
+  SetStatusText(strSelection);
+}
\ No newline at end of file
diff --git a/samples/ownerdrw/ownerdrw.def b/samples/ownerdrw/ownerdrw.def
new file mode 100644
index 0000000000..6f2236cfe5
--- /dev/null
+++ b/samples/ownerdrw/ownerdrw.def
@@ -0,0 +1,8 @@
+NAME         OWNERDRW
+DESCRIPTION  'Owner-draw sample'
+EXETYPE      WINDOWS
+STUB         'WINSTUB.EXE'
+CODE         PRELOAD MOVEABLE DISCARDABLE
+DATA         PRELOAD MOVEABLE MULTIPLE
+HEAPSIZE     4048
+STACKSIZE    16000
diff --git a/samples/ownerdrw/ownerdrw.rc b/samples/ownerdrw/ownerdrw.rc
new file mode 100644
index 0000000000..bbc00bdf4b
--- /dev/null
+++ b/samples/ownerdrw/ownerdrw.rc
@@ -0,0 +1,6 @@
+mondrian ICON   "mondrian.ico"
+bell BITMAP "bell.bmp"
+sound BITMAP "sound.bmp"
+nosound BITMAP "nosound.bmp"
+#include "wx/msw/wx.rc"
+
diff --git a/samples/ownerdrw/sound.bmp b/samples/ownerdrw/sound.bmp
new file mode 100644
index 0000000000000000000000000000000000000000..26f5f1883e29c465f0243ccff4ba2766b980229e
GIT binary patch
literal 370
zcma)#K@I{T5CogVWPO1C!FTN4zYq`Vk(=M*VVkfu;|Q8;vI5gn44r1a-jaOX(F=8=
z&Q#I?l@`}6DH2Deyc-It)=IaB=0~j=QEVF_kG}LLKf`E^u%iV8dx9~Z{F&2#nOj6;
Xd)eh_c=Y<>_}B8WjGS#|+C9N5tAudn

literal 0
HcmV?d00001

diff --git a/samples/regtest/key1.ico b/samples/regtest/key1.ico
new file mode 100644
index 0000000000000000000000000000000000000000..57a5209acb6245bba40312a49354d5784d7291f0
GIT binary patch
literal 318
zcmZvXF%H5o6hmEsXeQK&nURw*cZ2b7?ba*xC>)_13`n2n6qX97wi7#vQmJ8dT_@wx
zNGCgVa)yoes1#NI360B$)ljCI=NWgA^;4#2km1O(K_SfSxvMv%QV}XQFa!lB3dO`a
xM!bvzrs;59{rGjMt$F6t?hEd?Mqsb-6QYGX-pju~NX_L(vSq^;>o@y-_5&Q8M8W_7

literal 0
HcmV?d00001

diff --git a/samples/regtest/key2.ico b/samples/regtest/key2.ico
new file mode 100644
index 0000000000000000000000000000000000000000..082ff472913fcc457f7325b084398f0f24b65d0a
GIT binary patch
literal 318
zcma)%I}*bn3`CcSi<DHUQ~HRWNkbPpAIB;2t=!3PA#FY@q!j{bR#L)p&NAjC-ORWv
zcRXn#enXKsDrFFnRIN4G57CbzoZ*;D4j)hlv~I>r>%&<7zcW1I(35UP>FQ>q*3$VM
Th7P2&H;exE3xAQlcm2`{Aev48

literal 0
HcmV?d00001

diff --git a/samples/regtest/key3.ico b/samples/regtest/key3.ico
new file mode 100644
index 0000000000000000000000000000000000000000..0cbb4c3360d74049def5417d7bf4a34ebf862c11
GIT binary patch
literal 318
zcmaJ-yAHxI5OX9XGG=0C<n!1&)MF%ud`=njDf|VM7!Et_&;@+wdn<PekR+uP7`Fsm
z>_u0uV!}!G9|%Z6ZcbJqdhhaX#85;y5+yF#{6ZZ7+9EuWKa+50emf_d(<!s*kyy{%
r#vglsq37p_k*~E98l-pST8}HYJAjvpeJAD3BdBCh|I=s9kNbfyLg-WO

literal 0
HcmV?d00001

diff --git a/samples/regtest/makefile.g95 b/samples/regtest/makefile.g95
new file mode 100644
index 0000000000..5dc5b47810
--- /dev/null
+++ b/samples/regtest/makefile.g95
@@ -0,0 +1,37 @@
+#
+# File:		makefile.unx
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile for regtest example (UNIX).
+
+WXDIR = ../..
+
+# All common UNIX compiler flags and options are now in
+# this central makefile.
+include $(WXDIR)/src/makeg95.env
+
+OBJECTS = $(OBJDIR)/regtest.$(OBJSUFF) $(OBJDIR)/regtest_resources.$(OBJSUFF)
+
+all:    $(OBJDIR) regtest$(GUISUFFIX)$(EXESUFF)
+
+wx:
+
+$(OBJDIR):
+	mkdir $(OBJDIR)
+
+regtest$(GUISUFFIX)$(EXESUFF):	$(OBJECTS) $(WXLIB)
+	$(CC) $(LDFLAGS) -o regtest$(GUISUFFIX)$(EXESUFF) $(OBJECTS) $(LDLIBS)
+
+$(OBJDIR)/regtest.$(OBJSUFF):	regtest.$(SRCSUFF)
+	$(CC) -c $(CPPFLAGS) -o $@ regtest.$(SRCSUFF)
+
+$(OBJDIR)/regtest_resources.o:  regtest.rc
+	$(RESCOMP) -i regtest.rc -o $(OBJDIR)/regtest_resources.o $(RESFLAGS)
+
+clean:
+	rm -f $(OBJECTS) regtest$(GUISUFFIX).exe core *.rsc *.res
diff --git a/samples/regtest/makefile.nt b/samples/regtest/makefile.nt
new file mode 100644
index 0000000000..df589af4ee
--- /dev/null
+++ b/samples/regtest/makefile.nt
@@ -0,0 +1,64 @@
+#
+# File:		makefile.nt
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds regtest example (MS VC++).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+
+WXUSINGDLL=0
+
+!include $(WXDIR)\src\ntwxwin.mak
+
+THISDIR = $(WXDIR)\samples\regtest
+PROGRAM=regtest
+
+OBJECTS = $(PROGRAM).obj
+
+$(PROGRAM):    $(PROGRAM).exe
+
+all:    wx $(PROGRAM).exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt clean
+        cd $(THISDIR)
+
+$(PROGRAM).exe:      $(DUMMYOBJ) $(WXLIB) $(OBJECTS) $(PROGRAM).res
+	$(link) @<<
+-out:$(PROGRAM).exe
+$(LINKFLAGS)
+$(DUMMYOBJ) $(OBJECTS) $(PROGRAM).res
+$(LIBS)
+<<
+
+
+$(PROGRAM).obj:      $(PROGRAM).$(SRCSUFF) $(DUMMYOBJ)
+        $(cc) @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+$(PROGRAM).res :      $(PROGRAM).rc $(WXDIR)\include\wx\msw\wx.rc
+    $(rc) -r /i$(WXDIR)\include -fo$@ $(PROGRAM).rc
+
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
diff --git a/samples/regtest/registry.ico b/samples/regtest/registry.ico
new file mode 100644
index 0000000000000000000000000000000000000000..3ebfa3ace3528dcdfb2575240933107b298cba33
GIT binary patch
literal 1078
zcmb7@L2lbH5Jg9EK?^7lxhJqzMQ)KEg)1(_BbYz{!K>&<^)AOqRzi2|is+&s`-YP0
zv@i;E?9Z7$pTnW$kw_zV()R~Z`*tVt8Gkq|{Gk!K--$es>%kY$$Ol%8y|*oh@Rbl2
z$4V%d%LT7Osb48YBfv*fy8LC&IpsX$w56vw$LQm1*Tkl8{I|X)Mu&AJ*_Bt_#%R|>
zt#=%@@~S)IoGb;4Zrpaj=xiy@`0WDdW=JM)I`tG@8=_n1Y|hv7t@E{E(hd_>b6Fd9
zQL`;q^ASF0DoLyjheQ^t8+@D%ZK|vrFl~4as;?V3rZSfEY8$`$a1AwT*Ar`Ox!clF
zDP5#pZ=|&4fxOpSPrrBd?EOyXpnI!Laf=q;BL87wV>$#U@Cc5e1ADOh2joQcBRFzQ
zcfr5GX>s~N-A{nMl=Avi%G8u%q~u)#o&fnh@&sOs&bdy054JfE#J4Rl<0#B@b*zN{
zHRscu{mc>1DGoa1{F{C@Jo`CY!IQTRKU!~f-^7w?-Z<6Uc%KYjMxRU=Nu1B29V{6c
mWl{%g)h|pFO6t?XcVK@TVaIRb{eSCuH$REwkN6|_D)I}O#V85@

literal 0
HcmV?d00001

diff --git a/samples/regtest/regtest.cpp b/samples/regtest/regtest.cpp
new file mode 100644
index 0000000000..c9396bf398
--- /dev/null
+++ b/samples/regtest/regtest.cpp
@@ -0,0 +1,834 @@
+///////////////////////////////////////////////////////////////////////////////
+// Name:        registry.cpp
+// Purpose:     wxRegKey class demo
+// Author:      Vadim Zeitlin
+// Modified by: 
+// Created:     03.04.98
+// RCS-ID:      $Id$
+// Copyright:   (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
+// Licence:     wxWindows license
+///////////////////////////////////////////////////////////////////////////////
+
+// ============================================================================
+// declarations
+// ============================================================================
+
+// ----------------------------------------------------------------------------
+// headers
+// ----------------------------------------------------------------------------
+#include "wx/wxprec.h"
+
+#ifdef  __BORLANDC__
+  #pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+  #include "wx/wx.h"
+#endif
+
+#include "wx/log.h"
+#include "wx/treectrl.h"
+#include "wx/msw/registry.h"
+
+// ----------------------------------------------------------------------------
+// application type
+// ----------------------------------------------------------------------------
+class RegApp : public wxApp
+{ 
+public:
+  bool OnInit(void);
+};
+
+// ----------------------------------------------------------------------------
+// image list with registry icons
+// ----------------------------------------------------------------------------
+class RegImageList : public wxImageList
+{
+public:
+  enum Icon
+  {
+    Root,
+    ClosedKey,
+    OpenedKey,
+    TextValue,
+    BinaryValue,
+  };
+
+  RegImageList();
+};
+
+// ----------------------------------------------------------------------------
+// our control
+// ----------------------------------------------------------------------------
+class RegTreeCtrl : public wxTreeCtrl
+{
+public:
+  // ctor & dtor
+  RegTreeCtrl(wxWindow *parent, wxWindowID id);
+  virtual ~RegTreeCtrl();
+
+  // notifications
+  void OnDeleteItem   (wxTreeEvent& event);
+  void OnItemExpanding(wxTreeEvent& event);
+  void OnSelChanged   (wxTreeEvent& event);
+
+  void OnRightClick   (wxMouseEvent& event);
+  void OnChar         (wxKeyEvent& event);
+
+  // forwarded notifications (by the frame)
+  void OnMenuTest();
+
+  // operations
+  void DeleteSelected();
+  void CreateNewKey(const wxString& strName);
+  void CreateNewTextValue(const wxString& strName);
+  void CreateNewBinaryValue(const wxString& strName);
+
+  // information
+  bool IsKeySelected() const;
+
+  DECLARE_EVENT_TABLE();
+
+private:
+  // array of children of the node
+  struct TreeNode;
+  WX_DEFINE_ARRAY(TreeNode *, TreeChildren);
+  
+  // structure describing a registry key/value
+  struct TreeNode
+  {
+    RegTreeCtrl  *m_pTree;     // must be !NULL
+    TreeNode     *m_pParent;    // NULL only for the root node
+    long          m_id;         // the id of the tree control item
+    wxString      m_strName;    // name of the key/value
+    TreeChildren  m_aChildren;  // array of subkeys/values
+    bool          m_bKey;       // key or value?
+    wxRegKey     *m_pKey;       // only may be !NULL if m_bKey == true
+    long          m_lDummy;     // dummy subkey (to make expansion possible)
+
+    // ctor
+    TreeNode() { m_lDummy = 0; }
+
+    // trivial accessors
+    long      Id()     const { return m_id;              }
+    bool      IsRoot() const { return m_pParent == NULL; }
+    bool      IsKey()  const { return m_bKey;            }
+    TreeNode *Parent() const { return m_pParent;         }
+
+    // notifications
+    bool OnExpand();
+    void OnCollapse();
+
+    // operations
+    void Refresh() { OnCollapse(); OnExpand(); }
+    void AddDummy();
+    void DestroyChildren();
+    const char *FullName() const;
+
+    // get the associated key: make sure the pointer is !NULL
+    wxRegKey& Key() { if ( !m_pKey ) OnExpand(); return *m_pKey; }
+
+    // dtor deletes all children
+    ~TreeNode();
+  };
+
+  wxMenu      *m_pMenuPopup;
+  TreeNode    *m_pRoot;
+  wxImageList *m_imageList;
+
+  TreeNode *GetNode(const wxTreeEvent& event)
+    { return (TreeNode *)GetItemData(event.m_item.m_itemId); }
+
+public:
+  // create a new node and insert it to the tree
+  TreeNode *InsertNewTreeNode(TreeNode *pParent, 
+                              const wxString& strName,
+                              int idImage = RegImageList::ClosedKey,
+                              const wxString *pstrValue = NULL);
+  // add standard registry keys
+  void AddStdKeys();
+};
+
+// ----------------------------------------------------------------------------
+// the main window of our application
+// ----------------------------------------------------------------------------
+class RegFrame : public wxFrame
+{ 
+public:
+  // ctor & dtor
+  RegFrame(wxFrame *parent, char *title, int x, int y, int w, int h);
+  virtual ~RegFrame(void);
+    
+  // callbacks
+  void OnQuit (wxCommandEvent& event);
+  void OnAbout(wxCommandEvent& event);
+  void OnTest (wxCommandEvent& event);
+
+  void OnExpand  (wxCommandEvent& event);
+  void OnCollapse(wxCommandEvent& event);
+  void OnToggle  (wxCommandEvent& event);
+
+  void OnDelete   (wxCommandEvent& event);
+  void OnNewKey   (wxCommandEvent& event);
+  void OnNewText  (wxCommandEvent& event);
+  void OnNewBinary(wxCommandEvent& event);
+
+  bool OnClose  () { return TRUE; }
+
+  DECLARE_EVENT_TABLE();
+
+private:
+  RegTreeCtrl *m_treeCtrl;
+};
+
+// ----------------------------------------------------------------------------
+// various ids
+// ----------------------------------------------------------------------------
+
+enum
+{
+  Menu_Quit     = 100,
+  Menu_About,
+  Menu_Test,
+  Menu_Expand,
+  Menu_Collapse,
+  Menu_Toggle,
+  Menu_New,
+  Menu_NewKey,  
+  Menu_NewText, 
+  Menu_NewBinary,
+  Menu_Delete,
+
+  Ctrl_RegTree  = 200,
+};
+
+// ----------------------------------------------------------------------------
+// event tables
+// ----------------------------------------------------------------------------
+
+BEGIN_EVENT_TABLE(RegFrame, wxFrame)
+  EVT_MENU(Menu_Test,     RegFrame::OnTest)
+  EVT_MENU(Menu_About,    RegFrame::OnAbout)
+  EVT_MENU(Menu_Quit,     RegFrame::OnQuit)
+  EVT_MENU(Menu_Expand,   RegFrame::OnExpand)
+  EVT_MENU(Menu_Collapse, RegFrame::OnCollapse)
+  EVT_MENU(Menu_Toggle,   RegFrame::OnToggle)
+  EVT_MENU(Menu_Delete,   RegFrame::OnDelete)
+  EVT_MENU(Menu_NewKey,   RegFrame::OnNewKey)
+  EVT_MENU(Menu_NewText,  RegFrame::OnNewText)
+  EVT_MENU(Menu_NewBinary,RegFrame::OnNewBinary)
+END_EVENT_TABLE()
+
+BEGIN_EVENT_TABLE(RegTreeCtrl, wxTreeCtrl)
+  EVT_TREE_DELETE_ITEM   (Ctrl_RegTree, RegTreeCtrl::OnDeleteItem)
+  EVT_TREE_ITEM_EXPANDING(Ctrl_RegTree, RegTreeCtrl::OnItemExpanding)
+  EVT_TREE_SEL_CHANGED   (Ctrl_RegTree, RegTreeCtrl::OnSelChanged)
+
+  EVT_CHAR      (RegTreeCtrl::OnChar)
+  EVT_RIGHT_DOWN(RegTreeCtrl::OnRightClick)
+END_EVENT_TABLE()
+
+// ============================================================================
+// implementation
+// ============================================================================
+
+// ----------------------------------------------------------------------------
+// global functions
+// ----------------------------------------------------------------------------
+
+// create the "registry operations" menu
+wxMenu *CreateRegistryMenu()
+{
+  wxMenu *pMenuNew = new wxMenu;
+  pMenuNew->Append(Menu_NewKey,    "&Key",          "Create a new key");
+  pMenuNew->AppendSeparator();
+  pMenuNew->Append(Menu_NewText,   "&Text value",   "Create a new text value");
+  pMenuNew->Append(Menu_NewBinary, "&Binary value", "Create a new binary value");
+
+  wxMenu *pMenuReg = new wxMenu;
+  pMenuReg->Append(Menu_New, "&New", pMenuNew);
+  pMenuReg->Append(Menu_Delete,   "&Delete...", "Delete selected key/value");
+  pMenuReg->AppendSeparator();
+  pMenuReg->Append(Menu_Expand,   "&Expand",    "Expand current key");
+  pMenuReg->Append(Menu_Collapse, "&Collapse",  "Collapse current key");
+  pMenuReg->Append(Menu_Toggle,   "&Toggle",    "Toggle current key");
+
+  return pMenuReg;
+}
+
+// ----------------------------------------------------------------------------
+// application class
+// ----------------------------------------------------------------------------
+IMPLEMENT_APP(RegApp)
+
+// `Main program' equivalent, creating windows and returning main app frame
+bool RegApp::OnInit()
+{
+  // create the main frame window and show it
+  RegFrame *frame = new RegFrame(NULL, "wxRegKey Test", 50, 50, 600, 350);
+  frame->Show(true);
+  
+  SetTopWindow(frame);
+
+  return true;
+}
+
+// ----------------------------------------------------------------------------
+// RegFrame
+// ----------------------------------------------------------------------------
+
+RegFrame::RegFrame(wxFrame *parent, char *title, int x, int y, int w, int h)
+        : wxFrame(parent, -1, title, wxPoint(x, y), wxSize(w, h))
+{
+  // this reduces flicker effects
+  SetBackgroundColour(wxColour(255, 255, 255));
+
+  // set the icon
+  // ------------
+  SetIcon(wxIcon("app_icon"));
+
+  // create menu
+  // -----------
+  wxMenu *pMenuFile = new wxMenu;
+  pMenuFile->Append(Menu_Test, "Te&st", "Test key creation");
+  pMenuFile->AppendSeparator();
+  pMenuFile->Append(Menu_About, "&About...", "Show an extraordinarly beautiful dialog");
+  pMenuFile->AppendSeparator();
+  pMenuFile->Append(Menu_Quit,  "E&xit", "Quit this program");
+
+  wxMenuBar *pMenu = new wxMenuBar;
+  pMenu->Append(pMenuFile, "&File");
+  pMenu->Append(CreateRegistryMenu(),  "&Registry");
+  SetMenuBar(pMenu);
+
+  // create child controls
+  // ---------------------
+  m_treeCtrl = new RegTreeCtrl(this, Ctrl_RegTree);
+
+  // create the status line
+  // ----------------------
+  int aWidths[2];
+  aWidths[0] = 200;
+  aWidths[1] = -1;
+  CreateStatusBar(2);
+  SetStatusWidths(2, aWidths);
+}
+
+RegFrame::~RegFrame(void)
+{
+}
+
+void RegFrame::OnQuit(wxCommandEvent& event)
+{
+  Close(TRUE);
+}
+
+void RegFrame::OnAbout(wxCommandEvent& event)
+{
+  wxMessageDialog dialog(this, "wxRegistry sample\n(c) 1998 Vadim Zeitlin",
+                         "About wxRegistry", wxOK);
+
+  dialog.ShowModal();
+}
+
+void RegFrame::OnTest(wxCommandEvent& event)
+{
+  m_treeCtrl->OnMenuTest();
+}
+
+void RegFrame::OnExpand(wxCommandEvent& event)
+{
+  m_treeCtrl->ExpandItem(m_treeCtrl->GetSelection(), wxTREE_EXPAND_EXPAND);
+}
+
+void RegFrame::OnCollapse(wxCommandEvent& event)
+{
+  m_treeCtrl->ExpandItem(m_treeCtrl->GetSelection(), wxTREE_EXPAND_COLLAPSE);
+}
+
+void RegFrame::OnToggle(wxCommandEvent& event)
+{
+  m_treeCtrl->ExpandItem(m_treeCtrl->GetSelection(), wxTREE_EXPAND_TOGGLE);
+}
+
+void RegFrame::OnDelete(wxCommandEvent& event)
+{
+  m_treeCtrl->DeleteSelected();
+}
+
+void RegFrame::OnNewKey(wxCommandEvent& event)
+{
+  if ( m_treeCtrl->IsKeySelected() ) {
+    m_treeCtrl->CreateNewKey(
+      wxGetTextFromUser("Enter the name of the new key"));
+  }
+}
+
+void RegFrame::OnNewText(wxCommandEvent& event)
+{
+  if ( m_treeCtrl->IsKeySelected() ) {
+    m_treeCtrl->CreateNewTextValue(
+      wxGetTextFromUser("Enter the name for the new text value"));
+  }
+}
+
+void RegFrame::OnNewBinary(wxCommandEvent& event)
+{
+  if ( m_treeCtrl->IsKeySelected() ) {
+    m_treeCtrl->CreateNewBinaryValue(
+      wxGetTextFromUser("Enter the name for the new binary value"));
+  }
+}
+
+// ----------------------------------------------------------------------------
+// RegImageList
+// ----------------------------------------------------------------------------
+RegImageList::RegImageList() : wxImageList(16, 16, TRUE)
+{
+  // should be in sync with enum RegImageList::RegIcon
+  static const char *aszIcons[] = { "key1","key2","key3","value1","value2" };
+  wxString str = "icon_";
+  for ( uint n = 0; n < WXSIZEOF(aszIcons); n++ ) {
+    Add(wxIcon(str + aszIcons[n], wxBITMAP_TYPE_ICO_RESOURCE));
+  }
+}
+
+// ----------------------------------------------------------------------------
+// RegTreeCtrl
+// ----------------------------------------------------------------------------
+
+// create a new tree item and insert it into the tree
+RegTreeCtrl::TreeNode *RegTreeCtrl::InsertNewTreeNode(TreeNode *pParent, 
+                                                      const wxString& strName,
+                                                      int idImage,
+                                                      const wxString *pstrValue)
+{
+  // create new item & insert it
+  TreeNode *pNewNode = new TreeNode;
+  pNewNode->m_pTree  = this;
+  pNewNode->m_pParent = pParent;
+  pNewNode->m_strName = strName;
+  pNewNode->m_bKey    = pstrValue == NULL;
+  pNewNode->m_pKey    = NULL;
+  pNewNode->m_id      = InsertItem(pParent ? pParent->m_id : 0, 
+                                   pNewNode->IsKey() ? strName : *pstrValue,
+                                   idImage);
+
+  wxASSERT_MSG( pNewNode->m_id, "can't create tree control item!");
+
+  // save the pointer in the item
+  if ( !SetItemData(pNewNode->m_id, (long)pNewNode) ) {
+    wxFAIL_MSG("can't store item's data in tree control!");
+  }
+
+  // add it to the list of parent's children
+  if ( pParent != NULL ) {
+    pParent->m_aChildren.Add(pNewNode);
+  }
+
+  // force the [+] button (@@@ not very elegant...)
+  if ( pNewNode->IsKey() )
+    pNewNode->AddDummy();
+
+  return pNewNode;
+}
+
+RegTreeCtrl::RegTreeCtrl(wxWindow *parent, wxWindowID id)
+           : wxTreeCtrl(parent, id, wxDefaultPosition, wxDefaultSize, 
+                        wxTR_HAS_BUTTONS | wxSUNKEN_BORDER)
+{
+  // create the image list
+  // ---------------------
+  m_imageList = new RegImageList;
+  SetImageList(m_imageList, wxIMAGE_LIST_NORMAL);
+
+  // create root keys
+  // ----------------
+  m_pRoot = InsertNewTreeNode(NULL, "Registry Root", RegImageList::Root);
+
+  // create popup menu
+  // -----------------
+  m_pMenuPopup = CreateRegistryMenu();
+}
+
+RegTreeCtrl::~RegTreeCtrl()
+{
+  delete m_pMenuPopup;
+  delete m_pRoot;
+  delete m_imageList;
+}
+
+void RegTreeCtrl::AddStdKeys()
+{
+  for ( uint ui = 0; ui < wxRegKey::nStdKeys; ui++ ) {
+    InsertNewTreeNode(m_pRoot, wxRegKey::GetStdKeyName(ui));
+  }
+}
+
+// ----------------------------------------------------------------------------
+// notifications
+// ----------------------------------------------------------------------------
+
+void RegTreeCtrl::OnRightClick(wxMouseEvent& event)
+{
+  int iFlags;
+  long lId = HitTest(wxPoint(event.GetX(), event.GetY()), iFlags);
+  if ( iFlags & wxTREE_HITTEST_ONITEMLABEL ) {
+    // popup menu only if an item was clicked
+    wxASSERT( lId != 0 );
+    SelectItem(lId);
+    PopupMenu(m_pMenuPopup, event.GetX(), event.GetY());
+  }
+}
+
+
+void RegTreeCtrl::OnDeleteItem(wxTreeEvent& event)
+{
+}
+
+// test the key creation functions
+void RegTreeCtrl::OnMenuTest()
+{
+  long lId = GetSelection();
+  TreeNode *pNode = (TreeNode *)GetItemData(lId);
+
+  wxCHECK( pNode != NULL );
+
+  if ( pNode->IsRoot() ) {
+    wxLogError("Can't create a subkey under the root key.");
+    return;
+  }
+  if ( !pNode->IsKey() ) {
+    wxLogError("Can't create a subkey under a value!");
+    return;
+  }
+
+  wxRegKey key1(pNode->Key(), "key1");
+  if ( key1.Create() ) {
+    wxRegKey key2a(key1, "key2a"), key2b(key1, "key2b");
+    if ( key2a.Create() && key2b.Create() ) {
+      // put some values under the newly created keys
+      key1.SetValue("first_term", "10");
+      key1.SetValue("second_term", "7");
+      key2a = "this is the unnamed value";
+      key2b.SetValue("sum", 17);
+
+      // refresh tree
+      pNode->Refresh();
+      wxLogStatus("Test keys successfully added.");
+      return;
+    }
+  }
+  
+  wxLogError("Creation of test keys failed.");
+}
+
+void RegTreeCtrl::OnChar(wxKeyEvent& event)
+{
+  if ( event.KeyCode() == WXK_DELETE )
+    DeleteSelected();
+  else
+    wxTreeCtrl::OnChar(event);
+}
+
+void RegTreeCtrl::OnSelChanged(wxTreeEvent& event)
+{
+  wxFrame *pFrame = (wxFrame *)(wxWindow::GetParent());
+  pFrame->SetStatusText(GetNode(event)->FullName(), 1);
+}
+
+void RegTreeCtrl::OnItemExpanding(wxTreeEvent& event)
+{
+  TreeNode *pNode = GetNode(event);
+  bool bExpanding = event.m_code == wxTREE_EXPAND_EXPAND;
+
+  // expansion might take some time
+  wxSetCursor(*wxHOURGLASS_CURSOR);
+  wxLogStatus("Working...");
+  wxYield();  // to give the status line a chance to refresh itself
+
+  if ( pNode->IsKey() ) {
+    if ( bExpanding ) {
+      // expanding: add subkeys/values
+      if ( !pNode->OnExpand() )
+        return;
+    }
+    else {
+      // collapsing: clean up
+      pNode->OnCollapse();
+    }
+
+    // change icon for non root key
+    if ( !pNode->IsRoot() ) {
+      int idIcon = bExpanding ? RegImageList::OpenedKey 
+                              : RegImageList::ClosedKey;
+      SetItemImage(pNode->Id(), idIcon, idIcon);
+    }
+  }
+
+  wxLogStatus("Ok");
+  wxSetCursor(*wxSTANDARD_CURSOR);
+}
+
+// ----------------------------------------------------------------------------
+// TreeNode implementation
+// ----------------------------------------------------------------------------
+bool RegTreeCtrl::TreeNode::OnExpand()
+{
+  // remove dummy item
+  if ( m_lDummy != 0 )
+    m_pTree->DeleteItem(m_lDummy);
+
+  if ( IsRoot() ) {
+    // we're the root key
+    m_pTree->AddStdKeys();
+    return true;
+  }
+
+  if ( Parent()->IsRoot() ) {
+    // we're a standard key
+    m_pKey = new wxRegKey(m_strName);
+  }
+  else {
+    // we're a normal key
+    m_pKey = new wxRegKey(*(Parent()->m_pKey), m_strName);
+  }
+
+  if ( !m_pKey->Open() ) {
+    m_lDummy = 0;
+    wxLogError("The key '%s' can't be opened.", FullName());
+    return false;
+  }
+
+  // enumeration variables
+  long l;
+  wxString str;
+  bool bCont;
+
+  // enumerate all subkeys
+  bCont = m_pKey->GetFirstKey(str, l);
+  while ( bCont ) {
+    m_pTree->InsertNewTreeNode(this, str, RegImageList::ClosedKey);
+    bCont = m_pKey->GetNextKey(str, l);
+  }
+
+  // enumerate all values
+  bCont = m_pKey->GetFirstValue(str, l);
+  while ( bCont ) {
+    wxString strItem;
+    if (str.IsEmpty())
+        strItem = "<default>";
+    else
+        strItem = str;
+    strItem += " = ";
+
+    // determine the appropriate icon
+    RegImageList::Icon icon;
+    switch ( m_pKey->GetValueType(str) ) {
+      case wxRegKey::Type_String:
+      case wxRegKey::Type_Expand_String:
+      case wxRegKey::Type_Multi_String:
+        {
+          wxString strValue;
+          icon = RegImageList::TextValue;
+          m_pKey->QueryValue(str, strValue);
+          strItem += strValue;
+        }
+        break;
+
+      case wxRegKey::Type_None:
+        // @@ handle the error...
+        icon = RegImageList::BinaryValue;
+        break;
+
+      case wxRegKey::Type_Dword:
+        {
+          char szBuf[128];
+          long l;
+          m_pKey->QueryValue(str, &l);
+          sprintf(szBuf, "%lx", l);
+          strItem += szBuf;
+        }
+
+        // fall through
+
+      default:
+        icon = RegImageList::BinaryValue;
+    }
+
+    m_pTree->InsertNewTreeNode(this, str, icon, &strItem);
+    bCont = m_pKey->GetNextValue(str, l);
+  }
+
+  return true;
+}
+
+void RegTreeCtrl::TreeNode::OnCollapse()
+{
+  bool bHasChildren = !m_aChildren.IsEmpty();
+  DestroyChildren();
+  if ( bHasChildren )
+    AddDummy();
+  else
+    m_lDummy = 0;
+
+  delete m_pKey;
+  m_pKey = NULL;
+}
+
+void RegTreeCtrl::TreeNode::AddDummy()
+{
+  // insert dummy item forcing appearance of [+] button
+  m_lDummy = m_pTree->InsertItem(Id(), "");
+}
+
+void RegTreeCtrl::TreeNode::DestroyChildren()
+{
+  // destroy all children
+  uint nCount = m_aChildren.Count();
+  for ( uint n = 0; n < nCount; n++ ) {
+    long lId = m_aChildren[n]->Id();
+    delete m_aChildren[n];
+    m_pTree->DeleteItem(lId);
+  }
+
+  m_aChildren.Empty();
+}
+
+RegTreeCtrl::TreeNode::~TreeNode()
+{
+  DestroyChildren();
+
+  delete m_pKey;
+}
+
+const char *RegTreeCtrl::TreeNode::FullName() const
+{
+  static wxString s_strName;
+
+  if ( IsRoot() ) {
+    return "Registry Root";
+  }
+  else {
+    // our own registry key might not (yet) exist or we might be a value, 
+    // so just use the parent's and concatenate
+    s_strName = Parent()->FullName();
+    s_strName << '\\' << m_strName;
+
+    return s_strName;
+  }
+}
+
+// ----------------------------------------------------------------------------
+// operations on RegTreeCtrl
+// ----------------------------------------------------------------------------
+
+void RegTreeCtrl::DeleteSelected()
+{
+  long lCurrent = GetSelection(),
+       lParent  = GetParent(lCurrent);
+
+  if ( lParent == 0 ) {
+    wxLogError("Can't delete root key.");
+    return;
+  }
+
+  TreeNode *pCurrent = (TreeNode *)GetItemData(lCurrent),
+           *pParent  = (TreeNode *)GetItemData(lParent);
+
+  wxCHECK ( pCurrent && pParent );
+
+  if ( pParent->IsRoot() ) {
+    wxLogError("Can't delete standard key.");
+    return;
+  }
+
+  if ( pCurrent->IsKey() ) {
+    if ( wxMessageBox("Do you really want to delete this key?",
+                      "Confirmation", 
+                      wxICON_QUESTION | wxYES_NO | wxCANCEL, this) != wxYES ) {
+      return;
+    }
+
+    // must close key before deleting it
+    pCurrent->OnCollapse();
+
+    if ( pParent->Key().DeleteKey(pCurrent->m_strName) )
+      pParent->Refresh();
+  }
+  else {
+    if ( wxMessageBox("Do you really want to delete this value?",
+                      "Confirmation", 
+                      wxICON_QUESTION | wxYES_NO | wxCANCEL, this) != wxYES ) {
+      return;
+    }
+
+    if ( pParent->Key().DeleteValue(pCurrent->m_strName) )
+      pParent->Refresh();
+  }
+}
+
+void RegTreeCtrl::CreateNewKey(const wxString& strName)
+{
+  long lCurrent = GetSelection();
+  TreeNode *pCurrent = (TreeNode *)GetItemData(lCurrent);
+
+  wxCHECK( pCurrent != NULL );
+  
+  wxASSERT( pCurrent->IsKey() );  // check must have been done before
+
+  if ( pCurrent->IsRoot() ) {
+    wxLogError("Can't create a new key under the root key.");
+    return;
+  }
+
+  wxRegKey key(pCurrent->Key(), strName);
+  if ( key.Create() )
+    pCurrent->Refresh();
+}
+
+void RegTreeCtrl::CreateNewTextValue(const wxString& strName)
+{
+  long lCurrent = GetSelection();
+  TreeNode *pCurrent = (TreeNode *)GetItemData(lCurrent);
+
+  wxCHECK( pCurrent != NULL );
+  
+  wxASSERT( pCurrent->IsKey() );  // check must have been done before
+
+  if ( pCurrent->IsRoot() ) {
+    wxLogError("Can't create a new value under the root key.");
+    return;
+  }
+
+  if ( pCurrent->Key().SetValue(strName, "") )
+    pCurrent->Refresh();
+}
+
+void RegTreeCtrl::CreateNewBinaryValue(const wxString& strName)
+{
+  long lCurrent = GetSelection();
+  TreeNode *pCurrent = (TreeNode *)GetItemData(lCurrent);
+
+  wxCHECK( pCurrent != NULL );
+  
+  wxASSERT( pCurrent->IsKey() );  // check must have been done before
+
+  if ( pCurrent->IsRoot() ) {
+    wxLogError("Can't create a new value under the root key.");
+    return;
+  }
+
+  if ( pCurrent->Key().SetValue(strName, 0) )
+    pCurrent->Refresh();
+}
+
+bool RegTreeCtrl::IsKeySelected() const
+{
+  long lCurrent = GetSelection();
+  TreeNode *pCurrent = (TreeNode *)GetItemData(lCurrent);
+
+  wxCHECK_RET( pCurrent != NULL, false );
+
+  return pCurrent->IsKey();
+}
\ No newline at end of file
diff --git a/samples/regtest/regtest.rc b/samples/regtest/regtest.rc
new file mode 100644
index 0000000000..8d688bba6f
--- /dev/null
+++ b/samples/regtest/regtest.rc
@@ -0,0 +1,9 @@
+#include "wx/msw/wx.rc"
+
+app_icon 	ICON "registry.ico"
+icon_key1 	ICON "key1.ico"
+icon_key2 	ICON "key2.ico"
+icon_key3 	ICON "key3.ico"
+icon_value1 	ICON "value1.ico"
+icon_value2 	ICON "value2.ico"
+
diff --git a/samples/regtest/value1.ico b/samples/regtest/value1.ico
new file mode 100644
index 0000000000000000000000000000000000000000..d03a5d07629452d96cc127801a9e84007d98649b
GIT binary patch
literal 318
zcma)2F%kkH3|z*WxhqL?t(HEI4m;C%9be)pK0!LWxB*Wa3pZpp$xavsATVN#aGV3M
zx-xxoVg^iPKs)~;I&P{CA+toSmFkA|12eCf3?Dh|SiD%0&iMkAbfcNGr9vgX+Js;)
p?Z}f#lcDzMuifX8y!XTu<DQ~JH*6gWdjj{z{)j)7e}n^b23|($T_gYi

literal 0
HcmV?d00001

diff --git a/samples/regtest/value2.ico b/samples/regtest/value2.ico
new file mode 100644
index 0000000000000000000000000000000000000000..343fd1aaf0f7d99d7cd70f206cb0f46ccf8d21b2
GIT binary patch
literal 318
zcma)2Ar8YZ47_NQS{O7uxaWms&}?P?QXWvLU+5DC2P%1IM*))xc8TxKXM-p};>kI~
z@kqeUmF3Bum2f2k5`0FS_)w$^nHH@zst+tK%-pefJaQVC-ONR%`UJGRIIPu*uE%z)
oU1_5q8aelfqHIR~qmc_V)>OJKSONn30Q-A9;!out;li4LFUas}=l}o!

literal 0
HcmV?d00001

diff --git a/samples/taskbar/makefile.b32 b/samples/taskbar/makefile.b32
new file mode 100644
index 0000000000..497d91192b
--- /dev/null
+++ b/samples/taskbar/makefile.b32
@@ -0,0 +1,64 @@
+#
+# File:		makefile.bcc
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds tab example
+
+# WXWIN and BCCDIR are set by parent make
+
+WXDIR = $(WXWIN)
+!include $(WXDIR)\src\makeb32.env
+
+WXLIBDIR = $(WXDIR)\lib
+WXINC = $(WXDIR)\include\msw
+WXLIB = $(WXLIBDIR)\wx32.lib
+LIBS=$(WXLIB) cw32 import32 ole2w32
+
+TARGET=tbtest
+
+!if "$(FINAL)" == "0"
+LINKFLAGS=/v /Tpe /L$(WXLIBDIR);$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS= -v
+!else
+LINKFLAGS=/Tpe /L$(WXLIBDIR);$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS =
+!endif
+CPPFLAGS=$(DEBUG_FLAGS) $(OPT) @$(CFG)
+
+OBJECTS = tbtest.obj
+
+$(TARGET).exe:	$(OBJECTS) $(TARGET).def $(TARGET).res
+  tlink32 $(LINKFLAGS) @&&!
+c0w32.obj $(OBJECTS)
+$(TARGET)
+nul
+$(LIBS)
+$(TARGET).def
+!
+        brc32 -K $(TARGET).res
+
+.$(SRCSUFF).obj:
+	bcc32 $(CPPFLAGS) -c {$< }
+
+.c.obj:
+	bcc32 $(CPPFLAGS) -P- -c {$< }
+
+tbtest.obj:      tbtest.$(SRCSUFF)
+
+$(TARGET).res :      $(TARGET).rc $(WXDIR)\include\wx\msw\wx.rc
+    brc32 -r /i$(BCCDIR)\include /i$(WXDIR)\include $(TARGET)
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.rws
+
diff --git a/samples/taskbar/makefile.bcc b/samples/taskbar/makefile.bcc
new file mode 100644
index 0000000000..aa2c61b4a8
--- /dev/null
+++ b/samples/taskbar/makefile.bcc
@@ -0,0 +1,73 @@
+#
+# File:		makefile.bcc
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds tbtest example (DOS).
+
+!if "$(BCCDIR)" == ""
+!error You must define the BCCDIR variable in autoexec.bat, e.g. BCCDIR=d:\bc4
+!endif
+
+!if "$(WXWIN)" == ""
+!error You must define the WXWIN variable in autoexec.bat, e.g. WXWIN=c:\wx
+!endif
+
+WXDIR = $(WXWIN)
+!include $(WXDIR)\src\makebcc.env
+
+THISDIR = $(WXDIR)\samples\taskbar
+WXLIB = $(WXDIR)\lib\wx.lib
+LIBS=$(WXLIB) mathwl cwl import
+INC=-I$(WXDIR)\include\base -I$(WXDIR)\include\msw
+CFG=$(WXDIR)\src\wxwin.cfg
+
+!ifndef FINAL
+FINAL=0
+!endif
+
+!if "$(FINAL)" == "0"
+LINKFLAGS=/v/Vt /Twe /L$(WXDIR)\lib;$(BCCDIR)\lib
+OPT = -Od
+DEBUG_FLAGS= -v
+!else
+LINKFLAGS=/Twe /L$(WXDIR)\lib;$(BCCDIR)\lib
+OPT = -O2
+DEBUG_FLAGS=
+!endif
+CPPFLAGS=$(DEBUG_FLAGS) $(OPT) @$(CFG)
+
+OBJECTS = tbtest.obj
+
+tbtest:    tbtest.exe
+
+all:    tbtest.exe
+
+tbtest.exe:    $(WXLIB) tbtest.obj tbtest.def tbtest.res
+        tlink $(LINKFLAGS) @&&!
+c0wl.obj tbtest.obj
+tbtest
+nul
+$(LIBS)
+tbtest.def
+!
+        rc -31 -K tbtest.res
+
+.$(SRCSUFF).obj:
+	bcc $(CPPFLAGS) -c {$< }
+
+tbtest.obj:      tbtest.$(SRCSUFF)
+
+tbtest.res :      tbtest.rc $(WXDIR)\include\msw\wx.rc
+    rc -r /i$(BCCDIR)\include /i$(WXDIR)\include\msw /i$(WXDIR)\contrib\fafa tbtest
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.rws
diff --git a/samples/taskbar/makefile.dos b/samples/taskbar/makefile.dos
new file mode 100644
index 0000000000..1872f14856
--- /dev/null
+++ b/samples/taskbar/makefile.dos
@@ -0,0 +1,65 @@
+#
+# File:		makefile.dos
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds taskbar example (DOS).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+WXDIR = $(WXWIN)
+
+!include $(WXDIR)\src\makemsc.env
+
+THISDIR = $(WXDIR)\samples\taskbar
+
+!ifndef FINAL
+FINAL=0
+!endif
+
+HEADERS =
+SOURCES = tbtest.$(SRCSUFF)
+OBJECTS = tbtest.obj
+
+all:    tbtest.exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.dos FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.dos clean
+        cd $(THISDIR)
+
+tbtest.exe:      $(WXDIR)\src\msw\dummy.obj $(WXLIB) tbtest.obj tbtest.def tbtest.res
+        link $(LINKFLAGS) @<<
+tbtest.obj $(WXDIR)\src\msw\dummy.obj,
+tbtest,
+NUL,
+$(LIBS),
+tbtest.def
+;
+<<
+        rc -K tbtest.res
+
+tbtest.obj:      tbtest.$(SRCSUFF)
+        cl @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+tbtest.res :      tbtest.rc $(WXDIR)\include\wx\msw\wx.rc
+    rc -r /i$(WXDIR)\include tbtest
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
diff --git a/samples/taskbar/makefile.g95 b/samples/taskbar/makefile.g95
new file mode 100644
index 0000000000..a26fef6cd7
--- /dev/null
+++ b/samples/taskbar/makefile.g95
@@ -0,0 +1,37 @@
+#
+# File:		makefile.unx
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile for taskbar example
+
+WXDIR = ../..
+
+# All common UNIX compiler flags and options are now in
+# this central makefile.
+include $(WXDIR)/src/makeg95.env
+
+OBJECTS = $(OBJDIR)/tbtest.$(OBJSUFF) $(OBJDIR)/tbtest_resources.$(OBJSUFF)
+
+all:    $(OBJDIR) tbtest$(GUISUFFIX)$(EXESUFF)
+
+wx:
+
+$(OBJDIR):
+	mkdir $(OBJDIR)
+
+tbtest$(GUISUFFIX)$(EXESUFF):	$(OBJECTS) $(WXLIB)
+	$(CC) $(LDFLAGS) -o tbtest$(GUISUFFIX)$(EXESUFF) $(OBJECTS) $(LDLIBS)
+
+$(OBJDIR)/tbtest.$(OBJSUFF):	tbtest.$(SRCSUFF)
+	$(CC) -c $(CPPFLAGS) -o $@ tbtest.$(SRCSUFF)
+
+$(OBJDIR)/tbtest_resources.o:  tbtest.rc
+	$(RESCOMP) -i tbtest.rc -o $(OBJDIR)/tbtest_resources.o $(RESFLAGS)
+
+clean:
+	rm -f $(OBJECTS) tbtest$(GUISUFFIX).exe core *.rsc *.res
diff --git a/samples/taskbar/makefile.nt b/samples/taskbar/makefile.nt
new file mode 100644
index 0000000000..459749a077
--- /dev/null
+++ b/samples/taskbar/makefile.nt
@@ -0,0 +1,64 @@
+#
+# File:		makefile.nt
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds tab example (MS VC++).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+
+WXUSINGDLL=0
+
+!include $(WXDIR)\src\ntwxwin.mak
+
+THISDIR = $(WXDIR)\samples\taskbar
+PROGRAM=tbtest
+
+OBJECTS = $(PROGRAM).obj
+
+$(PROGRAM):    $(PROGRAM).exe
+
+all:    wx $(PROGRAM).exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt clean
+        cd $(THISDIR)
+
+$(PROGRAM).exe:      $(DUMMYOBJ) $(WXLIB) $(OBJECTS) $(PROGRAM).res
+	$(link) @<<
+-out:$(PROGRAM).exe
+$(LINKFLAGS)
+$(DUMMYOBJ) $(OBJECTS) $(PROGRAM).res
+$(LIBS)
+<<
+
+
+$(PROGRAM).obj:      $(PROGRAM).$(SRCSUFF) $(DUMMYOBJ)
+        $(cc) @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+$(PROGRAM).res :      $(PROGRAM).rc $(WXDIR)\include\wx\msw\wx.rc
+    $(rc) -r /i$(WXDIR)\include -fo$@ $(PROGRAM).rc
+
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
diff --git a/samples/taskbar/mondrian.ico b/samples/taskbar/mondrian.ico
new file mode 100644
index 0000000000000000000000000000000000000000..2310c5d275a87af295d5ea8dc79ea417a5e74c53
GIT binary patch
literal 766
zcmZQzU<5)11px*Sc)`TLAO@s0fLH;D9e|jTfdxnc0Z<M**w4TKL=5})Lnt5#WHKB$
zaDbtqp#doIAB-6O{|B*v7zjZ^AOa2W|NsACHyAJ}De?dRKnp(HN~rljcR;{k;{zQE
i@;}UZ|9Q?Fpp*~yJCwmWbLIrN`9Qm9%}2L?p!oo$cZ4ed

literal 0
HcmV?d00001

diff --git a/samples/taskbar/tbtest.cpp b/samples/taskbar/tbtest.cpp
new file mode 100644
index 0000000000..7618108bc6
--- /dev/null
+++ b/samples/taskbar/tbtest.cpp
@@ -0,0 +1,120 @@
+/////////////////////////////////////////////////////////////////////////////
+// Name:        tbtest.cpp
+// Purpose:     wxTaskBarIcon demo
+// Author:      Julian Smart
+// Modified by:
+// Created:     01/02/97
+// RCS-ID:      $Id$
+// Copyright:   (c)
+// Licence:   	wxWindows licence
+/////////////////////////////////////////////////////////////////////////////
+
+// For compilers that support precompilation, includes "wx.h".
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+#pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+#include "wx.h"
+#endif
+
+#include "wx/msw/taskbar.h"
+#include "tbtest.h"
+
+// Declare two frames
+MyDialog   *dialog = NULL;
+
+IMPLEMENT_APP(MyApp)
+
+bool MyApp::OnInit(void)
+{
+    wxIcon icon("mondrian_icon");
+
+    if (!m_taskBarIcon.SetIcon(icon, "wxTaskBarIcon Sample"))
+        wxMessageBox("Could not set icon.");
+
+    // Create the main frame window
+    dialog = new MyDialog(NULL, -1, "wxTaskBarIcon Test Dialog", wxPoint(-1, -1), wxSize(365, 290), wxDIALOG_MODELESS|wxDEFAULT_DIALOG_STYLE);
+
+    dialog->Show(TRUE);
+
+    return TRUE;
+}
+
+BEGIN_EVENT_TABLE(MyDialog, wxDialog)
+    EVT_BUTTON(wxID_OK, MyDialog::OnOK)
+    EVT_BUTTON(wxID_EXIT, MyDialog::OnExit)
+END_EVENT_TABLE()
+
+MyDialog::MyDialog(wxWindow* parent, const wxWindowID id, const wxString& title,
+    const wxPoint& pos, const wxSize& size, const long windowStyle):
+  wxDialog(parent, id, title, pos, size, windowStyle)
+{
+    Init();
+}
+
+void MyDialog::OnOK(wxCommandEvent& event)
+{
+    Show(FALSE);
+}
+
+void MyDialog::OnExit(wxCommandEvent& event)
+{
+    Close(TRUE);
+}
+
+void MyDialog::OnCloseWindow(wxCloseEvent& event)
+{
+    Destroy();
+}
+
+void MyDialog::Init(void)
+{
+  int dialogWidth = 365;
+  int dialogHeight = 290;
+
+  wxStaticText* stat = new wxStaticText(this, -1, "Press OK to hide me, Exit to quit.",
+    wxPoint(10, 20));
+  
+  wxStaticText* stat2 = new wxStaticText(this, -1, "Double-click on the taskbar icon to show me again.",
+    wxPoint(10, 40));
+
+  wxButton *okButton = new wxButton(this, wxID_OK, "OK", wxPoint(100, 230), wxSize(80, 25));
+  wxButton *exitButton = new wxButton(this, wxID_EXIT, "Exit", wxPoint(185, 230), wxSize(80, 25));
+  okButton->SetDefault();
+  this->Centre(wxBOTH);
+}
+
+// Overridables
+void MyTaskBarIcon::OnMouseMove(void)
+{
+}
+
+void MyTaskBarIcon::OnLButtonDown(void)
+{
+}
+
+void MyTaskBarIcon::OnLButtonUp(void)
+{
+}
+
+void MyTaskBarIcon::OnRButtonDown(void)
+{
+}
+
+void MyTaskBarIcon::OnRButtonUp(void)
+{
+}
+
+void MyTaskBarIcon::OnLButtonDClick(void)
+{
+    dialog->Show(TRUE);
+}
+
+void MyTaskBarIcon::OnRButtonDClick(void)
+{
+}
+
+
diff --git a/samples/taskbar/tbtest.def b/samples/taskbar/tbtest.def
new file mode 100644
index 0000000000..db80cc854b
--- /dev/null
+++ b/samples/taskbar/tbtest.def
@@ -0,0 +1,8 @@
+NAME         TBTest
+DESCRIPTION  'wxTaskBarIcon test'
+EXETYPE      WINDOWS
+STUB         'WINSTUB.EXE'
+CODE         PRELOAD MOVEABLE DISCARDABLE
+DATA         PRELOAD MOVEABLE MULTIPLE
+HEAPSIZE     1024
+STACKSIZE    16192
diff --git a/samples/taskbar/tbtest.h b/samples/taskbar/tbtest.h
new file mode 100644
index 0000000000..a1a01e3a56
--- /dev/null
+++ b/samples/taskbar/tbtest.h
@@ -0,0 +1,50 @@
+/////////////////////////////////////////////////////////////////////////////
+// Name:        tbtest.h
+// Purpose:     wxTaskBarIcon sample
+// Author:      Julian Smart
+// Modified by:
+// Created:     01/02/97
+// RCS-ID:      $Id$
+// Copyright:   (c)
+// Licence:   	wxWindows licence
+/////////////////////////////////////////////////////////////////////////////
+
+class MyTaskBarIcon: public wxTaskBarIcon
+{
+public:
+	MyTaskBarIcon() {};
+
+    virtual void OnMouseMove(void);
+    virtual void OnLButtonDown(void);
+    virtual void OnLButtonUp(void);
+    virtual void OnRButtonDown(void);
+    virtual void OnRButtonUp(void);
+    virtual void OnLButtonDClick(void);
+    virtual void OnRButtonDClick(void);
+};
+
+
+// Define a new application
+class MyApp: public wxApp
+{
+public:
+    bool OnInit(void);
+protected:
+    MyTaskBarIcon   m_taskBarIcon;
+};
+
+class MyDialog: public wxDialog
+{
+public:
+    MyDialog(wxWindow* parent, const wxWindowID id, const wxString& title,
+        const wxPoint& pos, const wxSize& size, const long windowStyle = wxDEFAULT_DIALOG_STYLE);
+
+    void OnOK(wxCommandEvent& event);
+    void OnExit(wxCommandEvent& event);
+    void OnCloseWindow(wxCloseEvent& event);
+    void Init(void);
+
+DECLARE_EVENT_TABLE()
+};
+
+
diff --git a/samples/taskbar/tbtest.rc b/samples/taskbar/tbtest.rc
new file mode 100644
index 0000000000..a05f21065a
--- /dev/null
+++ b/samples/taskbar/tbtest.rc
@@ -0,0 +1,3 @@
+mondrian_icon ICON "mondrian.ico"
+#include "wx/msw/wx.rc"
+
diff --git a/src/msw/ctl3d/borland/makefile.b32 b/src/msw/ctl3d/borland/makefile.b32
new file mode 100644
index 0000000000..1783689b82
--- /dev/null
+++ b/src/msw/ctl3d/borland/makefile.b32
@@ -0,0 +1,25 @@
+#
+# File:		makefile.b32
+# Author:       Andre Beltman
+# Created:	1995
+# Updated:	
+# Copyright:    (c) 1995, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Imports 32bit ctl3d library for Windows 95
+# and Borland C++ 4.x
+
+WXDIR = $(WXWIN)
+WXLIB = $(WXDIR)\lib
+
+LIBTARGET= $(WXLIB)\ctl3d32.lib
+
+all:    $(LIBTARGET)
+
+$(LIBTARGET):
+	erase $(LIBTARGET)
+        implib $(LIBTARGET) ..\ctl3d32.dll
+
+clean:
+        -erase $(LIBTARGET)
diff --git a/src/msw/ctl3d/borland/makefile.bcc b/src/msw/ctl3d/borland/makefile.bcc
new file mode 100644
index 0000000000..6a0bcdb158
--- /dev/null
+++ b/src/msw/ctl3d/borland/makefile.bcc
@@ -0,0 +1,25 @@
+#
+# File:		makefile.b32
+# Author:       Andre Beltman
+# Created:	1995
+# Updated:	
+# Copyright:    (c) 1995, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Imports ctl3d library
+# and Borland C++ 4.x
+
+WXDIR = $(WXWIN)
+WXLIB = $(WXDIR)\lib
+
+LIBTARGET= $(WXLIB)\ctl3dv2.lib
+
+all:    $(LIBTARGET)
+
+$(LIBTARGET):
+	erase $(LIBTARGET)
+        implib $(LIBTARGET) ..\ctl3dv2.dll
+
+clean:
+        -erase $(LIBTARGET)
diff --git a/src/msw/ctl3d/ctl3d.dll b/src/msw/ctl3d/ctl3d.dll
new file mode 100644
index 0000000000000000000000000000000000000000..74f3db72c6fe19728eb98fd0a72ca30c5cfbe6a4
GIT binary patch
literal 20964
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

literal 0
HcmV?d00001

diff --git a/src/msw/ctl3d/ctl3d32.dll b/src/msw/ctl3d/ctl3d32.dll
new file mode 100644
index 0000000000000000000000000000000000000000..a4d26ed9232e1ff1805ce699f41e999d60017f0a
GIT binary patch
literal 26623
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

literal 0
HcmV?d00001

diff --git a/src/msw/ctl3d/ctl3dv2.dll b/src/msw/ctl3d/ctl3dv2.dll
new file mode 100644
index 0000000000000000000000000000000000000000..7db141d43faf23bba0e6bd7699700c002a020a72
GIT binary patch
literal 27620
zcmeHwe|%KcweLQ2W+uZVpGgQm1cWdmq-X$v&?sW~oe5M7fxrZ{22sKfg@ooOVjF^E
z!;FU@^;xdY?e$8r+S~SWz1D{VcrpAaL7*0p(iE+w!Qu=_(=?`GOyivUU3;H1b0!J2
zz3;ux=l#*>oc(L<wbx#I?X}lld!NGt51o@tj4?BQs>)aZA^pwf&znDLQS2Cf(81mw
z@blXO(xRW=wrt({a_6S9(zRu)Hag3Szfrlqthn6y!1~9_O3O>vR5%OQm#i+WE}vu{
zt6|Q|vD|k}YgF=p2>kzAip)#ROlBWRv)Q9;2m6rynvDUSBRQca+gxV00!W_EZez2P
zZet7B_j2+_eJ|&f`C>}`sEa9WmZ_F+*r!^|%v39JY%c3cHaV&BGfJdrc|Wj@K%P{~
z0a(JkWs5TByQczeVNQNfPF}fkWzLHH#Y>mv%r98Be6E8HnKx(AqQboS`AZkib1hu7
zEN3ajlGy-WbHU=p_m5;uVm6k<nDzdgrFl7v<lOlS&C3gNmX1{ApU;v9oA5O4bkOrB
ziS)D%r2J`=FE8Vz6DCsrw7cnfcsf11`E%1uf~jEiJWNlMH;0}d^STWZ#jA$U)0T>-
z+{SaJQQTCMLOBOH{t7$goafKO{MpVa>9J9M?QoURe;+VOqH%C!u690NT2fI~y1}`6
z!v<u`Tl~P>#Tpkf=i6Cw!Lm8a7S4<2B(fyVkDR<Ya~I{zx3E;6ELc8w-l91L1@jl>
z=ByaPl6mIxyrnt03k$$Wy9TyAPX`3R2rUzJTubLXkdr@WVcxRAy$}K}XT@-4&zZk)
zS(FGHOW_U7TfAuT(s>K!<mKjAnVo0pEhcFodV6TZ)GG_{GP5rNfl<T*G%P6MxXmn)
zW6jN3=FV9vv81`n@}j^AY!EM;vwYcNy_uX9w`vSRgCsu#HD2f#b5^8kZ4~4zD_Hj6
zqMSi&AV*WUFc1HU-VD|9jHpwz=9cFfbBAfU3k!_7w+NyCKYZ?J+Lg0hX-(VNw5`?3
z+=T&&g&12|RKF%N`jH1tk!Jb3{^nLzRFsy)SD7$TRd?Phu|@04E9RDNjw?JoJ)Nx^
zX<|96*H^?9ATjOkxh!(4nawNR_*iMLirv$T*h8aite|35#rntNYi^pkg>6ckEb1+a
zuXuR+Zgw8+4Q9zKg{3kJCi_5UW#EBefTzaHD&)`r(rE`73(aC`m3hw&6XHwr{iI<L
zJCMSH?X!HYZlAk{ig#+oe*_^YR`R-)qMpPfi63%aD!+f^SQJ0NgWpj-$4#QPr>2{l
zD`%dX9*R7Hh}DWn3fnWxq6{5j5pbbfSYQ~tUSd7uHOoy(u30Ix_Gw>nbt~>3L8XCe
zkxeu&m^DsSJ<TlN|6M3mksl>-myyOj&uU$A05F>oX`4AGp40Mw7tMc^=j$x^BAUN|
z=X*8yfe<BuXL1}z?}+9P<N0+O{2Y;ADTibh+DJvghazB`!0~nF;e1<01%VzlUvXI#
zw@n+N8!`scZEQTon7d}`jM;~FR~FHb?J~}d6q*|l<0jFN&(+~`cdA(%OlsB>CbcR_
zt+K0CHnqyiMa1Xo^0~vui#qm{nbN1{+Q7Z<GaZ^kY@4~;v{EjYLz5W5($#8Ppj{Os
zH_ps3M53QI>L++$V~wtMNTY>9DOP1*KEyP?-qpV2yw-P5O*>T>g61}XxDu0wKIjDZ
ztc}(u(7#6O2L3GJ&rSSUhNt4{QruzV{I@Y76()3F^n7oL$v1S9NpYF?mYD)(mLK@o
zbnq?A4K?dU6YrYn#oi|Xx4|S>$tBAU9BP$=MzX!fbKI<t5@t|0GQm5}L1LwWi71Iq
zFPeRn)@S2J7#oz{rOC{<kT&!oI`4>jz#T8LrmJ`JXEoSjO~*8%AR{4Pq^vxZYswGY
z#tydY^Iek$-Uo-kq`2(oE}y%6$ZwLH)M}G@w?;7O1EtEU<k{+LI))~s?fmr*@He{N
z)uFgLEfVv&!ivi=&P1b&LAr}eF9whXF<_#B?4W@Zs)vWsIB!8ClcVY2___$6^gqG(
zgoT)uG~HzfCBumlq<Zzr1{l#MMhi`KSyUCGPi>n2Cv6_&Z92x;w8{kndjiK9=Eyq<
zIZF`?!b~XX!t^q82K^08ngpW~;A#~KmH!hoXB<6}Kz(?+jKhPj*~cYg3?%##XdJp|
z9Dpg9fN7HiDkM)ySn{~K@#~QwqOl>1f`0rZKzp|b92z!0f?UeG)T%HS`W~KVoFkIE
zu)Z!5*>T=i*B$Zg?uiilpG$a2@Z%SpUzAKIjXa!rTvjOtfh;J?AF<GO_UaUiR_AHG
zj;}5pd3CboC1qzgGUMb8t3Sy?3-l`4X(Xn}(d1}q_0E1<od&)e^q<w|wuR=ZN|AM^
z%SKe96Ur;yk)3rt5f8d1rF#=XW7OlwN<Wc6V<x)2G+%_u&hChU?q{4_BIZ_I7uXSw
zC<qmV$BXRgz68>ucG98)S>R5rYNQ~9;vB;Qdtw>r#1s~I6&e3((;=Kp$3-jSq<h2y
zfJt?{$N|)$5pm@Xty~m}5i_n2q!<J>Wpc<$#zW|S$uqOoL>v?88IsVTnEw6fch4GY
zk7tcd^~^kBa*Ba8Oa5eNG|aq4R~QH}8(d*&&k56XSNNN9D1!wYun5A3PC^S|ZcfiN
zp<b#n*OP0LLhrE92{mAWWY-QqXf+E>?WwWHD3eKR=BsIAVQkR4=BeqR!U3>FI!OSY
z<~S#vFlkNMeF@ZbEThYpYl_e5P~4rqT(hsxYRqp0J-u+zvhB;Y`wEjl!``DNbZ_r*
zlgE0(B#|vDSZA<Ett@U`rYY@TIpD@z8g1l9luJMh<O5jfyh=kA!+*Lj_HWy7jQyYc
z#r}*j*Hdbf3<KraY9rpRG=iwrR<+u!rcJPTz|+_W--~exLn04=*`dQ2=5~STJw(Iq
z!nA|~3GDM9tSl0_2atPGIYKfLI;4i&Ds}NjJtJE`UOb19(2A8vRiXN<!8L<C$881-
z*bT&Shh#n;$6jbgE16^d#n^iKT%A5QWVZtxeoC0H9m0G~PzoW$o#4YGY`VJ(;c}>e
z4r=t5o!m5_nn*^M{(8RDTcb<=I_%K3wy?A+?k<==-yuWB)k%*odUT{<!gNTGX6v`)
zP>o6vG<A$^tLdy7!W-XK)Ai;6#0vE0A^c>S^lpB$XfE3PXZ<w419`FLLtiKQ_UPvF
zgP=`lCNh6x{TdJ968U8Q#`-r~<YV#;=J}e5LkpDu9B@(JF{OoWbcLa#v8Ip-;jiW5
z8urwLY3e3YzP~;3Xj14my#xZoY1CjzeMa*&+KVu-jue5_x>Z+XJAl&`Jkt@i#&s)I
zOja`1g*7`291*54ayY35`N9f_5w-<J@?A{|+ws2KwDU;1S~v`=C`JIfN5aSqH|~45
ztwoI&d=6taUcOJ6<E7Kqr$4!zFyh(^f=33f?ROBVI@hq-(&hsA3<d@tPNAuAt~UqG
zV&7;+Q)DX~_*0Z6Y1#&5C~p(UI3jZ}l_UBta${!eis)El_1*#*>hW`%XZ~=`u6kDw
zx9;mPrMA_e3|zT|5CrDM13Z}=1IXkp=$o?ZTwG&@^Xq^l-pA<Ll8g>&wu@0JNWaF<
z@vXcjaq*<!nSqNvz#HS@V$Ma4gTJKh2gxYabfj>>;5ECr)MkksPfZs|Z7SM;d;q>H
z_&ur^x~PU;?#q26rG3YnW}uz7w}4|e&XU(fjy6kfjgGfiqA^<G;93Wb`Onor)sTZf
zw39Vx4}R3%SMGYPNKrb_kJq8VX@MgP<IG*c!pJr;7%V#sC2z$_Ftm%9*c-x*n5hBf
z^G*anGE@c7rbqK>&o~OhFiz$+g-lCJq9%F}rgY+fn)O3$1YZ}MGoF4G=~qnte}S>Q
z=Ur1MOGoF=h|K~Z64ROVQaCW2B-pscHLeT2I6!Ml4A?sGvlJt+El%qQSZoSoJ7})s
zo=6>=YOH0Ct2K?J61oYzNT8v6Ib>%6E0LHIe6fvd@K&F@%~R8=+c9kfdpo+)rdG8A
zjBiA>HvNU%%4+wyJ7D$oF8uRAl2t0y=fME*t6c#wcK=l=y3q;z(SiaKEH;Ty1^%dS
z(ZhTa@8B~pg>Uvf95XF7nivkkwwl(makXq)^X!!DTB1H8ZR?($g2<m?Kk`z{^5zC@
z)ktRBx*G^gSTr(m!{_?gQ}Z!(*pR6>(kvM#eR<b(l6|fqqV=u|oG!AQ6<1S+>w?b(
zWAajl>!QzfsnK<jpD6fT7Xq|B!q!M^Q+Xw|Di{o6LL_NO;2+7SALj^%$9hCMMk^=y
zK!5N<29r7ps#)&}A@#XFsjs?FUvn9Iw4tN5E%ar@by>EKgo*lTz3Z~ro&|$xG$FOL
zpg#jJyj4zy0rc}f0#tEb5J-Toi9mr)aW%`XYd+Ui1Mmp~*0?x})mL4vuQ_9+=8WRH
zCb>RPTp!3*Cy<=y{iQ{NZ{yGC^qmAAShmDZYE5!AQ)|{VR53PJNX-!osy^{A;oN|P
z26+!OS&JERr;_64LOSL`;14D^aBGsDAxRjiO$FMG@o5M#cLbltv`7j)EF&KEm&}JS
z>Ka8%A4hO`3#Jb#ySO>&|5+-GxKT1(1fl&V?CRj+z+&B)0CT=gCO@ep>lg+R2FRe#
z{YlizbtlHx!G-?5LC{t=@NiuM9`bNqqNxLLed=7|B03p0JvEo8i{q#qR?S1HV3=C<
zac^paLx8Civ$Ma#-9u@LT=uz}qvVZ=k~al~M)C%0$~1{XkZ@l}t{DnZRNT!WyD6%w
zQ#eI3NE8gcLmLD~(0r|5hW-={h0aK!Td884`hyVppGfT-8rlbI+EMTNlzI>4ugxo1
zN|&%p7TE^nlOJvIg^=E2;7<cFlDgWSjw1tMSdnhvyF0S5$iR$gU%xH&!CL@@Z6jJI
z2cQ2eXBc@jX?aEsC&nR65i&#Ks$Sq#zlm&N-o^FI|C9a+cpyr7Q?P%^Cl34DC{G?{
z>>t!6N#<IHg)}sSWhYU$7e%s%Q@A&h{cQ^Gi)7bPI4zQ$A|brz%j|i>5svsWdp?D!
zUt$^3Mf;v8eR2I>1M=b*tC-i6?7}^tMeRa|CQo8*ovy9*FbKwjXJ$S_J_VPIA{cL7
z3zbgVpno6r_8~i){8zYr+qLH?c3EBM#2QShFlg-MK^Sk`ghuzq$yf-&*n^AxIC+%b
zSB297BM#-lk2pv}7)Cx7wrQwR+C#@0kdh=BpmU|Do=_6fvEviY1@cF4+d9Hj3y|F`
z-LrKhNzxAHnfVfTe3Zm^LR!Plc~UUEf1dR6i*s;YYY3nClMr6bCk`hOOu3!IgejMT
zL9vqK2zhUf5P7MXIo6ObjxD)%r7#ID)~L_MU|+3-vxqzIgAQ1!+S$ZZo=N+Ba6X&&
zYZzjgI;{T#to!*v@)lAJ6b;jh$n>EV6#WPWWtg7^$ARV~FmPQ>8*ed+olWdU$lD#&
zY(mcR8Qe?1CHIoBM=>pMu7I806jnor3m^j`I2Hp>)~YB)!5{)b=>S$G8*K^RXw<u&
zYHV*InC+lG&BoY4d9_8A*G7o7o?gv%oWh2^7FlQ-!_SY~VD@XRz%kQH&bjyfZ*1vK
z9OCzCDH~aTPfKK$_Tu3>^el<=<%85SE|qIXkXqtSe}3|&S>fF0r_b7PU@D!;87*|Z
z484YnCRz7##dkS+8rO@CKWn38Z0vqbtIX4B6vKXs>lE5>J;_bY9y(;i*bJh4%wN*(
zaFqwYC6TCsl$RN%q!0oly#qD$g5C-i`i7w$RC_Gi&KsjRN9a@&?abHPflUN|cW?-`
zg9zX8C8rVSjYzu2G?GM5qWX?=h4$MTm7@uV;_7)ho9}&e&c1?P*vF-4i}6IHdR`V1
zU!zI9iB-$!2d|n$BB)n=gjaQHRhJv8rfXHrG+Bll3hvYj1`y6sENT=C1DkqMFo%*U
zl8PB6hL~IF(McrMiV^4&treBOiz*VGBEf=GSOYjpxEh^MFG8ldrz;d>+>6q6DC$K~
za!1_mvO?l93MaHuY(jUOl20yOq9O6W5uFr!`2f;p@=N6D2XmU;AP!S#bs|@dp%L9x
zLtYb_7z@x#8%5H&(xW{KmJ2$y?&5Ag&3j`G{`d;1S<SQ4tL!QCABHz~UKzPH2);ZV
z!qjw;FE2UjwT;t4oIzaU_)o$TBa*34XGc??!ajF57B<D*J&ra|{D{dg><-|z3RQ$&
z5Z|^#E7KVvoKbZ2g-w~zAS6v)<7R8A(LAM}=ndp4{X7m!=Q}(@X4v(kv1v$kWVqT0
zu{ahUgPhI`SG&luLqt-jSs4B4a;_b|Uu->fT}F!o`TuhG2Epu~b}OGj7#|ISTZ4M?
z0Ipvhfs);M8}010etVjoq7%Aokwwq}$<k3^br*J~W?%66Mu*=zGhcJ+%;ek_i|k9t
z)DEHf5=K;3pk09YzljiYls6%uzt2n1B9c0l)5iQYDmw+00tIbXjTF+#pj6qEJbQgj
z{K;N)--^9!)D#X*Y3AEjesmYzwvGS|o|;sWU|PM*2IG1%GvbLJ4_bpkh%5HL@rcd<
z5jJ1Pi){S78P95y&X?%X@^6Jln}Bc*jk8Z2LiZ1O@9n+NDY;gH?}Ku64A6k`M$q+u
z_S6g}xim~PE^=_b4yGwUemJX|b=c%Dz>W&`8~4~D=b*_SM0Ml{FCDk{adg|0;R?r2
z&kqTDxT6;b-`yE>%2d@EWx=SiQ3`&<NkNn3$QBKBqjre)U4nv#3Am&O=dj(9xD4?m
zFC#B9Rscc{+67be<NIvX;RND>L73Rpo5EKBfC&h0PItBAOl>g4IDRaL5SMW00#E>f
z?s-n-iU|H4P8nPlPw1`CxvtjD-VMFSVa)#DKs3Y*q#YxA_BMQRZ<+i*!2+$#AZ;?k
z$lxZnHTWrH%pnj$Qyeg{m#=>z(M<yCGqj1G11%MnUF|bmJ?IJfq9_IX9aZ@v*(JN$
zX1KbwLQ3(%Zs>b$yo;jU*Es3_9(0W^qF;hZRND%S-SD`@@_|7ltQG>I_6evb3Pkx_
z3BV&Ex&_aZV6;<HIDEEEcbOrM_w^y;cVM4ZK?}rO)-)bGKpYuQ(&;4xiB3MyT8G~Z
zeQ(qiSvX_Ywb`Gza^mXU$$WL!BAzu}qiO1o!8i$mxv`?%JgKj{h@*KZ)d>lpXaB`W
z{o%_IgIlQXa)dBXffz!M>N_R>9<mebf)TMEi-F%CjQIDai+m7D>V;De<nKZjC@U3N
z4}68+J6nK0K+J_37OR69Hahlro>Ma5#{mW-z`NV+&yJ<`gPi@%_<f4s)rfyKs8(FI
zs9i+<<*t{r6O85$?YXR~R#U0_G?IZ%<tuep5owOZ=Jt3_k=Z{Pp|9=}-fxpRzTeMs
zQra6`ZPac%Hnr!%zPbw$iepLS)`>y&C_67i5|8l1PG4PX#B=zQ2vK%BuiFp2#UxHf
zB>+>m?Apv4FS^Ay7Wz6jSma5BaI|L5@<WvRx;8$f0Vat7fTaMggv_`OLli@0biE9%
z71jZD8Q|<T2e*FVIi4E&i;Pa%87yn9Z+y8YUsfCL5r8)Ry39#pFCXZbr{Zno;VxN&
z$^QapScfLTFEY>JYY~#=c~pxA!_tAPZrWH_K3B!em-)arAaHhC<2u#-tr(8BfRi0O
zqhDgeoYKbi@2>vZ9VC05G?ns1l+#bW(#;-R$I~cvFs1HN#L}kvKrQB=f*E5;g@jy=
zj%U2$TZ=A(GM&4e(U--DjD`HWFh!^({l?H?Ru2K9IaptJUJJzl0!i@T$D}DW{$v19
zFvtf6Dfr3A@u8H65)=vcrf@QO&b~{L)OfNLkS?Pw>QFu6-2T?p<64lXXU0NJNz|f{
zcTH6CKaX_i999zBIIAZ8FG)A+PRmE=j_2?NJ`J3Po}U#|+`?Uf)bS%664aS>axG>s
z{nPkvqhWntvlZ&=GSt_pIQ4Z3@R!ij4`@2q*PY_c@X?N@b%X8G46c!)Knu9d(<9P4
z(0~bXK(qq;e+iWvYGoK11;as0SzS}a1HMb1eIG|8ZfDWC0r}B2bxS?m+C+wymZ4id
z{>#ulyoOM>aWx*G8oCmR7rHrj-caahIeHYuaLB>UEL<O>*tyF}(<Jqc_6Z-2|7iT!
zJI3BI;EsX#FEhhDaljoQk8Yc_VRCp52l<2*W((=~#EH?>$9P(q1%oy4o#Am_d-MT^
zvK$+>UfgT{vy13MXj7cm{=Z;~3Ei2_k1esH2LJU#-EkV{mb1WZ7MjYv_J?|T?StHF
zKa?=@P11W1PT`=#76q4gz}UW<B=QjP!qIfiSu7m5WWlfEa#!3K?TYG97Al1DYd5pd
zV$1>2#QR{yI8k!|>0zf<lTH{N0lC-WF={+*Z`;uUJB8LLW&-ZL(mXVYsBhC-n!uBE
zm8suu48~qBDFJ$wJKw4MTDMenTeJE{EUAfDTxkgh!r;8~{qpt|^u~u{BX_HY>^8ll
zIu*M?1@LS;#ZrLsS4dGwZ_>AOTDx$1Bbz~z9cTPW5?Mh|p19QIYD4BjR8w0u^g9YJ
z6t`g+Rr0z#zmsPi0T?!OdF^oQ!1peo0g;Kls*NSO+G!0#ez3a>8*D_7^cO*taFC_A
zTSG}w=t{rz&Ap4W7XB2hjKXxKZ2^3Hr?@FZrV&bz!{uls!24zTP)@In+4(swC#94~
z(QcxV-5-ZjSWh8%o9-t`L-$xDn{UkbeVJ{ibnr{z(x35Vb~2@BtJxB<u<pxj&dM6i
zm2c5p`Cs<H=c145#<Ts7YBxp$P|+74?82vduVDu~a58n6jzi-5X>bcKHp7KLF7R9$
zLR_gfI@2;Wsn0-%&4F8bNqsZeCzz~TE^s2KvUb>QqdHN2?7GGWz{)kR+26!xa8G`{
zmY=36UrOo<`Jbn7h3wzJ2elh_q{!RPNrduhrfat#TW^~75FO*Liz~lTAZLF-e<2|1
zP^WhO3-bmpI!jO%_q^W6p6#k1$KrU9AsfBh!u?tPe9(mh>1{PA1_5*m-xIsuB4Bdy
zVi!NOhUefSUxn#R>}fc6^t9$yeivDw5t0C>QO#A_&wowYRugQYA(>5X1i!-DyFja&
z#w`!$%mqF9ABLpPye1HU%B1TLgMVt(1^+u754KPIF2Y4lHo2TW=Q48E=RU8v&MNNn
zngGOkhS!3-hO#*SB^<hII<6BF$a{M)ca@${t4`FrPVzB-AEYR*Ga0UvcevUDwiJEP
z$;&zjYk^G^O4#Df<V5wBvnPQdejMqh5*X6$zs|cU#4PlzMAG1Dl|avzI6UWjq7IEq
z)Y=cA9c`Mple4t9xX;nVeLCYCshzlgtK_xun+Sm<Ec0}wfZw?0!b}*yi<ybV&m4T_
z4{(KsuIflhKzqsFBOt9!;%_1727nk&!t(&(@szZ|;KJd4kT*YhnxT1Hzs(P&YKkie
z-G1Ylv4r~s0)(M&!xw(R8*Y~ZLoj&%!JBNS9=CEz`}TM*RnR2s!%Xy3h?AJ@A0b0*
zU%4-iE@W-1u|7ldw9nZwaqWc<fGqUCAm*_fX60C`#Ejr4=LEL#w5I>!U%WUA!40`l
z8S8^NxZnmrU)41r4tr=)-3{3hzSdhnt?(biM-V&q;DR4JMi7h*wP9$jp|_b*WLNT%
z^!o(YxMgylksIAE;~LZmFoa*4#bI6a@DVrjaj<R;?a|=ik|*b@U2!MTS)Mr<<Y#%$
zpe`rz9u)Q_NY`^C<IDI=gzui4HDowC$lfHJ9oXzy@yZVFUW+AXkD5J<6wOjK+eKlS
zDo&3lsN(c^tct}%>#aVFad&9xpec|&ac2{WXK(AzPVXM{vl<OE$N<sqK+V`;ED>6N
zhH4I{YlP9;9<O86gb<`_b<DxF@AoSOe+FpiBTO7?=$kmjHI7b*kIsA2UmKnEI4ZY>
zzM;YO8J(~3;-zSUh&Km6IoU5E7w?XVlY`GS0)8?K++sLGUyZeZl~N+HuXhExlB|X-
z>iBE=$G`HPDE=zyrMteSJ@#Tq5j=9bTbs5dw0%*rH-K4%b9Fem3J@i)Bi26T@d$i?
zX8$`-q1+}4Yt{X&T&aqrzMhPqPK$^R!m&@qnyq#0>kLQ6Ldt#}5mNSCL`d0>BH132
zHnS#eUylfBTNdHcCOEpIv0sk9haPj0qLUNjj)Y5M&fSniF6{C9knQwpOS~lZsr!rR
z^mZJi4)fV~Kd6OE%v5rYh{^F=ZF2mICPzT-EB8bG(x)}9`{;@?wnyAgj`z5@w_I~V
zQo!HiB5yi}$S}Ug^#%7bh&2rZ6L^&TI$;YfuEKuB6+C{m1u|qO8N#^IH5&rL$ooIQ
zW<)HP<W}tBl|r9lsFD=718)w|<p6$)Xxt5T&X({Vo)N~LFL_QuGGH3<inXy@1-dS>
zux)vr4C^-s;F~a8--SBnINlG55egTa(Wut05O8(U>Hj6S1H1g!?<Lu~Ia(om*sW}v
zp`$gdJ#@+f-f%lVB})g;^r~^cXt0G{q=U5g+WgmHqH5r9!Zowda<Sj1HI(-I;`KLl
zB)ALnH7PW}#4qr>I%8k}HGr)rF#WALIugOpzZD&hb0fsiPUmRfig_90(T(86eC_Px
z#0~J3txaf92c!U-s5bv?d>4p~r<L0mpP_@K0ES{}=lAv2TEW?C_YvdT<M6cmNxG0L
zjDT1Nfh#D}-1F4%8?2gByUo7<@Y=N&EwA0b8F`_LEcBr!s=7!`#=gjC);m>k8mX73
zsM-9TXFdI7B->(y-xA5@C!>1#kx0DDcn0muU<K&qUyHzPVn}}{BIbr({wl6o8OujR
zvIiQ|_DFWBG2Km9urv?8QR|GSwKMVFI3EhX(Gah@w*8DmDT{2H=vw$=tSe#!;6vec
z9KnZ=Y6=skPi!^y|0jkr6sDOI`nO)1t(9xGk5Lxe8>eCXv5#%yE0BqA1F+ZS+uduV
zk+t|fdIL6o>np0bQAJoeArGPQtI@Rtso?7d98VAqWYSK4307>a+9C#*x!55eR>cDH
zh_+D7(lqbgT=Q!Ee*8$k{cfJAEfm_P0POg@NPfYRrPe^}ti*<=QWG9}@ZlByzhL*@
zV&0Y6aJpseu3asTLarJYR9I$vj@wUjn3lwO^XE%!C`)5=4L4T{-M*P4*^aa{=5sii
zFKrC-WsPN59BG*i`Qn|w#D<Ec99`Y<y>r>ylP6ubw$6eiC-BS`)6Z|)>tZOI&$N<C
z%bV=`3t8|p7W_bpSaJJ3YYl#@@q3H~e~K$5)}oc3KbVx?<J$(OW1@r=PtQFCht1SK
zT(ROs*z?WZr$zkQxu$5G=N~iVA0rPzW`mOFxUx8{(ET&4Pc?Ss$O7e8*Ux7hz4fEp
zkI6@si?R6Z?_?bL{PoIPzjI|&VpnCtjwT#F?rcg_D^Kreu*{#cv!Uhatqq<gwP@w&
zM@|!NHESd~0J+L?;x`t*G0fkVsH%?~Qyg2^mBE=^d%nq(p*1Y?BQ<R^T~65~9e$R*
z_bdy(!n8=89@)X@TLkXH159eMiI^mLCzY}#_V+7qJzQaWufh~u!L&$`Ud^RPvh~P3
z7Mvjk?~zulEYb)`IAmf(K-$lS;=G)Vi;Y*+Y)A>lYxJ=h*URmT7c2HFUFx}(4oW&a
ze>5wW#2iyahdQdIji?Ls;C|d57ElrR85t_XhcrIy5DJ=g%B7u0GaE9yGSvgBn)p$L
zBfS>#$||fK`&|1fyOqY-V<Rpla_;JZ0W7!{tNn@KDz<kGv!*4CR(_#0Wp=Gxcm=PJ
z&YCyxCqJ?`RCYIip6*K?En1>i>lC;7@J{ycGmciI%-&s*^iP=$XsBbKa=oQxH`hf+
zO+-}TN|1*rv_IaXKt_Re$pMzK-BHGt<OiRV9)8|h#va^p31piS9&WKHM{vT;dvuHi
zAC_Qk!T!k)4p4*tsRli2=0^Y=rGx_mSZ($Ll`@twISgvvv>zD5I`(-VQCAeC37dtu
z!#Tp16n5pBq>44cYfOnK<{!f0k#Tb2oH<IhIkBr^vHU^#fXs%2?dp}xmbsW4I~&sX
zltKHYR17`HYG<4+v!1(F8EzTl>9&=PI@hcmU7(zmkCdA-8?K+f{pix*B=%6b-P7G(
zVZkNjmgX;7ZdJ}^6q@Pn&aHN(I_Yb^!E@z~Msq~<RVS@{@R)KI<d`c=ElZXzDNw4d
zla#d9S()!Ap07-}ek_Gm&Ylx6Ij<j+V8I5QPWKY5iDZMJ<LNU_RE~6u)Y*#EhaY@M
zIm&UFzve59gj?)55)GY=ApeVFg-W%3Ms-r9tW?|n-4l*f*p$fFh}_=N0r9%N@)(;`
zJJXvJsE~J@JvM2NFNfsH(`us6dsJE)U1nTdCtD#W2YS=VcX$4yFpzw%2+!Y$d`}I0
z`9nN2D<D_29ae`{K!unR8!C@0t_Tex;iT_{V8Jo_e+-j}GU+~-rxnT_Enyw82A`$R
zeY7mx#kci@D0qT$G8<aHx{Eiaoi0;(1#CDg6e=0vfybiesUV8rVl7jfJcrthDYMK5
zp|DTydVtANGj8TSiO_$S%-Rr6#XY%FW@0Bsm@r*rY3n=*A3Tz!RkQI#xN$CYA;J|%
z<J(JY%N&`*oq-0o5L}LgucgRRBEkfeZ<}f6<;%We;&`fn&xi6$vt+gfVKPh&6SGK*
z=SZv!>8+?|N4R*p%)W)NdW_7rB6I<N3c{utCN==!GNcD195PjA-$q!RDKo1iOJB^8
z*><EGP<{)-JJByM!X~7LA^dmHF%;qM;Sw8*@Qr&-Y!t%#(`637KUwB*@643haOC4#
zN^AteEBFq{7=&MB$oNK;EZqnCsGj2%nT<yHy?bQlM3@S`Oh!2AJ{e!G0)1wg-442>
z@d%NgCd+Ir(x2Un5b1;wG8>2V4)9?j(iKx=_Bz7<KzTaCH1O#w2p{{Z%-%q_1nKbz
zvp~-@gtuV4CLw$geAov(V*vM4q#yl?%-%-04f*$iznxeZ-$J?z_2wgd6E9l-0^wu8
zHy7dlK{A_%(2F$6Ee!p580i<$50aBVp?`S@N233W5l%pO9__8RnK;~D@O?S*(;**g
z5I%1;v6U!KwaKhWf(YE;4|8E#E8R#wUSv-9%%WZEAY2?V<6;ySUWzs*=;j@VrrVu(
z2NKrDFi3mPxyuLe*{hS-jV%ejiFsqD4=~_5rHs2czf}VbCfcV3cT-6}HX`k6J=SMT
zco!cJ7^N2G$4plJ6?Rn>79hFVto{aRH``NdGVXEX-;d>Qn$vu{(fjys#$6lN-^c$a
zV{Sk1f`cJLj37$FbQis){Qv$1@j0qzlExUawq+K4zxOM(@f;vt(nd$~!TEb^{~UK#
z(ia-q4J%x{9ohH&zrYkD+vDHBr#9n<CBB^AwnPK@!MhTmQn9tij@>YZr>n&W>)4a4
zN}gE1vACp?ty@*HwzzTwkC&BhTvft~OV(~!U%pPj=;a1WbzAEMw9@FhP>b`6i$BI`
zWQP~A&hvOQy@1E1kMU@G1&{WtczpaC9-p-1(e)EN!rgdWdkc?Nv#foWgYz3VOix%R
zThi33i`?~2S1i;j>;c>A#S3n*0>s*=rTN}LI3FOoT$l*~E-VQIm(;2z@y?SG!CYwY
zD1uhC>Y9HUa^eu^$6cox|4f;C>ZJLL7BT)Yz*U<zZCL*}KC)F>;;byk#{dlw6P(rS
z)<3?^xo%atv!t}b`B-sr3BEN~R#yCY#fGPx>r2WjR&Cf&yn2$;Sj)MwvYcRJ<%l^e
z))nht7j%|CRbElN(YYEQAAG!`wCpLI$<51LJ)b`*wur|T@Mm6eH4hh21Z4{-jID;-
zTJz|-SJn%rz#54(MZm1z^TEX*<jDwN*~v$CT!LQ)?_xshXrTPwVkcKqqKN0?JPQ`~
z-B4nk{KG6?r-2wJlDX<j+4qu;qswuf>G-e-HpM)ai)-@mExo4J*R_kw8@=ct+VnF2
zcf|k!Q7O|idlMd4A<LrgXJ@j;x-*eC<wjiMaNv11@-Cj|Bj2*nG*S1T$5pVi_~DAj
z{xgy2Yh{hrS{MYOfQg{AF4Ml1&S*puI4F&4M*g3nHRYs&oa-UD4xoq)x48D!^1H6Q
zQg#ukT=6!&znf^RrQ<y-zCcCIaf+~cC9TR|u0@BlOpSH>BMZ!pb%BV_(pYygl85*y
zxF8zq8X`*(KN?wx_`%2u#NUl9NBnH02=VigRfr#ttU>%lWFz8dA|;4_5P1q0+D@Ur
zCnLP6z0aCFGoR&05(6|!LhngBYy7*cjO~36AkW2vd=DT;fu$kh|0#iZP3r!4kv<sl
zU!-&$s(4Le^gT1{c;%#6PeYHP{t3VzkNB?={7%#tqu?Kk6>#qk)ZZDczoSq6F{mFv
z{rwStI>GM({H}NszYw3nNd)@uPqFw9n!ZgMJwKRgf^rnA-C4-T;RuErA9cZf{(Xld
zcx&LmCldeof|5HJFKP|-)xCv}?YteKyZZ#-rBBWwPeGn9!B@zIM5~Rr3J$)Jz+WrS
zE@p8a$5*|Gs!b8`Js1y~mpq3LN9ZE|({zy^zQ0;*=}7*?)h>T0`X|Uu<yW()_TFI@
zA3leN8^Mj%Vc0V_T1Vg+m8D*bL@!HXp?D9Whj#^L2!s&tKW^pRzQb4+`<fSjaY0ld
z1Enz+0;`!GMEO27n17v%5rh`keX^bv?=EAOqf1<Pw1VeM{y*T<Q!fxALN&Z5zjZ*Y
z01~6ss5ALT8w!L_P>r1?|2>8R$cR>BhsnRhPyn&e3U=Xoa<o9qI?YPr9HNCyf2|#J
z7{vSm2lZVDGvMp$I(KEK^;wp#Y!7H!fajgNg158f&$E2yEZ;JCX!&ayHYmk2DxC^3
zIuWEhI~OoWu8S)6QSq<g(@l^j#eHeIs}+!$_ySBD!VFw|X{xP7>=wi>)zTOdmez&_
zEUpdW8c=I(EfTdr$vu|%%9AttdU?RlO+mkT&hKFh*oFKIleq40T+0Oviywc<I<`>i
zOXpR!>Qk}&2EPk4qEj&84p7=f-$bh~x*#`YK{&EByA^NgpKGo!3d@(Wd<hy0=tEQ=
zpv%NQy7h^g1kscw1P<yy4-&+=MWDaI2Wj}{mF{6d%b)A3!tWh4r6q_L-bV)xn!x1u
z{2~XF?DHRtMh9^VeQyKl*H8|_l}^zXnaR{vUKnQbd6>yQ`iPC8rQfRcu1<1D21}`g
zhFK_V-R{=bbcO}KY*O*&V#e_0Qhcm*{^G&{`YLYD3dWY_Q7k@_KBt?PvtpSBW7vgm
zYfa-eQ|s%A7_hAgpmZN%VQUhMqyS<aDToD6A$Dy9VxNA3*wwK(cz5i50Y?UH_)LRP
z*4kGEF(wCW=xFDM!Eq|X|2}$^z7r8-e|TBRYfe0}cej{><Jj!z+nT!5nKb=NreV}`
zili{Qb>OeW%!U@(JJLdD`Tl=R63H|RIfecEklgFE1kw=yFN%+`h+|KTUJ-T;SRjQp
z23kBd%}%`iMc<fd7J?+m9}BIOZsD0Ed;T86GXa^CL?#KIe;~Y$d&eX5PRbMt6k|-o
z6ZO9G`6}KLbE;MNA9mwNxShCQ^D4%5n`ii3hOc1IJ7{e*sl+^g4_`oRO&2fbDtWDn
zyG_Oo1u}pFvvEU%J~TlY^xX@^HB51j0H@IuB+-9ib|ubAhbcuPaIM1UzNQ?ZA)sO5
zLje$c+(1<FU!Hx@jshj`YT^-8SMq{N(KY%qDp^Iogmf$>iYrBNry9|l97<k_Qj~gA
z^i&Dxzv{R#`rMJgpQgA5EAF92{HuU}uu?SirueB6@PGGa_?^H%Mmtk8u;&QyCn-ga
zo8qT~IN<;D&G6p`{4;T1SaA~*qwK#e8J}OkvHVT(QzhVEo_rJjOaT5#c$+|RTaEa)
z0lyiCxHrX5m4N?$-wgkF;J*{<Cf~mw#vi{sgzHl@w=uua9lEKZZFwj!W_os09EV|k
z+?1w?#>H6=ae~OF26<jFHTjtYoWT8_NwlQ=U1t($ORVlIj?9L%*bzhmeC?BxS}a8g
z4~|}`xz@(Rr}evJ;X%tuBF`B-YW%C`vh)q4pM{6yPzrg_;OWA(fI5U}2)6@HmB?de
zkygNSG7TP-*DNykoGk$SAi%j3WR`?{&j5V68sRTcIu`j^fPWF`Y~a5O={mrZCu+A@
zVp9;N+a)#?;eL32rZJOLq~Z6-5<En*v<~I>AuK_djqoXiGZE$k&n$#fQlLwK|NSK4
zVLFZW$-{KPZh{BNBCP`)d6-6`4><^J=r4JeW+R-B@RxK@4$o2r;K;Mo3_4dL{3_ac
z6yaL*^H;!s3?8#z-^63o*O3I#iT>T5IrZ+lCo`-^U`y-|9}K}B;wFD4Ko7o2`G#0o
zN-Qd3s(Rmjc@Gri&cq4B(yYmoC)+1Fv9o>rNoQ$QaoL&;rPc6g@{&xHtS_l3URzv-
z-D}nQ)y2-oo^npM!=*_Tr=ytm$;Bn5m21~I%Qvlhyx6&>v<w+l>&r?@;FGApXVeLH
z$~}OsEGgc+30vUe)y{Rrt2Q}{%gRd2?5qbKRF#!gmQ1XGOGD&3F)Gx=R8#{+*sqtY
zow%tK#5l_<H*G2{tKco8WOeasI?B5_yLz+WAL)N^;2#|L|Ca+2rvJ0}{onb+Whdss
z?<@GxB1V7TG-_d<qd#gH!~d+dRs?t=ieD{jXlOtIGz}>mXdE8kNy>*bkk`wY&Fg(0
zaa9e+r?kxby_;0EeY1Cqm;S=uO~4dQX_=31Pe%O&@0LUO3xu}=gdrtrXu-#|)JD5^
z%bWNMglh?gdAESdT5ovEcKmt6&4h*}+qN7^OiT=fIS8|D@!D)Qz<4)r-s}zUNv?gq
zJsG(I53_AzYP&5S&wnPf<aWx{@N8{IrCxaU_rZfoz3`moj6z!iPcoR+2hZhNPG+=U
zS})`JwN2-U#vhGaar`-^bM{B{2R;j~i_{ho+^daHHUC3(K6+Y83tshl`B2_0DEE4+
ztG8mjZxU2^s}CJ|=Xro=f!Dj8Qd;o5di{CtitRr}kG6WZ|M;D13VsNT6l|~70(Gm`
z`5blno$zyqaKelLAl~f=Ksp7W<9c`w7o2y(Ti$`(AP_KHz_o<!kPY<gdYJtUFzfy*
z%=YjzI*g!4Z%fd#1@vs*9=`D0)1Y~?_qnIhF9bvng3ahxG^pGD#-T$8H+%Kqhh6|6
zWehA{3><Q97BtWxPy;s!Qna~vv)~)rJiA$NnfE;q)&t(GU^mS#)%$!nd|EGjGw~1u
zs0LGO^D>&JTf^1i@Q5f3!<kzQ2AYRps;^gj!}sej#OD|c7g^K*pS|H-QJ6Ow^oHJ+
z7ifr{?bWI`{9+X526(oH!_7L(oBh+X9W?(-6sF&PZH8orH|a1WvIcsH2Re1@_+0#9
z_-4W7_$k?M>PJGmiRY^lKB!r+694>7!NSFPD;MUu7PJ2{{}End35VZeRnfy)T1C1x
z(0jd^0wcSiq70^|YyF1eg(YiB85@PX$<roJpFAxGFG4UJdJm<4m}S$dlBe=kZ7gQ7
ze_Lu^X&LNPe$oWEi8!7oEc1)YA1_<KiO!$cyowE(^PTu#`)8<}^TfYvR1Wyzu(1i=
zU0ha9uu~^xPMHK-o!Yz=R}~h*EH5irwShN^Jl*AWFDP16ymr-wd8M14DqFvH9d3I>
zqt1Ub{M%PV-z4Xh>C>l9!~^&3aNs|P<(HMNu6(?LqwSBfQJ_nM(Me-dCuB~UFnI!}
dZ7lG(SCvH>Hkg^&va(er<r@Si2ADrJ|2IW#tn~l@

literal 0
HcmV?d00001

diff --git a/src/msw/ctl3d/msvc/ctl3d.h b/src/msw/ctl3d/msvc/ctl3d.h
new file mode 100644
index 0000000000..de7e67aa50
--- /dev/null
+++ b/src/msw/ctl3d/msvc/ctl3d.h
@@ -0,0 +1,61 @@
+/*-----------------------------------------------------------------------
+|	CTL3D.DLL
+|	
+|	Adds 3d effects to Windows controls
+|
+|	See ctl3d.doc for info
+|		
+-----------------------------------------------------------------------*/
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+BOOL WINAPI Ctl3dSubclassDlg(HWND, WORD);
+BOOL WINAPI Ctl3dSubclassDlgEx(HWND, DWORD);
+WORD WINAPI Ctl3dGetVer(void);
+BOOL WINAPI Ctl3dEnabled(void);
+HBRUSH WINAPI Ctl3dCtlColor(HDC, LONG);	// ARCHAIC, use Ctl3dCtlColorEx
+HBRUSH WINAPI Ctl3dCtlColorEx(UINT wm, WPARAM wParam, LPARAM lParam);
+BOOL WINAPI Ctl3dColorChange(void);
+BOOL WINAPI Ctl3dSubclassCtl(HWND);
+LONG WINAPI Ctl3dDlgFramePaint(HWND, UINT, WPARAM, LPARAM);
+
+BOOL WINAPI Ctl3dAutoSubclass(HANDLE);
+
+BOOL WINAPI Ctl3dRegister(HANDLE);
+BOOL WINAPI Ctl3dUnregister(HANDLE);
+
+//begin DBCS: far east short cut key support
+VOID WINAPI Ctl3dWinIniChange(void);
+//end DBCS
+
+
+/* Ctl3dSubclassDlg3d flags */
+#define CTL3D_BUTTONS		0x0001
+#define CTL3D_LISTBOXES		0x0002		
+#define CTL3D_EDITS			0x0004	
+#define CTL3D_COMBOS			0x0008		
+#define CTL3D_STATICTEXTS	0x0010		
+#define CTL3D_STATICFRAMES	0x0020
+
+#define CTL3D_NODLGWINDOW       0x00010000
+#define CTL3D_ALL				0xffff
+
+#define WM_DLGBORDER (WM_USER+3567)
+/* WM_DLGBORDER *(int FAR *)lParam return codes */
+#define CTL3D_NOBORDER		0
+#define CTL3D_BORDER			1
+
+#define WM_DLGSUBCLASS (WM_USER+3568)
+/* WM_DLGSUBCLASS *(int FAR *)lParam return codes */
+#define CTL3D_NOSUBCLASS	0
+#define CTL3D_SUBCLASS		1
+
+/* Resource ID for 3dcheck.bmp (for .lib version of ctl3d) */
+#define CTL3D_3DCHECK 26567
+
+
+#ifdef __cplusplus
+}
+#endif
diff --git a/src/msw/ctl3d/msvc/ctl3d.lib b/src/msw/ctl3d/msvc/ctl3d.lib
new file mode 100644
index 0000000000000000000000000000000000000000..2bd74e2114e2909f073a5ef6e7467e8b215a71fe
GIT binary patch
literal 2560
zcmeH}OK;Oa5Xb)^4Ue>HUIjsUMHL5B^?;NfIOG5%;UVP^5tW=cIEfW3xptMf5{Qd0
zNEV-hFT(fX2;YG5%x=7E`^W{sN_oxt_urY>+1dQ816P47P$RCPIvY)pw197wO8UJv
zi2UC2M-^YUPwA(DxQ<<(f8|E++%=Lr%$YXfD=6pNXfi*&oG*N5vl;p;BoA1mFd<6h
zMdnGI=Si%brwQS!7T-Xf*Qd8Z=!X=+U0&R_3b|vFl7o03d(4jlXYRX8B!`S!Mxkp(
zn)0Xp=fwvfoM7eJ{u>jbL)&G<PwT&kf?2SftiwewTi-Macg^JV4#pJ!Xz4|UfQsL;
zio*4xLduW5O$l#Vg}+h4H?cnm&*!1xz&*}j&MXR4ty%183~>vMY2-xS!VtL60(rYA
z?Ai*c|Ga;1-4%tAR<ODM+A8dx&Fb};KMU4d1+{+8UK&B%L5rVzei?=O3?O;P5fo=c
zqnY`!tv@<9X$9Ezr;I|;iMDfR`A<%8rHwu!G5yc%qSCfiw)va7(KPzxQ}LSl(^g?S
zHp}ZDpw01<t1s8ixjS*ZAVSjR1e8pP(t%crHLr6=I%x<dZ%qk*bIa@e&%EGG;OPTs
z=HHwV`j)1FU*FRx{`PUC0-y~_$6*i07z0E8)yK?i=R3KE*|ZxV?M&|EJ_Z`R#n}-#
zRg9|7K9r^|m!T>OYv;(J|Km?*fJ&LhG5UBf(%m!q{EW`&1%0mQH5}th`Zu6byr}6u
zu<vNvX6lh*Gw!Y1urDcU@b;zC&0Qjo3Qhea*QTG8w9Tig&a#&EtgN}bhGNZwJ(1}D
Gx%c0Y>ai&R

literal 0
HcmV?d00001

diff --git a/src/msw/ctl3d/msvc/ctl3dv2.lib b/src/msw/ctl3d/msvc/ctl3dv2.lib
new file mode 100644
index 0000000000000000000000000000000000000000..9d409891423d0bbb831ccbfd315c78189b17f174
GIT binary patch
literal 2560
zcmeHJ%Wl(95IrF+1=_TE6oh!Dhy|)xAkqbkEPy0Dq##9&+N@YOi4`olHcD<K5F2lh
zEdBwB&tnOHz<A=Z@4YrV7D!+zb~590?z|^IYQRO{0@5qmM0GM4A#MTRDwX8>R!{kz
z`RU{DReZ_b%igbHoAobUb?Pn=-(;LF6MO|__$KO%AD>TWzO!2O{RQGSlN1!fL{^9;
zk&P#^ay%&nU)At?sPXx9>xF(u9^B@`O{pL^a^yM!(JpovKM0(u@6Hk5Vz?m`^rnpl
zGW+@P-a98)xTgJ@LU<@)ng4YDa}`X2`Dhu=I{Ep!P;gs0F3TVJKbU(;BS`%>q{48?
zW{3zs^j0N!Ln`>o1$-U5z3^-rY6jfl2wGxcxMDIy4eX7Tqr90$aF+>exiD<&42k`m
zzhienZX^|~=U=3P-O;g043qO2e-bP+hV*<(E*#Wxl0Cw=(BSu;ovToK0Pz8PP}B%V
zT{yD(qrOQhz^uPiD5!>@B>S5EWCT~*-~(da{#-6BO`Ro+-`G`S_0gx|)#E2p!O~R8
zedqY?qsji0sV|n!nLBd4Kq0=z0Vq)k)4t8L_9+rRi6!wSF6n%RO8Bn+hEMV{@q*WZ
zCk?9SN7o43HDUYtHIMb*`;DT*7o{h;Zgg;nA<*YvT}<?GzF`f_x;X$TFIMM1K%qsB
zQcPN(U8I~+F8#D9j7+^@YyRK<XauNG={iIgZ`Zu-6MB9^>*zf_7xd{5@j3Y$P$@2I
z+6Ly1rcR~_xt3{r>pILOMJv)=I&Eu-+%F9Eht`;WR5CW7q;-~$tfyte<rPw_-nhqW
I@Bg{`FRw|wz5oCK

literal 0
HcmV?d00001

diff --git a/src/msw/ctl3d/readme.txt b/src/msw/ctl3d/readme.txt
new file mode 100644
index 0000000000..58c656ba7d
--- /dev/null
+++ b/src/msw/ctl3d/readme.txt
@@ -0,0 +1,31 @@
+
+CTL3D
+-----
+
+CTL3D gives 3D controls to 16-bit Windows 3.1 applications.
+Its use in wxWindows is controlled by the CTL3D symbol
+in include/base/wx_setup.h.
+
+If using a 16-bit compiler, copy ctl3dv2.lib to your compiler
+library directory, and remember to distribute ctl3dv2.dll
+with your applications. The DLL should be copied to
+windows/system and DELETED from the application installation
+directory.
+
+If using Watcom C++ in 386 mode, things are slightly more complex: you need
+to link with Patrick Halke's ctl3d32.obj which provides an interface
+from 32-bits to the 16-bit CTL3DV2 library. Link your application
+with ctl3d32.obj file instead of ctl3dv2.lib, distributing
+ctl3dv2.dll as above.
+
+ctl3d.dll           ; Version 1 of the CTL3D library DLL: obsolete
+ctl3dv2.dll         ; Version 2 of the CTL3D library DLL
+readme.txt          ; This file
+
+msvc/ctl3d.h        ; Header file for either version of CTL3D
+msvc/ctl3d.lib      ; Import library for 16-bit compilers
+watcom/import32.zip ; Import libraries for Watcom WIN32 compilation
+wat386/             ; Source & objects for Watcom 386 object file to
+                    ; interface 16<->32 bit modes
+borland/            ; Makefiles for making import libraries for Borland
+
diff --git a/src/msw/ctl3d/wat32/import32.zip b/src/msw/ctl3d/wat32/import32.zip
new file mode 100644
index 0000000000000000000000000000000000000000..69f318ccbd57f63d280ea7bd996529795ce21f6a
GIT binary patch
literal 22993
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
z%0A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

literal 0
HcmV?d00001

diff --git a/src/msw/ctl3d/wat386/ctl3d.h b/src/msw/ctl3d/wat386/ctl3d.h
new file mode 100644
index 0000000000..de7e67aa50
--- /dev/null
+++ b/src/msw/ctl3d/wat386/ctl3d.h
@@ -0,0 +1,61 @@
+/*-----------------------------------------------------------------------
+|	CTL3D.DLL
+|	
+|	Adds 3d effects to Windows controls
+|
+|	See ctl3d.doc for info
+|		
+-----------------------------------------------------------------------*/
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+BOOL WINAPI Ctl3dSubclassDlg(HWND, WORD);
+BOOL WINAPI Ctl3dSubclassDlgEx(HWND, DWORD);
+WORD WINAPI Ctl3dGetVer(void);
+BOOL WINAPI Ctl3dEnabled(void);
+HBRUSH WINAPI Ctl3dCtlColor(HDC, LONG);	// ARCHAIC, use Ctl3dCtlColorEx
+HBRUSH WINAPI Ctl3dCtlColorEx(UINT wm, WPARAM wParam, LPARAM lParam);
+BOOL WINAPI Ctl3dColorChange(void);
+BOOL WINAPI Ctl3dSubclassCtl(HWND);
+LONG WINAPI Ctl3dDlgFramePaint(HWND, UINT, WPARAM, LPARAM);
+
+BOOL WINAPI Ctl3dAutoSubclass(HANDLE);
+
+BOOL WINAPI Ctl3dRegister(HANDLE);
+BOOL WINAPI Ctl3dUnregister(HANDLE);
+
+//begin DBCS: far east short cut key support
+VOID WINAPI Ctl3dWinIniChange(void);
+//end DBCS
+
+
+/* Ctl3dSubclassDlg3d flags */
+#define CTL3D_BUTTONS		0x0001
+#define CTL3D_LISTBOXES		0x0002		
+#define CTL3D_EDITS			0x0004	
+#define CTL3D_COMBOS			0x0008		
+#define CTL3D_STATICTEXTS	0x0010		
+#define CTL3D_STATICFRAMES	0x0020
+
+#define CTL3D_NODLGWINDOW       0x00010000
+#define CTL3D_ALL				0xffff
+
+#define WM_DLGBORDER (WM_USER+3567)
+/* WM_DLGBORDER *(int FAR *)lParam return codes */
+#define CTL3D_NOBORDER		0
+#define CTL3D_BORDER			1
+
+#define WM_DLGSUBCLASS (WM_USER+3568)
+/* WM_DLGSUBCLASS *(int FAR *)lParam return codes */
+#define CTL3D_NOSUBCLASS	0
+#define CTL3D_SUBCLASS		1
+
+/* Resource ID for 3dcheck.bmp (for .lib version of ctl3d) */
+#define CTL3D_3DCHECK 26567
+
+
+#ifdef __cplusplus
+}
+#endif
diff --git a/src/msw/ctl3d/wat386/ctl3d32.c b/src/msw/ctl3d/wat386/ctl3d32.c
new file mode 100644
index 0000000000..67f845071e
--- /dev/null
+++ b/src/msw/ctl3d/wat386/ctl3d32.c
@@ -0,0 +1,285 @@
+/*
+ * File:	ctl3d32.c
+ * Purpose:	32bit interface to CTL3D functions for Watcom C/C++
+ * Author:	Patrick Halke
+ * Created:	1995
+ * Updated:	
+ * Copyright:	(c) 1995
+ */
+
+#include <malloc.h>
+
+#include <windows.h>
+
+#include "ctl3d.h"
+
+#if defined(__WINDOWS_386__)
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#undef FAR
+#define FAR
+
+#define INDIR_INT INDIR_WORD
+#define INDIR_UINT INDIR_WORD
+#define INDIR_WPARAM INDIR_UINT
+#define INDIR_LPARAM INDIR_DWORD
+#define INDIR_LONG INDIR_DWORD
+#define INDIR_ULONG INDIR_DWORD
+
+#ifdef STRICT
+#define INDIR_HANDLE INDIR_PTR
+#define INDIR_HWND INDIR_PTR
+#define INDIR_HDC INDIR_PTR
+#else
+#define INDIR_HANDLE INDIR_UINT
+#define INDIR_HWND INDIR_UINT
+#define INDIR_HDC INDIR_UINT
+#endif
+
+typedef struct tagCTL3DFUNCTIONS {
+    HINSTANCE	dll;
+    /* Function Handles */
+    HINDIR	_Ctl3dSubclassDlg;
+    HINDIR	_Ctl3dSubclassDlgEx;
+    HINDIR	_Ctl3dGetVer;
+    HINDIR	_Ctl3dEnabled;
+    HINDIR	_Ctl3dCtlColor;
+    HINDIR	_Ctl3dCtlColorEx;
+    HINDIR	_Ctl3dColorChange;
+    HINDIR	_Ctl3dSubclassCtl;
+    HINDIR	_Ctl3dDlgFramePaint;
+    HINDIR	_Ctl3dAutoSubclass;
+    HINDIR	_Ctl3dRegister;
+    HINDIR	_Ctl3dUnregister;
+    HINDIR	_Ctl3dWinIniChange;
+} CTL3DFUNCTIONS;
+
+static CTL3DFUNCTIONS	Ctl3dFunc = { 0 };
+
+static BOOL load_functions( CTL3DFUNCTIONS* functions )
+{
+    FARPROC		proc;
+    HINSTANCE		dll;
+
+    dll = LoadLibrary( "CTL3D.DLL" );
+    if( dll < HINSTANCE_ERROR ) {
+	return( FALSE );
+    }
+
+    /* Function thunks */
+    
+    proc = GetProcAddress(dll, "Ctl3dSubclassDlg");
+    functions->_Ctl3dSubclassDlg = GetIndirectFunctionHandle( proc,
+	INDIR_HWND,
+	INDIR_WORD,
+	INDIR_ENDLIST );
+    
+    proc = GetProcAddress( dll, "Ctl3dSubclassDlgEx" );
+    functions->_Ctl3dSubclassDlgEx = GetIndirectFunctionHandle( proc,
+	INDIR_HWND,
+	INDIR_DWORD,
+	INDIR_ENDLIST );
+    
+    proc = GetProcAddress( dll, "Ctl3dGetVer" );
+    functions->_Ctl3dGetVer = GetIndirectFunctionHandle( proc,
+	INDIR_ENDLIST );
+    
+    proc = GetProcAddress( dll, "Ctl3dEnabled" );
+    functions->_Ctl3dEnabled = GetIndirectFunctionHandle( proc,
+	INDIR_ENDLIST );
+    
+    proc = GetProcAddress( dll, "Ctl3dCtlColor" );
+    functions->_Ctl3dCtlColor = GetIndirectFunctionHandle( proc,
+	INDIR_HDC,
+	INDIR_LONG,
+	INDIR_ENDLIST );
+    
+    proc = GetProcAddress( dll, "Ctl3dCtlColorEx" );
+    functions->_Ctl3dCtlColorEx = GetIndirectFunctionHandle( proc,
+	INDIR_UINT,
+	INDIR_WPARAM,
+	INDIR_LPARAM,
+	INDIR_ENDLIST );
+
+    proc = GetProcAddress( dll, "Ctl3dColorChange" );
+    functions->_Ctl3dColorChange = GetIndirectFunctionHandle( proc,
+	INDIR_ENDLIST );
+
+    proc = GetProcAddress( dll, "Ctl3dSubclassCtl" );
+    functions->_Ctl3dSubclassCtl = GetIndirectFunctionHandle( proc,
+	INDIR_HWND,
+	INDIR_ENDLIST );
+  
+    proc = GetProcAddress( dll, "Ctl3dDlgFramePaint" );
+    functions->_Ctl3dDlgFramePaint = GetIndirectFunctionHandle( proc,
+	INDIR_HWND,
+	INDIR_UINT,
+	INDIR_WPARAM,
+	INDIR_LPARAM,
+	INDIR_ENDLIST );
+  
+    proc = GetProcAddress( dll, "Ctl3dAutoSubclass" );
+    functions->_Ctl3dAutoSubclass = GetIndirectFunctionHandle( proc,
+	INDIR_HANDLE,
+	INDIR_ENDLIST );
+  
+    proc = GetProcAddress( dll, "Ctl3dRegister" );
+    functions->_Ctl3dRegister = GetIndirectFunctionHandle( proc,
+	INDIR_HANDLE,
+	INDIR_ENDLIST );
+  
+    proc = GetProcAddress( dll, "Ctl3dUnregister" );
+    functions->_Ctl3dUnregister = GetIndirectFunctionHandle( proc,
+	INDIR_HANDLE,
+	INDIR_ENDLIST );
+  
+    proc = GetProcAddress( dll, "Ctl3dWinIniChange" );
+    functions->_Ctl3dWinIniChange = GetIndirectFunctionHandle( proc,
+	INDIR_ENDLIST );
+
+    functions->dll = dll;
+    return( TRUE );
+}
+
+static void unload_functions( CTL3DFUNCTIONS * functions )
+{
+    FreeLibrary( functions->dll );
+    functions->dll = 0;
+}
+
+/* Function Definitions */
+
+BOOL WINAPI Ctl3dSubclassDlg(HWND hwnd, WORD w)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+    return FALSE;
+  
+  return (BOOL)InvokeIndirectFunction(Ctl3dFunc._Ctl3dSubclassDlg,
+				      hwnd, w);
+}
+
+BOOL WINAPI Ctl3dSubclassDlgEx(HWND hwnd, DWORD dw)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+    return FALSE;
+  
+  return (BOOL)InvokeIndirectFunction(Ctl3dFunc._Ctl3dSubclassDlgEx,
+				      hwnd, dw);
+}
+
+WORD WINAPI Ctl3dGetVer(void)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+      return FALSE;
+  
+  return (WORD)InvokeIndirectFunction(Ctl3dFunc._Ctl3dGetVer);
+}
+
+BOOL WINAPI Ctl3dEnabled(void)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+      return FALSE;
+  
+  return (BOOL)InvokeIndirectFunction(Ctl3dFunc._Ctl3dEnabled);
+}
+
+HBRUSH WINAPI Ctl3dCtlColor(HDC hdc, LONG l)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+    return FALSE;
+  
+  return (HBRUSH)InvokeIndirectFunction(Ctl3dFunc._Ctl3dCtlColor,
+				        hdc, l);
+}
+
+HBRUSH WINAPI Ctl3dCtlColorEx(UINT ui, WPARAM wp, LPARAM lp)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+    return FALSE;
+  
+  return (HBRUSH)InvokeIndirectFunction(Ctl3dFunc._Ctl3dCtlColorEx,
+				        ui, wp, lp);
+}
+
+BOOL WINAPI Ctl3dColorChange(void)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+    return FALSE;
+  
+  return (BOOL)InvokeIndirectFunction(Ctl3dFunc._Ctl3dColorChange);
+}
+
+BOOL WINAPI Ctl3dSubclassCtl(HWND hwnd)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+    return FALSE;
+  
+  return (BOOL)InvokeIndirectFunction(Ctl3dFunc._Ctl3dSubclassCtl,
+				      hwnd);
+}
+
+LONG WINAPI Ctl3dDlgFramePaint(HWND hwnd, UINT ui, WPARAM wp, LPARAM lp)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+    return FALSE;
+  
+  return (LONG)InvokeIndirectFunction(Ctl3dFunc._Ctl3dDlgFramePaint,
+				      hwnd, ui, wp, lp);
+}
+
+BOOL WINAPI Ctl3dAutoSubclass(HANDLE hnd)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+    return FALSE;
+  
+  return (BOOL)InvokeIndirectFunction(Ctl3dFunc._Ctl3dAutoSubclass,
+				      hnd);
+}
+
+BOOL WINAPI Ctl3dRegister(HANDLE hnd)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+    return FALSE;
+  
+  return (BOOL)InvokeIndirectFunction(Ctl3dFunc._Ctl3dRegister,
+				      hnd);
+}
+
+BOOL WINAPI Ctl3dUnregister(HANDLE hnd)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+    return FALSE;
+  
+  return (BOOL)InvokeIndirectFunction(Ctl3dFunc._Ctl3dUnregister,
+				      hnd);
+}
+
+VOID WINAPI Ctl3dWinIniChange(void)
+{
+  if (!Ctl3dFunc.dll)
+    if (!load_functions(&Ctl3dFunc))
+      return;
+  
+  InvokeIndirectFunction(Ctl3dFunc._Ctl3dWinIniChange);
+}
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif	// __WINDOWS_386__
diff --git a/src/msw/ctl3d/wat386/ctl3d32.lnk b/src/msw/ctl3d/wat386/ctl3d32.lnk
new file mode 100644
index 0000000000..2ada8d2a55
--- /dev/null
+++ b/src/msw/ctl3d/wat386/ctl3d32.lnk
@@ -0,0 +1 @@
++-ctl3d32.obj
diff --git a/src/msw/ctl3d/wat386/ctl3d32.obj b/src/msw/ctl3d/wat386/ctl3d32.obj
new file mode 100644
index 0000000000000000000000000000000000000000..2fe304562567eadf6b2bb277e5d5920a5796537b
GIT binary patch
literal 6699
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

literal 0
HcmV?d00001

diff --git a/src/msw/ctl3d/wat386/ctl3d32.txt b/src/msw/ctl3d/wat386/ctl3d32.txt
new file mode 100644
index 0000000000..8e6b8b6e6b
--- /dev/null
+++ b/src/msw/ctl3d/wat386/ctl3d32.txt
@@ -0,0 +1,11 @@
+Using this package should be no big problem. You only need to change your
+wx_setup.h for including the CTL3D stuff, compile ctl3d32.c and add
+ctl3d32.obj to wx.lib (or just link it with your application).
+
+Please send bug reports to 'patrick@zaphod.ruhr.de'.
+
+
+Good luck
+
+- patrick
+
diff --git a/src/msw/ctl3d/wat386/makefile.wat b/src/msw/ctl3d/wat386/makefile.wat
new file mode 100644
index 0000000000..1f0858491a
--- /dev/null
+++ b/src/msw/ctl3d/wat386/makefile.wat
@@ -0,0 +1,23 @@
+CC	= wcc386
+CXX	= wpp386
+LIB     = wlib
+IFLAGS  = -i=..\\..\\include\\base;..\\..\\include\\msw
+CFLAGS  = $(IFLAGS) -zq -zW -w1 -d2 -ot -3 -dwx_msw
+
+WXDIR   = ..\\..
+LIBTARGET = $(WXDIR)\\lib\\wx.lib
+
+C_SRCS = ctl3d32.c
+
+OBJECTS = $(C_SRCS:.c=.obj) $(CC_SRCS:.cc=.obj)
+
+.c.obj:
+	$(CC) $(CFLAGS) $<
+
+.cc.obj:
+	$(CXX) $(CFLAGS) $< 
+
+all: $(OBJECTS) $(LIBTARGET)
+
+$(LIBTARGET): $(OBJECTS)
+	$(LIB) /P=256 $(LIBTARGET) @ctl3d32.lnk
diff --git a/src/msw/ole/droptgt.cpp b/src/msw/ole/droptgt.cpp
new file mode 100644
index 0000000000..7ff89237d5
--- /dev/null
+++ b/src/msw/ole/droptgt.cpp
@@ -0,0 +1,459 @@
+///////////////////////////////////////////////////////////////////////////////
+// Name:        ole/droptgt.cpp
+// Purpose:     wxDropTarget implementation
+// Author:      Vadim Zeitlin
+// Modified by: 
+// Created:     
+// RCS-ID:      $Id$
+// Copyright:   (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
+// Licence:     wxWindows license
+///////////////////////////////////////////////////////////////////////////////
+
+// ============================================================================
+// Declarations
+// ============================================================================
+
+// ----------------------------------------------------------------------------
+// headers
+// ----------------------------------------------------------------------------
+
+#ifdef __GNUG__
+#pragma implementation "droptgt.h"
+#endif
+
+// For compilers that support precompilation, includes "wx.h".
+#define IN_WX_MAIN_CPP
+#include "wx/wxprec.h"
+
+#if defined(__BORLANDC__)
+#pragma hdrstop
+#endif
+
+#include  <wx/setup.h>
+
+#if USE_DRAG_AND_DROP
+
+#include  <wx/log.h>
+
+#ifdef __WIN32__
+#ifndef __GNUWIN32__
+#include  <shlobj.h>            // for DROPFILES structure
+#endif
+#else
+#include <shellapi.h>
+#endif
+
+#include  <wx/msw/ole/droptgt.h>
+
+#ifndef __WIN32__
+#include <ole2.h>
+#include <olestd.h>
+#endif
+
+#include  <wx/msw/ole/oleutils.h>
+
+// ----------------------------------------------------------------------------
+// IDropTarget interface: forward all interesting things to wxDropTarget
+// (the name is unfortunate, but wx_I_DropTarget is not at all the same thing
+//  as wxDropTarget which is 'public' class, while this one is private)
+// ----------------------------------------------------------------------------
+
+class wxIDropTarget : public IDropTarget
+{
+public:
+  wxIDropTarget(wxDropTarget *p);
+ ~wxIDropTarget();
+
+  // IDropTarget methods
+  STDMETHODIMP DragEnter(LPDATAOBJECT, DWORD, POINTL, LPDWORD);
+  STDMETHODIMP DragOver(DWORD, POINTL, LPDWORD);
+  STDMETHODIMP DragLeave(void);
+  STDMETHODIMP Drop(LPDATAOBJECT, DWORD, POINTL, LPDWORD);
+
+  // @@ we assume that if QueryGetData() returns S_OK, than we can really
+  //    get data in this format, so we remember here the format for which
+  //    QueryGetData() succeeded
+  void SetSupportedFormat(wxDataFormat cfFormat) { m_cfFormat = cfFormat; }
+
+  DECLARE_IUNKNOWN_METHODS;
+
+protected:
+  IDataObject   *m_pIDataObject;  // !NULL between DragEnter and DragLeave/Drop
+  wxDropTarget  *m_pTarget;       // the real target (we're just a proxy)
+
+  wxDataFormat   m_cfFormat;      // the format in which to ask for data
+
+private:
+  static inline DWORD GetDropEffect(DWORD flags);
+};
+
+// ============================================================================
+// wxIDropTarget implementation
+// ============================================================================
+
+// Name    : static wxDropTarget::GetDropEffect
+// Purpose : determine the drop operation from keyboard/mouse state.
+// Returns : DWORD combined from DROPEFFECT_xxx constants 
+// Params  : [in] DWORD flags       kbd & mouse flags as passed to
+//                                  IDropTarget methods
+// Notes   : We do "move" normally and "copy" if <Ctrl> is pressed,
+//           which is the standard behaviour (currently there is no 
+//           way to redefine it)
+DWORD wxIDropTarget::GetDropEffect(DWORD flags)
+{
+  return flags & MK_CONTROL ? DROPEFFECT_COPY : DROPEFFECT_MOVE;
+}
+
+wxIDropTarget::wxIDropTarget(wxDropTarget *pTarget)
+{ 
+  m_cRef         = 0; 
+  m_pTarget      = pTarget;
+  m_cfFormat     = 0;
+  m_pIDataObject = NULL; 
+}
+
+wxIDropTarget::~wxIDropTarget() 
+{ 
+}
+
+BEGIN_IID_TABLE(wxIDropTarget)
+  ADD_IID(Unknown)
+  ADD_IID(DropTarget)
+END_IID_TABLE;
+
+IMPLEMENT_IUNKNOWN_METHODS(wxIDropTarget)
+
+#if 0
+  STDMETHODIMP wxIDropTarget::QueryInterface(REFIID riid, void **ppv)
+  {                                                                           
+//    wxLogQueryInterface(wxIDropTarget, riid);                                    
+                                                                              
+    if ( IsIidFromList(riid, ms_aIids, WXSIZEOF(ms_aIids)) ) {                  
+      *ppv = this;
+      AddRef();                                                               
+                                                                              
+      return S_OK;                                                            
+    }                                                                         
+    else {                                                                    
+      *ppv = NULL;                                                            
+                                                                              
+      return (HRESULT) E_NOINTERFACE;
+    }                                                                         
+  }                                                                           
+                                                                              
+  STDMETHODIMP_(ULONG) wxIDropTarget::AddRef()                                    
+  {                                                                           
+    wxLogAddRef(wxIDropTarget, m_cRef);                                          
+                                                                              
+    return ++m_cRef;                                                          
+  }                                                                           
+                                                                              
+  STDMETHODIMP_(ULONG) wxIDropTarget::Release()                                   
+  {                                                                           
+    wxLogRelease(wxIDropTarget, m_cRef);                                         
+                                                                              
+    if ( --m_cRef == 0 ) {                                                    
+      delete this;                                                            
+      return 0;                                                               
+    }                                                                         
+    else                                                                      
+      return m_cRef;                                                          
+  }
+#endif
+
+// Name    : wxIDropTarget::DragEnter
+// Purpose : Called when the mouse enters the window (dragging something)
+// Returns : S_OK
+// Params  : [in] IDataObject *pIDataSource : source data
+//           [in] DWORD        grfKeyState  : kbd & mouse state
+//           [in] POINTL       pt           : mouse coordinates
+//           [out]DWORD       *pdwEffect    : effect flag
+// Notes   : 
+STDMETHODIMP wxIDropTarget::DragEnter(IDataObject *pIDataSource,
+                                      DWORD        grfKeyState,
+                                      POINTL       pt,
+                                      DWORD       *pdwEffect)
+{
+  wxLogDebug("IDropTarget::DragEnter");
+
+  wxASSERT( m_pIDataObject == NULL );
+
+  if ( !m_pTarget->IsAcceptedData(pIDataSource) ) {
+    // we don't accept this kind of data
+    *pdwEffect = DROPEFFECT_NONE;
+
+    return S_OK;
+  }
+
+  // @@ should check the point also?
+  
+  *pdwEffect = GetDropEffect(grfKeyState);
+
+  // get hold of the data object
+  m_pIDataObject = pIDataSource;
+  m_pIDataObject->AddRef();
+
+  // give some visual feedback
+  m_pTarget->OnEnter();
+
+  return S_OK;
+}
+
+// Name    : wxIDropTarget::DragOver
+// Purpose : Indicates that the mouse was moved inside the window represented
+//           by this drop target.
+// Returns : S_OK
+// Params  : [in] DWORD   grfKeyState     kbd & mouse state
+//           [in] POINTL  pt              mouse coordinates
+//           [out]LPDWORD pdwEffect       effect flag
+// Notes   : We're called on every WM_MOUSEMOVE, so this function should be 
+//           very efficient.
+STDMETHODIMP wxIDropTarget::DragOver(DWORD   grfKeyState,
+                                     POINTL  pt,
+                                     LPDWORD pdwEffect)
+{
+  // there are too many of them... wxLogDebug("IDropTarget::DragOver");
+
+  *pdwEffect = m_pIDataObject == NULL ? DROPEFFECT_NONE 
+                                      : GetDropEffect(grfKeyState);
+  return S_OK;
+}
+
+// Name    : wxIDropTarget::DragLeave
+// Purpose : Informs the drop target that the operation has left its window.
+// Returns : S_OK
+// Notes   : good place to do any clean-up
+STDMETHODIMP wxIDropTarget::DragLeave()
+{
+  wxLogDebug("IDropTarget::DragLeave");
+
+  // remove the UI feedback
+  m_pTarget->OnLeave();
+
+  // release the held object
+  RELEASE_AND_NULL(m_pIDataObject);
+    
+  return S_OK;
+}
+
+// Name    : wxIDropTarget::Drop
+// Purpose : Instructs the drop target to paste data that was just now 
+//           dropped on it.
+// Returns : S_OK
+// Params  : [in] IDataObject *pIDataSource     the data to paste
+//           [in] DWORD        grfKeyState      kbd & mouse state
+//           [in] POINTL       pt               where the drop occured?
+//           [ouy]DWORD       *pdwEffect        operation effect
+// Notes   : 
+STDMETHODIMP wxIDropTarget::Drop(IDataObject *pIDataSource, 
+                                 DWORD        grfKeyState, 
+                                 POINTL       pt, 
+                                 DWORD       *pdwEffect)
+{
+  wxLogDebug("IDropTarget::Drop");
+
+  // @@ I don't know why there is this parameter, but so far I assume
+  //    that it's the same we've already got in DragEnter
+  wxASSERT( m_pIDataObject == pIDataSource );
+
+  STGMEDIUM stm;
+  *pdwEffect = DROPEFFECT_NONE; 
+  
+  // should be set by SetSupportedFormat() call
+  wxASSERT( m_cfFormat != 0 );
+
+  FORMATETC fmtMemory;
+  fmtMemory.cfFormat  = m_cfFormat;
+  fmtMemory.ptd       = NULL; 
+  fmtMemory.dwAspect  = DVASPECT_CONTENT;
+  fmtMemory.lindex    = -1;
+  fmtMemory.tymed     = TYMED_HGLOBAL;  // @@@@ to add other media
+
+  HRESULT hr = pIDataSource->GetData(&fmtMemory, &stm);
+  if ( SUCCEEDED(hr) ) {
+    if ( stm.hGlobal != NULL ) {
+      if ( m_pTarget->OnDrop(pt.x, pt.y, GlobalLock(stm.hGlobal)) )
+        *pdwEffect = GetDropEffect(grfKeyState);
+      //else: DROPEFFECT_NONE
+
+      GlobalUnlock(stm.hGlobal);
+      ReleaseStgMedium(&stm);
+    }
+  }
+  else
+  {
+    // wxLogApiError("GetData", hr);
+  }
+
+  // release the held object
+  RELEASE_AND_NULL(m_pIDataObject);
+
+  return S_OK;
+}
+
+// ============================================================================
+// wxDropTarget implementation
+// ============================================================================
+
+// ----------------------------------------------------------------------------
+// ctor/dtor
+// ----------------------------------------------------------------------------
+
+wxDropTarget::wxDropTarget()
+{
+  // create an IDropTarget implementation which will notify us about 
+  // d&d operations.
+  m_pIDropTarget = new wxIDropTarget(this);
+  m_pIDropTarget->AddRef();
+}
+
+wxDropTarget::~wxDropTarget()
+{
+  ReleaseInterface(m_pIDropTarget);
+}
+
+// ----------------------------------------------------------------------------
+// [un]register drop handler
+// ----------------------------------------------------------------------------
+
+bool wxDropTarget::Register(WXHWND hwnd)
+{
+  HRESULT hr = ::CoLockObjectExternal(m_pIDropTarget, TRUE, FALSE);
+  if ( FAILED(hr) ) {
+    // wxLogApiError("CoLockObjectExternal", hr);
+    return FALSE;
+  }
+
+  hr = ::RegisterDragDrop((HWND) hwnd, m_pIDropTarget);
+  if ( FAILED(hr) ) {
+    ::CoLockObjectExternal(m_pIDropTarget, FALSE, FALSE);
+
+    // wxLogApiError("RegisterDragDrop", hr);
+    return FALSE;
+  }
+
+  return TRUE;
+}
+
+void wxDropTarget::Revoke(WXHWND hwnd)
+{
+  HRESULT hr = ::RevokeDragDrop((HWND) hwnd);
+
+  if ( FAILED(hr) )
+  {
+    // wxLogApiError("RevokeDragDrop", hr);
+  }
+
+  ::CoLockObjectExternal(m_pIDropTarget, FALSE, TRUE);
+}
+
+// ----------------------------------------------------------------------------
+// determine if we accept data of this type
+// ----------------------------------------------------------------------------
+bool wxDropTarget::IsAcceptedData(IDataObject *pIDataSource) const
+{
+  // this strucutre describes a data of any type (first field will be
+  // changing) being passed through global memory block.
+  static FORMATETC s_fmtMemory = { 
+    0,
+    NULL, 
+    DVASPECT_CONTENT, 
+    -1, 
+    TYMED_HGLOBAL 
+  };
+
+  // cycle thorugh all supported formats
+  for ( size_t n = 0; n < GetFormatCount(); n++ ) {
+    s_fmtMemory.cfFormat = GetFormat(n);
+    // @ don't use SUCCEEDED macro here: QueryGetData returns 1 (whatever it
+    //   means) for file drag and drop
+    if ( pIDataSource->QueryGetData(&s_fmtMemory) == S_OK ) {
+      // remember this format: we'll later ask for data in it
+      m_pIDropTarget->SetSupportedFormat(s_fmtMemory.cfFormat);
+      return TRUE;
+    }
+  }
+
+  return FALSE;
+}
+
+// ============================================================================
+// wxTextDropTarget
+// ============================================================================
+
+bool wxTextDropTarget::OnDrop(long x, long y, const void *pData)
+{
+  return OnDropText(x, y, (const char *)pData);
+}
+
+size_t wxTextDropTarget::GetFormatCount() const
+{
+  return 1;
+}
+
+wxDataFormat wxTextDropTarget::GetFormat(size_t WXUNUSED(n)) const
+{
+  return CF_TEXT;
+}
+
+// ============================================================================
+// wxFileDropTarget
+// ============================================================================
+
+bool wxFileDropTarget::OnDrop(long x, long y, const void *pData)
+{
+  // the documentation states that the first member of DROPFILES structure
+  // is a "DWORD offset of double NUL terminated file list". What they mean by 
+  // this (I wonder if you see it immediately) is that the list starts at
+  // ((char *)&(pDropFiles.pFiles)) + pDropFiles.pFiles. We're also advised to
+  // use DragQueryFile to work with this structure, but not told where and how
+  // to get HDROP.
+  HDROP hdrop = (HDROP)pData;   // @@ it works, but I'm not sure about it
+
+  // get number of files (magic value -1)
+  UINT nFiles = ::DragQueryFile(hdrop, -1, NULL, 0);
+  
+  // for each file get the length, allocate memory and then get the name
+  char **aszFiles = new char *[nFiles];
+  UINT len, n;
+  for ( n = 0; n < nFiles; n++ ) {
+    // +1 for terminating NUL
+    len = ::DragQueryFile(hdrop, n, NULL, 0) + 1;
+
+    aszFiles[n] = new char[len];
+
+    UINT len2 = ::DragQueryFile(hdrop, n, aszFiles[n], len);
+    if ( len2 != len - 1 ) {
+      wxLogDebug("In wxFileDropTarget::OnDrop DragQueryFile returned %d "
+                 "characters, %d expected.", len2, len - 1);
+    }
+  }
+
+  bool bResult = OnDropFiles(x, y, nFiles, (const char**) aszFiles);
+
+  // free memory
+  for ( n = 0; n < nFiles; n++ ) {
+    delete [] aszFiles[n];
+  }
+  delete [] aszFiles;
+
+  return bResult;
+}
+
+size_t wxFileDropTarget::GetFormatCount() const
+{
+  return 1;
+}
+
+wxDataFormat wxFileDropTarget::GetFormat(size_t WXUNUSED(n)) const
+{
+#ifdef __WIN32__
+  return CF_HDROP;
+#else
+  // TODO: how to implement this in WIN16?
+  return CF_TEXT;
+#endif
+}
+
+#endif
+ // USE_DRAG_AND_DROP
diff --git a/src/msw/ole/oleutils.cpp b/src/msw/ole/oleutils.cpp
new file mode 100644
index 0000000000..39165f2aac
--- /dev/null
+++ b/src/msw/ole/oleutils.cpp
@@ -0,0 +1,193 @@
+///////////////////////////////////////////////////////////////////////////////
+// Name:        ole/oleutils.cpp
+// Purpose:     implementation of OLE helper functions
+// Author:      Vadim Zeitlin
+// Modified by: 
+// Created:     19.02.98
+// RCS-ID:      $Id$
+// Copyright:   (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
+// Licence:     wxWindows license
+///////////////////////////////////////////////////////////////////////////////
+
+// ============================================================================
+// Declarations
+// ============================================================================
+
+// ----------------------------------------------------------------------------
+// headers
+// ----------------------------------------------------------------------------
+
+#ifdef __GNUG__
+#pragma implementation "oleutils.h"
+#endif
+
+// For compilers that support precompilation, includes "wx.h".
+#define IN_WX_MAIN_CPP
+#include "wx/wxprec.h"
+
+#if defined(__BORLANDC__)
+#pragma hdrstop
+#endif
+
+#include  <wx/setup.h>
+
+#if USE_DRAG_AND_DROP
+
+#include  <wx/log.h>
+
+#include <windows.h>
+
+// OLE
+#include  <wx/msw/ole/uuid.h>
+#include  <wx/msw/ole/oleutils.h>
+
+#ifndef __BORLANDC__
+#include  <docobj.h>
+#endif
+
+// ============================================================================
+// Implementation
+// ============================================================================
+
+// return TRUE if the iid is in the array
+bool IsIidFromList(REFIID riid, const IID *aIids[], size_t nCount)
+{
+  for ( size_t i = 0; i < nCount; i++ ) {
+    if ( riid == *aIids[i] )
+      return TRUE;
+  }
+
+  return FALSE;
+}
+
+// ----------------------------------------------------------------------------
+// Debug support
+// ----------------------------------------------------------------------------
+
+#ifdef  __DEBUG__
+
+const char *GetIidName(REFIID riid)
+{
+  // an association between symbolic name and numeric value of an IID
+  struct KNOWN_IID {
+    const IID  *pIid;
+    const char *szName;
+  };
+
+  // construct the table containing all known interfaces
+  #define ADD_KNOWN_IID(name) { &IID_I##name, #name }
+
+  static const KNOWN_IID aKnownIids[] = {
+    ADD_KNOWN_IID(AdviseSink),
+    ADD_KNOWN_IID(AdviseSink2),
+    ADD_KNOWN_IID(BindCtx),
+    ADD_KNOWN_IID(ClassFactory),
+    ADD_KNOWN_IID(ContinueCallback),
+    ADD_KNOWN_IID(EnumOleDocumentViews),
+    ADD_KNOWN_IID(OleCommandTarget),
+    ADD_KNOWN_IID(OleDocument),
+    ADD_KNOWN_IID(OleDocumentSite),
+    ADD_KNOWN_IID(OleDocumentView),
+    ADD_KNOWN_IID(Print),
+    ADD_KNOWN_IID(DataAdviseHolder),
+    ADD_KNOWN_IID(DataObject),
+    ADD_KNOWN_IID(Debug),
+    ADD_KNOWN_IID(DebugStream),
+    ADD_KNOWN_IID(DfReserved1),
+    ADD_KNOWN_IID(DfReserved2),
+    ADD_KNOWN_IID(DfReserved3),
+    ADD_KNOWN_IID(Dispatch),
+    ADD_KNOWN_IID(DropSource),
+    ADD_KNOWN_IID(DropTarget),
+    ADD_KNOWN_IID(EnumCallback),
+    ADD_KNOWN_IID(EnumFORMATETC),
+    ADD_KNOWN_IID(EnumGeneric),
+    ADD_KNOWN_IID(EnumHolder),
+    ADD_KNOWN_IID(EnumMoniker),
+    ADD_KNOWN_IID(EnumOLEVERB),
+    ADD_KNOWN_IID(EnumSTATDATA),
+    ADD_KNOWN_IID(EnumSTATSTG),
+    ADD_KNOWN_IID(EnumString),
+    ADD_KNOWN_IID(EnumUnknown),
+    ADD_KNOWN_IID(EnumVARIANT),
+    ADD_KNOWN_IID(ExternalConnection),
+    ADD_KNOWN_IID(InternalMoniker),
+    ADD_KNOWN_IID(LockBytes),
+    ADD_KNOWN_IID(Malloc),
+    ADD_KNOWN_IID(Marshal),
+    ADD_KNOWN_IID(MessageFilter),
+    ADD_KNOWN_IID(Moniker),
+    ADD_KNOWN_IID(OleAdviseHolder),
+    ADD_KNOWN_IID(OleCache),
+    ADD_KNOWN_IID(OleCache2),
+    ADD_KNOWN_IID(OleCacheControl),
+    ADD_KNOWN_IID(OleClientSite),
+    ADD_KNOWN_IID(OleContainer),
+    ADD_KNOWN_IID(OleInPlaceActiveObject),
+    ADD_KNOWN_IID(OleInPlaceFrame),
+    ADD_KNOWN_IID(OleInPlaceObject),
+    ADD_KNOWN_IID(OleInPlaceSite),
+    ADD_KNOWN_IID(OleInPlaceUIWindow),
+    ADD_KNOWN_IID(OleItemContainer),
+    ADD_KNOWN_IID(OleLink),
+    ADD_KNOWN_IID(OleManager),
+    ADD_KNOWN_IID(OleObject),
+    ADD_KNOWN_IID(OlePresObj),
+    ADD_KNOWN_IID(OleWindow),
+    ADD_KNOWN_IID(PSFactory),
+    ADD_KNOWN_IID(ParseDisplayName),
+    ADD_KNOWN_IID(Persist),
+    ADD_KNOWN_IID(PersistFile),
+    ADD_KNOWN_IID(PersistStorage),
+    ADD_KNOWN_IID(PersistStream),
+    ADD_KNOWN_IID(ProxyManager),
+    ADD_KNOWN_IID(RootStorage),
+    ADD_KNOWN_IID(RpcChannel),
+    ADD_KNOWN_IID(RpcProxy),
+    ADD_KNOWN_IID(RpcStub),
+    ADD_KNOWN_IID(RunnableObject),
+    ADD_KNOWN_IID(RunningObjectTable),
+    ADD_KNOWN_IID(StdMarshalInfo),
+    ADD_KNOWN_IID(Storage),
+    ADD_KNOWN_IID(Stream),
+    ADD_KNOWN_IID(StubManager),
+    ADD_KNOWN_IID(Unknown),
+    ADD_KNOWN_IID(ViewObject),
+    ADD_KNOWN_IID(ViewObject2),
+  };
+
+  // don't clobber preprocessor name space
+  #undef ADD_KNOWN_IID
+
+  // try to find the interface in the table
+  for ( uint ui = 0; ui < WXSIZEOF(aKnownIids); ui++ ) {
+    if ( riid == *aKnownIids[ui].pIid ) {
+      return aKnownIids[ui].szName;
+    }
+  }
+
+  // unknown IID, just transform to string
+  static Uuid s_uuid;
+  s_uuid.Set(riid);
+  return s_uuid;
+}
+
+void wxLogQueryInterface(const char *szInterface, REFIID riid)
+{
+  wxLogTrace("%s::QueryInterface (iid = %s)", szInterface, GetIidName(riid));
+}
+
+void wxLogAddRef(const char *szInterface, ULONG cRef)
+{
+  wxLogTrace("After %s::AddRef: m_cRef = %d", szInterface, cRef + 1);
+}
+
+void wxLogRelease(const char *szInterface, ULONG cRef)
+{
+  wxLogTrace("After %s::Release: m_cRef = %d", szInterface, cRef - 1);
+}
+
+#endif  //DEBUG
+
+#endif
+  // USE_DRAG_AND_DROP
diff --git a/src/msw/ole/uuid.cpp b/src/msw/ole/uuid.cpp
new file mode 100644
index 0000000000..31e73a27fd
--- /dev/null
+++ b/src/msw/ole/uuid.cpp
@@ -0,0 +1,153 @@
+///////////////////////////////////////////////////////////////////////////////
+// Name:        ole/uuid.cpp
+// Purpose:     implements Uuid class, see uuid.h for details
+// Author:      Vadim Zeitlin
+// Modified by: 
+// Created:     12.09.96
+// RCS-ID:      $Id$
+// Copyright:   (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
+// Licence:     wxWindows license
+///////////////////////////////////////////////////////////////////////////////
+
+// ============================================================================
+// Declarations
+// ============================================================================
+
+#ifdef __GNUG__
+#pragma implementation "uuid.h"
+#endif
+
+// For compilers that support precompilation, includes "wx.h".
+#define IN_WX_MAIN_CPP
+#include "wx/wxprec.h"
+
+#if defined(__BORLANDC__)
+#pragma hdrstop
+#endif
+
+#include  <wx/setup.h>
+
+#if USE_DRAG_AND_DROP
+
+// standard headers
+#include  <rpc.h>                       // UUID related functions
+
+#include  <wx/msw/ole/uuid.h>
+
+
+
+// ============================================================================
+// Implementation
+// ============================================================================
+
+// length of UUID in C format
+#define   UUID_CSTRLEN  100     // real length is 66
+
+// copy ctor
+Uuid::Uuid(const Uuid& uuid)
+{
+  // bitwise copy Ok for UUIDs 
+  m_uuid = uuid.m_uuid;              
+
+  // force the string to be allocated by RPC
+  // (we free it later with RpcStringFree)
+  UuidToString(&m_uuid, &m_pszUuid);
+
+  // allocate new buffer
+  m_pszCForm = new char[UUID_CSTRLEN];
+  // and fill it
+  memcpy(m_pszCForm, uuid.m_pszCForm, UUID_CSTRLEN);
+}
+
+// assignment operator
+Uuid& Uuid::operator=(const Uuid& uuid)
+{
+  m_uuid = uuid.m_uuid;
+
+  // force the string to be allocated by RPC
+  // (we free it later with RpcStringFree)
+  UuidToString(&m_uuid, &m_pszUuid);
+
+  // allocate new buffer if not done yet
+  if ( !m_pszCForm )
+    m_pszCForm = new char[UUID_CSTRLEN];
+
+  // and fill it
+  memcpy(m_pszCForm, uuid.m_pszCForm, UUID_CSTRLEN);
+
+  return *this;
+}
+
+// dtor
+Uuid::~Uuid() 
+{ 
+  // this string must be allocated by RPC!
+  // (otherwise you get a debug breakpoint deep inside RPC DLL)
+  if ( m_pszUuid ) 
+    RpcStringFree(&m_pszUuid);
+
+  // perhaps we should just use a static buffer and not bother
+  // with new and delete?
+  if ( m_pszCForm )
+    delete [] m_pszCForm;
+}
+
+// update string representation of new UUID
+void Uuid::Set(const UUID &uuid)
+{
+  m_uuid = uuid;
+
+  // get string representation
+  UuidToString(&m_uuid, &m_pszUuid);
+
+  // cache UUID in C format
+  UuidToCForm();
+}
+
+// create a new UUID
+void Uuid::Create()
+{
+  UUID uuid;
+
+  // can't fail
+  UuidCreate(&uuid);
+  
+  Set(uuid);
+}
+
+// set the value
+bool Uuid::Set(const char *pc)
+{
+  // get UUID from string
+  if ( UuidFromString((uchar *)pc, &m_uuid) != RPC_S_OK)
+    // failed: probably invalid string
+    return FALSE;
+
+  // transform it back to string to normalize it
+  UuidToString(&m_uuid, &m_pszUuid);
+
+  // update m_pszCForm
+  UuidToCForm();
+
+  return TRUE;
+}
+
+// stores m_uuid in m_pszCForm in a format required by
+// DEFINE_GUID macro: i.e. something like
+//  0x7D8A2281L,0x4C61,0x11D0,0xBA,0xBD,0x00,0x00,0xC0,0x18,0xBA,0x27
+// m_pszUuid is of the form (no, it's not quite the same UUID :-)
+//  6aadc650-67b0-11d0-bac8-0000c018ba27
+void Uuid::UuidToCForm()
+{
+  if ( m_pszCForm == NULL )
+    m_pszCForm = new char[UUID_CSTRLEN];
+
+  wsprintf(m_pszCForm, "0x%8.8X,0x%4.4X,0x%4.4X,0x%2.2X,0x2.2%X,"
+           "0x2.2%X,0x2.2%X,0x2.2%X,0x2.2%X,0x2.2%X,0x2.2%X",
+           m_uuid.Data1, m_uuid.Data2, m_uuid.Data3,
+           m_uuid.Data4[1], m_uuid.Data4[2], m_uuid.Data4[3], m_uuid.Data4[4],
+           m_uuid.Data4[5], m_uuid.Data4[6], m_uuid.Data4[7], m_uuid.Data4[8]);
+}
+
+#endif
+  // USE_DRAG_AND_DROP
diff --git a/utils/nplugin/docs/notes.txt b/utils/nplugin/docs/notes.txt
new file mode 100644
index 0000000000..ee3d1412ea
--- /dev/null
+++ b/utils/nplugin/docs/notes.txt
@@ -0,0 +1,32 @@
+Notes about plugins
+
+
+ I have users that want to visit my pages with tclets, but they do not
+    have the plugin. What can I do?
+
+	Add a pluginspage=http://www.sunlabs.com/tcl/plugin/ name=value
+	pair to the embed statement. This will cause Navigator to find
+	the plugin for your user and suggest they install it. The user
+	is then prompted to download and install the plugin, and then she
+	has to restart the browser and revisit your page. Very inconvenient
+	and only slightly better than giving your users the broken image
+	icon. Netscape says they are working on a more automatic solution.
+
+
+
+
+14. Your demos work just fine, but when I visit my own pages with tclets in
+    them, at http://www.myserver.com/~mypages/mypage.html, I still get the
+    broken image icon. Why doesn't it work for me?
+
+	This is likely because your web server -- the program that sends
+	the pages to your browser when you click on a URL -- is not
+	sending the right mime-type when it sends the '.tcl' file. You
+	can work around this by adding a type=application/x-tcl name=value
+	pair to the embed statement, which will cause Navigator to infer
+	that it should use the Tcl plugin anyways. A better solution is
+	to ask your system administrator to configure the web server to
+	send the mime type application/x-tcl when it sends files with a
+	'.tcl' extension. Nearly all web servers in the world nowadays
+	are already configured to do this, the only ones we are aware of
+	that do not are some older versions of Apache.
diff --git a/utils/nplugin/lib/dummy b/utils/nplugin/lib/dummy
new file mode 100644
index 0000000000..bfdf726d49
--- /dev/null
+++ b/utils/nplugin/lib/dummy
@@ -0,0 +1 @@
+I'm just here to force the creation of a LIB directory.
diff --git a/utils/nplugin/samples/gui/gui.cpp b/utils/nplugin/samples/gui/gui.cpp
new file mode 100644
index 0000000000..3ae118fda0
--- /dev/null
+++ b/utils/nplugin/samples/gui/gui.cpp
@@ -0,0 +1,186 @@
+/*
+ * File:	simple.cpp
+ * Purpose:	Minimal wxWindows plugin
+ * Author:	Julian Smart
+ * Created:	1997
+ * Updated:	
+ * Copyright:   (c) Julian Smart
+ */
+
+/* static const char sccsid[] = "%W% %G%"; */
+
+#ifdef __GNUG__
+#pragma implementation
+#pragma interface
+#endif
+
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+#pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+#include "wx/wx.h"
+#endif
+
+#include <fstream.h>
+
+#include "NPApp.h"
+#include "NPFrame.h"
+
+#define ID_HELLO    10
+
+// Define a new application type
+class MyApp: public wxPluginApp
+{ public:
+    virtual wxFrame *OnInit(void);
+    virtual wxPluginFrame* OnNewInstance(const wxPluginData& data);
+};
+
+// Define a new frame type
+class MyFrame: public wxPluginFrame
+{ public:
+    MyFrame(const wxPluginData& data);
+    
+ public:
+    // Let's paint directly onto the 'frame'; we don't need a subwindow
+    void OnPaint(wxPaintEvent& event);
+    void OnMouseEvent(wxMouseEvent& event);
+    void OnHello(wxCommandEvent& event);
+
+    // Called when the file has been downloaded
+    virtual void OnNPNewFile(NPStream *stream, const wxString& fname);
+
+    void CentreStrings(wxDC& dc);
+
+   DECLARE_EVENT_TABLE()
+
+ protected:
+    wxStringList    m_strings;
+    float           m_xpos;
+    float           m_ypos;
+};
+
+BEGIN_EVENT_TABLE(MyFrame, wxFrame)
+	EVT_SIZE(MyFrame::OnSize)
+	EVT_PAINT(MyFrame::OnPaint)
+	EVT_MOUSE_EVENTS(MyFrame::OnMouseEvent)
+	EVT_BUTTON(ID_HELLO, MyFrame::OnHello)
+END_EVENT_TABLE()
+
+IMPLEMENT_APP(MyApp)
+
+// No app initialisation necessary, and for a plugin there is no
+// top frame.
+wxFrame *MyApp::OnInit(void)
+{
+    return NULL;
+}
+
+// Called whenever a new plugin instance is called. We could check
+// various things here in 'data' but we won't bother.
+wxPluginFrame* MyApp::OnNewInstance(const wxPluginData& data)
+{
+    // Implicitly added to list of plugin frames
+    return new MyFrame(data);
+}
+
+// My frame constructor
+MyFrame::MyFrame(const wxPluginData& data):
+  wxPluginFrame(data)
+{
+    m_xpos = -1;
+    m_ypos = -1;
+
+    wxMenuBar *menuBar = new wxMenuBar;
+    wxMenu *menu = new wxMenu;
+    menu->Append(1, "E&xit");
+    menuBar->Append(menu, "&File");
+
+    SetMenuBar(menuBar);
+
+    new wxTextCtrl(this, -1, "", wxPoint(10, 30), wxSize(200, 25), wxSUNKEN_BORDER);
+    new wxButton(this, ID_HELLO, "Hello", wxPoint(10, 70));
+}
+
+void MyFrame::OnPaint(wxPaintEvent& event)
+{
+    wxPaintDC dc(this);
+
+    dc.SetBrush(*wxCYAN_BRUSH);
+    dc.SetPen(*wxRED_PEN);
+
+    int w, h;
+    GetClientSize(&w, &h);
+
+    dc.DrawRectangle(0, 0, w, h);
+
+    wxFont swissFont(10, wxSWISS, wxNORMAL, wxNORMAL);
+    dc.SetFont(swissFont);
+    dc.SetBackgroundMode(wxTRANSPARENT);
+
+    CentreStrings(dc);
+}
+
+// Called when the file has been downloaded
+void MyFrame::OnNPNewFile(NPStream *stream, const wxString& fname)
+{
+    ifstream str(fname);
+    char buf[201];
+
+    while ( !str.eof() )
+    {
+        buf[0] = 0;
+        str.getline(buf, 200);
+
+        if ( buf[0] != 0 )
+            m_strings.Add(buf);
+    }
+    Refresh();
+}
+
+void MyFrame::CentreStrings(wxDC& dc)
+{
+    int y = 5;
+    int cw, ch;
+    GetClientSize(&cw, &ch);
+
+    wxNode *node = m_strings.First();
+    while ( node )
+    {
+        char *s = (char *)node->Data();
+        float w, h;
+        dc.GetTextExtent(s, &w, &h);
+
+        int x = wxMax(0, (cw - w)/2);
+        dc.DrawText(s, x, y);
+
+        y += h + (h/2);
+
+        node = node->Next();
+    }
+}
+
+// This implements a tiny doodling program. Drag the mouse using
+// the left button.
+void MyFrame::OnMouseEvent(wxMouseEvent& event)
+{
+  float x, y;
+  event.Position(&x, &y);
+  wxClientDC dc(this);
+
+  if (m_xpos > -1 && m_ypos > -1 && event.Dragging() && event.LeftIsDown())
+  {
+    dc.SetPen(wxBLACK_PEN);
+    dc.SetBrush(wxTRANSPARENT_BRUSH);
+    dc.DrawLine(m_xpos, m_ypos, x, y);
+  }
+  m_xpos = x;
+  m_ypos = y;
+}
+
+void MyFrame::OnHello(wxCommandEvent& event)
+{
+    wxMessageBox("Hello!");
+}
diff --git a/utils/nplugin/samples/gui/gui.h b/utils/nplugin/samples/gui/gui.h
new file mode 100644
index 0000000000..01e46d64b6
--- /dev/null
+++ b/utils/nplugin/samples/gui/gui.h
@@ -0,0 +1,59 @@
+/*
+ * File:	gui.h
+ * Purpose:	wxWindows plugin with a few GUI elements
+ * Author:	Julian Smart
+ * Created:	1997
+ * Updated:	
+ * Copyright:   (c) Julian Smart
+ */
+
+#ifndef __GUIH__
+#define __GUIH__
+
+// Define a new application type
+class MyApp: public wxPluginApp
+{ public:
+    virtual wxFrame *OnInit(void);
+    virtual wxPluginFrame* OnNewInstance(const wxPluginData& data);
+};
+
+class MyApp;
+class MyFrame;
+class MyCanvas;
+
+class MyFrame: public wxPluginFrame
+{
+public:
+	MyFrame(const wxPluginData& data);
+	virtual ~MyFrame();
+
+	void OldOnMenuCommand(int id);
+
+private:
+	wxMenu*		fileMenu;
+	wxMenuBar*	menuBar;
+	MyCanvas*	leftCanvas;
+	MyCanvas*	rightCanvas;
+    wxSplitterWindow* splitter;
+};
+
+class MyCanvas: public wxScrolledWindow
+{
+public:
+	MyCanvas(wxWindow* parent, int x, int y, int w, int h);
+	virtual ~MyCanvas();
+
+	void OnPaint(wxPaintEvent& event);
+
+DECLARE_EVENT_TABLE()
+};
+
+// ID for the menu quit command
+#define SPLIT_QUIT          1
+#define SPLIT_HORIZONTAL    2
+#define SPLIT_VERTICAL      3
+#define SPLIT_UNSPLIT       4
+
+
+#endif
+
diff --git a/utils/nplugin/samples/gui/makefile.nt b/utils/nplugin/samples/gui/makefile.nt
new file mode 100644
index 0000000000..2487d04e37
--- /dev/null
+++ b/utils/nplugin/samples/gui/makefile.nt
@@ -0,0 +1,70 @@
+#
+# File:		makefile.nt
+# Author:	Julian Smart
+# Created:	1997
+# Updated:	
+# Copyright:	(c) 1997, Julian Smart
+#
+# "%W% %G%"
+#
+# Makefile : Builds gui plugin example (MS VC++).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+
+# Application is a DLL
+DLL=1
+
+EXTRAINC=/I$(WXDIR)\utils\nplugin\src
+
+!include $(WXDIR)\src\ntwxwin.mak
+
+THISDIR = $(WXDIR)\utils\nplugin\examples\gui
+PROGRAM=npgui32
+PLUGINLIB=$(WXDIR)\utils\nplugin\lib\nplugin.lib
+
+OBJECTS = gui.obj
+
+all:    $(PROGRAM).dll
+
+$(PROGRAM):    $(PROGRAM).exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt dllnp FINAL=$(FINAL)
+        cd $(THISDIR)
+
+# Update the dynamic link library
+
+$(PROGRAM).dll: $(DUMMYOBJ) $(OBJECTS) $(WXDIR)\lib\wx.lib $(PLUGINLIB) $(PROGRAM).res $(PROGRAM).def
+    $(link) $(LINKFLAGS) \
+    -out:$(PROGRAM).dll   \
+    -def:$(PROGRAM).def \
+    $(DUMMYOBJ) $(OBJECTS) $(PROGRAM).res $(WXDIR)\lib\wx.lib $(PLUGINLIB) \
+    $(guilibsdll) msvcrt.lib shell32.lib comctl32.lib ctl3d32.lib
+
+gui.obj:      gui.$(SRCSUFF) gui.h $(DUMMYOBJ)
+        $(cc) @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+$(PROGRAM).res :      $(PROGRAM).rc $(WXDIR)\include\wx\msw\wx.rc
+    $(rc) -r /i$(WXDIR)\include -fo$@ $(PROGRAM).rc
+
+copy:
+	copy npgui32.dll "c:\program files\Netscape\Navigator\program\plugins"
+	copy npgui32.dll "c:\program files\Internet Explorer\plugins"
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
+        -erase *.dll
+        -erase *.exp
+        -erase *.lib
+        -erase *.ilk
diff --git a/utils/nplugin/samples/gui/npgui32.def b/utils/nplugin/samples/gui/npgui32.def
new file mode 100644
index 0000000000..1107bb98f5
--- /dev/null
+++ b/utils/nplugin/samples/gui/npgui32.def
@@ -0,0 +1,9 @@
+LIBRARY   NPGUI32
+
+CODE	  PRELOAD MOVEABLE DISCARDABLE
+DATA	  PRELOAD SINGLE
+
+EXPORTS
+	NP_GetEntryPoints   @1
+	NP_Initialize       @2
+	NP_Shutdown         @3
diff --git a/utils/nplugin/samples/gui/npgui32.rc b/utils/nplugin/samples/gui/npgui32.rc
new file mode 100644
index 0000000000..cafee455df
--- /dev/null
+++ b/utils/nplugin/samples/gui/npgui32.rc
@@ -0,0 +1,44 @@
+#include "wx/msw/wx.rc"
+
+/////////////////////////////////////////////////////////////////////////////
+//
+// Version
+//
+
+VS_VERSION_INFO VERSIONINFO
+ FILEVERSION 1,0,0,1
+ PRODUCTVERSION 1,0,0,1
+ FILEFLAGSMASK 0x3fL
+#ifdef _DEBUG
+ FILEFLAGS 0x1L
+#else
+ FILEFLAGS 0x0L
+#endif
+ FILEOS 0x4L
+ FILETYPE 0x2L
+ FILESUBTYPE 0x0L
+BEGIN
+    BLOCK "StringFileInfo"
+    BEGIN
+        BLOCK "040904e4"
+        BEGIN
+            VALUE "CompanyName",     "Julian Smart\0"
+            VALUE "FileDescription", "wxWindows GUI example plugin file\0"
+            VALUE "FileVersion",     "0.0.0.1\0"
+            VALUE "InternalName",    "wxWindows GUI Plugin\0"
+            VALUE "LegalCopyright",  "Copyright Julian Smart 1997\0"
+            VALUE "LegalTrademarks", "\0"
+            VALUE "OriginalFilename","npgui32.dll\0"
+            VALUE "ProductName",     "wxWindows GUI Plugin Sample\0"
+            VALUE "ProductVersion",  "0.0.0.1\0"
+            VALUE "MIMEType",        "wxgui/mime-type\0"
+            VALUE "FileExtents",     "gui\0"
+            VALUE "FileOpenName",    "wxWindows GUI (*.gui)\0"
+        END
+    END
+    BLOCK "VarFileInfo"
+    BEGIN
+        VALUE "Translation", 0x409, 1252
+    END
+END
+
diff --git a/utils/nplugin/samples/simple/makefile.nt b/utils/nplugin/samples/simple/makefile.nt
new file mode 100644
index 0000000000..66e55eee46
--- /dev/null
+++ b/utils/nplugin/samples/simple/makefile.nt
@@ -0,0 +1,70 @@
+#
+# File:		makefile.nt
+# Author:	Julian Smart
+# Created:	1997
+# Updated:	
+# Copyright:	(c) 1997, Julian Smart
+#
+# "%W% %G%"
+#
+# Makefile : Builds simple plugin example (MS VC++).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+
+# Application is a DLL
+DLL=1
+
+EXTRAINC=/I$(WXDIR)\utils\nplugin\src
+
+!include $(WXDIR)\src\ntwxwin.mak
+
+THISDIR = $(WXDIR)\utils\nplugin\smples\simple
+PROGRAM=npsimple32
+PLUGINLIB=$(WXDIR)\utils\nplugin\lib\nplugin.lib
+
+OBJECTS = simple.obj
+
+all:    $(PROGRAM).dll
+
+$(PROGRAM):    $(PROGRAM).exe
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt dllnp FINAL=$(FINAL)
+        cd $(THISDIR)
+
+# Update the dynamic link library
+
+$(PROGRAM).dll: $(DUMMYOBJ) $(OBJECTS) $(WXDIR)\lib\wx.lib $(PLUGINLIB) $(PROGRAM).res $(PROGRAM).def
+    $(link) $(LINKFLAGS) \
+    -out:$(PROGRAM).dll   \
+    -def:$(PROGRAM).def \
+    $(DUMMYOBJ) $(OBJECTS) $(PROGRAM).res $(WXDIR)\lib\wx.lib $(PLUGINLIB) \
+    $(guilibsdll) msvcrt.lib shell32.lib comctl32.lib ctl3d32.lib
+
+simple.obj:      simple.$(SRCSUFF) $(DUMMYOBJ)
+        $(cc) @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+$(PROGRAM).res :      $(PROGRAM).rc $(WXDIR)\include\wx\msw\wx.rc
+    $(rc) -r /i$(WXDIR)\include -fo$@ $(PROGRAM).rc
+
+copy:
+	copy npsimple32.dll "c:\program files\Netscape\Navigator\program\plugins"
+	copy npsimple32.dll "c:\program files\Internet Explorer\plugins"
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
+        -erase *.dll
+        -erase *.exp
+        -erase *.lib
+        -erase *.ilk
diff --git a/utils/nplugin/samples/simple/npsimple32.def b/utils/nplugin/samples/simple/npsimple32.def
new file mode 100644
index 0000000000..e3af3116fe
--- /dev/null
+++ b/utils/nplugin/samples/simple/npsimple32.def
@@ -0,0 +1,9 @@
+LIBRARY   NPSIMPLE32
+
+CODE	  PRELOAD MOVEABLE DISCARDABLE
+DATA	  PRELOAD SINGLE
+
+EXPORTS
+	NP_GetEntryPoints   @1
+	NP_Initialize       @2
+	NP_Shutdown         @3
diff --git a/utils/nplugin/samples/simple/npsimple32.rc b/utils/nplugin/samples/simple/npsimple32.rc
new file mode 100644
index 0000000000..f2d4903226
--- /dev/null
+++ b/utils/nplugin/samples/simple/npsimple32.rc
@@ -0,0 +1,44 @@
+#include "wx/msw/wx.rc"
+
+/////////////////////////////////////////////////////////////////////////////
+//
+// Version
+//
+
+VS_VERSION_INFO VERSIONINFO
+ FILEVERSION 1,0,0,1
+ PRODUCTVERSION 1,0,0,1
+ FILEFLAGSMASK 0x3fL
+#ifdef _DEBUG
+ FILEFLAGS 0x1L
+#else
+ FILEFLAGS 0x0L
+#endif
+ FILEOS 0x4L
+ FILETYPE 0x2L
+ FILESUBTYPE 0x0L
+BEGIN
+    BLOCK "StringFileInfo"
+    BEGIN
+        BLOCK "040904e4"
+        BEGIN
+            VALUE "CompanyName",     "Julian Smart\0"
+            VALUE "FileDescription", "wxWindows simple example plugin file\0"
+            VALUE "FileVersion",     "0.0.0.1\0"
+            VALUE "InternalName",    "wxWindows Simple Plugin\0"
+            VALUE "LegalCopyright",  "Copyright Julian Smart 1997\0"
+            VALUE "LegalTrademarks", "\0"
+            VALUE "OriginalFilename","npsimple32.dll\0"
+            VALUE "ProductName",     "wxWindows Simple Plugin Sample\0"
+            VALUE "ProductVersion",  "0.0.0.1\0"
+            VALUE "MIMEType",        "wxsimple/mime-type\0"
+            VALUE "FileExtents",     "smp\0"
+            VALUE "FileOpenName",    "wxWindows Simple (*.smp)\0"
+        END
+    END
+    BLOCK "VarFileInfo"
+    BEGIN
+        VALUE "Translation", 0x409, 1252
+    END
+END
+
diff --git a/utils/nplugin/samples/simple/simple.cpp b/utils/nplugin/samples/simple/simple.cpp
new file mode 100644
index 0000000000..137e7b0585
--- /dev/null
+++ b/utils/nplugin/samples/simple/simple.cpp
@@ -0,0 +1,174 @@
+/*
+ * File:	simple.cpp
+ * Purpose:	Minimal wxWindows plugin
+ * Author:	Julian Smart
+ * Created:	1997
+ * Updated:	
+ * Copyright:   (c) Julian Smart
+ */
+
+/* static const char sccsid[] = "%W% %G%"; */
+
+#ifdef __GNUG__
+#pragma implementation
+#pragma interface
+#endif
+
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+#pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+#include "wx/wx.h"
+#endif
+
+#include <fstream.h>
+
+#include "NPApp.h"
+#include "NPFrame.h"
+
+// Define a new application type
+class MyApp: public wxPluginApp
+{ public:
+    virtual wxFrame *OnInit(void);
+    virtual wxPluginFrame* OnNewInstance(const wxPluginData& data);
+};
+
+// Define a new frame type
+class MyFrame: public wxPluginFrame
+{ public:
+    MyFrame(const wxPluginData& data);
+    
+ public:
+    // Let's paint directly onto the 'frame'; we don't need a subwindow
+    void OnPaint(wxPaintEvent& event);
+    void OnDraw(wxDC& dc);
+    void OnMouseEvent(wxMouseEvent& event);
+
+    // Called when the file has been downloaded
+    virtual void OnNPNewFile(NPStream *stream, const wxString& fname);
+
+    void CentreStrings(wxDC& dc);
+
+   DECLARE_EVENT_TABLE()
+
+ protected:
+    wxStringList    m_strings;
+    long            m_xpos;
+    long            m_ypos;
+};
+
+BEGIN_EVENT_TABLE(MyFrame, wxFrame)
+	EVT_SIZE(MyFrame::OnSize)
+	EVT_PAINT(MyFrame::OnPaint)
+	EVT_MOUSE_EVENTS(MyFrame::OnMouseEvent)
+END_EVENT_TABLE()
+
+IMPLEMENT_APP(MyApp)
+
+// No app initialisation necessary, and for a plugin there is no
+// top frame.
+wxFrame *MyApp::OnInit(void)
+{
+    return NULL;
+}
+
+// Called whenever a new plugin instance is called. We could check
+// various things here in 'data' but we won't bother.
+wxPluginFrame* MyApp::OnNewInstance(const wxPluginData& data)
+{
+    // Implicitly added to list of plugin frames
+    return new MyFrame(data);
+}
+
+// My frame constructor
+MyFrame::MyFrame(const wxPluginData& data):
+  wxPluginFrame(data)
+{
+    m_xpos = -1;
+    m_ypos = -1;
+}
+
+void MyFrame::OnPaint(wxPaintEvent& event)
+{
+    wxPaintDC dc(this);
+
+    OnDraw(dc);
+}
+
+void MyFrame::OnDraw(wxDC& dc)
+{
+    dc.SetBrush(*wxCYAN_BRUSH);
+    dc.SetPen(*wxRED_PEN);
+
+    int w, h;
+    GetClientSize(&w, &h);
+
+    dc.DrawRectangle(0, 0, w, h);
+
+    wxFont swissFont(10, wxSWISS, wxNORMAL, wxNORMAL);
+    dc.SetFont(swissFont);
+    dc.SetBackgroundMode(wxTRANSPARENT);
+
+    CentreStrings(dc);
+}
+
+// Called when the file has been downloaded
+void MyFrame::OnNPNewFile(NPStream *stream, const wxString& fname)
+{
+    ifstream str(fname);
+    char buf[201];
+
+    while ( !str.eof() )
+    {
+        buf[0] = 0;
+        str.getline(buf, 200);
+
+        if ( buf[0] != 0 )
+            m_strings.Add(buf);
+    }
+    Refresh();
+}
+
+void MyFrame::CentreStrings(wxDC& dc)
+{
+    int y = 5;
+    int cw, ch;
+    GetClientSize(&cw, &ch);
+
+    wxNode *node = m_strings.First();
+    while ( node )
+    {
+        char *s = (char *)node->Data();
+        long w, h;
+        dc.GetTextExtent(s, &w, &h);
+
+        int x = wxMax(0, (cw - w)/2);
+        dc.DrawText(s, x, y);
+
+        y += h + (h/2);
+
+        node = node->Next();
+    }
+}
+
+// This implements a tiny doodling program. Drag the mouse using
+// the left button.
+void MyFrame::OnMouseEvent(wxMouseEvent& event)
+{
+  long x, y;
+  event.Position(&x, &y);
+  wxClientDC dc(this);
+
+  if (m_xpos > -1 && m_ypos > -1 && event.Dragging() && event.LeftIsDown())
+  {
+    dc.SetPen(wxBLACK_PEN);
+    dc.SetBrush(wxTRANSPARENT_BRUSH);
+    dc.DrawLine(m_xpos, m_ypos, x, y);
+  }
+  m_xpos = x;
+  m_ypos = y;
+}
+
diff --git a/utils/nplugin/src/makefile.nt b/utils/nplugin/src/makefile.nt
new file mode 100644
index 0000000000..b3e4491221
--- /dev/null
+++ b/utils/nplugin/src/makefile.nt
@@ -0,0 +1,78 @@
+#
+# File:		makefile.nt
+# Author:	Julian Smart
+# Created:	1993
+# Updated:	
+# Copyright:	(c) 1993, AIAI, University of Edinburgh
+#
+# "%W% %G%"
+#
+# Makefile : Builds controls example (MS VC++).
+# Use FINAL=1 argument to nmake to build final version with no debugging
+# info
+
+# Set WXDIR for your system
+WXDIR = $(WXWIN)
+
+# Application is a DLL
+DLL=1
+
+!include $(WXDIR)\src\ntwxwin.mak
+
+PLUGINDIR = $(WXDIR)\utils\nplugin
+THISDIR = $(PLUGINDIR)\src
+LIBTARGET=$(PLUGINDIR)\lib\nplugin.lib
+
+OBJECTS = npwin.obj npshell.obj NPFrame.obj NPApp.obj
+
+all:    $(LIBTARGET)
+
+wx:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt FINAL=$(FINAL)
+        cd $(THISDIR)
+
+wxclean:
+        cd $(WXDIR)\src\msw
+        nmake -f makefile.nt clean
+        cd $(THISDIR)
+
+$(LIBTARGET): $(OBJECTS)
+	-erase $(LIBTARGET)
+	$(implib) @<<
+-out:$(LIBTARGET)
+-machine:$(CPU)
+$(OBJECTS)
+<<
+
+npwin.obj:      npwin.cpp npapi.h npupp.h
+        $(cc) @<<
+$(CPPFLAGS2) /c /Tp $*.$(SRCSUFF)
+<<
+
+npshell.obj:      npshell.cpp npapi.h NPApp.h NPFrame.h
+        $(cc) @<<
+$(CPPFLAGS2) /c /Tp $*.$(SRCSUFF)
+<<
+
+NPFrame.obj:      NPFrame.cpp NPFrame.h NPApp.h npapi.h
+        $(cc) @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+NPApp.obj:      NPApp.cpp NPApp.h NPFrame.h npapi.h
+        $(cc) @<<
+$(CPPFLAGS) /c /Tp $*.$(SRCSUFF)
+<<
+
+clean:
+        -erase *.obj
+        -erase *.exe
+        -erase *.res
+        -erase *.map
+        -erase *.sbr
+        -erase *.pdb
+        -erase *.dll
+        -erase *.exp
+        -erase *.ilk
+        -erase $(LIBTARGET)
diff --git a/utils/nplugin/src/npapi.h b/utils/nplugin/src/npapi.h
new file mode 100644
index 0000000000..bbb631c3d4
--- /dev/null
+++ b/utils/nplugin/src/npapi.h
@@ -0,0 +1,258 @@
+/*
+ *  npapi.h $Revision$
+ *  Netscape client plug-in API spec
+ */
+
+#ifndef _NPAPI_H_
+#define _NPAPI_H_
+
+
+/* XXX this needs to get out of here */
+#if defined(__MWERKS__)
+#ifndef XP_MAC
+#define XP_MAC
+#endif
+#endif
+
+
+/*
+ *  Version constants
+ */
+
+#define NP_VERSION_MAJOR 0
+#define NP_VERSION_MINOR 6
+
+
+
+/* 
+ *  Basic types
+ */
+ 
+#ifndef _UINT16
+typedef unsigned short uint16;
+#endif
+#ifndef _UINT32
+typedef unsigned long uint32;
+#endif
+#ifndef _INT16
+typedef short int16;
+#endif
+#ifndef _INT32
+typedef long int32;
+#endif
+
+#ifndef FALSE
+#define FALSE (0)
+#endif
+#ifndef TRUE
+#define TRUE (1)
+#endif
+#ifndef NULL
+#define NULL (0L)
+#endif
+
+typedef unsigned char   NPBool;
+typedef void*           NPEvent;
+typedef int16           NPError;
+typedef char*           NPMIMEType;
+
+
+/*
+ *  NPP is a plug-in's opaque instance handle
+ */
+typedef struct _NPP
+{
+    void*   pdata;                /* plug-in private data */
+    void*   ndata;                /* netscape private data */
+} NPP_t;
+
+typedef NPP_t*  NPP;
+
+
+
+typedef struct _NPStream
+{
+    void*       pdata;                /* plug-in private data */
+    void*       ndata;                /* netscape private data */
+    const char* url;
+    uint32      end;
+    uint32      lastmodified;
+} NPStream;
+
+typedef struct _NPByteRange
+{
+    int32                   offset;                /* negative offset means from the end */
+    uint32                  length;
+    struct _NPByteRange*    next;
+} NPByteRange;
+
+
+typedef struct _NPSavedData
+{
+    int32   len;
+    void*   buf;
+} NPSavedData;
+
+
+
+typedef struct _NPRect
+{
+    uint16  top;
+    uint16  left;
+    uint16  bottom;
+    uint16  right;
+} NPRect;
+
+typedef struct _NPWindow 
+{
+    void*   window;                 /* platform specific window handle */
+    uint32  x;                      /* position of top left corner relative to a netscape page */
+    uint32  y;                   
+    uint32  width;                  /* maximum window size */
+    uint32  height;
+    NPRect  clipRect;               /* clipping rectangle in port coordinates */
+} NPWindow;
+
+
+
+typedef struct _NPFullPrint
+{
+    NPBool      pluginPrinted;      /* Set TRUE if plugin handled fullscreen printing */
+    NPBool      printOne;           /* TRUE if plugin should print one copy to default printer */
+    void*       platformPrint;      /* Platform-specific printing info */
+} NPFullPrint;
+
+typedef struct _NPEmbedPrint
+{
+    NPWindow    window;
+    void*       platformPrint;      /* Platform-specific printing info */
+} NPEmbedPrint;
+
+typedef struct _NPPrint
+{
+    uint16              mode;       /* NP_FULL or NP_EMBED */
+    union
+    {
+        NPFullPrint     fullPrint;  /* if mode is NP_FULL */
+        NPEmbedPrint    embedPrint; /* if mode is NP_EMBED */
+    } print;
+} NPPrint;
+
+
+
+
+#ifdef XP_MAC
+
+/*
+ *  Mac-specific structures and definitions.
+ */
+ 
+#include <Quickdraw.h>
+#include <Events.h>
+
+typedef struct NP_Port
+{
+    CGrafPtr    port;           /* Grafport */
+    int32       portx;          /* position inside the topmost window */
+    int32       porty;
+} NP_Port;
+
+/*
+ *  Non-standard event types that can be passed to HandleEvent
+ */
+#define getFocusEvent       (osEvt + 16)
+#define loseFocusEvent      (osEvt + 17)
+#define adjustCursorEvent   (osEvt + 18)
+
+#endif /* XP_MAC */
+
+
+
+
+#define NP_EMBED        1
+#define NP_FULL         2
+#define NP_BACKGROUND   3
+
+#define NP_NORMAL       1
+#define NP_SEEK         2
+#define NP_ASFILE       3
+
+#define NP_MAXREADY (((unsigned)(~0)<<1)>>1)
+
+
+/*
+ *  Error and reason code definitions.
+ */
+
+#define NP_NOERR  0
+#define NP_EINVAL 1
+#define NP_EABORT 2
+
+#define NPERR_BASE                      0
+#define NPERR_NO_ERROR                  (NPERR_BASE + 0)
+#define NPERR_GENERIC_ERROR             (NPERR_BASE + 1)
+#define NPERR_INVALID_INSTANCE_ERROR    (NPERR_BASE + 2)
+#define NPERR_INVALID_FUNCTABLE_ERROR   (NPERR_BASE + 3)
+#define NPERR_MODULE_LOAD_FAILED_ERROR  (NPERR_BASE + 4)
+#define NPERR_OUT_OF_MEMORY_ERROR       (NPERR_BASE + 5)
+#define NPERR_INVALID_PLUGIN_ERROR      (NPERR_BASE + 6)
+#define NPERR_INVALID_PLUGIN_DIR_ERROR  (NPERR_BASE + 7)
+#define NPERR_INCOMPATIBLE_VERSION_ERROR (NPERR_BASE + 8)
+
+#define NPRES_BASE                      0
+#define NPRES_NETWORK_ERR               (NPRES_BASE + 0)
+#define NPRES_USER_BREAK                (NPRES_BASE + 1)
+#define NPRES_DONE                      (NPRES_BASE + 3)
+
+
+
+/*
+ *  Function prototypes.
+ *  Functions beginning with 'NPP' are functions provided by the plugin that Netscape will call.
+ *  Functions beginning with 'NPN' are functions provided by Netscape that the plugin will call.
+ */
+
+#if defined(_WINDOWS) && !defined(__WIN32__)
+#define NP_LOADDS  _loadds
+#else
+#define NP_LOADDS
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+NPError               NPP_Initialize(void);
+void                  NPP_Shutdown(void);
+NPError     NP_LOADDS NPP_New(NPMIMEType pluginType, NPP instance, uint16 mode, int16 argc, char* argn[], char* argv[], NPSavedData* saved);
+NPError     NP_LOADDS NPP_Destroy(NPP instance, NPSavedData** save);
+NPError     NP_LOADDS NPP_SetWindow(NPP instance, NPWindow* window);
+NPError     NP_LOADDS NPP_NewStream(NPP instance, NPMIMEType type, NPStream* stream, NPBool seekable, uint16* stype);
+NPError     NP_LOADDS NPP_DestroyStream(NPP instance, NPStream* stream, NPError reason);
+int32       NP_LOADDS NPP_WriteReady(NPP instance, NPStream* stream);
+int32       NP_LOADDS NPP_Write(NPP instance, NPStream* stream, int32 offset, int32 len, void* buffer);
+void        NP_LOADDS NPP_StreamAsFile(NPP instance, NPStream* stream, const char* fname);
+void        NP_LOADDS NPP_Print(NPP instance, NPPrint* platformPrint);
+int16                 NPP_HandleEvent(NPP instance, void* event);
+
+void        NPN_Version(int* plugin_major, int* plugin_minor, int* netscape_major, int* netscape_minor);
+NPError     NPN_GetURL(NPP instance, const char* url, const char* window);
+NPError     NPN_PostURL(NPP instance, const char* url, const char* window, uint32 len, const char* buf, NPBool file);
+NPError     NPN_RequestRead(NPStream* stream, NPByteRange* rangeList);
+NPError     NPN_NewStream(NPP instance, NPMIMEType type, NPStream* stream);
+int32       NPN_Write(NPP instance, NPStream* stream, int32 len, void* buffer);
+NPError     NPN_DestroyStream(NPP instance, NPStream* stream, NPError reason);
+void        NPN_Status(NPP instance, const char* message);
+const char* NPN_UserAgent(NPP instance);
+void*       NPN_MemAlloc(uint32 size);
+void        NPN_MemFree(void* ptr);
+uint32      NPN_MemFlush(uint32 size);
+void		NPN_ReloadPlugins(NPBool reloadPages);
+
+#ifdef __cplusplus
+}  /* end extern "C" */
+#endif
+
+
+#endif /* _NPAPI_H_ */
+
diff --git a/utils/nplugin/src/npapp.cpp b/utils/nplugin/src/npapp.cpp
new file mode 100644
index 0000000000..e9c43029c3
--- /dev/null
+++ b/utils/nplugin/src/npapp.cpp
@@ -0,0 +1,277 @@
+/*
+ * File:	NPApp.cc
+ * Purpose:	wxPluginApp implementation
+ * Author:	Julian Smart
+ * Created:	1997
+ * Updated:
+ * Copyright:   (c) Julian Smart
+ */
+
+// For compilers that support precompilation, includes "wx/wx.h".
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+#pragma hdrstop
+#endif
+
+#include "NPApp.h"
+#include "NPFrame.h"
+
+#include <windows.h>
+
+IMPLEMENT_ABSTRACT_CLASS(wxPluginApp, wxApp)
+
+wxPluginApp *wxGetPluginApp(void)
+{
+    if ( wxTheApp && wxTheApp->IsKindOf(CLASSINFO(wxPluginApp)))
+        return (wxPluginApp *)wxTheApp;
+    else
+        return NULL;
+}
+
+wxPluginApp::wxPluginApp(void)
+{
+  m_data.m_argc = NULL;
+  m_data.m_argn = NULL;
+  m_data.m_argv = NULL;
+  m_data.m_type = 0;
+  m_data.m_instance = 0;
+  m_data.m_mode = 0;
+  m_data.m_window = 0;
+}
+
+wxPluginApp::~wxPluginApp(void)
+{
+    if ( m_data.m_argn )
+        delete[] m_data.m_argn;
+    if ( m_data.m_argv )
+        delete[] m_data.m_argv;
+}
+
+// Add a frame
+void wxPluginApp::AddFrame(wxPluginFrame *frame)
+{
+    m_frames.Append(frame);
+}
+
+// Remove a frame
+void wxPluginApp::RemoveFrame(wxPluginFrame *frame)
+{
+    m_frames.DeleteObject(frame);
+}
+
+// Find a frame given a NP instance
+wxPluginFrame *wxPluginApp::FindFrame(NPP instance)
+{
+    wxNode *node = m_frames.First();
+    while ( node )
+    {
+        wxPluginFrame *frame = (wxPluginFrame *)node->Data();
+        if ( frame->GetInstance() == instance )
+        {
+            return frame;
+        }
+        node = node->Next();
+    }
+    return NULL;
+}
+
+void wxPluginApp::SetAttributeValues(const int n, char *argn[], char *argv[])
+{
+    if ( m_data.m_argn )
+        delete[] m_data.m_argn;
+    if ( m_data.m_argv )
+        delete[] m_data.m_argv;
+
+    m_data.m_argc = n;
+
+    m_data.m_argn = new wxString[n];
+    m_data.m_argv = new wxString[n];
+    int i;
+    for ( i = 0; i < n ; i ++)
+    {
+        m_data.m_argn[i] = argn[i];
+        m_data.m_argv[i] = argv[i];
+    }
+}
+
+///////////////////////////////////////////////////////////////
+// Netscape Plugin API calls routed via wxPluginApp
+
+NPError   wxPluginApp::NPP_Destroy(NPP instance, NPSavedData** save)
+{
+    wxPluginFrame *frame = FindFrame(instance);
+    if ( frame )
+    {
+        frame->OnClose();
+        delete frame;
+    }
+    return NPERR_NO_ERROR;
+}
+
+NPError   wxPluginApp::NPP_DestroyStream(NPP instance, NPStream* stream, NPError reason)
+{
+   return NPERR_NO_ERROR;
+}
+
+/*
+jref      wxPluginApp::NPP_GetJavaClass(void)
+{
+   return 0;
+}
+*/
+
+NPError   wxPluginApp::NPP_Initialize(void)
+{
+    static int init = FALSE;
+
+    if ( init == TRUE )
+        MessageBox(NULL, "wxPluginApp::NPP_Initialize:\nabout to call wxEntry for 2nd time!!!", "wxPlugin", MB_OK);
+
+    wxEntry((WXHINSTANCE) GetModuleHandle(NULL));
+
+    init = TRUE;
+
+//    MessageBox(NULL, "wxPluginApp::NPP_Initialize: have called wxEntry", "wxPlugin", MB_OK);
+    return NPERR_NO_ERROR;
+}
+
+NPError   wxPluginApp::NPP_New(NPMIMEType pluginType, NPP instance, uint16 mode,
+                        int16 argc, char* argn[], char* argv[], NPSavedData* saved)
+{
+//    MessageBox(NULL, "wxPluginApp::NPP_New", "wxPlugin", MB_OK);
+
+    // Save values so frame can be created in first NPP_SetWindow
+    if ( m_data.m_instance != 0 )
+    {
+        MessageBox(NULL, "wxPluginApp::NPP_New: whoops, 2 NPP_New calls in succession without NPP_SetWindow.\n Need to modify my code!", "wxPlugin", MB_OK);
+        return NPERR_NO_ERROR;
+    }
+
+    m_data.m_instance = instance;
+    m_data.m_type = pluginType;
+    m_data.m_mode = mode;
+
+    SetAttributeValues(argc, argn, argv);
+
+    // Unfortunately, we may get a stream event before we've got a valid window
+    // handle, so we just have to go ahead and create a new instance.
+    wxPluginFrame *frame = OnNewInstance(m_data);
+
+    m_data.m_instance = NULL;
+    m_data.m_window = NULL;
+    delete[] m_data.m_argv;
+    delete[] m_data.m_argn;
+    m_data.m_argv = NULL;
+    m_data.m_argn = NULL;
+
+    return NPERR_NO_ERROR;
+}
+
+NPError   wxPluginApp::NPP_NewStream(NPP instance, NPMIMEType type, NPStream *stream,
+                        NPBool seekable, uint16* stype)
+{
+    // By default, we want to receive a file instead of a stream.
+    wxPluginFrame *frame = FindFrame(instance);
+    if ( frame )
+    {
+        return frame->OnNPNewStream(type, stream, seekable, stype);
+    }
+    return NPERR_NO_ERROR;
+}
+
+void wxPluginApp::NPP_Print(NPP instance, NPPrint* printInfo)
+{
+    if (instance == NULL)
+        return;
+
+    wxPluginFrame *frame = FindFrame(instance);
+    if ( frame )
+    {
+        frame->OnNPPrint(printInfo);
+    }
+}
+
+NPError      wxPluginApp::NPP_SetWindow(NPP instance, NPWindow* window)
+{
+//    MessageBox(NULL, "wxPluginApp::NPP_SetWindow", "wxPlugin", MB_OK);
+
+    if ( window )
+        wxDebugMsg("%d\n", (int) window->window);
+
+    wxPluginFrame *frame = FindFrame(instance);
+    if ( frame )
+    {
+        frame->SetNPWindow(window);
+    }
+    else
+    {
+#if 0
+        // No such frame: must make it.
+        if ( m_data.m_instance == NULL )
+        {
+            MessageBox(NULL, "wxPluginApp::NPP_SetWindow: whoops, no data to create window. SetWindow called in funny order?", "wxPlugin", MB_OK);
+            return NPERR_NO_ERROR;
+        }
+
+        if ( window->window == NULL )
+        {
+            // We're receiving a NULL window before we've even received
+            // a valid window. Ignore this silly thing.
+            return NPERR_NO_ERROR;
+        }
+
+        m_data.m_window = window;
+        m_data.m_instance = instance;
+
+//        wxPluginFrame *frame = OnNewInstance(m_data);
+
+        m_data.m_instance = NULL;
+        m_data.m_window = NULL;
+        delete[] m_data.m_argv;
+        delete[] m_data.m_argn;
+        m_data.m_argv = NULL;
+        m_data.m_argn = NULL;
+#endif
+    }
+    return NPERR_NO_ERROR;
+}
+
+void      wxPluginApp::NPP_Shutdown(void)
+{
+    // Clean up wxWindows
+    CleanUp();
+}
+
+void      wxPluginApp::NPP_StreamAsFile(NPP instance, NPStream* stream, const char *fname)
+{
+    wxPluginFrame *frame = FindFrame(instance);
+    if ( frame )
+    {
+        wxString str(fname);
+        frame->OnNPNewFile(stream, str);
+    }
+}
+
+/*
+void      wxPluginApp::NPP_URLNotify(NPP instance, const char* url, NPReason reason,
+                        void* notifyData)
+{
+}
+*/
+
+int32     wxPluginApp::NPP_Write(NPP instance, NPStream* stream, int32 offset, int32 len,
+                        void* buf)
+{
+    return len;              // The number of bytes accepted
+}
+
+static int32 STREAMBUFSIZE = 0X0FFFFFFF;   // If we are reading from a file in NPAsFile
+                                    // mode so we can take any size stream in our
+                                    // write call (since we ignore it)
+
+int32     wxPluginApp::NPP_WriteReady(NPP instance, NPStream* stream)
+{
+    return STREAMBUFSIZE;   // Number of bytes ready to accept in NPP_Write()
+}
+
diff --git a/utils/nplugin/src/npapp.h b/utils/nplugin/src/npapp.h
new file mode 100644
index 0000000000..238a612313
--- /dev/null
+++ b/utils/nplugin/src/npapp.h
@@ -0,0 +1,91 @@
+/*
+ * File:	NPApp.h
+ * Purpose:	wxPluginApp declaration
+ * Author:	Julian Smart
+ * Created:	1997
+ * Updated:	
+ * Copyright:   (c) Julian Smart
+ */
+
+#ifndef __PLUGINAPP__
+#define __PLUGINAPP__
+
+#include "wx/wx.h"
+#include "npapi.h"
+
+class wxPluginFrame;
+
+// Data passed to OnNewInstance
+class wxPluginData
+{
+public:
+    NPP         m_instance;
+    NPMIMEType  m_type;
+    NPWindow*   m_window;
+    int         m_mode;
+    int         m_argc;
+    wxString*   m_argn;
+    wxString*   m_argv;
+};
+
+class WXDLLEXPORT wxPluginApp: public wxApp
+{
+  DECLARE_ABSTRACT_CLASS(wxPluginApp)
+
+public:
+  wxPluginApp(void);
+  ~wxPluginApp(void);
+
+  // Find a frame given a NP instance
+  wxPluginFrame *FindFrame(NPP instance);
+
+  // Add a frame
+  void AddFrame(wxPluginFrame *frame);
+
+  // Remove a frame
+  void RemoveFrame(wxPluginFrame *frame);
+
+  // Set attribute/values for the last instance
+  void SetAttributeValues(const int n, char *argn[], char *argv[]);
+
+  ///////////////////////////////////////////////////////////////
+  // Higher-level API than NP API
+  virtual wxPluginFrame *OnNewInstance(const wxPluginData& data) = 0;
+
+  ///////////////////////////////////////////////////////////////
+  // Netscape Plugin API calls routed via wxPluginApp
+
+  virtual NPError   NPP_Destroy(NPP instance, NPSavedData** save);
+  virtual NPError   NPP_DestroyStream(NPP instance, NPStream* stream, NPError reason);
+//  virtual jref      NPP_GetJavaClass(void);
+  virtual NPError   NPP_Initialize(void);
+  virtual NPError   NPP_New(NPMIMEType pluginType, NPP instance, uint16 mode,
+                        int16 argc, char* argn[], char* argv[], NPSavedData* saved);
+  virtual NPError   NPP_NewStream(NPP instance, NPMIMEType type, NPStream *stream,
+                        NPBool seekable, uint16* stype);
+  virtual void      NPP_Print(NPP instance, NPPrint* platformPrint);
+  virtual NPError   NPP_SetWindow(NPP instance, NPWindow* window);
+  virtual void      NPP_Shutdown(void);
+  virtual void      NPP_StreamAsFile(NPP instance, NPStream* stream, const char *fname);
+/*
+  virtual void      NPP_URLNotify(NPP instance, const char* url, NPReason reason,
+                        void* notifyData);
+*/
+  virtual int32     NPP_Write(NPP instance, NPStream* stream, int32 offset, int32 len,
+                        void* buf);
+  virtual int32     NPP_WriteReady(NPP instance, NPStream* stream);
+
+protected:
+
+  // List of plugin frames
+  wxList        m_frames;
+
+  // Temporary NPP_New arguments so we can wait until NPP_SetWindow is called
+  // before creating a frame
+  wxPluginData  m_data;
+};
+
+wxPluginApp *wxGetPluginApp(void);
+
+#endif
+
diff --git a/utils/nplugin/src/npframe.cpp b/utils/nplugin/src/npframe.cpp
new file mode 100644
index 0000000000..e3e3f63661
--- /dev/null
+++ b/utils/nplugin/src/npframe.cpp
@@ -0,0 +1,293 @@
+/*
+ * File:	NPFrame.cc
+ * Purpose:	wxPluginFrame implementation
+ * Author:	Julian Smart
+ * Created:	1997
+ * Updated:
+ * Copyright:   (c) Julian Smart
+ */
+
+// For compilers that support precompilation, includes "wx/wx.h".
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+#pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+#include "wx/frame.h"
+#endif
+
+#include "wx/dcprint.h"
+
+#include "NPFrame.h"
+#include "NPApp.h"
+
+#include <windows.h>
+
+extern wxList wxModelessWindows;
+extern char wxFrameClassName[];
+
+IMPLEMENT_DYNAMIC_CLASS(wxPluginFrame, wxFrame)
+
+wxPluginFrame::wxPluginFrame(void)
+{
+    m_npWindow = NULL;
+    m_npInstance = NULL;
+    m_nAttributes = 0;
+    m_names = NULL;
+    m_values = NULL;
+}
+
+bool wxPluginFrame::Create(const wxPluginData& data)
+{
+    SetName("pluginFrame");
+
+    m_npWindow = NULL;
+    m_npInstance = NULL;
+    m_nAttributes = 0;
+    m_names = NULL;
+    m_values = NULL;
+    m_npWindow = data.m_window;
+    m_npInstance = data.m_instance;
+
+    SetAttributeValues(data.m_argc, data.m_argn, data.m_argv);
+    SetNPWindow(data.m_window);
+
+    wxModelessWindows.Append(this);
+
+    if (wxTheApp->IsKindOf(CLASSINFO(wxPluginApp)))
+    {
+        ((wxPluginApp *)wxTheApp)->AddFrame(this);
+    }
+    return TRUE;
+}
+
+wxPluginFrame::~wxPluginFrame(void)
+{
+    if (wxTheApp->IsKindOf(CLASSINFO(wxPluginApp)))
+    {
+        ((wxPluginApp *)wxTheApp)->RemoveFrame(this);
+    }
+
+    if ( GetHWND() )
+        UnsubclassWin();
+    m_hWnd = 0;
+
+    if ( m_names )
+        delete[] m_names;
+    if ( m_values )
+        delete[] m_values;
+}
+
+// Get size *available for subwindows* i.e. excluding menu bar etc.
+// For XView, this is the same as GetSize
+void wxPluginFrame::GetClientSize(int *x, int *y) const
+{
+    if ( !m_hWnd )
+    {
+        *x = 0; *y = 0;
+        return;
+    }
+    wxFrame::GetClientSize(x, y);
+}
+
+// Set the client size (i.e. leave the calculation of borders etc.
+// to wxWindows)
+void wxPluginFrame::SetClientSize(const int width, const int height)
+{
+    if ( !m_hWnd )
+        return ;
+
+    wxFrame::SetClientSize(width, height);
+}
+
+void wxPluginFrame::GetSize(int *width, int *height) const
+{
+    if ( !m_hWnd )
+    {
+        *width = 0; *height = 0;
+        return;
+    }
+    wxFrame::GetSize(width, height);
+}
+
+void wxPluginFrame::GetPosition(int *x, int *y) const
+{
+    if ( !m_hWnd )
+    {
+        *x = 0; *y = 0;
+        return;
+    }
+    wxFrame::GetPosition(x, y);
+}
+
+void wxPluginFrame::SetAttributeValues(const int n, const char *argn[], const char *argv[])
+{
+    if ( m_names )
+        delete[] m_names;
+    if ( m_values )
+        delete[] m_values;
+
+    m_nAttributes = n;
+
+    m_names = new wxString[n];
+    m_values = new wxString[n];
+    int i;
+    for ( i = 0; i < n ; i ++)
+    {
+        m_names[i] = argn[i];
+        m_values[i] = argv[i];
+    }
+}
+
+void wxPluginFrame::SetAttributeValues(const int n, const wxString* argn, const wxString* argv)
+{
+    if ( m_names )
+        delete[] m_names;
+    if ( m_values )
+        delete[] m_values;
+
+    m_nAttributes = n;
+
+    m_names = new wxString[n];
+    m_values = new wxString[n];
+    int i;
+    for ( i = 0; i < n ; i ++)
+    {
+        m_names[i] = argn[i];
+        m_values[i] = argv[i];
+    }
+}
+
+void wxPluginFrame::SetSize(const int x, const int y, const int width, const int height, const int sizeFlags)
+{
+    // Can't allow app to set the size.
+    return;
+}
+
+// Sets and subclasses the platform-specific window handle
+bool wxPluginFrame::SetNPWindow(NPWindow *window)
+{
+    if ( !window || !window->window)
+    {
+        if ( m_hWnd )
+        {
+            wxMessageBox("Unsubclassing window prematurely");
+            UnsubclassWin();
+            m_hWnd = 0;
+        }
+        m_npWindow = NULL;
+    }
+    else
+    {
+        if ( m_hWnd )
+        {
+            if ( m_hWnd == (WXHWND) window->window )
+            {
+                // Does this mean a resize?
+                return TRUE;
+            }
+        }
+
+        m_npWindow = window;
+        m_hWnd = (WXHWND) window->window;
+        SubclassWin(m_hWnd);
+        m_windowId = ::GetWindowLong((HWND) m_hWnd, GWL_ID);
+    }
+    return TRUE;
+}
+
+NPError wxPluginFrame::OnNPNewStream(NPMIMEType type, NPStream *stream, bool seekable, uint16* stype)
+{
+    *stype = NP_ASFILE;
+    return NPERR_NO_ERROR;
+}
+
+void wxPluginFrame::OnNPNewFile(NPStream *stream, const wxString& fname)
+{
+}
+
+void wxPluginFrame::OnNPPrint(NPPrint* printInfo)
+{
+        if (printInfo->mode == NP_FULL)
+        {
+            //
+            // *Developers*: If your plugin would like to take over
+            // printing completely when it is in full-screen mode,
+            // set printInfo->pluginPrinted to TRUE and print your
+            // plugin as you see fit.  If your plugin wants Netscape
+            // to handle printing in this case, set printInfo->pluginPrinted
+            // to FALSE (the default) and do nothing.  If you do want
+            // to handle printing yourself, printOne is true if the
+            // print button (as opposed to the print menu) was clicked.
+            // On the Macintosh, platformPrint is a THPrint; on Windows,
+            // platformPrint is a structure (defined in npapi.h) containing
+            // the printer name, port, etc.
+            //
+            void* platformPrint = printInfo->print.fullPrint.platformPrint;
+            NPBool printOne = printInfo->print.fullPrint.printOne;
+            
+            printInfo->print.fullPrint.pluginPrinted = FALSE; // Do the default
+        
+        }
+        else    // If not fullscreen, we must be embedded
+        {
+            //
+            // *Developers*: If your plugin is embedded, or is full-screen
+            // but you returned false in pluginPrinted above, NPP_Print
+            // will be called with mode == NP_EMBED.  The NPWindow
+            // in the printInfo gives the location and dimensions of
+            // the embedded plugin on the printed page.  On the Macintosh,
+            // platformPrint is the printer port; on Windows, platformPrint
+            // is the handle to the printing device context.
+            //
+            NPWindow* printWindow = &(printInfo->print.embedPrint.window);
+            void* platformPrint = printInfo->print.embedPrint.platformPrint;
+
+            HDC hDC = (HDC) platformPrint;
+            wxRectangle rect;
+            rect.x = printWindow->x;
+            rect.y = printWindow->y;
+            rect.width = printWindow->width;
+            rect.height = printWindow->height;
+
+			int saveIt = ::SaveDC(hDC);
+
+            wxPrinterDC *printerDC = new wxPrinterDC((WXHDC) hDC);
+
+            OnPrint(*printerDC, rect);
+
+            printerDC->SetHDC(0);
+			delete printerDC;
+
+			::RestoreDC(hDC, saveIt);
+        }
+ }
+
+void wxPluginFrame::OnPrint(wxPrinterDC& dc, wxRectangle& rect)
+{
+    // We must do some transformations here
+	RECT winRect;
+/*
+	winRect.left = rect.x;
+	winRect.top = rect.y;
+	winRect.right = rect.x + rect.right;
+	winRect.bottom = rect.y + rect.height;
+*/
+	POINT winPoint[2];
+	winPoint[0].x = rect.x;
+	winPoint[0].y = rect.y;
+	winPoint[1].x = rect.x + rect.width;
+	winPoint[1].y = rect.y + rect.height;
+
+	if (!LPtoDP((HDC) dc.GetHDC(), winPoint, 2))
+		wxMessageBox("LPtoDP failed.");
+
+    OnDraw(dc);
+}
+
+void wxPluginFrame::OnDraw(wxDC& dc)
+{
+}
+
diff --git a/utils/nplugin/src/npframe.h b/utils/nplugin/src/npframe.h
new file mode 100644
index 0000000000..23a45da355
--- /dev/null
+++ b/utils/nplugin/src/npframe.h
@@ -0,0 +1,81 @@
+/*
+ * File:	NPFrame.h
+ * Purpose:	wxPluginFrame declaration
+ * Author:	Julian Smart
+ * Created:	1997
+ * Updated:	
+ * Copyright:   (c) Julian Smart
+ */
+
+#ifndef __PLUGINFRAME__
+#define __PLUGINFRAME__
+
+#include "wx/frame.h"
+#include "NPApp.h"
+#include "npapi.h"
+
+WXDLLEXPORT extern const char *wxFrameNameStr;
+
+class wxPrinterDC;
+class WXDLLEXPORT wxPluginFrame: public wxFrame
+{
+  DECLARE_DYNAMIC_CLASS(wxPluginFrame)
+
+public:
+  wxPluginFrame(void);
+  inline wxPluginFrame(const wxPluginData& data)
+  {
+      m_npWindow = NULL;
+      m_npInstance = NULL;
+      m_nAttributes = 0;
+      m_names = NULL;
+      m_values = NULL;
+
+      Create(data);
+  }
+
+  ~wxPluginFrame(void);
+
+  bool Create(const wxPluginData& data);
+
+  // Sets and subclasses the platform-specific window handle
+  virtual bool SetNPWindow(NPWindow *window);
+  inline NPWindow *GetNPWindow(void) { return m_npWindow; }
+
+  void SetClientSize(const int width, const int height);
+  void GetClientSize(int *width, int *height) const;
+
+  void GetSize(int *width, int *height) const ;
+  void GetPosition(int *x, int *y) const ;
+  void SetSize(const int x, const int y, const int width, const int height, const int sizeFlags = wxSIZE_AUTO);
+
+  // Accessors
+  inline int GetAttributeCount(void) const { return m_nAttributes; }
+  inline wxString GetAttributeName(const int n) { return m_names[n]; }
+  inline wxString GetAttributeValue(const int n) { return m_values[n]; }
+
+  void SetAttributeValues(const int n, const char* argn[], const char *argv[]);
+  void SetAttributeValues(const int n, const wxString* argn, const wxString* argv);
+  inline void SetInstance(const NPP instance) { m_npInstance = instance; };
+  inline NPP GetInstance(void) { return m_npInstance; }
+
+  // Overridables: low-level
+  virtual NPError OnNPNewStream(NPMIMEType type, NPStream *stream, bool seekable, uint16* stype);
+  virtual void OnNPNewFile(NPStream *stream, const wxString& fname);
+  virtual void OnNPPrint(NPPrint* printInfo);
+
+  // Overridables: high-level
+  virtual void OnPrint(wxPrinterDC& dc, wxRectangle& rect);
+  virtual void OnDraw(wxDC& dc);
+
+protected:
+
+  wxString*     m_names;
+  wxString*     m_values;
+  int           m_nAttributes;
+  NPP           m_npInstance;
+  NPWindow*     m_npWindow;
+};
+
+#endif
+
diff --git a/utils/nplugin/src/npshell.cpp b/utils/nplugin/src/npshell.cpp
new file mode 100644
index 0000000000..fa040054de
--- /dev/null
+++ b/utils/nplugin/src/npshell.cpp
@@ -0,0 +1,278 @@
+//::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
+//
+// npshell.cpp
+//
+// This file defines a "shell" plugin that plugin developers can use
+// as the basis for a real plugin.  This shell just provides empty
+// implementations of all functions that the plugin can implement
+// that will be called by Netscape (the NPP_xxx methods defined in 
+// npapi.h). 
+//
+//::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
+
+#ifndef _NPAPI_H_
+#include "npapi.h"
+#endif
+
+#include <windows.h>
+#include <string.h>
+#include <stdio.h>
+
+#include "NPApp.h"
+
+//
+// Instance state information about the plugin.
+//
+// *Developers*: Use this struct to hold per-instance
+//               information that you'll need in the
+//               various functions in this file.
+//
+typedef struct _PluginInstance
+{
+    NPWindow*       fWindow;
+    uint16          fMode;
+    
+} PluginInstance;
+
+
+
+//------------------------------------------------------------------------------------
+// NPP_Initialize:
+//------------------------------------------------------------------------------------
+NPError NPP_Initialize(void)
+{
+//    MessageBox(NULL, "NPP_Initialize", "NPTest", MB_OK);
+
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        return app->NPP_Initialize();
+    else
+        return NPERR_NO_ERROR;
+}
+
+
+//------------------------------------------------------------------------------------
+// NPP_Shutdown:
+//------------------------------------------------------------------------------------
+void NPP_Shutdown(void)
+{
+//    MessageBox(NULL, "NPP_Shutdown", "wxPlugin", MB_OK);
+
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        app->NPP_Shutdown();
+}
+
+
+//------------------------------------------------------------------------------------
+// NPP_New:
+//------------------------------------------------------------------------------------
+NPError NP_LOADDS
+NPP_New(NPMIMEType pluginType,
+                NPP instance,
+                uint16 mode,
+                int16 argc,
+                char* argn[],
+                char* argv[],
+                NPSavedData* saved)
+{
+//    MessageBox(NULL, "NPP_New", "NPTest", MB_OK);
+
+    if (instance == NULL)
+        return NPERR_INVALID_INSTANCE_ERROR;
+
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        return app->NPP_New(pluginType, instance, mode, argc, argn, argv, saved);
+    else
+        return NPERR_NO_ERROR;
+}
+
+//------------------------------------------------------------------------------------
+// NPP_Destroy:
+//------------------------------------------------------------------------------------
+NPError NP_LOADDS
+NPP_Destroy(NPP instance, NPSavedData** save)
+{
+//    MessageBox(NULL, "NPP_Destroy", "NPTest", MB_OK);
+
+    if (instance == NULL)
+        return NPERR_INVALID_INSTANCE_ERROR;
+
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        return app->NPP_Destroy(instance, save);
+    else
+        return NPERR_NO_ERROR;
+}
+
+
+//------------------------------------------------------------------------------------
+// NPP_SetWindow:
+//------------------------------------------------------------------------------------
+NPError NP_LOADDS
+NPP_SetWindow(NPP instance, NPWindow* window)
+{
+//    MessageBox(NULL, "NPP_SetWindow", "NPTest", MB_OK);
+
+    if (instance == NULL)
+        return NPERR_INVALID_INSTANCE_ERROR;
+
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        return app->NPP_SetWindow(instance, window);
+    else
+        return NPERR_NO_ERROR;
+}
+
+
+//------------------------------------------------------------------------------------
+// NPP_NewStream:
+//------------------------------------------------------------------------------------
+NPError NP_LOADDS
+NPP_NewStream(NPP instance,
+                            NPMIMEType type,
+                            NPStream *stream, 
+                            NPBool seekable,
+                            uint16 *stype)
+{
+//    MessageBox(NULL, "NPP_NewStream", "NPTest", MB_OK);
+
+    if (instance == NULL)
+        return NPERR_INVALID_INSTANCE_ERROR;
+
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        return app->NPP_NewStream(instance, type, stream, seekable, stype);
+    else
+        return NPERR_NO_ERROR;
+}
+
+
+
+//
+// *Developers*: 
+// These next 2 functions are directly relevant in a plug-in which handles the
+// data in a streaming manner.  If you want zero bytes because no buffer space
+// is YET available, return 0.  As long as the stream has not been written
+// to the plugin, Navigator will continue trying to send bytes.  If the plugin
+// doesn't want them, just return some large number from NPP_WriteReady(), and
+// ignore them in NPP_Write().  For a NP_ASFILE stream, they are still called
+// but can safely be ignored using this strategy.
+//
+
+static int32 STREAMBUFSIZE = 0X0FFFFFFF;   // If we are reading from a file in NPAsFile
+                                    // mode so we can take any size stream in our
+                                    // write call (since we ignore it)
+
+//------------------------------------------------------------------------------------
+// NPP_WriteReady:
+//------------------------------------------------------------------------------------
+int32 NP_LOADDS
+NPP_WriteReady(NPP instance, NPStream *stream)
+{
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        return app->NPP_WriteReady(instance, stream);
+    else
+        return STREAMBUFSIZE;
+
+    return STREAMBUFSIZE;   // Number of bytes ready to accept in NPP_Write()
+}
+
+
+
+//------------------------------------------------------------------------------------
+// NPP_Write:
+//------------------------------------------------------------------------------------
+int32 NP_LOADDS
+NPP_Write(NPP instance, NPStream *stream, int32 offset, int32 len, void *buffer)
+{
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        return app->NPP_Write(instance, stream, offset, len, buffer);
+    else
+        return len;              // The number of bytes accepted
+}
+
+
+
+//------------------------------------------------------------------------------------
+// NPP_DestroyStream:
+//------------------------------------------------------------------------------------
+NPError NP_LOADDS
+NPP_DestroyStream(NPP instance, NPStream *stream, NPError reason)
+{
+    if (instance == NULL)
+        return NPERR_INVALID_INSTANCE_ERROR;
+
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        return app->NPP_DestroyStream(instance, stream, reason);
+    else
+        return NPERR_NO_ERROR;
+}
+
+
+//------------------------------------------------------------------------------------
+// NPP_StreamAsFile:
+//------------------------------------------------------------------------------------
+void NP_LOADDS
+NPP_StreamAsFile(NPP instance, NPStream *stream, const char* fname)
+{
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        app->NPP_StreamAsFile(instance, stream, fname);
+}
+
+
+
+//------------------------------------------------------------------------------------
+// NPP_Print:
+//------------------------------------------------------------------------------------
+void NP_LOADDS
+NPP_Print(NPP instance, NPPrint* printInfo)
+{
+    if (printInfo == NULL)   // trap invalid parm
+        return;
+    if ( instance == NULL )
+        return;
+
+    wxPluginApp *app = wxGetPluginApp();
+    if ( app )
+        app->NPP_Print(instance, printInfo);
+}
+
+
+//------------------------------------------------------------------------------------
+// NPP_HandleEvent:
+// Mac-only.
+//------------------------------------------------------------------------------------
+int16 NPP_HandleEvent(NPP instance, void* event)
+{
+    NPBool eventHandled = FALSE;
+    if (instance == NULL)
+        return eventHandled;
+        
+    PluginInstance* This = (PluginInstance*) instance->pdata;
+    
+    //
+    // *Developers*: The "event" passed in is a Macintosh
+    // EventRecord*.  The event.what field can be any of the
+    // normal Mac event types, or one of the following additional
+    // types defined in npapi.h: getFocusEvent, loseFocusEvent,
+    // adjustCursorEvent.  The focus events inform your plugin
+    // that it will become, or is no longer, the recepient of
+    // key events.  If your plugin doesn't want to receive key
+    // events, return false when passed at getFocusEvent.  The
+    // adjustCursorEvent is passed repeatedly when the mouse is
+    // over your plugin; if your plugin doesn't want to set the
+    // cursor, return false.  Handle the standard Mac events as
+    // normal.  The return value for all standard events is currently
+    // ignored except for the key event: for key events, only return
+    // true if your plugin has handled that particular key event. 
+    //
+    
+    return eventHandled;
+}
+
diff --git a/utils/nplugin/src/npupp.h b/utils/nplugin/src/npupp.h
new file mode 100644
index 0000000000..1c352d2245
--- /dev/null
+++ b/utils/nplugin/src/npupp.h
@@ -0,0 +1,799 @@
+/*
+ *  npupp.h $Revision$
+ *  function call mecahnics needed by platform specific glue code.
+ */
+
+
+#ifndef _NPUPP_H_
+#define _NPUPP_H_
+
+#ifndef GENERATINGCFM
+#define GENERATINGCFM 0
+#endif
+
+#ifndef _NPAPI_H_
+#include "npapi.h"
+#endif
+
+/******************************************************************************************
+   plug-in function table macros
+ 	        for each function in and out of the plugin API we define
+                    typedef NPP_FooUPP
+					#define NewNPP_FooProc
+					#define CallNPP_FooProc
+			for mac, define the UPP magic for PPC/68K calling
+ *******************************************************************************************/
+
+
+/* NPP_Initialize */
+
+#if GENERATINGCFM
+typedef UniversalProcPtr NPP_InitializeUPP;
+
+enum {
+	uppNPP_InitializeProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(0))		
+		| RESULT_SIZE(SIZE_CODE(0))
+};
+
+#define NewNPP_InitializeProc(FUNC)		\
+		(NPP_InitializeUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_InitializeProcInfo, GetCurrentArchitecture())
+#define CallNPP_InitializeProc(FUNC)		\
+		(void)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_InitializeProcInfo)
+		
+#else
+
+typedef void (*NPP_InitializeUPP)(void);
+#define NewNPP_InitializeProc(FUNC)		\
+		((NPP_InitializeUPP) (FUNC))
+#define CallNPP_InitializeProc(FUNC)		\
+		(*(FUNC))()
+
+#endif
+
+
+/* NPP_Shutdown */
+
+#if GENERATINGCFM
+typedef UniversalProcPtr NPP_ShutdownUPP;
+
+enum {
+	uppNPP_ShutdownProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(0))		
+		| RESULT_SIZE(SIZE_CODE(0))
+};
+
+#define NewNPP_ShutdownProc(FUNC)		\
+		(NPP_ShutdownUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_ShutdownProcInfo, GetCurrentArchitecture())
+#define CallNPP_ShutdownProc(FUNC)		\
+		(void)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_ShutdownProcInfo)
+		
+#else
+
+typedef void (*NPP_ShutdownUPP)(void);
+#define NewNPP_ShutdownProc(FUNC)		\
+		((NPP_ShutdownUPP) (FUNC))
+#define CallNPP_ShutdownProc(FUNC)		\
+		(*(FUNC))()
+
+#endif
+
+
+/* NPP_New */
+
+#if GENERATINGCFM
+typedef UniversalProcPtr NPP_NewUPP;
+
+enum {
+	uppNPP_NewProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPMIMEType)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(uint16)))
+		| STACK_ROUTINE_PARAMETER(4, SIZE_CODE(sizeof(int16)))
+		| STACK_ROUTINE_PARAMETER(5, SIZE_CODE(sizeof(char **)))
+		| STACK_ROUTINE_PARAMETER(6, SIZE_CODE(sizeof(char **)))
+		| STACK_ROUTINE_PARAMETER(7, SIZE_CODE(sizeof(NPSavedData *)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+
+#define NewNPP_NewProc(FUNC)		\
+		(NPP_NewUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_NewProcInfo, GetCurrentArchitecture())
+#define CallNPP_NewProc(FUNC, ARG1, ARG2, ARG3, ARG4, ARG5, ARG6, ARG7) \
+		(NPError)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_NewProcInfo, \
+								   (ARG1), (ARG2), (ARG3), (ARG4), (ARG5), (ARG6), (ARG7))
+#else
+
+typedef NPError	(*NPP_NewUPP)(NPMIMEType pluginType, NPP instance, uint16 mode, int16 argc, char* argn[], char* argv[], NPSavedData* saved);
+#define NewNPP_NewProc(FUNC)		\
+		((NPP_NewUPP) (FUNC))
+#define CallNPP_NewProc(FUNC, ARG1, ARG2, ARG3, ARG4, ARG5, ARG6, ARG7)		\
+		(*(FUNC))((ARG1), (ARG2), (ARG3), (ARG4), (ARG5), (ARG6), (ARG7))
+
+#endif
+
+
+/* NPP_Destroy */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPP_DestroyUPP;
+enum {
+	uppNPP_DestroyProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPSavedData **)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+#define NewNPP_DestroyProc(FUNC)		\
+		(NPP_DestroyUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_DestroyProcInfo, GetCurrentArchitecture())
+#define CallNPP_DestroyProc(FUNC, ARG1, ARG2)		\
+		(NPError)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_DestroyProcInfo, (ARG1), (ARG2))
+#else
+
+typedef NPError	(*NPP_DestroyUPP)(NPP instance, NPSavedData** save);
+#define NewNPP_DestroyProc(FUNC)		\
+		((NPP_DestroyUPP) (FUNC))
+#define CallNPP_DestroyProc(FUNC, ARG1, ARG2)		\
+		(*(FUNC))((ARG1), (ARG2))
+
+#endif
+
+
+/* NPP_SetWindow */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPP_SetWindowUPP;
+enum {
+	uppNPP_SetWindowProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPWindow *)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+#define NewNPP_SetWindowProc(FUNC)		\
+		(NPP_SetWindowUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_SetWindowProcInfo, GetCurrentArchitecture())
+#define CallNPP_SetWindowProc(FUNC, ARG1, ARG2)		\
+		(NPError)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_SetWindowProcInfo, (ARG1), (ARG2))
+
+#else
+
+typedef NPError	(*NPP_SetWindowUPP)(NPP instance, NPWindow* window);
+#define NewNPP_SetWindowProc(FUNC)		\
+		((NPP_SetWindowUPP) (FUNC))
+#define CallNPP_SetWindowProc(FUNC, ARG1, ARG2)		\
+		(*(FUNC))((ARG1), (ARG2))
+
+#endif
+
+
+/* NPP_NewStream */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPP_NewStreamUPP;
+enum {
+	uppNPP_NewStreamProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPMIMEType)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(NPStream *)))
+		| STACK_ROUTINE_PARAMETER(4, SIZE_CODE(sizeof(NPBool)))
+		| STACK_ROUTINE_PARAMETER(5, SIZE_CODE(sizeof(uint16 *)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+#define NewNPP_NewStreamProc(FUNC)		\
+		(NPP_NewStreamUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_NewStreamProcInfo, GetCurrentArchitecture())
+#define CallNPP_NewStreamProc(FUNC, ARG1, ARG2, ARG3, ARG4, ARG5)		\
+		(NPError)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_NewStreamProcInfo, (ARG1), (ARG2), (ARG3), (ARG4), (ARG5))
+#else
+
+typedef NPError	(*NPP_NewStreamUPP)(NPP instance, NPMIMEType type, NPStream* stream, NPBool seekable, uint16* stype);
+#define NewNPP_NewStreamProc(FUNC)		\
+		((NPP_NewStreamUPP) (FUNC))
+#define CallNPP_NewStreamProc(FUNC, ARG1, ARG2, ARG3, ARG4, ARG5) \
+		(*(FUNC))((ARG1), (ARG2), (ARG3), (ARG4), (ARG5))
+#endif
+
+
+/* NPP_DestroyStream */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPP_DestroyStreamUPP;
+enum {
+	uppNPP_DestroyStreamProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPStream *)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(NPError)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+#define NewNPP_DestroyStreamProc(FUNC)		\
+		(NPP_DestroyStreamUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_DestroyStreamProcInfo, GetCurrentArchitecture())
+#define CallNPP_DestroyStreamProc(FUNC,  NPParg, NPStreamPtr, NPErrorArg)		\
+		(NPError)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_DestroyStreamProcInfo, (NPParg), (NPStreamPtr), (NPErrorArg))
+
+#else
+
+typedef NPError	(*NPP_DestroyStreamUPP)(NPP instance, NPStream* stream, NPError reason);
+#define NewNPP_DestroyStreamProc(FUNC)		\
+		((NPP_DestroyStreamUPP) (FUNC))
+#define CallNPP_DestroyStreamProc(FUNC,  NPParg, NPStreamPtr, NPErrorArg)		\
+		(*(FUNC))((NPParg), (NPStreamPtr), (NPErrorArg))
+
+#endif
+
+
+/* NPP_WriteReady */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPP_WriteReadyUPP;
+enum {
+	uppNPP_WriteReadyProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPStream *)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(int32)))
+};
+#define NewNPP_WriteReadyProc(FUNC)		\
+		(NPP_WriteReadyUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_WriteReadyProcInfo, GetCurrentArchitecture())
+#define CallNPP_WriteReadyProc(FUNC,  NPParg, NPStreamPtr)		\
+		(int32)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_WriteReadyProcInfo, (NPParg), (NPStreamPtr))
+
+#else
+
+typedef int32 (*NPP_WriteReadyUPP)(NPP instance, NPStream* stream);
+#define NewNPP_WriteReadyProc(FUNC)		\
+		((NPP_WriteReadyUPP) (FUNC))
+#define CallNPP_WriteReadyProc(FUNC,  NPParg, NPStreamPtr)		\
+		(*(FUNC))((NPParg), (NPStreamPtr))
+
+#endif
+
+
+/* NPP_Write */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPP_WriteUPP;
+enum {
+	uppNPP_WriteProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPStream *)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(int32)))
+		| STACK_ROUTINE_PARAMETER(4, SIZE_CODE(sizeof(int32)))
+		| STACK_ROUTINE_PARAMETER(5, SIZE_CODE(sizeof(void*)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(int32)))
+};
+#define NewNPP_WriteProc(FUNC)		\
+		(NPP_WriteUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_WriteProcInfo, GetCurrentArchitecture())
+#define CallNPP_WriteProc(FUNC,  NPParg, NPStreamPtr, offsetArg, lenArg, bufferPtr)		\
+		(int32)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_WriteProcInfo, (NPParg), (NPStreamPtr), (offsetArg), (lenArg), (bufferPtr))
+
+#else
+
+typedef int32 (*NPP_WriteUPP)(NPP instance, NPStream* stream, int32 offset, int32 len, void* buffer);
+#define NewNPP_WriteProc(FUNC)		\
+		((NPP_WriteUPP) (FUNC))
+#define CallNPP_WriteProc(FUNC,  NPParg, NPStreamPtr, offsetArg, lenArg, bufferPtr)		\
+		(*(FUNC))((NPParg), (NPStreamPtr), (offsetArg), (lenArg), (bufferPtr))
+
+#endif
+
+
+/* NPP_StreamAsFile */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPP_StreamAsFileUPP;
+enum {
+	uppNPP_StreamAsFileProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPStream *)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(const char *)))
+		| RESULT_SIZE(SIZE_CODE(0))
+};
+#define NewNPP_StreamAsFileProc(FUNC)		\
+		(NPP_StreamAsFileUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_StreamAsFileProcInfo, GetCurrentArchitecture())
+#define CallNPP_StreamAsFileProc(FUNC, ARG1, ARG2, ARG3)		\
+		(void)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_StreamAsFileProcInfo, (ARG1), (ARG2), (ARG3))
+
+#else
+
+typedef void (*NPP_StreamAsFileUPP)(NPP instance, NPStream* stream, const char* fname);
+#define NewNPP_StreamAsFileProc(FUNC)		\
+		((NPP_StreamAsFileUPP) (FUNC))
+#define CallNPP_StreamAsFileProc(FUNC,  ARG1, ARG2, ARG3)		\
+		(*(FUNC))((ARG1), (ARG2), (ARG3))
+#endif
+
+
+/* NPP_Print */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPP_PrintUPP;
+enum {
+	uppNPP_PrintProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPPrint *)))
+		| RESULT_SIZE(SIZE_CODE(0))
+};
+#define NewNPP_PrintProc(FUNC)		\
+		(NPP_PrintUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_PrintProcInfo, GetCurrentArchitecture())
+#define CallNPP_PrintProc(FUNC,  NPParg, voidPtr)		\
+		(void)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_PrintProcInfo, (NPParg), (voidPtr))
+
+#else
+
+typedef void (*NPP_PrintUPP)(NPP instance, NPPrint* platformPrint);
+#define NewNPP_PrintProc(FUNC)		\
+		((NPP_PrintUPP) (FUNC))
+#define CallNPP_PrintProc(FUNC,  NPParg, NPPrintArg)		\
+		(*(FUNC))((NPParg), (NPPrintArg))
+
+#endif
+
+
+/* NPP_HandleEvent */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPP_HandleEventUPP;
+enum {
+	uppNPP_HandleEventProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(void *)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(int16)))
+};
+#define NewNPP_HandleEventProc(FUNC)		\
+		(NPP_HandleEventUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_HandleEventProcInfo, GetCurrentArchitecture())
+#define CallNPP_HandleEventProc(FUNC,  NPParg, voidPtr)		\
+		(int16)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPP_HandleEventProcInfo, (NPParg), (voidPtr))
+
+#else
+
+typedef int16 (*NPP_HandleEventUPP)(NPP instance, void* event);
+#define NewNPP_HandleEventProc(FUNC)		\
+		((NPP_HandleEventUPP) (FUNC))
+#define CallNPP_HandleEventProc(FUNC,  NPParg, voidPtr)		\
+		(*(FUNC))((NPParg), (voidPtr))
+
+#endif
+
+
+
+
+/*
+ *  Netscape entry points
+ */
+
+
+/* NPN_GetUrl */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_GetURLUPP;
+enum {
+	uppNPN_GetURLProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(const char*)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(const char*)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+#define NewNPN_GetURLProc(FUNC)		\
+		(NPN_GetURLUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_GetURLProcInfo, GetCurrentArchitecture())
+#define CallNPN_GetURLProc(FUNC, ARG1, ARG2, ARG3) \
+		(NPError)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_GetURLProcInfo, (ARG1), (ARG2), (ARG3))
+#else
+
+typedef NPError	(*NPN_GetURLUPP)(NPP instance, const char* url, const char* window);
+#define NewNPN_GetURLProc(FUNC)		\
+		((NPN_GetURLUPP) (FUNC))
+#define CallNPN_GetURLProc(FUNC, ARG1, ARG2, ARG3)		\
+		(*(FUNC))((ARG1), (ARG2), (ARG3))
+#endif
+
+
+/* NPN_PostUrl */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_PostURLUPP;
+enum {
+	uppNPN_PostURLProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(const char*)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(const char*)))
+		| STACK_ROUTINE_PARAMETER(4, SIZE_CODE(sizeof(uint32)))
+		| STACK_ROUTINE_PARAMETER(5, SIZE_CODE(sizeof(const char*)))
+		| STACK_ROUTINE_PARAMETER(6, SIZE_CODE(sizeof(NPBool)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+#define NewNPN_PostURLProc(FUNC)		\
+		(NPN_PostURLUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_PostURLProcInfo, GetCurrentArchitecture())
+#define CallNPN_PostURLProc(FUNC, ARG1, ARG2, ARG3, ARG4, ARG5, ARG6) \
+		(NPError)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_PostURLProcInfo, (ARG1), (ARG2), (ARG3), (ARG4), (ARG5), (ARG6))
+#else
+
+typedef NPError (*NPN_PostURLUPP)(NPP instance, const char* url, const char* window, uint32 len, const char* buf, NPBool file);
+#define NewNPN_PostURLProc(FUNC)		\
+		((NPN_PostURLUPP) (FUNC))
+#define CallNPN_PostURLProc(FUNC, ARG1, ARG2, ARG3, ARG4, ARG5, ARG6) \
+		(*(FUNC))((ARG1), (ARG2), (ARG3), (ARG4), (ARG5), (ARG6))
+#endif
+
+
+/* NPN_RequestRead */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_RequestReadUPP;
+enum {
+	uppNPN_RequestReadProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPStream *)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPByteRange *)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+#define NewNPN_RequestReadProc(FUNC)		\
+		(NPN_RequestReadUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_RequestReadProcInfo, GetCurrentArchitecture())
+#define CallNPN_RequestReadProc(FUNC,  stream, range)		\
+		(NPError)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_RequestReadProcInfo, (stream), (range))
+
+#else
+
+typedef NPError	(*NPN_RequestReadUPP)(NPStream* stream, NPByteRange* rangeList);
+#define NewNPN_RequestReadProc(FUNC)		\
+		((NPN_RequestReadUPP) (FUNC))
+#define CallNPN_RequestReadProc(FUNC, stream, range)		\
+		(*(FUNC))((stream), (range))
+
+#endif
+
+
+/* NPN_NewStream */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_NewStreamUPP;
+enum {
+	uppNPN_NewStreamProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP )))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPMIMEType)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(NPStream *)))
+		| STACK_ROUTINE_PARAMETER(4, SIZE_CODE(sizeof(NPBool)))
+		| STACK_ROUTINE_PARAMETER(5, SIZE_CODE(sizeof(uint16*)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+#define NewNPN_NewStreamProc(FUNC)		\
+		(NPN_NewStreamUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_NewStreamProcInfo, GetCurrentArchitecture())
+#define CallNPN_NewStreamProc(FUNC, npp, type, stream)		\
+		(NPError)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_NewStreamProcInfo, (npp), (type), (stream))	
+
+#else
+
+typedef NPError	(*NPN_NewStreamUPP)(NPP instance, NPMIMEType type, NPStream* stream);
+#define NewNPN_NewStreamProc(FUNC)		\
+		((NPN_NewStreamUPP) (FUNC))
+#define CallNPN_NewStreamProc(FUNC, npp, type, stream)		\
+		(*(FUNC))((npp), (type), (stream))
+
+#endif
+
+
+/* NPN_Write */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_WriteUPP;
+enum {
+	uppNPN_WriteProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP )))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPStream *)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(int32)))
+		| STACK_ROUTINE_PARAMETER(4, SIZE_CODE(sizeof(void*)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(int32)))
+};
+#define NewNPN_WriteProc(FUNC)		\
+		(NPN_WriteUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_WriteProcInfo, GetCurrentArchitecture())
+#define CallNPN_WriteProc(FUNC, npp, stream, len, buffer)		\
+		(int32)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_WriteProcInfo, (npp), (stream), (len), (buffer))	
+
+#else
+
+typedef int32 (*NPN_WriteUPP)(NPP instance, NPStream* stream, int32 len, void* buffer);
+#define NewNPN_WriteProc(FUNC)		\
+		((NPN_WriteUPP) (FUNC))
+#define CallNPN_WriteProc(FUNC, npp, stream, len, buffer)		\
+		(*(FUNC))((npp), (stream), (len), (buffer))
+
+#endif
+
+
+/* NPN_DestroyStream */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_DestroyStreamUPP;
+enum {
+	uppNPN_DestroyStreamProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP )))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPStream *)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(NPError)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+#define NewNPN_DestroyStreamProc(FUNC)		\
+		(NPN_DestroyStreamUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_DestroyStreamProcInfo, GetCurrentArchitecture())
+#define CallNPN_DestroyStreamProc(FUNC, npp, stream, err)		\
+		(NPError)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_DestroyStreamProcInfo, (npp), (stream), (err))	
+
+#else
+
+typedef NPError (*NPN_DestroyStreamUPP)(NPP instance, NPStream* stream, NPError reason);
+#define NewNPN_DestroyStreamProc(FUNC)		\
+		((NPN_DestroyStreamUPP) (FUNC))
+#define CallNPN_DestroyStreamProc(FUNC, npp, stream, err)		\
+		(*(FUNC))((npp), (stream), (err))
+
+#endif
+
+
+/* NPN_Status */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_StatusUPP;
+enum {
+	uppNPN_StatusProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(char *)))
+};
+
+#define NewNPN_StatusProc(FUNC)		\
+		(NPN_StatusUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_StatusProcInfo, GetCurrentArchitecture())
+#define CallNPN_StatusProc(FUNC, npp, msg)		\
+		(void)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_StatusProcInfo, (npp), (msg))	
+
+#else
+
+typedef void (*NPN_StatusUPP)(NPP instance, const char* message);
+#define NewNPN_StatusProc(FUNC)		\
+		((NPN_StatusUPP) (FUNC))
+#define CallNPN_StatusProc(FUNC, npp, msg)		\
+		(*(FUNC))((npp), (msg))	
+
+#endif
+
+
+/* NPN_UserAgent */
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_UserAgentUPP;
+enum {
+        uppNPN_UserAgentProcInfo = kThinkCStackBased
+                | STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPP)))
+                | RESULT_SIZE(SIZE_CODE(sizeof(const char *)))
+};
+
+#define NewNPN_UserAgentProc(FUNC)              \
+                (NPN_UserAgentUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_UserAgentProcInfo, GetCurrentArchitecture())
+#define CallNPN_UserAgentProc(FUNC, ARG1)               \
+                (const char*)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_UserAgentProcInfo, (ARG1))
+
+#else
+
+typedef const char*	(*NPN_UserAgentUPP)(NPP instance);
+#define NewNPN_UserAgentProc(FUNC)              \
+                ((NPN_UserAgentUPP) (FUNC))
+#define CallNPN_UserAgentProc(FUNC, ARG1)               \
+                (*(FUNC))((ARG1))
+
+#endif
+
+
+/* NPN_MemAlloc */
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_MemAllocUPP;
+enum {
+	uppNPN_MemAllocProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(uint32)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(void *)))
+};
+
+#define NewNPN_MemAllocProc(FUNC)		\
+		(NPN_MemAllocUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_MemAllocProcInfo, GetCurrentArchitecture())
+#define CallNPN_MemAllocProc(FUNC, ARG1)		\
+		(void*)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_MemAllocProcInfo, (ARG1))	
+
+#else
+
+typedef void* (*NPN_MemAllocUPP)(uint32 size);
+#define NewNPN_MemAllocProc(FUNC)		\
+		((NPN_MemAllocUPP) (FUNC))
+#define CallNPN_MemAllocProc(FUNC, ARG1)		\
+		(*(FUNC))((ARG1))	
+
+#endif
+
+
+/* NPN__MemFree */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_MemFreeUPP;
+enum {
+	uppNPN_MemFreeProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(void *)))
+};
+
+#define NewNPN_MemFreeProc(FUNC)		\
+		(NPN_MemFreeUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_MemFreeProcInfo, GetCurrentArchitecture())
+#define CallNPN_MemFreeProc(FUNC, ARG1)		\
+		(void)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_MemFreeProcInfo, (ARG1))
+
+#else
+
+typedef void (*NPN_MemFreeUPP)(void* ptr);
+#define NewNPN_MemFreeProc(FUNC)		\
+		((NPN_MemFreeUPP) (FUNC))
+#define CallNPN_MemFreeProc(FUNC, ARG1)		\
+		(*(FUNC))((ARG1))	
+
+#endif
+
+
+/* NPN_MemFlush */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_MemFlushUPP;
+enum {
+	uppNPN_MemFlushProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(uint32)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(uint32)))
+};
+
+#define NewNPN_MemFlushProc(FUNC)		\
+		(NPN_MemFlushUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_MemFlushProcInfo, GetCurrentArchitecture())
+#define CallNPN_MemFlushProc(FUNC, ARG1)		\
+		(uint32)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_MemFlushProcInfo, (ARG1))	
+
+#else
+
+typedef uint32 (*NPN_MemFlushUPP)(uint32 size);
+#define NewNPN_MemFlushProc(FUNC)		\
+		((NPN_MemFlushUPP) (FUNC))
+#define CallNPN_MemFlushProc(FUNC, ARG1)		\
+		(*(FUNC))((ARG1))	
+
+#endif
+
+
+
+/* NPN_ReloadPlugins */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPN_ReloadPluginsUPP;
+enum {
+	uppNPN_ReloadPluginsProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPBool)))
+		| RESULT_SIZE(SIZE_CODE(0))
+};
+
+#define NewNPN_ReloadPluginsProc(FUNC)		\
+		(NPN_ReloadPluginsUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPN_ReloadPluginsProcInfo, GetCurrentArchitecture())
+#define CallNPN_ReloadPluginsProc(FUNC, ARG1)		\
+		(void)CallUniversalProc((UniversalProcPtr)(FUNC), uppNPN_ReloadPluginsProcInfo, (ARG1))	
+
+#else
+
+typedef void (*NPN_ReloadPluginsUPP)(NPBool reloadPages);
+#define NewNPN_ReloadPluginsProc(FUNC)		\
+		((NPN_ReloadPluginsUPP) (FUNC))
+#define CallNPN_ReloadPluginsProc(FUNC, ARG1)		\
+		(*(FUNC))((ARG1))	
+
+#endif
+
+
+
+
+/******************************************************************************************
+ * The actual plugin function table definitions
+ *******************************************************************************************/
+
+typedef struct _NPPluginFuncs {
+	uint16 size;
+	uint16 version;
+    NPP_NewUPP newp;
+    NPP_DestroyUPP destroy;
+    NPP_SetWindowUPP setwindow;
+    NPP_NewStreamUPP newstream;
+    NPP_DestroyStreamUPP destroystream;
+	NPP_StreamAsFileUPP asfile;
+    NPP_WriteReadyUPP writeready;
+    NPP_WriteUPP write;
+    NPP_PrintUPP print;
+    NPP_HandleEventUPP event;
+} NPPluginFuncs;
+
+typedef struct _NPNetscapeFuncs {
+	uint16 size;
+	uint16 version;
+    NPN_GetURLUPP geturl;
+    NPN_PostURLUPP posturl;
+    NPN_RequestReadUPP requestread;
+    NPN_NewStreamUPP newstream;
+    NPN_WriteUPP write;
+    NPN_DestroyStreamUPP destroystream;
+    NPN_StatusUPP status;
+    NPN_UserAgentUPP uagent;
+	NPN_MemAllocUPP memalloc;
+	NPN_MemFreeUPP memfree;
+	NPN_MemFlushUPP memflush;
+	NPN_ReloadPluginsUPP reloadplugins;
+} NPNetscapeFuncs;
+
+
+
+#ifdef XP_MAC
+/******************************************************************************************
+ * Mac platform-specific plugin glue stuff
+ *******************************************************************************************/
+
+/*
+ * Main entry point of the plugin.
+ * This routine will be called when the plugin is loaded. The function
+ * tables are passed in and the plugin fills in the NPPluginFuncs table
+ * and NPPShutdownUPP for Netscape's use.
+ */
+
+#if GENERATINGCFM
+
+typedef UniversalProcPtr NPP_MainEntryUPP;
+enum {
+	uppNPP_MainEntryProcInfo = kThinkCStackBased
+		| STACK_ROUTINE_PARAMETER(1, SIZE_CODE(sizeof(NPNetscapeFuncs*)))
+		| STACK_ROUTINE_PARAMETER(2, SIZE_CODE(sizeof(NPPluginFuncs*)))
+		| STACK_ROUTINE_PARAMETER(3, SIZE_CODE(sizeof(NPP_ShutdownUPP*)))
+		| RESULT_SIZE(SIZE_CODE(sizeof(NPError)))
+};
+#define NewNPP_MainEntryProc(FUNC)		\
+		(NPP_MainEntryUPP) NewRoutineDescriptor((ProcPtr)(FUNC), uppNPP_MainEntryProcInfo, GetCurrentArchitecture())
+#define CallNPP_MainEntryProc(FUNC,  netscapeFunc, pluginFunc, shutdownUPP)		\
+		CallUniversalProc((UniversalProcPtr)(FUNC), (ProcInfoType)uppNPP_MainEntryProcInfo, (netscapeFunc), (pluginFunc), (shutdownUPP))
+
+#else
+
+typedef NPError (*NPP_MainEntryUPP)(NPNetscapeFuncs*, NPPluginFuncs*, NPP_ShutdownUPP*);
+#define NewNPP_MainEntryProc(FUNC)		\
+		((NPP_MainEntryUPP) (FUNC))
+#define CallNPP_MainEntryProc(FUNC,  netscapeFunc, pluginFunc, shutdownUPP)		\
+		(*(FUNC))((netscapeFunc), (pluginFunc), (shutdownUPP))
+
+#endif
+#endif /* MAC */
+
+
+#ifdef _WINDOWS
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/* plugin meta member functions */
+
+NPError WINAPI NP_GetEntryPoints(NPPluginFuncs* pFuncs);
+
+NPError WINAPI NP_Initialize(NPNetscapeFuncs* pFuncs);
+
+NPError WINAPI NP_Shutdown();
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _WINDOWS */
+
+
+#endif /* _NPUPP_H_ */
+
diff --git a/utils/nplugin/src/npwin.cpp b/utils/nplugin/src/npwin.cpp
new file mode 100644
index 0000000000..f97ef498a7
--- /dev/null
+++ b/utils/nplugin/src/npwin.cpp
@@ -0,0 +1,186 @@
+/* npwin.cpp */
+#include "windows.h"
+
+#include "npapi.h"
+#include "npupp.h"
+
+#ifdef __WIN32__
+    #define NP_EXPORT
+#else
+    #define NP_EXPORT _export
+#endif
+
+static NPNetscapeFuncs* g_pNavigatorFuncs = NULL;
+
+
+/*   PLUGIN DLL entry points   */
+/* These are the Windows specific DLL entry points, not the "normal" plugin
+   entry points.  The "normal" ones are in NPSHELL.CPP
+*/
+
+/* fills in the func table used by Navigator to call entry points in
+   plugin DLL.  Note that these entry points ensure that DS is loaded
+   by using the NP_LOADDS macro, when compiling for Win16
+*/
+NPError WINAPI NP_EXPORT NP_GetEntryPoints(NPPluginFuncs* pFuncs)
+{
+    /* trap a NULL ptr */
+    if(pFuncs == NULL)
+        return NPERR_INVALID_FUNCTABLE_ERROR;
+
+    /* if the plugin's function table is smaller than the plugin expects,
+       then they are incompatible, and should return an error */
+    if(pFuncs->size < sizeof NPPluginFuncs)
+        return NPERR_INVALID_FUNCTABLE_ERROR;
+
+    pFuncs->version       = (NP_VERSION_MAJOR << 8) | NP_VERSION_MINOR;
+    pFuncs->newp          = NPP_New;
+    pFuncs->destroy       = NPP_Destroy;
+    pFuncs->setwindow     = NPP_SetWindow;
+    pFuncs->newstream     = NPP_NewStream;
+    pFuncs->destroystream = NPP_DestroyStream;
+    pFuncs->asfile        = NPP_StreamAsFile;
+    pFuncs->writeready    = NPP_WriteReady;
+    pFuncs->write         = NPP_Write;
+    pFuncs->print         = NPP_Print;
+    pFuncs->event         = NULL;       /* reserved */
+
+    return NPERR_NO_ERROR;
+}
+
+/* called immediately after the plugin DLL is loaded
+*/
+NPError WINAPI NP_EXPORT NP_Initialize(NPNetscapeFuncs* pFuncs)
+{
+    /* trap a NULL ptr */
+    if(pFuncs == NULL)
+        return NPERR_INVALID_FUNCTABLE_ERROR;
+
+    g_pNavigatorFuncs = pFuncs; /* save it for future reference */
+
+    /* if the plugin's major ver level is lower than the Navigator's,
+       then they are incompatible, and should return an error */
+    if(HIBYTE(pFuncs->version) > NP_VERSION_MAJOR)
+        return NPERR_INCOMPATIBLE_VERSION_ERROR;
+
+    /* if the Navigator's function table is smaller than the plugin expects,
+       then they are incompatible, and should return an error */
+    if(pFuncs->size < sizeof NPNetscapeFuncs)
+        return NPERR_INVALID_FUNCTABLE_ERROR;
+
+    return NPP_Initialize();
+}
+
+/* called immediately before the plugin DLL is unloaded
+*/
+NPError WINAPI NP_EXPORT NP_Shutdown()
+{
+    NPP_Shutdown();
+
+    g_pNavigatorFuncs = NULL;
+
+    return NPERR_NO_ERROR;
+}
+
+
+/*    NAVIGATOR Entry points    */
+
+/* These entry points expect to be called from within the plugin.  The
+   noteworthy assumption is that DS has already been set to point to the
+   plugin's DLL data segment.  Don't call these functions from outside
+   the plugin without ensuring DS is set to the DLLs data segment first,
+   typically using the NP_LOADDS macro
+*/
+
+/* returns the major/minor version numbers of the Plugin API for the plugin
+   and the Navigator
+*/
+void NPN_Version(int* plugin_major, int* plugin_minor, int* netscape_major, int* netscape_minor)
+{
+    *plugin_major   = NP_VERSION_MAJOR;
+    *plugin_minor   = NP_VERSION_MINOR;
+    *netscape_major = HIBYTE(g_pNavigatorFuncs->version);
+    *netscape_minor = LOBYTE(g_pNavigatorFuncs->version);
+}
+
+/* causes the specified URL to be fetched and streamed in
+*/
+NPError NPN_GetURL(NPP instance, const char *url, const char *window)
+{
+    return g_pNavigatorFuncs->geturl(instance, url, window);
+}
+
+NPError NPN_PostURL(NPP instance, const char* url, const char* window, uint32 len, const char* buf, NPBool file)
+{
+    return g_pNavigatorFuncs->posturl(instance, url, window, len, buf, file);
+}
+
+/* Requests that a number of bytes be provided on a stream.  Typically
+   this would be used if a stream was in "pull" mode.  An optional
+   position can be provided for streams which are seekable.
+*/
+NPError NPN_RequestRead(NPStream* stream, NPByteRange* rangeList)
+{
+    return g_pNavigatorFuncs->requestread(stream, rangeList);
+}
+
+/* Creates a new stream of data from the plug-in to be interpreted
+   by Netscape in the current window.
+*/
+NPError NPN_NewStream(NPP instance, NPMIMEType type, NPStream *stream)
+{
+    return g_pNavigatorFuncs->newstream(instance, type, stream);
+}
+
+/* Provides len bytes of data.
+*/
+int32 NPN_Write(NPP instance, NPStream *stream,
+                int32 len, void *buffer)
+{
+    return g_pNavigatorFuncs->write(instance, stream, len, buffer);
+}
+
+/* Closes a stream object.  
+reason indicates why the stream was closed.
+*/
+NPError NPN_DestroyStream(NPP instance, NPStream* stream, NPError reason)
+{
+    return g_pNavigatorFuncs->destroystream(instance, stream, reason);
+}
+
+/* Provides a text status message in the Netscape client user interface
+*/
+void NPN_Status(NPP instance, const char *message)
+{
+    g_pNavigatorFuncs->status(instance, message);
+}
+
+/* returns the user agent string of Navigator, which contains version info
+*/
+const char* NPN_UserAgent(NPP instance)
+{
+    return g_pNavigatorFuncs->uagent(instance);
+}
+
+/* allocates memory from the Navigator's memory space.  Necessary so that
+   saved instance data may be freed by Navigator when exiting.
+*/
+void* NPN_MemAlloc(uint32 size)
+{
+    return g_pNavigatorFuncs->memalloc(size);
+}
+
+/* reciprocal of MemAlloc() above
+*/
+void NPN_MemFree(void* ptr)
+{
+    g_pNavigatorFuncs->memfree(ptr);
+}
+
+/* private function to Netscape.  do not use!
+*/
+void NPN_ReloadPlugins(NPBool reloadPages)
+{
+    g_pNavigatorFuncs->reloadplugins(reloadPages);
+}
+
-- 
2.47.2