=================================================================== RCS file: /home/cvs/OpenXM_contrib2/windows/engine2000/ox_plot_win.c,v retrieving revision 1.4 retrieving revision 1.7 diff -u -p -r1.4 -r1.7 --- OpenXM_contrib2/windows/engine2000/ox_plot_win.c 2002/07/30 03:48:34 1.4 +++ OpenXM_contrib2/windows/engine2000/ox_plot_win.c 2014/03/25 19:24:43 1.7 @@ -45,7 +45,7 @@ * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. * - * $OpenXM: OpenXM_contrib2/windows/engine2000/ox_plot_win.c,v 1.3 2002/07/30 03:06:20 noro Exp $ + * $OpenXM: OpenXM_contrib2/windows/engine2000/ox_plot_win.c,v 1.6 2002/10/03 03:05:44 noro Exp $ */ #include "ca.h" #include "parse.h" @@ -62,9 +62,7 @@ static int remotes; static int depth,scrn; extern jmp_buf ox_env; -extern DWORD MainThread; - static int busy; HBRUSH ClearBrush,DrawBrush; @@ -92,11 +90,18 @@ int search_active_canvas() return -1; } +volatile DWORD MainThread; +volatile int canvas_created; +extern HANDLE hMainThreadReady,hCanvasCreated; + void create_canvas(struct canvas *can) { alloc_pixmap(can); can->real_can = can; + WaitForSingleObject(hMainThreadReady,(DWORD)-1); + ResetEvent(hCanvasCreated); PostThreadMessage(MainThread,WM_APP,can->index,0); + WaitForSingleObject(hCanvasCreated,(DWORD)-1); } void destroy_canvas(struct canvas *can) @@ -201,4 +206,9 @@ void draw_frame0(DRAWABLE d,POINT spos,POINT epos) rect.left = spos.x; rect.top = spos.y; rect.right = epos.x; rect.bottom = epos.y; FrameRect(d,&rect,DrawBrush); +} + +/* dummy function */ +void set_drawcolor(unsigned int c) +{ }