File: Screen.c

package info (click to toggle)
gridengine 6.2-4
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 51,532 kB
  • ctags: 51,172
  • sloc: ansic: 418,155; java: 37,080; sh: 22,593; jsp: 7,699; makefile: 5,292; csh: 4,244; xml: 2,901; cpp: 2,086; perl: 1,895; tcl: 1,188; lisp: 669; ruby: 642; yacc: 393; lex: 266
file content (98 lines) | stat: -rw-r--r-- 2,587 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/* 
 * Motif Tools Library, Version 3.1
 * $Id$
 * 
 * Written by David Flanagan.
 * Copyright (c) 1992-2001 by David Flanagan.
 * All Rights Reserved.  See the file COPYRIGHT for details.
 * This is open source software.  See the file LICENSE for details.
 * There is no warranty for this software.  See NO_WARRANTY for details.
 *
 * $Log$
 * Revision 1.1.1.1  2001/07/18 11:06:03  root
 * Initial checkin.
 *
 * Revision 1.2  2001/06/12 16:25:28  andre
 * *** empty log message ***
 *
 *
 */

#include <Xmt/Xmt.h>
#include <Xmt/ScreenP.h>
#include <Xmt/AppResP.h>
#include <Xmt/Hash.h>
#include <X11/IntrinsicP.h>


/* ARGSUSED */
#if NeedFunctionPrototypes
static void DestroyCallback(Widget w, XtPointer tag, XtPointer data)
#else
static void DestroyCallback(w, tag, data)
Widget w;
XtPointer tag;
XtPointer data;
#endif
{
    XmtPerScreenInfo *info = (XmtPerScreenInfo *)tag;
    XmtAppResources *app = XmtGetApplicationResources(w);

    /* remove the info structure from the per-screen hash table */
    XmtHashTableDelete(app->screen_table, (XtPointer)XtScreen(w));

    /*
     * Free array of dialogs.
     * The dialogs themselves will be destroyed by whatever destroyed
     * the shell.
     */
    XtFree((char *)info->help_dialog_cache.dialogs);

    /* free the info structure itself */
    XtFree((char *)info);
}

/*
 * We cache dialogs by appshell and by screen.
 * XXX a 2D hashtable would be nice here, so we don't do a double lookup.
 */
#if NeedFunctionPrototypes
XmtPerScreenInfo *XmtGetPerScreenInfo(Widget w)
#else
XmtPerScreenInfo *XmtGetPerScreenInfo(w)
Widget w;
#endif
{
    XmtAppResources *app = XmtGetApplicationResources(w);
    XmtPerScreenInfo *info;
    Screen *screen = XtScreenOfObject(w);
    Widget shell;
    Boolean status;

    status = XmtHashTableLookup(app->screen_table,
				(XtPointer) screen,
				(XtPointer *) &info);

    if (!status) {
	info = (XmtPerScreenInfo *) XtCalloc(1, sizeof(XmtPerScreenInfo));
	/*
	 * the info->topmost_shell field is the highest level shell on this
	 * screen within the widget hierarchy.  It might be the root shell or
	 * it might not be.  I assert that the algorithm below always yields
	 * a shell widget, but it doesn't really matter.
	 */
	for(shell=NULL; w; shell = w, w = XtParent(w)) {
	    if (!XtIsWidget(w)) continue;
	    if (w->core.screen != screen) break;
	}

	info->topmost_shell = shell;
	XtAddCallback(shell, XtNdestroyCallback,
		      DestroyCallback, (XtPointer) info);
	XmtHashTableStore(app->screen_table,
			  (XtPointer) screen,
			  (XtPointer) info);
    }

    return info;
}