--- np2/x11/toolkit.h 2003/12/19 16:08:01 1.4 +++ np2/x11/toolkit.h 2007/01/10 15:55:27 1.10 @@ -1,3 +1,5 @@ +/* $Id: toolkit.h,v 1.10 2007/01/10 15:55:27 monaka Exp $ */ + /* * Copyright (c) 2003 NONAKA Kimihiro * All rights reserved. @@ -10,8 +12,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 +28,6 @@ #ifndef NP2_X11_TOOLKIT_H__ #define NP2_X11_TOOLKIT_H__ -#if !defined(USE_GTK) && !defined(USE_QT) && !defined(USE_SDL) -#error undefined USE_GTK and USE_QT and USE_SDL!!! -#endif - typedef struct { const char* (*get_toolkit)(void); BOOL (*arginit)(int* argc, char*** argv); @@ -42,11 +38,33 @@ typedef struct { 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) && !defined(USE_SDL) +void toolkit_msgbox(const char *title, const char *msg); + +#if (USE_GTK + USE_GTK2 + USE_SDL) > 1 + +extern gui_toolkit_t* toolkitp; + +void toolkit_initialize(void); +#define toolkit_terminate() (*toolkitp->terminate)() +#define toolkit_arginit(argcp, argvp) (*toolkitp->arginit)(argcp, argvp) +#define toolkit_widget_create() (*toolkitp->widget_create)() +#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 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() @@ -55,24 +73,11 @@ typedef struct { #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() +#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) && !defined(USE_GTK) && !defined(USE_SDL) - -#include "qt/qttoolkit.h" - -#define toolkit_initialize() -#define toolkit_terminate() gui_qt_terminate() -#define toolkit_arginit(argcp, argvp) gui_qt_arginit(argcp, argvp) -#define toolkit_widget_create() gui_qt_widget_create() -#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() -#define toolkit_set_window_title(s) gui_qt_set_window_title(s) - -#elif defined(USE_SDL) && !defined(USE_GTK) && !defined(USE_QT) +#elif USE_SDL > 0 #include "sdl/sdl_toolkit.h" @@ -85,20 +90,11 @@ typedef struct { #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) #else -extern gui_toolkit_t* toolkitp; - -void toolkit_initialize(void); -#define toolkit_terminate() (*toolkitp->terminate)() -#define toolkit_arginit(argcp, argvp) (*toolkitp->arginit)(argcp, argvp) -#define toolkit_widget_create() (*toolkitp->widget_create)() -#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) +#error need to defined USE_GTK or USE_SDL !!! #endif