7 #include <X11/cursorfont.h>
9 /********** data ************/
12 #define CHECK_BUTTON_ON_WIDTH 16
13 #define CHECK_BUTTON_ON_HEIGHT 16
15 static char *CHECK_BUTTON_ON
[] = {
33 #define CHECK_BUTTON_OFF_WIDTH 16
34 #define CHECK_BUTTON_OFF_HEIGHT 16
36 static char *CHECK_BUTTON_OFF
[] = {
54 #define RADIO_BUTTON_ON_WIDTH 15
55 #define RADIO_BUTTON_ON_HEIGHT 15
56 static char *RADIO_BUTTON_ON
[] = {
74 #define RADIO_BUTTON_OFF_WIDTH 15
75 #define RADIO_BUTTON_OFF_HEIGHT 15
76 static char *RADIO_BUTTON_OFF
[] = {
95 static char *BUTTON_ARROW
[] = {
100 ".#............ ...",
101 "#............. ...",
102 ".#............ ...",
104 "...#. ............",
108 #define BUTTON_ARROW_WIDTH 18
109 #define BUTTON_ARROW_HEIGHT 10
112 static char *BUTTON_ARROW2
[] = {
125 #define BUTTON_ARROW2_WIDTH 18
126 #define BUTTON_ARROW2_HEIGHT 10
129 static char *SCROLLER_DIMPLE
[] = {
138 #define SCROLLER_DIMPLE_WIDTH 6
139 #define SCROLLER_DIMPLE_HEIGHT 6
142 static char *SCROLLER_ARROW_UP
[] = {
154 static char *HI_SCROLLER_ARROW_UP
[] = {
166 #define SCROLLER_ARROW_UP_WIDTH 9
167 #define SCROLLER_ARROW_UP_HEIGHT 9
170 static char *SCROLLER_ARROW_DOWN
[] = {
182 static char *HI_SCROLLER_ARROW_DOWN
[] = {
194 #define SCROLLER_ARROW_DOWN_WIDTH 9
195 #define SCROLLER_ARROW_DOWN_HEIGHT 9
199 static char *SCROLLER_ARROW_LEFT
[] = {
211 static char *HI_SCROLLER_ARROW_LEFT
[] = {
223 #define SCROLLER_ARROW_LEFT_WIDTH 9
224 #define SCROLLER_ARROW_LEFT_HEIGHT 9
227 static char *SCROLLER_ARROW_RIGHT
[] = {
239 static char *HI_SCROLLER_ARROW_RIGHT
[] = {
251 #define SCROLLER_ARROW_RIGHT_WIDTH 9
252 #define SCROLLER_ARROW_RIGHT_HEIGHT 9
255 static char *POPUP_INDICATOR
[] = {
266 #define POPUP_INDICATOR_WIDTH 11
267 #define POPUP_INDICATOR_HEIGHT 8
271 static char *PULLDOWN_INDICATOR
[] = {
280 #define PULLDOWN_INDICATOR_WIDTH 9
281 #define PULLDOWN_INDICATOR_HEIGHT 7
284 #define CHECK_MARK_WIDTH 8
285 #define CHECK_MARK_HEIGHT 10
287 static char *CHECK_MARK
[] = {
300 #define STIPPLE_WIDTH 8
301 #define STIPPLE_HEIGHT 8
302 static unsigned char STIPPLE_BITS
[] = {
303 0x55, 0xaa, 0x55, 0xaa, 0x55, 0xaa, 0x55, 0xaa};
306 extern void W_ReadConfigurations(void);
309 extern W_ViewProcedureTable _WindowViewProcedures
;
310 extern W_ViewProcedureTable _FrameViewProcedures
;
311 extern W_ViewProcedureTable _LabelViewProcedures
;
312 extern W_ViewProcedureTable _ButtonViewProcedures
;
313 extern W_ViewProcedureTable _TextFieldViewProcedures
;
314 extern W_ViewProcedureTable _ScrollerViewProcedures
;
315 extern W_ViewProcedureTable _ScrollViewProcedures
;
316 extern W_ViewProcedureTable _ListViewProcedures
;
317 extern W_ViewProcedureTable _BrowserViewProcedures
;
318 extern W_ViewProcedureTable _PopUpButtonViewProcedures
;
319 extern W_ViewProcedureTable _ColorWellViewProcedures
;
320 extern W_ViewProcedureTable _ScrollViewViewProcedures
;
321 extern W_ViewProcedureTable _SliderViewProcedures
;
322 extern W_ViewProcedureTable _SplitViewViewProcedures
;
325 * All widget classes defined must have an entry here.
327 static W_ViewProcedureTable
*procedureTables
[16];
329 static W_ViewProcedureTable
**userProcedureTable
= NULL
;
330 static int userWidgetCount
=0;
333 /***** end data ******/
340 procedureTables
[WC_Window
] = &_WindowViewProcedures
;
341 procedureTables
[WC_Frame
] = &_FrameViewProcedures
;
342 procedureTables
[WC_Label
] = &_LabelViewProcedures
;
343 procedureTables
[WC_Button
] = &_ButtonViewProcedures
;
344 procedureTables
[WC_TextField
] = &_TextFieldViewProcedures
;
345 procedureTables
[WC_Scroller
] = &_ScrollerViewProcedures
;
346 procedureTables
[WC_List
] = &_ListViewProcedures
;
347 procedureTables
[WC_Browser
] = &_BrowserViewProcedures
;
348 procedureTables
[WC_PopUpButton
] = &_PopUpButtonViewProcedures
;
349 procedureTables
[WC_ColorWell
] = &_ColorWellViewProcedures
;
350 procedureTables
[WC_ScrollView
] = &_ScrollViewViewProcedures
;
351 procedureTables
[WC_Slider
] = &_SliderViewProcedures
;
352 procedureTables
[WC_SplitView
] = &_SplitViewViewProcedures
;
357 renderPixmap(W_Screen
*screen
, Pixmap d
, Pixmap mask
, char **data
,
358 int width
, int height
)
361 GC whiteGC
= WMColorGC(screen
->white
);
362 GC blackGC
= WMColorGC(screen
->black
);
363 GC lightGC
= WMColorGC(screen
->gray
);
364 GC darkGC
= WMColorGC(screen
->darkGray
);
368 XSetForeground(screen
->display
, screen
->monoGC
, 0);
370 for (y
= 0; y
< height
; y
++) {
371 for (x
= 0; x
< width
; x
++) {
372 switch (data
[y
][x
]) {
375 XDrawPoint(screen
->display
, d
, whiteGC
, x
, y
);
380 XDrawPoint(screen
->display
, mask
, screen
->monoGC
, x
, y
);
384 XDrawPoint(screen
->display
, d
, lightGC
, x
, y
);
389 XDrawPoint(screen
->display
, d
, darkGC
, x
, y
);
395 XDrawPoint(screen
->display
, d
, blackGC
, x
, y
);
405 makePixmap(W_Screen
*sPtr
, char **data
, int width
, int height
, int masked
)
407 Pixmap pixmap
, mask
= None
;
409 pixmap
= XCreatePixmap(sPtr
->display
, W_DRAWABLE(sPtr
), width
, height
,
413 mask
= XCreatePixmap(sPtr
->display
, W_DRAWABLE(sPtr
), width
, height
, 1);
414 XSetForeground(sPtr
->display
, sPtr
->monoGC
, 1);
415 XFillRectangle(sPtr
->display
, mask
, sPtr
->monoGC
, 0, 0, width
, height
);
418 renderPixmap(sPtr
, pixmap
, mask
, data
, width
, height
);
420 return WMCreatePixmapFromXPixmaps(sPtr
, pixmap
, mask
, width
, height
,
425 #define T_WINGS_IMAGES_FILE RESOURCE_PATH"/Images.tiff"
426 #define T_DEFAULT_OBJECT_ICON_FILE RESOURCE_PATH"/defaultIcon.tiff"
428 #define X_WINGS_IMAGES_FILE RESOURCE_PATH"/Images.xpm"
429 #define X_DEFAULT_OBJECT_ICON_FILE RESOURCE_PATH"/defaultIcon.xpm"
433 loadPixmaps(WMScreen
*scr
)
447 image
= RLoadImage(scr
->rcontext
, T_WINGS_IMAGES_FILE
, 0);
449 image
= RLoadImage(scr
->rcontext
, X_WINGS_IMAGES_FILE
, 0);
451 wwarning("WINGs: could not load widget images file: %s",
452 RMessageForError(RErrorCode
));
456 /* make it have a gray background */
457 tmp
= RGetSubImage(image
, 0, 0, 24, 24);
458 RCombineImageWithColor(tmp
, &gray
);
459 scr
->homeIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
461 /* make it have a white background */
462 tmp
= RGetSubImage(image
, 0, 0, 24, 24);
463 RCombineImageWithColor(tmp
, &white
);
464 scr
->altHomeIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
467 /* Magnifying Glass Icon for ColorPanel */
468 tmp
= RGetSubImage(image
, 24, 0, 40, 32);
469 RCombineImageWithColor(tmp
, &gray
);
470 scr
->magnifyIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
472 tmp
= RGetSubImage(image
, 24, 0, 40, 32);
473 RCombineImageWithColor(tmp
, &white
);
474 scr
->altMagnifyIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
476 /* ColorWheel Icon for ColorPanel */
477 tmp
= RGetSubImage(image
, 0, 25, 24, 24);
478 scr
->wheelIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
480 /* GrayScale Icon for ColorPanel */
481 tmp
= RGetSubImage(image
, 65, 0, 40, 24);
482 scr
->grayIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
484 /* RGB Icon for ColorPanel */
485 tmp
= RGetSubImage(image
, 25, 33, 40, 24);
486 scr
->rgbIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
488 /* CMYK Icon for ColorPanel */
489 tmp
= RGetSubImage(image
, 65, 25, 40, 24);
490 scr
->cmykIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
492 /* HSB Icon for ColorPanel */
493 tmp
= RGetSubImage(image
, 0, 57, 40, 24);
494 scr
->hsbIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
496 /* CustomColorPalette Icon for ColorPanel */
497 tmp
= RGetSubImage(image
, 81, 57, 40, 24);
498 scr
->customPaletteIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
500 /* ColorList Icon for ColorPanel */
501 tmp
= RGetSubImage(image
, 41, 57, 40, 24);
502 scr
->colorListIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
505 RDestroyImage(image
);
508 scr
->defaultObjectIcon
=
509 WMCreatePixmapFromFile(scr
, T_DEFAULT_OBJECT_ICON_FILE
);
510 if (!scr
->defaultObjectIcon
) {
511 scr
->defaultObjectIcon
=
512 WMCreatePixmapFromFile(scr
, X_DEFAULT_OBJECT_ICON_FILE
);
514 if (!scr
->defaultObjectIcon
) {
515 wwarning("WINGs: could not load default icon file");
525 WMCreateSimpleApplicationScreen(Display
*display
)
529 scr
= WMCreateScreen(display
, DefaultScreen(display
));
531 scr
->aflags
.hasAppIcon
= 0;
532 scr
->aflags
.simpleApplication
= 1;
540 WMCreateScreen(Display
*display
, int screen
)
542 return WMCreateScreenWithRContext(display
, screen
,
543 RCreateContext(display
, screen
, NULL
));
548 WMCreateScreenWithRContext(Display
*display
, int screen
, RContext
*context
)
553 static int initialized
= 0;
559 initProcedureTable();
561 W_ReadConfigurations();
563 assert(W_ApplicationInitialized());
566 scrPtr
= malloc(sizeof(W_Screen
));
569 memset(scrPtr
, 0, sizeof(W_Screen
));
571 scrPtr
->aflags
.hasAppIcon
= 1;
573 scrPtr
->display
= display
;
574 scrPtr
->screen
= screen
;
575 scrPtr
->rcontext
= context
;
577 scrPtr
->depth
= context
->depth
;
579 scrPtr
->visual
= context
->visual
;
580 scrPtr
->lastEventTime
= 0;
582 scrPtr
->colormap
= context
->cmap
;
584 scrPtr
->rootWin
= RootWindow(display
, screen
);
586 scrPtr
->fontCache
= WMCreateHashTable(WMStringPointerHashCallbacks
);
588 /* initially allocate some colors */
589 WMWhiteColor(scrPtr
);
590 WMBlackColor(scrPtr
);
592 WMDarkGrayColor(scrPtr
);
594 gcv
.graphics_exposures
= False
;
596 gcv
.function
= GXxor
;
597 gcv
.foreground
= W_PIXEL(scrPtr
->white
);
598 if (gcv
.foreground
== 0) gcv
.foreground
= 1;
599 scrPtr
->xorGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
), GCFunction
600 |GCGraphicsExposures
|GCForeground
, &gcv
);
602 gcv
.function
= GXxor
;
603 gcv
.foreground
= W_PIXEL(scrPtr
->gray
);
604 gcv
.subwindow_mode
= IncludeInferiors
;
605 scrPtr
->ixorGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
), GCFunction
606 |GCGraphicsExposures
|GCForeground
607 |GCSubwindowMode
, &gcv
);
609 gcv
.function
= GXcopy
;
610 scrPtr
->copyGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
), GCFunction
611 |GCGraphicsExposures
, &gcv
);
613 scrPtr
->clipGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
), GCFunction
614 |GCGraphicsExposures
, &gcv
);
617 stipple
= XCreateBitmapFromData(display
, W_DRAWABLE(scrPtr
),
618 STIPPLE_BITS
, STIPPLE_WIDTH
, STIPPLE_HEIGHT
);
619 gcv
.foreground
= W_PIXEL(scrPtr
->darkGray
);
620 gcv
.background
= W_PIXEL(scrPtr
->gray
);
621 gcv
.fill_style
= FillStippled
;
622 gcv
.stipple
= stipple
;
623 scrPtr
->stippleGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
),
624 GCForeground
|GCBackground
|GCStipple
625 |GCFillStyle
|GCGraphicsExposures
, &gcv
);
627 gcv
.foreground
= W_PIXEL(scrPtr
->black
);
628 gcv
.background
= W_PIXEL(scrPtr
->white
);
629 scrPtr
->textFieldGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
),
630 GCForeground
|GCBackground
, &gcv
);
632 /* we need a 1bpp drawable for the monoGC, so borrow this one */
633 scrPtr
->monoGC
= XCreateGC(display
, stipple
, 0, NULL
);
635 XFreePixmap(display
, stipple
);
638 scrPtr
->normalFont
= WMSystemFontOfSize(scrPtr
, 12);
640 scrPtr
->boldFont
= WMBoldSystemFontOfSize(scrPtr
, 12);
642 if (!scrPtr
->boldFont
)
643 scrPtr
->boldFont
= scrPtr
->normalFont
;
645 if (!scrPtr
->normalFont
) {
646 wwarning("could not load any fonts. Make sure your font installation"
647 "and locale settings are correct.");
652 scrPtr
->checkButtonImageOn
= makePixmap(scrPtr
, CHECK_BUTTON_ON
,
653 CHECK_BUTTON_ON_WIDTH
,
654 CHECK_BUTTON_ON_HEIGHT
, False
);
656 scrPtr
->checkButtonImageOff
= makePixmap(scrPtr
, CHECK_BUTTON_OFF
,
657 CHECK_BUTTON_OFF_WIDTH
,
658 CHECK_BUTTON_OFF_HEIGHT
, False
);
660 scrPtr
->radioButtonImageOn
= makePixmap(scrPtr
, RADIO_BUTTON_ON
,
661 RADIO_BUTTON_ON_WIDTH
,
662 RADIO_BUTTON_ON_HEIGHT
, False
);
664 scrPtr
->radioButtonImageOff
= makePixmap(scrPtr
, RADIO_BUTTON_OFF
,
665 RADIO_BUTTON_OFF_WIDTH
,
666 RADIO_BUTTON_OFF_HEIGHT
, False
);
668 scrPtr
->buttonArrow
= makePixmap(scrPtr
, BUTTON_ARROW
,
669 BUTTON_ARROW_WIDTH
, BUTTON_ARROW_HEIGHT
,
672 scrPtr
->pushedButtonArrow
= makePixmap(scrPtr
, BUTTON_ARROW2
,
673 BUTTON_ARROW2_WIDTH
, BUTTON_ARROW2_HEIGHT
,
677 scrPtr
->scrollerDimple
= makePixmap(scrPtr
, SCROLLER_DIMPLE
,
678 SCROLLER_DIMPLE_WIDTH
,
679 SCROLLER_DIMPLE_HEIGHT
, False
);
682 scrPtr
->upArrow
= makePixmap(scrPtr
, SCROLLER_ARROW_UP
,
683 SCROLLER_ARROW_UP_WIDTH
,
684 SCROLLER_ARROW_UP_HEIGHT
, True
);
686 scrPtr
->downArrow
= makePixmap(scrPtr
, SCROLLER_ARROW_DOWN
,
687 SCROLLER_ARROW_DOWN_WIDTH
,
688 SCROLLER_ARROW_DOWN_HEIGHT
, True
);
690 scrPtr
->leftArrow
= makePixmap(scrPtr
, SCROLLER_ARROW_LEFT
,
691 SCROLLER_ARROW_LEFT_WIDTH
,
692 SCROLLER_ARROW_LEFT_HEIGHT
, True
);
694 scrPtr
->rightArrow
= makePixmap(scrPtr
, SCROLLER_ARROW_RIGHT
,
695 SCROLLER_ARROW_RIGHT_WIDTH
,
696 SCROLLER_ARROW_RIGHT_HEIGHT
, True
);
698 scrPtr
->hiUpArrow
= makePixmap(scrPtr
, HI_SCROLLER_ARROW_UP
,
699 SCROLLER_ARROW_UP_WIDTH
,
700 SCROLLER_ARROW_UP_HEIGHT
, True
);
702 scrPtr
->hiDownArrow
= makePixmap(scrPtr
, HI_SCROLLER_ARROW_DOWN
,
703 SCROLLER_ARROW_DOWN_WIDTH
,
704 SCROLLER_ARROW_DOWN_HEIGHT
, True
);
706 scrPtr
->hiLeftArrow
= makePixmap(scrPtr
, HI_SCROLLER_ARROW_LEFT
,
707 SCROLLER_ARROW_LEFT_WIDTH
,
708 SCROLLER_ARROW_LEFT_HEIGHT
, True
);
710 scrPtr
->hiRightArrow
= makePixmap(scrPtr
, HI_SCROLLER_ARROW_RIGHT
,
711 SCROLLER_ARROW_RIGHT_WIDTH
,
712 SCROLLER_ARROW_RIGHT_HEIGHT
, True
);
714 scrPtr
->popUpIndicator
= makePixmap(scrPtr
, POPUP_INDICATOR
,
715 POPUP_INDICATOR_WIDTH
,
716 POPUP_INDICATOR_HEIGHT
, True
);
718 scrPtr
->pullDownIndicator
= makePixmap(scrPtr
, PULLDOWN_INDICATOR
,
719 PULLDOWN_INDICATOR_WIDTH
,
720 PULLDOWN_INDICATOR_HEIGHT
, True
);
722 scrPtr
->checkMark
= makePixmap(scrPtr
, CHECK_MARK
,
724 CHECK_MARK_HEIGHT
, True
);
728 scrPtr
->defaultCursor
= XCreateFontCursor(display
, XC_left_ptr
);
730 scrPtr
->textCursor
= XCreateFontCursor(display
, XC_xterm
);
732 scrPtr
->internalMessage
= XInternAtom(display
, "_WINGS_MESSAGE", False
);
734 scrPtr
->attribsAtom
= XInternAtom(display
, "_GNUSTEP_WM_ATTR", False
);
736 scrPtr
->deleteWindowAtom
= XInternAtom(display
, "WM_DELETE_WINDOW", False
);
738 scrPtr
->protocolsAtom
= XInternAtom(display
, "WM_PROTOCOLS", False
);
740 scrPtr
->clipboardAtom
= XInternAtom(display
, "CLIPBOARD", False
);
742 scrPtr
->rootView
= W_CreateRootView(scrPtr
);
744 W_InitApplication(scrPtr
);
751 WMHangData(WMWidget
*widget
, void *data
)
753 W_VIEW(widget
)->hangedData
= data
;
758 WMGetHangedData(WMWidget
*widget
)
760 return W_VIEW(widget
)->hangedData
;
766 WMDestroyWidget(WMWidget
*widget
)
768 W_DestroyView(W_VIEW(widget
));
773 WMSetFocusToWidget(WMWidget
*widget
)
775 W_SetFocusOfTopLevel(W_TopLevelOfView(W_VIEW(widget
)), W_VIEW(widget
));
781 * Realizes the widget and all it's children.
785 WMRealizeWidget(WMWidget
*w
)
787 W_RealizeView(W_VIEW(w
));
791 WMMapWidget(WMWidget
*w
)
793 W_MapView(W_VIEW(w
));
798 makeChildrenAutomap(W_View
*view
, int flag
)
800 view
= view
->childrenList
;
803 view
->flags
.mapWhenRealized
= flag
;
804 makeChildrenAutomap(view
, flag
);
806 view
= view
->nextSister
;
812 WMMapSubwidgets(WMWidget
*w
)
814 /* make sure that subwidgets created after the parent was realized
816 if (!W_VIEW(w
)->flags
.realized
) {
817 makeChildrenAutomap(W_VIEW(w
), True
);
819 W_MapSubviews(W_VIEW(w
));
825 WMUnmapSubwidgets(WMWidget
*w
)
827 if (!W_VIEW(w
)->flags
.realized
) {
828 makeChildrenAutomap(W_VIEW(w
), False
);
830 W_UnmapSubviews(W_VIEW(w
));
837 WMUnmapWidget(WMWidget
*w
)
839 W_UnmapView(W_VIEW(w
));
844 WMSetWidgetBackgroundColor(WMWidget
*w
, WMColor
*color
)
846 if (W_CLASS(w
) < WC_UserWidget
847 && procedureTables
[W_CLASS(w
)]->setBackgroundColor
) {
849 (*procedureTables
[W_CLASS(w
)]->setBackgroundColor
)(w
, color
);
851 } else if (W_CLASS(w
) >= WC_UserWidget
852 && userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->setBackgroundColor
) {
854 (*userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->setBackgroundColor
)(w
, color
);
857 W_SetViewBackgroundColor(W_VIEW(w
), color
);
863 WMMoveWidget(WMWidget
*w
, int x
, int y
)
865 if (W_CLASS(w
) < WC_UserWidget
866 && procedureTables
[W_CLASS(w
)]->move
) {
868 (*procedureTables
[W_CLASS(w
)]->move
)(w
, x
, y
);
870 } else if (W_CLASS(w
) >= WC_UserWidget
871 && userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->move
) {
873 (*userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->move
)(w
, x
, y
);
876 W_MoveView(W_VIEW(w
), x
, y
);
882 WMResizeWidget(WMWidget
*w
, unsigned int width
, unsigned int height
)
884 if (W_CLASS(w
) < WC_UserWidget
885 && procedureTables
[W_CLASS(w
)]->resize
) {
887 (*procedureTables
[W_CLASS(w
)]->resize
)(w
, width
, height
);
889 } else if (W_CLASS(w
) >= WC_UserWidget
890 && userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->resize
) {
892 (*userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->resize
)(w
, width
, height
);
895 W_ResizeView(W_VIEW(w
), width
, height
);
902 W_RegisterUserWidget(W_ViewProcedureTable
*procTable
)
904 W_ViewProcedureTable
**newTable
;
907 newTable
= wmalloc(sizeof(W_ViewProcedureTable
*)*userWidgetCount
);
908 memcpy(newTable
, userProcedureTable
,
909 sizeof(W_ViewProcedureTable
*)*(userWidgetCount
-1));
911 newTable
[userWidgetCount
-1] = procTable
;
913 free(userProcedureTable
);
915 userProcedureTable
= newTable
;
917 return userWidgetCount
+ WC_UserWidget
- 1;
923 WMScreenRContext(WMScreen
*scr
)
925 return scr
->rcontext
;
931 WMWidgetWidth(WMWidget
*w
)
933 return W_VIEW(w
)->size
.width
;
938 WMWidgetHeight(WMWidget
*w
)
940 return W_VIEW(w
)->size
.height
;
945 WMWidgetXID(WMWidget
*w
)
947 return W_VIEW(w
)->window
;
952 WMWidgetScreen(WMWidget
*w
)
954 return W_VIEW(w
)->screen
;
960 WMScreenMainLoop(WMScreen
*scr
)
965 WMNextEvent(scr
->display
, &event
);
966 WMHandleEvent(&event
);
973 WMScreenDisplay(WMScreen
*scr
)
980 WMScreenDepth(WMScreen
*scr
)
987 WMRedisplayWidget(WMWidget
*w
)
989 W_RedisplayView(W_VIEW(w
));