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
309 extern void W_ReadConfigurations(void);
312 extern W_ViewProcedureTable _WindowViewProcedures
;
313 extern W_ViewProcedureTable _FrameViewProcedures
;
314 extern W_ViewProcedureTable _LabelViewProcedures
;
315 extern W_ViewProcedureTable _ButtonViewProcedures
;
316 extern W_ViewProcedureTable _TextFieldViewProcedures
;
317 extern W_ViewProcedureTable _ScrollerViewProcedures
;
318 extern W_ViewProcedureTable _ScrollViewProcedures
;
319 extern W_ViewProcedureTable _ListViewProcedures
;
320 extern W_ViewProcedureTable _BrowserViewProcedures
;
321 extern W_ViewProcedureTable _PopUpButtonViewProcedures
;
322 extern W_ViewProcedureTable _ColorWellViewProcedures
;
323 extern W_ViewProcedureTable _ScrollViewViewProcedures
;
324 extern W_ViewProcedureTable _SliderViewProcedures
;
325 extern W_ViewProcedureTable _SplitViewViewProcedures
;
326 extern W_ViewProcedureTable _TabViewViewProcedures
;
329 * All widget classes defined must have an entry here.
331 static W_ViewProcedureTable
*procedureTables
[16];
333 static W_ViewProcedureTable
**userProcedureTable
= NULL
;
334 static int userWidgetCount
=0;
337 /***** end data ******/
344 procedureTables
[WC_Window
] = &_WindowViewProcedures
;
345 procedureTables
[WC_Frame
] = &_FrameViewProcedures
;
346 procedureTables
[WC_Label
] = &_LabelViewProcedures
;
347 procedureTables
[WC_Button
] = &_ButtonViewProcedures
;
348 procedureTables
[WC_TextField
] = &_TextFieldViewProcedures
;
349 procedureTables
[WC_Scroller
] = &_ScrollerViewProcedures
;
350 procedureTables
[WC_List
] = &_ListViewProcedures
;
351 procedureTables
[WC_Browser
] = &_BrowserViewProcedures
;
352 procedureTables
[WC_PopUpButton
] = &_PopUpButtonViewProcedures
;
353 procedureTables
[WC_ColorWell
] = &_ColorWellViewProcedures
;
354 procedureTables
[WC_ScrollView
] = &_ScrollViewViewProcedures
;
355 procedureTables
[WC_Slider
] = &_SliderViewProcedures
;
356 procedureTables
[WC_SplitView
] = &_SplitViewViewProcedures
;
357 procedureTables
[WC_TabView
] = &_TabViewViewProcedures
;
362 renderPixmap(W_Screen
*screen
, Pixmap d
, Pixmap mask
, char **data
,
363 int width
, int height
)
366 GC whiteGC
= WMColorGC(screen
->white
);
367 GC blackGC
= WMColorGC(screen
->black
);
368 GC lightGC
= WMColorGC(screen
->gray
);
369 GC darkGC
= WMColorGC(screen
->darkGray
);
373 XSetForeground(screen
->display
, screen
->monoGC
, 0);
375 for (y
= 0; y
< height
; y
++) {
376 for (x
= 0; x
< width
; x
++) {
377 switch (data
[y
][x
]) {
380 XDrawPoint(screen
->display
, d
, whiteGC
, x
, y
);
385 XDrawPoint(screen
->display
, mask
, screen
->monoGC
, x
, y
);
389 XDrawPoint(screen
->display
, d
, lightGC
, x
, y
);
394 XDrawPoint(screen
->display
, d
, darkGC
, x
, y
);
400 XDrawPoint(screen
->display
, d
, blackGC
, x
, y
);
410 makePixmap(W_Screen
*sPtr
, char **data
, int width
, int height
, int masked
)
412 Pixmap pixmap
, mask
= None
;
414 pixmap
= XCreatePixmap(sPtr
->display
, W_DRAWABLE(sPtr
), width
, height
,
418 mask
= XCreatePixmap(sPtr
->display
, W_DRAWABLE(sPtr
), width
, height
, 1);
419 XSetForeground(sPtr
->display
, sPtr
->monoGC
, 1);
420 XFillRectangle(sPtr
->display
, mask
, sPtr
->monoGC
, 0, 0, width
, height
);
423 renderPixmap(sPtr
, pixmap
, mask
, data
, width
, height
);
425 return WMCreatePixmapFromXPixmaps(sPtr
, pixmap
, mask
, width
, height
,
430 #define T_WINGS_IMAGES_FILE RESOURCE_PATH"/Images.tiff"
431 #define T_DEFAULT_OBJECT_ICON_FILE RESOURCE_PATH"/defaultIcon.tiff"
433 #define X_WINGS_IMAGES_FILE RESOURCE_PATH"/Images.xpm"
434 #define X_DEFAULT_OBJECT_ICON_FILE RESOURCE_PATH"/defaultIcon.xpm"
438 loadPixmaps(WMScreen
*scr
)
452 image
= RLoadImage(scr
->rcontext
, T_WINGS_IMAGES_FILE
, 0);
454 image
= RLoadImage(scr
->rcontext
, X_WINGS_IMAGES_FILE
, 0);
456 wwarning("WINGs: could not load widget images file: %s",
457 RMessageForError(RErrorCode
));
461 /* make it have a gray background */
462 tmp
= RGetSubImage(image
, 0, 0, 24, 24);
463 RCombineImageWithColor(tmp
, &gray
);
464 scr
->homeIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
466 /* make it have a white background */
467 tmp
= RGetSubImage(image
, 0, 0, 24, 24);
468 RCombineImageWithColor(tmp
, &white
);
469 scr
->altHomeIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
472 /* Magnifying Glass Icon for ColorPanel */
473 tmp
= RGetSubImage(image
, 24, 0, 40, 32);
474 RCombineImageWithColor(tmp
, &gray
);
475 scr
->magnifyIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
478 tmp = RGetSubImage(image, 24, 0, 40, 32);
479 RCombineImageWithColor(tmp, &white);
480 scr->altMagnifyIcon = WMCreatePixmapFromRImage(scr, tmp, 128);
483 /* ColorWheel Icon for ColorPanel */
484 tmp
= RGetSubImage(image
, 0, 25, 24, 24);
485 scr
->wheelIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
487 /* GrayScale Icon for ColorPanel */
488 tmp
= RGetSubImage(image
, 65, 0, 40, 24);
489 scr
->grayIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
491 /* RGB Icon for ColorPanel */
492 tmp
= RGetSubImage(image
, 25, 33, 40, 24);
493 scr
->rgbIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
495 /* CMYK Icon for ColorPanel */
496 tmp
= RGetSubImage(image
, 65, 25, 40, 24);
497 scr
->cmykIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
499 /* HSB Icon for ColorPanel */
500 tmp
= RGetSubImage(image
, 0, 57, 40, 24);
501 scr
->hsbIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
503 /* CustomColorPalette Icon for ColorPanel */
504 tmp
= RGetSubImage(image
, 81, 57, 40, 24);
505 scr
->customPaletteIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
507 /* ColorList Icon for ColorPanel */
508 tmp
= RGetSubImage(image
, 41, 57, 40, 24);
509 scr
->colorListIcon
= WMCreatePixmapFromRImage(scr
, tmp
, 128);
512 RDestroyImage(image
);
515 scr
->defaultObjectIcon
=
516 WMCreatePixmapFromFile(scr
, T_DEFAULT_OBJECT_ICON_FILE
);
517 if (!scr
->defaultObjectIcon
) {
518 scr
->defaultObjectIcon
=
519 WMCreatePixmapFromFile(scr
, X_DEFAULT_OBJECT_ICON_FILE
);
521 if (!scr
->defaultObjectIcon
) {
522 wwarning("WINGs: could not load default icon file");
532 WMCreateSimpleApplicationScreen(Display
*display
)
536 scr
= WMCreateScreen(display
, DefaultScreen(display
));
538 scr
->aflags
.hasAppIcon
= 0;
539 scr
->aflags
.simpleApplication
= 1;
547 WMCreateScreen(Display
*display
, int screen
)
549 return WMCreateScreenWithRContext(display
, screen
,
550 RCreateContext(display
, screen
, NULL
));
555 WMCreateScreenWithRContext(Display
*display
, int screen
, RContext
*context
)
560 static int initialized
= 0;
566 initProcedureTable();
568 W_ReadConfigurations();
570 assert(W_ApplicationInitialized());
573 scrPtr
= malloc(sizeof(W_Screen
));
576 memset(scrPtr
, 0, sizeof(W_Screen
));
578 scrPtr
->aflags
.hasAppIcon
= 1;
580 scrPtr
->display
= display
;
581 scrPtr
->screen
= screen
;
582 scrPtr
->rcontext
= context
;
584 scrPtr
->depth
= context
->depth
;
586 scrPtr
->visual
= context
->visual
;
587 scrPtr
->lastEventTime
= 0;
589 scrPtr
->colormap
= context
->cmap
;
591 scrPtr
->rootWin
= RootWindow(display
, screen
);
593 scrPtr
->fontCache
= WMCreateHashTable(WMStringPointerHashCallbacks
);
595 /* initially allocate some colors */
596 WMWhiteColor(scrPtr
);
597 WMBlackColor(scrPtr
);
599 WMDarkGrayColor(scrPtr
);
601 gcv
.graphics_exposures
= False
;
603 gcv
.function
= GXxor
;
604 gcv
.foreground
= W_PIXEL(scrPtr
->white
);
605 if (gcv
.foreground
== 0) gcv
.foreground
= 1;
606 scrPtr
->xorGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
), GCFunction
607 |GCGraphicsExposures
|GCForeground
, &gcv
);
609 gcv
.function
= GXxor
;
610 gcv
.foreground
= W_PIXEL(scrPtr
->gray
);
611 gcv
.subwindow_mode
= IncludeInferiors
;
612 scrPtr
->ixorGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
), GCFunction
613 |GCGraphicsExposures
|GCForeground
614 |GCSubwindowMode
, &gcv
);
616 gcv
.function
= GXcopy
;
617 scrPtr
->copyGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
), GCFunction
618 |GCGraphicsExposures
, &gcv
);
620 scrPtr
->clipGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
), GCFunction
621 |GCGraphicsExposures
, &gcv
);
624 stipple
= XCreateBitmapFromData(display
, W_DRAWABLE(scrPtr
),
625 STIPPLE_BITS
, STIPPLE_WIDTH
, STIPPLE_HEIGHT
);
626 gcv
.foreground
= W_PIXEL(scrPtr
->darkGray
);
627 gcv
.background
= W_PIXEL(scrPtr
->gray
);
628 gcv
.fill_style
= FillStippled
;
629 gcv
.stipple
= stipple
;
630 scrPtr
->stippleGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
),
631 GCForeground
|GCBackground
|GCStipple
632 |GCFillStyle
|GCGraphicsExposures
, &gcv
);
634 gcv
.foreground
= W_PIXEL(scrPtr
->black
);
635 gcv
.background
= W_PIXEL(scrPtr
->white
);
636 scrPtr
->textFieldGC
= XCreateGC(display
, W_DRAWABLE(scrPtr
),
637 GCForeground
|GCBackground
, &gcv
);
639 /* we need a 1bpp drawable for the monoGC, so borrow this one */
640 scrPtr
->monoGC
= XCreateGC(display
, stipple
, 0, NULL
);
642 scrPtr
->stipple
= stipple
;
644 scrPtr
->normalFont
= WMSystemFontOfSize(scrPtr
, 12);
646 scrPtr
->boldFont
= WMBoldSystemFontOfSize(scrPtr
, 12);
648 if (!scrPtr
->boldFont
)
649 scrPtr
->boldFont
= scrPtr
->normalFont
;
651 if (!scrPtr
->normalFont
) {
652 wwarning("could not load any fonts. Make sure your font installation"
653 "and locale settings are correct.");
658 scrPtr
->checkButtonImageOn
= makePixmap(scrPtr
, CHECK_BUTTON_ON
,
659 CHECK_BUTTON_ON_WIDTH
,
660 CHECK_BUTTON_ON_HEIGHT
, False
);
662 scrPtr
->checkButtonImageOff
= makePixmap(scrPtr
, CHECK_BUTTON_OFF
,
663 CHECK_BUTTON_OFF_WIDTH
,
664 CHECK_BUTTON_OFF_HEIGHT
, False
);
666 scrPtr
->radioButtonImageOn
= makePixmap(scrPtr
, RADIO_BUTTON_ON
,
667 RADIO_BUTTON_ON_WIDTH
,
668 RADIO_BUTTON_ON_HEIGHT
, False
);
670 scrPtr
->radioButtonImageOff
= makePixmap(scrPtr
, RADIO_BUTTON_OFF
,
671 RADIO_BUTTON_OFF_WIDTH
,
672 RADIO_BUTTON_OFF_HEIGHT
, False
);
674 scrPtr
->buttonArrow
= makePixmap(scrPtr
, BUTTON_ARROW
,
675 BUTTON_ARROW_WIDTH
, BUTTON_ARROW_HEIGHT
,
678 scrPtr
->pushedButtonArrow
= makePixmap(scrPtr
, BUTTON_ARROW2
,
679 BUTTON_ARROW2_WIDTH
, BUTTON_ARROW2_HEIGHT
,
683 scrPtr
->scrollerDimple
= makePixmap(scrPtr
, SCROLLER_DIMPLE
,
684 SCROLLER_DIMPLE_WIDTH
,
685 SCROLLER_DIMPLE_HEIGHT
, False
);
688 scrPtr
->upArrow
= makePixmap(scrPtr
, SCROLLER_ARROW_UP
,
689 SCROLLER_ARROW_UP_WIDTH
,
690 SCROLLER_ARROW_UP_HEIGHT
, True
);
692 scrPtr
->downArrow
= makePixmap(scrPtr
, SCROLLER_ARROW_DOWN
,
693 SCROLLER_ARROW_DOWN_WIDTH
,
694 SCROLLER_ARROW_DOWN_HEIGHT
, True
);
696 scrPtr
->leftArrow
= makePixmap(scrPtr
, SCROLLER_ARROW_LEFT
,
697 SCROLLER_ARROW_LEFT_WIDTH
,
698 SCROLLER_ARROW_LEFT_HEIGHT
, True
);
700 scrPtr
->rightArrow
= makePixmap(scrPtr
, SCROLLER_ARROW_RIGHT
,
701 SCROLLER_ARROW_RIGHT_WIDTH
,
702 SCROLLER_ARROW_RIGHT_HEIGHT
, True
);
704 scrPtr
->hiUpArrow
= makePixmap(scrPtr
, HI_SCROLLER_ARROW_UP
,
705 SCROLLER_ARROW_UP_WIDTH
,
706 SCROLLER_ARROW_UP_HEIGHT
, True
);
708 scrPtr
->hiDownArrow
= makePixmap(scrPtr
, HI_SCROLLER_ARROW_DOWN
,
709 SCROLLER_ARROW_DOWN_WIDTH
,
710 SCROLLER_ARROW_DOWN_HEIGHT
, True
);
712 scrPtr
->hiLeftArrow
= makePixmap(scrPtr
, HI_SCROLLER_ARROW_LEFT
,
713 SCROLLER_ARROW_LEFT_WIDTH
,
714 SCROLLER_ARROW_LEFT_HEIGHT
, True
);
716 scrPtr
->hiRightArrow
= makePixmap(scrPtr
, HI_SCROLLER_ARROW_RIGHT
,
717 SCROLLER_ARROW_RIGHT_WIDTH
,
718 SCROLLER_ARROW_RIGHT_HEIGHT
, True
);
720 scrPtr
->popUpIndicator
= makePixmap(scrPtr
, POPUP_INDICATOR
,
721 POPUP_INDICATOR_WIDTH
,
722 POPUP_INDICATOR_HEIGHT
, True
);
724 scrPtr
->pullDownIndicator
= makePixmap(scrPtr
, PULLDOWN_INDICATOR
,
725 PULLDOWN_INDICATOR_WIDTH
,
726 PULLDOWN_INDICATOR_HEIGHT
, True
);
728 scrPtr
->checkMark
= makePixmap(scrPtr
, CHECK_MARK
,
730 CHECK_MARK_HEIGHT
, True
);
734 scrPtr
->defaultCursor
= XCreateFontCursor(display
, XC_left_ptr
);
736 scrPtr
->textCursor
= XCreateFontCursor(display
, XC_xterm
);
742 blank
= XCreatePixmap(display
, scrPtr
->stipple
, 1, 1, 1);
743 XSetForeground(display
, scrPtr
->monoGC
, 0);
744 XFillRectangle(display
, blank
, scrPtr
->monoGC
, 0, 0, 1, 1);
746 scrPtr
->invisibleCursor
= XCreatePixmapCursor(display
, blank
, blank
,
748 XFreePixmap(display
, blank
);
751 scrPtr
->internalMessage
= XInternAtom(display
, "_WINGS_MESSAGE", False
);
753 scrPtr
->attribsAtom
= XInternAtom(display
, "_GNUSTEP_WM_ATTR", False
);
755 scrPtr
->deleteWindowAtom
= XInternAtom(display
, "WM_DELETE_WINDOW", False
);
757 scrPtr
->protocolsAtom
= XInternAtom(display
, "WM_PROTOCOLS", False
);
759 scrPtr
->clipboardAtom
= XInternAtom(display
, "CLIPBOARD", False
);
761 scrPtr
->rootView
= W_CreateRootView(scrPtr
);
764 scrPtr
->balloon
= W_CreateBalloon(scrPtr
);
767 W_InitApplication(scrPtr
);
774 WMHangData(WMWidget
*widget
, void *data
)
776 W_VIEW(widget
)->hangedData
= data
;
781 WMGetHangedData(WMWidget
*widget
)
783 return W_VIEW(widget
)->hangedData
;
789 WMDestroyWidget(WMWidget
*widget
)
791 W_DestroyView(W_VIEW(widget
));
796 WMSetFocusToWidget(WMWidget
*widget
)
798 W_SetFocusOfTopLevel(W_TopLevelOfView(W_VIEW(widget
)), W_VIEW(widget
));
804 * Realizes the widget and all it's children.
808 WMRealizeWidget(WMWidget
*w
)
810 W_RealizeView(W_VIEW(w
));
814 WMMapWidget(WMWidget
*w
)
816 W_MapView(W_VIEW(w
));
821 makeChildrenAutomap(W_View
*view
, int flag
)
823 view
= view
->childrenList
;
826 view
->flags
.mapWhenRealized
= flag
;
827 makeChildrenAutomap(view
, flag
);
829 view
= view
->nextSister
;
835 WMMapSubwidgets(WMWidget
*w
)
837 /* make sure that subwidgets created after the parent was realized
839 if (!W_VIEW(w
)->flags
.realized
) {
840 makeChildrenAutomap(W_VIEW(w
), True
);
842 W_MapSubviews(W_VIEW(w
));
848 WMUnmapSubwidgets(WMWidget
*w
)
850 if (!W_VIEW(w
)->flags
.realized
) {
851 makeChildrenAutomap(W_VIEW(w
), False
);
853 W_UnmapSubviews(W_VIEW(w
));
860 WMUnmapWidget(WMWidget
*w
)
862 W_UnmapView(W_VIEW(w
));
867 WMSetWidgetBackgroundColor(WMWidget
*w
, WMColor
*color
)
869 if (W_CLASS(w
) < WC_UserWidget
870 && procedureTables
[W_CLASS(w
)]->setBackgroundColor
) {
872 (*procedureTables
[W_CLASS(w
)]->setBackgroundColor
)(w
, color
);
874 } else if (W_CLASS(w
) >= WC_UserWidget
875 && userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->setBackgroundColor
) {
877 (*userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->setBackgroundColor
)(w
, color
);
880 W_SetViewBackgroundColor(W_VIEW(w
), color
);
886 WMMoveWidget(WMWidget
*w
, int x
, int y
)
888 if (W_CLASS(w
) < WC_UserWidget
889 && procedureTables
[W_CLASS(w
)]->move
) {
891 (*procedureTables
[W_CLASS(w
)]->move
)(w
, x
, y
);
893 } else if (W_CLASS(w
) >= WC_UserWidget
894 && userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->move
) {
896 (*userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->move
)(w
, x
, y
);
899 W_MoveView(W_VIEW(w
), x
, y
);
905 WMResizeWidget(WMWidget
*w
, unsigned int width
, unsigned int height
)
907 if (W_CLASS(w
) < WC_UserWidget
908 && procedureTables
[W_CLASS(w
)]->resize
) {
910 (*procedureTables
[W_CLASS(w
)]->resize
)(w
, width
, height
);
912 } else if (W_CLASS(w
) >= WC_UserWidget
913 && userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->resize
) {
915 (*userProcedureTable
[W_CLASS(w
)-WC_UserWidget
]->resize
)(w
, width
, height
);
918 W_ResizeView(W_VIEW(w
), width
, height
);
925 W_RegisterUserWidget(W_ViewProcedureTable
*procTable
)
927 W_ViewProcedureTable
**newTable
;
930 newTable
= wmalloc(sizeof(W_ViewProcedureTable
*)*userWidgetCount
);
931 memcpy(newTable
, userProcedureTable
,
932 sizeof(W_ViewProcedureTable
*)*(userWidgetCount
-1));
934 newTable
[userWidgetCount
-1] = procTable
;
936 free(userProcedureTable
);
938 userProcedureTable
= newTable
;
940 return userWidgetCount
+ WC_UserWidget
- 1;
946 WMScreenRContext(WMScreen
*scr
)
948 return scr
->rcontext
;
954 WMWidgetWidth(WMWidget
*w
)
956 return W_VIEW(w
)->size
.width
;
961 WMWidgetHeight(WMWidget
*w
)
963 return W_VIEW(w
)->size
.height
;
968 WMWidgetXID(WMWidget
*w
)
970 return W_VIEW(w
)->window
;
975 WMWidgetScreen(WMWidget
*w
)
977 return W_VIEW(w
)->screen
;
983 WMScreenMainLoop(WMScreen
*scr
)
988 WMNextEvent(scr
->display
, &event
);
989 WMHandleEvent(&event
);
996 WMScreenDisplay(WMScreen
*scr
)
1003 WMScreenDepth(WMScreen
*scr
)
1010 WMRedisplayWidget(WMWidget
*w
)
1012 W_RedisplayView(W_VIEW(w
));