--- np2/x11/toolkit.h 2003/12/11 15:11:56 1.3 +++ np2/x11/toolkit.h 2005/03/12 12:36:13 1.9 @@ -10,8 +10,6 @@ * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES @@ -28,10 +26,6 @@ #ifndef NP2_X11_TOOLKIT_H__ #define NP2_X11_TOOLKIT_H__ -#if !defined(USE_GTK) && !defined(USE_QT) -#error undefined both USE_GTK and USE_QT!!! -#endif - typedef struct { const char* (*get_toolkit)(void); BOOL (*arginit)(int* argc, char*** argv); @@ -40,10 +34,14 @@ typedef struct { void (*widget_show)(void); void (*widget_mainloop)(void); void (*widget_quit)(void); + void (*event_process)(void); void (*set_window_title)(const char* str); + void (*messagebox)(const char *title, const char *msg); } gui_toolkit_t; -#if defined(USE_GTK) && defined(USE_QT) +void toolkit_msgbox(const char *title, const char *msg); + +#if (USE_GTK + USE_GTK2 + USE_QT + USE_SDL + USE_X11) > 1 extern gui_toolkit_t* toolkitp; @@ -54,11 +52,17 @@ void toolkit_initialize(void); #define toolkit_widget_show() (*toolkitp->widget_show)() #define toolkit_widget_mainloop() (*toolkitp->widget_mainloop)() #define toolkit_widget_quit() (*toolkitp->widget_quit)() +#define toolkit_event_process() (*toolkitp->event_process)() #define toolkit_set_window_title(s) (*toolkitp->set_window_title)(s) +#define toolkit_messagebox(t,m) (*toolkitp->messagebox)(t,m) -#elif defined(USE_GTK) +#elif USE_GTK > 0 || USE_GTK2 > 0 +#if USE_GTK2 > 0 +#include "gtk2/gtk_toolkit.h" +#elif USE_GTK > 0 #include "gtk/gtk_toolkit.h" +#endif #define toolkit_initialize() #define toolkit_terminate() @@ -67,9 +71,11 @@ void toolkit_initialize(void); #define toolkit_widget_show() gui_gtk_widget_show() #define toolkit_widget_mainloop() gui_gtk_widget_mainloop() #define toolkit_widget_quit() gui_gtk_widget_quit() +#define toolkit_event_process() gui_gtk_event_process() #define toolkit_set_window_title(s) gui_gtk_set_window_title(s) +#define toolkit_messagebox(t,m) gui_gtk_messagebox(t,m) -#elif defined(USE_QT) +#elif USE_QT > 0 #include "qt/qttoolkit.h" @@ -80,7 +86,43 @@ void toolkit_initialize(void); #define toolkit_widget_show() gui_qt_widget_show() #define toolkit_widget_mainloop() gui_qt_widget_mainloop() #define toolkit_widget_quit() gui_qt_widget_quit() +#define toolkit_event_process() gui_qt_event_process() #define toolkit_set_window_title(s) gui_qt_set_window_title(s) +#define toolkit_messagebox(t,m) gui_qt_messagebox(t,m) + +#elif USE_SDL > 0 + +#include "sdl/sdl_toolkit.h" + +#define toolkit_initialize() +#define toolkit_terminate() +#define toolkit_arginit(argcp, argvp) gui_sdl_arginit(argcp, argvp) +#define toolkit_widget_create() gui_sdl_widget_create() +#define toolkit_widget_show() gui_sdl_widget_show() +#define toolkit_widget_mainloop() gui_sdl_widget_mainloop() +#define toolkit_widget_quit() gui_sdl_widget_quit() +#define toolkit_event_process() gui_sdl_event_process() +#define toolkit_set_window_title(s) gui_sdl_set_window_title(s) +#define toolkit_messagebox(t,m) gui_sdl_messagebox(t,m) + +#elif USE_X11 > 0 + +#include "x11/x11_toolkit.h" + +#define toolkit_initialize() +#define toolkit_terminate() +#define toolkit_arginit(argcp, argvp) gui_x11_arginit(argcp, argvp) +#define toolkit_widget_create() gui_x11_widget_create() +#define toolkit_widget_show() gui_x11_widget_show() +#define toolkit_widget_mainloop() gui_x11_widget_mainloop() +#define toolkit_widget_quit() gui_x11_widget_quit() +#define toolkit_event_process() gui_x11_event_process() +#define toolkit_set_window_title(s) gui_x11_set_window_title(s) +#define toolkit_messagebox(t,m) gui_x11_messagebox(t,m) + +#else + +#error undefined USE_GTK and USE_QT and USE_SDL and USE_X11!!! #endif