--- np2/x11/toolkit.h 2003/11/16 16:43:45 1.1 +++ 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,53 +28,73 @@ #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); + void (*terminate)(void); void (*widget_create)(void); 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_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() (*widget_create)() -#define toolkit_widget_show() (*widget_show)() -#define toolkit_widget_mainloop() (*widget_mainloop)() -#define toolkit_widget_quit() (*widget_quit)() +#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 defined(USE_GTK) +#elif USE_GTK > 0 || USE_GTK2 > 0 -#include "gtk/gtktoolkit.h" +#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() #define toolkit_arginit(argcp, argvp) gui_gtk_arginit(argcp, argvp) #define toolkit_widget_create() gui_gtk_widget_create() #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 USE_SDL > 0 -#elif defined(USE_QT) +#include "sdl/sdl_toolkit.h" #define toolkit_initialize() -#define toolkit_arginit(argcp, argvp) -#define toolkit_widget_create() -#define toolkit_widget_show() -#define toolkit_widget_mainloop() -#define toolkit_widget_quit() -#define toolkit_set_window_title(s) +#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) + +#else + +#error need to defined USE_GTK or USE_SDL !!! #endif