/*
*Copyright (C) 1994-2000 The XFree86 Project, Inc. All Rights Reserved.
*
*Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
*"Software"), to deal in the Software without restriction, including
*without limitation the rights to use, copy, modify, merge, publish,
*distribute, sublicense, and/or sell copies of the Software, and to
*permit persons to whom the Software is furnished to do so, subject to
*the following conditions:
*
*The above copyright notice and this permission notice shall be
*included in all copies or substantial portions of the Software.
*
*THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
*EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
*MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
*NONINFRINGEMENT. IN NO EVENT SHALL THE XFREE86 PROJECT BE LIABLE FOR
*ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
*CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
*WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*
*Except as contained in this notice, the name of the XFree86 Project
*shall not be used in advertising or otherwise to promote the sale, use
*or other dealings in this Software without prior written authorization
*from the XFree86 Project.
*
* Authors: Earle F. Philhower, III
*/
#ifdef HAVE_XWIN_CONFIG_H
#include <xwin-config.h>
#endif
#include <X11/Xatom.h>
#include "propertyst.h"
#include "windowstr.h"
#include "winmultiwindowclass.h"
#include "win.h"
/*
* Local function
*/
DEFINE_ATOM_HELPER(AtmWmWindowRole, "WM_WINDOW_ROLE")
int
winMultiWindowGetClassHint (WindowPtr pWin, char **res_name, char **res_class)
{
struct _Window *pwin;
struct _Property *prop;
int len_name, len_class;
if (!pWin || !res_name || !res_class)
{
ErrorF ("winMultiWindowGetClassHint - pWin, res_name, or res_class was "
"NULL\n");
return 0;
}
pwin = (struct _Window*) pWin;
if (pwin->optional)
prop = (struct _Property *) pwin->optional->userProps;
else
prop = NULL;
*res_name = *res_class = NULL;
while (prop)
{
if (prop->propertyName == XA_WM_CLASS
&& prop->type == XA_STRING
&& prop->format == 8
&& prop->data)
{
len_name = strlen ((char *) prop->data);
(*res_name) = malloc (len_name + 1);
if (!*res_name)
{
ErrorF ("winMultiWindowGetClassHint - *res_name was NULL\n");
return 0;
}
/* Add one to len_name to allow copying of trailing 0 */
strncpy ((*res_name), prop->data, len_name + 1);
if (len_name == prop->size)
len_name--;
len_class = strlen (((char *)prop->data) + 1 + len_name);
(*res_class) = malloc (len_class + 1);
if (!*res_class)
{
ErrorF ("winMultiWindowGetClassHint - *res_class was NULL\n");
/* Free the previously allocated res_name */
free (*res_name);
return 0;
}
strcpy ((*res_class), ((char *)prop->data) + 1 + len_name);
return 1;
}
else
prop = prop->next;
}
return 0;
}
int
winMultiWindowGetWMHints (WindowPtr pWin, WinXWMHints *hints)
{
struct _Window *pwin;
struct _Property *prop;
if (!pWin || !hints)
{
ErrorF ("winMultiWindowGetWMHints - pWin or hints was NULL\n");
return 0;
}
pwin = (struct _Window*) pWin;
if (pwin->optional)
prop = (struct _Property *) pwin->optional->userProps;
else
prop = NULL;
memset (hints, 0, sizeof (WinXWMHints));
while (prop)
{
if (prop->propertyName == XA_WM_HINTS
&& prop->data)
{
memcpy (hints, prop->data, sizeof (WinXWMHints));
return 1;
}
else
prop = prop->next;
}
return 0;
}
int
winMultiWindowGetWindowRole (WindowPtr pWin, char **res_role)
{
struct _Window *pwin;
struct _Property *prop;
int len_role;
if (!pWin || !res_role)
return 0;
pwin = (struct _Window*) pWin;
if (pwin->optional)
prop = (struct _Property *) pwin->optional->userProps;
else
prop = NULL;
*res_role = NULL;
while (prop)
{
if (prop->propertyName == AtmWmWindowRole ()
&& prop->type == XA_STRING
&& prop->format == 8
&& prop->data)
{
len_role= prop->size;
(*res_role) = malloc (len_role + 1);
if (!*res_role)
{
ErrorF ("winMultiWindowGetWindowRole - *res_role was NULL\n");
return 0;
}
strncpy ((*res_role), prop->data, len_role);
(*res_role)[len_role] = 0;
return 1;
}
else
prop = prop->next;
}
return 0;
}
int
winMultiWindowGetWMNormalHints (WindowPtr pWin, WinXSizeHints *hints)
{
struct _Window *pwin;
struct _Property *prop;
if (!pWin || !hints)
{
ErrorF ("winMultiWindowGetWMNormalHints - pWin or hints was NULL\n");
return 0;
}
pwin = (struct _Window*) pWin;
if (pwin->optional)
prop = (struct _Property *) pwin->optional->userProps;
else
prop = NULL;
memset (hints, 0, sizeof (WinXSizeHints));
while (prop)
{
if (prop->propertyName == XA_WM_NORMAL_HINTS
&& prop->data)
{
memcpy (hints, prop->data, sizeof (WinXSizeHints));
return 1;
}
else
prop = prop->next;
}
return 0;
}
int
winMultiWindowGetTransientFor (WindowPtr pWin, WindowPtr *ppDaddy)
{
struct _Window *pwin;
struct _Property *prop;
if (!pWin)
{
ErrorF ("winMultiWindowGetTransientFor - pWin was NULL\n");
return 0;
}
pwin = (struct _Window*) pWin;
if (pwin->optional)
prop = (struct _Property *) pwin->optional->userProps;
else
prop = NULL;
if (ppDaddy)
*ppDaddy = NULL;
while (prop)
{
if (prop->propertyName == XA_WM_TRANSIENT_FOR)
{
if (ppDaddy)
memcpy (*ppDaddy, prop->data, sizeof (WindowPtr));
return 1;
}
else
prop = prop->next;
}
return 0;
}
int
winMultiWindowGetWMName (WindowPtr pWin, char **wmName)
{
struct _Window *pwin;
struct _Property *prop;
int len_name;
if (!pWin || !wmName)
{
ErrorF ("winMultiWindowGetClassHint - pWin, res_name, or res_class was "
"NULL\n");
return 0;
}
pwin = (struct _Window*) pWin;
if (pwin->optional)
prop = (struct _Property *) pwin->optional->userProps;
else
prop = NULL;
*wmName = NULL;
while (prop)
{
if (prop->propertyName == XA_WM_NAME
&& prop->type == XA_STRING
&& prop->data)
{
len_name = prop->size;
(*wmName) = malloc (len_name + 1);
if (!*wmName)
{
ErrorF ("winMultiWindowGetWMName - *wmName was NULL\n");
return 0;
}
strncpy ((*wmName), prop->data, len_name);
(*wmName)[len_name] = 0;
return 1;
}
else
prop = prop->next;
}
return 0;
}
|