leocad/linux/system.cpp
2012-03-17 22:43:53 +00:00

763 lines
22 KiB
C++

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <gdk/gdkx.h>
#include <gdk/gdkkeysyms.h>
#include <gtk/gtk.h>
#include <X11/keysym.h>
#include <sys/time.h>
#include "opengl.h"
#include "gtkmisc.h"
#include "camera.h"
#include "project.h"
#include "system.h"
#include "main.h"
#include "toolbar.h"
#include "dialogs.h"
#include "globals.h"
#include "lc_application.h"
// =============================================================================
// Cursor functions
int Sys_MessageBox (const char* text, const char* caption, int type)
{
return msgbox_execute (text, caption, type);
}
// =============================================================================
// Memory rendering
typedef struct
{
int width, height;
Display *xdisplay;
GLXPixmap glxpixmap;
GLXContext glxcontext;
GdkPixmap *pixmap;
GdkVisual *visual;
} LC_RENDER;
void* Sys_StartMemoryRender(int width, int height)
{
LC_RENDER* render = (LC_RENDER*) malloc (sizeof (LC_RENDER));
int attrlist[] = { GLX_RGBA, GLX_DEPTH_SIZE, 16, 0 };
XVisualInfo *vi;
Pixmap xpixmap;
render->width = width;
render->height = height;
render->xdisplay = GDK_DISPLAY();
vi = pfnglXChooseVisual (render->xdisplay, DefaultScreen (render->xdisplay), attrlist);
render->visual = gdkx_visual_get (vi->visualid);
render->glxcontext = pfnglXCreateContext (render->xdisplay, vi, NULL, True);
render->pixmap = gdk_pixmap_new (NULL, width, height, render->visual->depth);
xpixmap = (Pixmap)GDK_DRAWABLE_XID(render->pixmap);
render->glxpixmap = pfnglXCreateGLXPixmap (render->xdisplay, vi, xpixmap);
XFree(vi);
pfnglXMakeCurrent (render->xdisplay, render->glxpixmap, render->glxcontext);
return render;
}
void Sys_FinishMemoryRender(void* param)
{
LC_RENDER* render = (LC_RENDER*)param;
// gtk_gl_area_make_current (GTK_GL_AREA (drawing_area));
if (render->glxcontext == pfnglXGetCurrentContext ())
pfnglXMakeCurrent (render->xdisplay, None, NULL);
pfnglXDestroyContext (render->xdisplay, render->glxcontext);
pfnglXDestroyGLXPixmap (render->xdisplay, render->glxpixmap);
pfnglXWaitGL();
gdk_pixmap_unref (render->pixmap);
pfnglXWaitX();
free(render);
}
// =============================================================================
// Misc stuff
// FIXME: should have a table of LC_KEY_* defined
bool Sys_KeyDown(int Key)
{
char keys[32];
int x;
XQueryKeymap(GDK_DISPLAY(), keys);
if (Key == KEY_CONTROL)
{
x = XKeysymToKeycode(GDK_DISPLAY(), XK_Control_L);
if (keys[x/8] & (1 << (x % 8)))
return true;
x = XKeysymToKeycode(GDK_DISPLAY(), XK_Control_R);
if (keys[x/8] & (1 << (x % 8)))
return true;
}
else if (Key == KEY_ALT)
{
x = XKeysymToKeycode(GDK_DISPLAY(), XK_Alt_L);
if (keys[x/8] & (1 << (x % 8)))
return true;
x = XKeysymToKeycode(GDK_DISPLAY(), XK_Alt_R);
if (keys[x/8] & (1 << (x % 8)))
return true;
}
return false;
}
// String
char* strupr(char* string)
{
char *cp;
for (cp=string; *cp; ++cp)
{
if ('a' <= *cp && *cp <= 'z')
*cp += 'A' - 'a';
}
return string;
}
char* strlwr(char* string)
{
char *cp;
for (cp = string; *cp; ++cp)
{
if ('A' <= *cp && *cp <= 'Z')
*cp += 'a' - 'A';
}
return string;
}
int stricmp(const char* str1, const char* str2)
{
return g_ascii_strcasecmp(str1, str2);
}
void SystemPumpMessages()
{
while (gtk_events_pending ())
gtk_main_iteration ();
}
long SystemGetTicks()
{
static int basetime = 0;
struct timezone tzp;
struct timeval tp;
gettimeofday (&tp, &tzp);
if (!basetime)
basetime = tp.tv_sec;
return (tp.tv_sec-basetime)*1000 + tp.tv_usec/1000;
}
// User Interface
void SystemUpdateCategories(bool SearchOnly)
{
}
static void create_bitmap_and_mask_from_xpm (GdkBitmap **bitmap, GdkBitmap **mask, const char **xpm)
{
int height, width, colors;
char pixmap_buffer [(32 * 32)/8];
char mask_buffer [(32 * 32)/8];
int x, y, pix;
int transparent_color, black_color;
sscanf (xpm [0], "%d %d %d %d", &height, &width, &colors, &pix);
g_assert (height == 32);
g_assert (width == 32);
g_assert (colors == 3);
transparent_color = ' ';
black_color = '.';
for (y = 0; y < 32; y++)
for (x = 0; x < 32;)
{
char value = 0, maskv = 0;
for (pix = 0; pix < 8; pix++, x++)
if (xpm [4+y][x] != transparent_color)
{
maskv |= 1 << pix;
if (xpm [4+y][x] != black_color)
value |= 1 << pix;
}
pixmap_buffer [(y * 4 + x/8)-1] = value;
mask_buffer [(y * 4 + x/8)-1] = maskv;
}
*bitmap = gdk_bitmap_create_from_data (NULL, pixmap_buffer, 32, 32);
*mask = gdk_bitmap_create_from_data (NULL, mask_buffer, 32, 32);
}
void SystemUpdateAction(int new_action, int old_action)
{
#include "pixmaps/cr_brick.xpm"
#include "pixmaps/cr_light.xpm"
#include "pixmaps/cr_spot.xpm"
#include "pixmaps/cr_cam.xpm"
#include "pixmaps/cr_sel.xpm"
#include "pixmaps/cr_selm.xpm"
#include "pixmaps/cr_move.xpm"
#include "pixmaps/cr_rot.xpm"
#include "pixmaps/cr_paint.xpm"
#include "pixmaps/cr_erase.xpm"
#include "pixmaps/cr_pan.xpm"
#include "pixmaps/cr_rotv.xpm"
#include "pixmaps/cr_roll.xpm"
#include "pixmaps/cr_zoom.xpm"
#include "pixmaps/cr_zoomr.xpm"
if (!drawing_area)
return;
GtkWidget* button;
const char** xpm = NULL;
int x, y;
switch (new_action)
{
case LC_ACTION_SELECT: button = tool_toolbar.select;
{
x = 0; y = 2;
// TODO: FIX ME !!!
if (Sys_KeyDown (KEY_CONTROL))
xpm = cr_selm;
else
xpm = cr_sel;
} break;
case LC_ACTION_INSERT:
button = tool_toolbar.brick; xpm = cr_brick; x = 8; y = 3; break;
case LC_ACTION_LIGHT:
button = tool_toolbar.light; xpm = cr_light; x = 15; y = 15; break;
case LC_ACTION_SPOTLIGHT:
button = tool_toolbar.spot; xpm = cr_spot; x = 7; y = 10; break;
case LC_ACTION_CAMERA:
button = tool_toolbar.camera; xpm = cr_cam; x = 15; y = 9; break;
case LC_ACTION_MOVE:
button = tool_toolbar.move; xpm = cr_move; x = 15; y = 15; break;
case LC_ACTION_ROTATE:
button = tool_toolbar.rotate; xpm = cr_rot; x = 15; y = 15; break;
case LC_ACTION_ERASER:
button = tool_toolbar.erase; xpm = cr_erase; x = 0; y = 10; break;
case LC_ACTION_PAINT:
button = tool_toolbar.paint; xpm = cr_paint; x = 14; y = 14; break;
case LC_ACTION_ZOOM:
button = tool_toolbar.zoom; xpm = cr_zoom; x = 15; y = 15; break;
case LC_ACTION_ZOOM_REGION:
button = tool_toolbar.zoomreg; xpm = cr_zoomr; x = 9; y = 9; break;
case LC_ACTION_PAN:
button = tool_toolbar.pan; xpm = cr_pan; x = 15; y = 15; break;
case LC_ACTION_ROTATE_VIEW:
button = tool_toolbar.rotview; xpm = cr_rotv; x = 15; y = 15; break;
case LC_ACTION_ROLL:
button = tool_toolbar.roll; xpm = cr_roll; x = 15; y = 15; break;
default:
return;
}
GdkBitmap *bitmap;
GdkBitmap *mask;
GdkCursor *cursor;
GdkColor white = {0, 0xffff, 0xffff, 0xffff};
GdkColor black = {0, 0x0000, 0x0000, 0x0000};
if (GDK_IS_WINDOW(drawing_area))
{
if (xpm != NULL)
{
create_bitmap_and_mask_from_xpm (&bitmap, &mask, xpm);
cursor = gdk_cursor_new_from_pixmap (bitmap, mask, &white, &black, x, y);
gdk_window_set_cursor (drawing_area->window, cursor);
}
else
{
cursor = gdk_cursor_new (GDK_LEFT_PTR);
gdk_window_set_cursor (drawing_area->window, cursor);
gdk_cursor_destroy (cursor);
}
}
ignore_commands = true;
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(button), TRUE);
ignore_commands = false;
}
void SystemUpdateColorList(int new_color)
{
colorlist_set(new_color);
}
void SystemUpdateRenderingMode(bool bFast)
{
if (!main_toolbar.fast)
return;
ignore_commands = true;
gtk_toggle_tool_button_set_active(GTK_TOGGLE_TOOL_BUTTON(main_toolbar.fast), bFast);
ignore_commands = false;
}
void SystemUpdateUndoRedo(char* undo, char* redo)
{
gpointer item;
char text[50];
strcpy(text, "Undo ");
if (undo)
strcat(text, undo);
item = gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_edit_undo");
if (!item)
return;
gtk_label_set_text (GTK_LABEL (GTK_BIN (item)->child), text);
gtk_widget_set_sensitive (GTK_WIDGET (item), undo != NULL);
strcpy(text, "Redo ");
if (redo)
strcat(text, redo);
item = gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_edit_redo");
gtk_label_set_text (GTK_LABEL (GTK_BIN (item)->child), text);
gtk_widget_set_sensitive (GTK_WIDGET (item), redo != NULL);
gtk_widget_set_sensitive (main_toolbar.undo, undo != NULL);
gtk_widget_set_sensitive (main_toolbar.redo, redo != NULL);
}
void SystemUpdateSnap(const unsigned long snap)
{
if (!main_toolbar.angle)
return;
ignore_commands = true;
gtk_toggle_tool_button_set_active(GTK_TOGGLE_TOOL_BUTTON(main_toolbar.angle), (snap & LC_DRAW_SNAP_A) != 0);
ignore_commands = false;
void* item;
ignore_commands = true;
item = gtk_object_get_data(GTK_OBJECT(main_toolbar.snap_menu), "snap_x");
gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), (snap & LC_DRAW_SNAP_X) ? TRUE : FALSE);
item = gtk_object_get_data(GTK_OBJECT(main_toolbar.snap_menu), "snap_y");
gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), (snap & LC_DRAW_SNAP_Y) ? TRUE : FALSE);
item = gtk_object_get_data(GTK_OBJECT(main_toolbar.snap_menu), "snap_z");
gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), (snap & LC_DRAW_SNAP_Z) ? TRUE : FALSE);
item = gtk_object_get_data(GTK_OBJECT(main_toolbar.lock_menu), "lock_x");
gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), (snap & LC_DRAW_LOCK_X) ? TRUE : FALSE);
item = gtk_object_get_data(GTK_OBJECT(main_toolbar.lock_menu), "lock_y");
gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), (snap & LC_DRAW_LOCK_Y) ? TRUE : FALSE);
item = gtk_object_get_data(GTK_OBJECT(main_toolbar.lock_menu), "lock_z");
gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), (snap & LC_DRAW_LOCK_Z) ? TRUE : FALSE);
ignore_commands = false;
}
void SystemUpdateCurrentCamera(Camera* pOld, Camera* pNew, Camera* pCamera)
{
gpointer item = NULL;
gpointer menu = gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "cameras_menu");
if (!menu)
return;
GList *lst = gtk_container_children (GTK_CONTAINER (menu));
for (int i = 0; pCamera; i++, pCamera = pCamera->m_pNext)
if (pNew == pCamera)
{
if (i >= 7)
item = g_list_nth_data (lst, i-7);
else
{
guint len = g_list_length (lst);
if (len > 7)
item = g_list_nth_data (lst, len - 7 + i);
else
item = g_list_nth_data (lst, i);
}
break;
}
if (item)
{
ignore_commands = true;
gtk_check_menu_item_set_state (GTK_CHECK_MENU_ITEM (item), TRUE);
ignore_commands = false;
}
}
void SystemUpdateCameraMenu(Camera* pCamera)
{
GtkWidget *menu = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "cameras_menu"));
GtkWidget *item = NULL;
Camera* pFirst = pCamera;
GList *lst;
int i;
if (!menu)
return;
// empty the menu
while ((lst = gtk_container_children (GTK_CONTAINER (menu))) != NULL)
gtk_container_remove (GTK_CONTAINER (menu), GTK_WIDGET (lst->data));
// add user cameras
for (i = 0; pCamera; i++, pCamera = pCamera->m_pNext)
if (i > 6)
{
GSList* grp = item ? gtk_radio_menu_item_group (GTK_RADIO_MENU_ITEM (item)) : NULL;
item = gtk_radio_menu_item_new_with_label (grp, pCamera->GetName());
gtk_menu_append (GTK_MENU (menu), item);
gtk_widget_show (item);
gtk_signal_connect (GTK_OBJECT (item), "activate", GTK_SIGNAL_FUNC (OnCommand),
GINT_TO_POINTER (i + ID_CAMERA_FIRST));
}
if (i > 7)
menu_separator (menu);
// add standard cameras
for (pCamera = pFirst, i = 0; pCamera && (i < 7); i++, pCamera = pCamera->m_pNext)
{
GSList* grp = item ? gtk_radio_menu_item_group (GTK_RADIO_MENU_ITEM (item)) : NULL;
item = gtk_radio_menu_item_new_with_label (grp, pCamera->GetName());
gtk_menu_append (GTK_MENU (menu), item);
gtk_widget_show (item);
gtk_signal_connect (GTK_OBJECT (item), "activate", GTK_SIGNAL_FUNC (OnCommand),
GINT_TO_POINTER (i + ID_CAMERA_FIRST));
}
}
void SystemUpdateTime(bool bAnimation, int nTime, int nTotal)
{
GtkWidget *item;
if (!anim_toolbar.first)
return;
gtk_widget_set_sensitive (anim_toolbar.first, nTime != 1);
gtk_widget_set_sensitive (anim_toolbar.prev, nTime > 1);
gtk_widget_set_sensitive (anim_toolbar.next, nTime < nTotal);
gtk_widget_set_sensitive (anim_toolbar.last, nTime != nTotal);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_view_step_first"));
gtk_widget_set_sensitive (item, nTime != 1);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_view_step_previous"));
gtk_widget_set_sensitive (item, nTime > 1);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_view_step_next"));
gtk_widget_set_sensitive (item, nTime < nTotal);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_view_step_last"));
gtk_widget_set_sensitive (item, nTime != nTotal);
char text[11];
if (bAnimation)
sprintf(text, "%i/%i", nTime, nTotal);
else
sprintf(text, " Step %i ", nTime);
gtk_label_set (GTK_LABEL (label_step), text);
// step dlg
}
void SystemUpdateAnimation(bool bAnimation, bool bAddKeys)
{
if (!anim_toolbar.play)
return;
ignore_commands = true;
gtk_widget_set_sensitive (anim_toolbar.play, bAnimation);
gtk_widget_set_sensitive (anim_toolbar.stop, FALSE);
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON(anim_toolbar.anim), bAnimation);
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON(anim_toolbar.keys), bAddKeys);
gpointer item = gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_copykeys");
gtk_label_set_text (GTK_LABEL (GTK_BIN (item)->child),
bAnimation ? "Copy Keys from Instructions" : "Copy Keys from Animation");
ignore_commands = false;
}
void SystemUpdateSnap(unsigned short move_snap, unsigned short RotateSnap)
{
if (!label_snap)
return;
char Text[256], xy[32], z[32];
lcGetActiveProject()->GetSnapDistanceText(xy, z);
sprintf(Text, " M: %s %s R: %d ", xy, z, RotateSnap);
gtk_label_set (GTK_LABEL (label_snap), Text);
}
void SystemUpdateSelected(unsigned long flags, int SelectedCount, Object* Focus)
{
GtkWidget *item;
// select all/none/invert/by name (menu)
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_edit_select_all"));
if (!item)
return;
gtk_widget_set_sensitive (item, (flags & LC_SEL_UNSELECTED) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_edit_select_none"));
gtk_widget_set_sensitive (item, (flags & (LC_SEL_PIECE|LC_SEL_CAMERA|LC_SEL_LIGHT)) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_edit_select_invert"));
gtk_widget_set_sensitive (item, (flags & LC_SEL_NO_PIECES) == 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_edit_select_byname"));
gtk_widget_set_sensitive (item, (flags & LC_SEL_NO_PIECES) == 0);
// cut, copy (menu/toolbar)
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_edit_cut"));
gtk_widget_set_sensitive (item, (flags & (LC_SEL_PIECE|LC_SEL_CAMERA|LC_SEL_LIGHT)) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_edit_copy"));
gtk_widget_set_sensitive (item, (flags & (LC_SEL_PIECE|LC_SEL_CAMERA|LC_SEL_LIGHT)) != 0);
gtk_widget_set_sensitive (main_toolbar.cut, (flags & (LC_SEL_PIECE|LC_SEL_CAMERA|LC_SEL_LIGHT)) != 0);
gtk_widget_set_sensitive (main_toolbar.copy, (flags & (LC_SEL_PIECE|LC_SEL_CAMERA|LC_SEL_LIGHT)) != 0);
// delete, array, hide sel/unsel, unhideall, copykeys (menu)
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_delete"));
gtk_widget_set_sensitive (item, (flags & (LC_SEL_PIECE|LC_SEL_CAMERA|LC_SEL_LIGHT)) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_array"));
gtk_widget_set_sensitive (item, (flags & LC_SEL_PIECE) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_hide_selected"));
gtk_widget_set_sensitive (item, (flags & LC_SEL_PIECE) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_hide_unselected"));
gtk_widget_set_sensitive (item, (flags & LC_SEL_UNSELECTED) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_unhide_all"));
gtk_widget_set_sensitive (item, (flags & LC_SEL_HIDDEN) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_copykeys"));
gtk_widget_set_sensitive (item, (flags & (LC_SEL_PIECE|LC_SEL_CAMERA|LC_SEL_LIGHT)) != 0);
// groups (menu)
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_group"));
gtk_widget_set_sensitive (item, (flags & LC_SEL_CANGROUP) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_ungroup"));
gtk_widget_set_sensitive (item, (flags & LC_SEL_GROUP) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_group_add"));
gtk_widget_set_sensitive (item, (flags & (LC_SEL_GROUP|LC_SEL_FOCUSGROUP)) == LC_SEL_GROUP);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_group_remove"));
gtk_widget_set_sensitive (item, (flags & LC_SEL_FOCUSGROUP) != 0);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_piece_group_edit"));
gtk_widget_set_sensitive (item, (flags & LC_SEL_NO_PIECES) == 0);
gtk_widget_set_sensitive (tool_toolbar.prev, (flags & LC_SEL_PIECE) != 0);
gtk_widget_set_sensitive (tool_toolbar.next, (flags & LC_SEL_PIECE) != 0);
}
void SystemUpdateRecentMenu (String names[4])
{
GtkWidget *item;
char buf[32];
for (int i = 0; i < 4; i++)
{
sprintf (buf, "menu_file_recent%d", i+1);
item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), buf));
if (!names[i].IsEmpty ())
{
if (i == 0)
{
gtk_label_set_text (GTK_LABEL (GTK_BIN (item)->child), "Recent Files");
gtk_widget_set_sensitive (item, FALSE);
}
else
gtk_widget_hide (item);
}
else
{
char text[LC_MAXPATH+4];
sprintf (text, "_%d- %s", i+1, (char*)names[i]);
gtk_label_set_text_with_mnemonic(GTK_LABEL(GTK_BIN(item)->child), text);
gtk_widget_show(item);
gtk_widget_set_sensitive(item, TRUE);
}
}
}
void SystemUpdatePaste(bool enable)
{
gtk_widget_set_sensitive (main_toolbar.paste, enable);
GtkWidget *item = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (((GtkWidget*)(*main_window))), "menu_edit_paste"));
gtk_widget_set_sensitive (item, enable);
}
void SystemUpdatePlay(bool play, bool stop)
{
gtk_widget_set_sensitive (anim_toolbar.play, play);
gtk_widget_set_sensitive (anim_toolbar.stop, stop);
}
void SystemInit()
{
}
void SystemFinish()
{
}
// FIXME: remove
int SystemDoMessageBox(const char* prompt, int mode)
{
return msgbox_execute (prompt, "LeoCAD", mode);
}
bool SystemDoDialog(int mode, void* param)
{
switch (mode)
{
case LC_DLG_FILE_OPEN_PROJECT:
return openprojectdlg_execute ((char*)param) == LC_OK;
case LC_DLG_FILE_SAVE_PROJECT:
return saveprojectdlg_execute ((char*)param) == LC_OK;
case LC_DLG_FILE_MERGE_PROJECT:
return openprojectdlg_execute ((char*)param) == LC_OK;
case LC_DLG_FILE_OPEN:
return openprojectdlg_execute ((char*)param) == LC_OK;
case LC_DLG_ABOUT:
return aboutdlg_execute(param) == LC_OK;
case LC_DLG_ARRAY:
return arraydlg_execute(param) == LC_OK;
case LC_DLG_HTML:
return htmldlg_execute(param) == LC_OK;
case LC_DLG_POVRAY:
return povraydlg_execute(param) == LC_OK;
case LC_DLG_WAVEFRONT:
return wavefrontdlg_execute(param) == LC_OK;
case LC_DLG_PREFERENCES:
return preferencesdlg_execute(param) == LC_OK;
case LC_DLG_PICTURE_SAVE:
return savepicturedlg_execute (param) == LC_OK;
case LC_DLG_MINIFIG:
return minifigdlg_execute(param) == LC_OK;
case LC_DLG_PROPERTIES:
return propertiesdlg_execute(param) == LC_OK;
case LC_DLG_LIBRARY:
return librarydlg_execute(param) == LC_OK;
case LC_DLG_SELECTBYNAME:
break;
case LC_DLG_STEPCHOOSE:
break;
case LC_DLG_EDITGROUPS:
return groupeditdlg_execute(param) == LC_OK;
case LC_DLG_GROUP:
return groupdlg_execute(param) == LC_OK;
}
return false;
}
void SystemDoPopupMenu(int nMenu, int x, int y)
{
}
void SystemDoWaitCursor(int code)
{
GdkWindow* window = ((GtkWidget*)(*main_window))->window;
if (!GDK_IS_WINDOW(window))
return;
if (code == 1)
{
GdkCursor *cursor = gdk_cursor_new (GDK_WATCH);
gdk_window_set_cursor(window, cursor);
gdk_cursor_destroy (cursor);
}
else
{
GdkCursor *cursor = gdk_cursor_new (GDK_LEFT_PTR);
gdk_window_set_cursor(window, cursor);
gdk_cursor_destroy (cursor);
}
}
void SystemExportClipboard(File* clip)
{
}
File* SystemImportClipboard()
{
return NULL;
}
void SystemSetWindowCaption(char* caption)
{
gtk_window_set_title (GTK_WINDOW (((GtkWidget*)(*main_window))), caption);
}
void SystemPieceComboAdd(char* name)
{
piececombo_add(name);
}
void SystemCaptureMouse()
{
}
void SystemReleaseMouse()
{
}
void SystemStartProgressBar(int nLower, int nUpper, int nStep, const char* Text)
{
}
void SytemEndProgressBar()
{
}
void SytemStepProgressBar()
{
}