1999-10-04 15:06:00 -07:00
|
|
|
/*
|
2004-01-19 14:30:35 -08:00
|
|
|
* Copyright (C) 2000-2004 Carsten Haitzler, Geoff Harrison and various contributors
|
2000-04-05 16:22:56 -07:00
|
|
|
*
|
1999-10-04 15:06:00 -07:00
|
|
|
* 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:
|
2000-04-05 16:22:56 -07:00
|
|
|
*
|
1999-10-04 15:06:00 -07:00
|
|
|
* The above copyright notice and this permission notice shall be included in
|
|
|
|
* all copies of the Software, its documentation and marketing & publicity
|
|
|
|
* materials, and acknowledgment shall be given in the documentation, materials
|
|
|
|
* and software packages that this Software was used.
|
2000-04-05 16:22:56 -07:00
|
|
|
*
|
1999-10-04 15:06:00 -07:00
|
|
|
* 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 AUTHORS 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.
|
|
|
|
*/
|
1999-08-17 15:56:46 -07:00
|
|
|
#include "E.h"
|
|
|
|
|
|
|
|
EWin *
|
|
|
|
FindEwinByBase(Window win)
|
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
EWin *const *ewins;
|
1999-08-17 15:56:46 -07:00
|
|
|
int i, num;
|
|
|
|
|
|
|
|
EDBUG(6, "FindEwinByBase");
|
2004-04-01 14:41:22 -08:00
|
|
|
ewins = EwinListGetAll(&num);
|
1999-08-17 15:56:46 -07:00
|
|
|
for (i = 0; i < num; i++)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
if (win == ewins[i]->win)
|
2004-03-26 13:21:47 -08:00
|
|
|
return ewins[i];
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
1999-08-17 15:56:46 -07:00
|
|
|
EDBUG_RETURN(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
EWin *
|
|
|
|
FindEwinByChildren(Window win)
|
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
EWin *const *ewins;
|
1999-08-17 15:56:46 -07:00
|
|
|
int i, j, num;
|
|
|
|
|
|
|
|
EDBUG(6, "FindEwinByChildren");
|
|
|
|
|
2004-04-01 14:41:22 -08:00
|
|
|
ewins = EwinListGetAll(&num);
|
1999-08-17 15:56:46 -07:00
|
|
|
for (i = 0; i < num; i++)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
if ((win == ewins[i]->client.win) || (win == ewins[i]->win_container))
|
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
return ewins[i];
|
2003-05-22 12:15:03 -07:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
for (j = 0; j < ewins[i]->border->num_winparts; j++)
|
|
|
|
if (win == ewins[i]->bits[j].win)
|
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
return ewins[i];
|
2003-05-22 12:15:03 -07:00
|
|
|
}
|
|
|
|
}
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
1999-08-17 15:56:46 -07:00
|
|
|
EDBUG_RETURN(NULL);
|
|
|
|
}
|
|
|
|
|
2003-12-07 01:54:37 -08:00
|
|
|
EWin *
|
|
|
|
FindEwinByPartial(const char *match, int type)
|
|
|
|
{
|
|
|
|
EWin *ewin = NULL;
|
2004-03-26 13:21:47 -08:00
|
|
|
EWin *const *ewins;
|
2003-12-07 01:54:37 -08:00
|
|
|
int i, num, len;
|
|
|
|
char ewinid[FILEPATH_LEN_MAX];
|
|
|
|
|
|
|
|
EDBUG(6, "FindEwinByPartial");
|
|
|
|
|
|
|
|
len = strlen(match);
|
|
|
|
if (len <= 0)
|
2004-03-20 07:49:05 -08:00
|
|
|
goto done;
|
2003-12-07 01:54:37 -08:00
|
|
|
|
2004-04-01 14:41:22 -08:00
|
|
|
ewins = EwinListGetAll(&num);
|
2003-12-07 01:54:37 -08:00
|
|
|
if (ewins == NULL)
|
2004-03-20 07:49:05 -08:00
|
|
|
goto done;
|
2003-12-07 01:54:37 -08:00
|
|
|
|
|
|
|
for (i = 0; i < num; i++)
|
|
|
|
{
|
|
|
|
if (type == '+')
|
|
|
|
{
|
|
|
|
/* Match start of window ID */
|
|
|
|
sprintf(ewinid, "%x", (unsigned)ewins[i]->client.win);
|
|
|
|
if (strncmp(ewinid, match, len))
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
else if (type == '=')
|
|
|
|
{
|
|
|
|
/* Match name (substring) */
|
2004-02-28 17:30:18 -08:00
|
|
|
if (!strstr(ewins[i]->icccm.wm_name, match))
|
2003-12-07 01:54:37 -08:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
else
|
2004-03-20 07:49:05 -08:00
|
|
|
goto done;
|
2003-12-07 01:54:37 -08:00
|
|
|
|
|
|
|
ewin = ewins[i];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2004-03-20 07:49:05 -08:00
|
|
|
done:
|
2003-12-07 01:54:37 -08:00
|
|
|
EDBUG_RETURN(ewin);
|
|
|
|
}
|
|
|
|
|
1999-08-17 15:56:46 -07:00
|
|
|
EWin *
|
|
|
|
FindEwinByDecoration(Window win)
|
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
EWin *const *ewins;
|
1999-08-17 15:56:46 -07:00
|
|
|
int i, j, num;
|
|
|
|
|
|
|
|
EDBUG(6, "FindEwinByDecoration");
|
|
|
|
|
2004-04-01 14:41:22 -08:00
|
|
|
ewins = EwinListGetAll(&num);
|
1999-08-17 15:56:46 -07:00
|
|
|
for (i = 0; i < num; i++)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
for (j = 0; j < ewins[i]->border->num_winparts; j++)
|
|
|
|
{
|
|
|
|
if (win == ewins[i]->bits[j].win)
|
2004-03-26 13:21:47 -08:00
|
|
|
return ewins[i];
|
2003-05-22 12:15:03 -07:00
|
|
|
}
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
2004-03-26 13:21:47 -08:00
|
|
|
|
1999-08-17 15:56:46 -07:00
|
|
|
EDBUG_RETURN(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
ActionClass *
|
|
|
|
FindActionClass(Window win)
|
|
|
|
{
|
|
|
|
Button *b;
|
|
|
|
EWin *ewin;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
EDBUG(6, "FindActionClass");
|
2003-12-07 01:18:55 -08:00
|
|
|
|
1999-08-17 15:56:46 -07:00
|
|
|
b = FindButton(win);
|
|
|
|
if (b)
|
2003-12-07 01:18:55 -08:00
|
|
|
EDBUG_RETURN(ButtonGetAClass(b));
|
|
|
|
|
1999-08-17 15:56:46 -07:00
|
|
|
ewin = FindEwinByDecoration(win);
|
|
|
|
if (ewin)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
for (i = 0; i < ewin->border->num_winparts; i++)
|
|
|
|
if (win == ewin->bits[i].win)
|
|
|
|
EDBUG_RETURN(ewin->border->part[i].aclass);
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
2003-12-07 01:18:55 -08:00
|
|
|
|
2004-03-20 07:49:05 -08:00
|
|
|
for (i = 0; i < Conf.desks.num; i++)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
ActionClass *ac;
|
|
|
|
|
|
|
|
if (win == desks.desk[i].win)
|
|
|
|
{
|
|
|
|
ac = FindItem("DESKBINDINGS", 0, LIST_FINDBY_NAME,
|
|
|
|
LIST_TYPE_ACLASS);
|
|
|
|
EDBUG_RETURN(ac);
|
|
|
|
}
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
2003-12-07 01:18:55 -08:00
|
|
|
|
1999-08-17 15:56:46 -07:00
|
|
|
EDBUG_RETURN(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
EWin *
|
|
|
|
FindEwinByMenu(Menu * m)
|
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
EWin *const *ewins;
|
1999-08-17 15:56:46 -07:00
|
|
|
int i, num;
|
|
|
|
|
|
|
|
EDBUG(6, "FindEwinByMenu");
|
2003-12-14 09:24:34 -08:00
|
|
|
|
2004-04-01 14:41:22 -08:00
|
|
|
ewins = EwinListGetAll(&num);
|
1999-08-17 15:56:46 -07:00
|
|
|
for (i = 0; i < num; i++)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
if (ewins[i]->menu == m)
|
|
|
|
return ewins[i];
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
2003-12-14 09:24:34 -08:00
|
|
|
|
2004-03-26 13:21:47 -08:00
|
|
|
EDBUG_RETURN(NULL);
|
1999-08-17 15:56:46 -07:00
|
|
|
}
|
|
|
|
|
1999-09-08 17:39:43 -07:00
|
|
|
Group **
|
|
|
|
ListWinGroups(EWin * ewin, char group_select, int *num)
|
|
|
|
{
|
|
|
|
Group **groups = NULL;
|
|
|
|
Group **groups2 = NULL;
|
|
|
|
int i, j, killed = 0;
|
|
|
|
|
|
|
|
switch (group_select)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
case GROUP_SELECT_EWIN_ONLY:
|
|
|
|
groups = (Group **) Emalloc(sizeof(Group *) * ewin->num_groups);
|
|
|
|
groups =
|
|
|
|
(Group **) memcpy(groups, ewin->groups,
|
|
|
|
sizeof(Group *) * ewin->num_groups);
|
|
|
|
*num = ewin->num_groups;
|
|
|
|
break;
|
|
|
|
case GROUP_SELECT_ALL_EXCEPT_EWIN:
|
|
|
|
groups2 = (Group **) ListItemType(num, LIST_TYPE_GROUP);
|
|
|
|
if (groups2)
|
|
|
|
{
|
|
|
|
for (i = 0; i < (*num); i++)
|
|
|
|
{
|
|
|
|
for (j = 0; j < ewin->num_groups; j++)
|
|
|
|
{
|
|
|
|
if (ewin->groups[j] == groups2[i])
|
|
|
|
{
|
|
|
|
groups2[i] = NULL;
|
|
|
|
killed++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
groups = (Group **) Emalloc(sizeof(Group *) * (*num - killed));
|
|
|
|
j = 0;
|
|
|
|
for (i = 0; i < (*num); i++)
|
|
|
|
if (groups2[i])
|
|
|
|
groups[j++] = groups2[i];
|
|
|
|
(*num) -= killed;
|
|
|
|
Efree(groups2);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case GROUP_SELECT_ALL:
|
|
|
|
default:
|
|
|
|
groups = (Group **) ListItemType(num, LIST_TYPE_GROUP);
|
|
|
|
break;
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
1999-09-08 17:39:43 -07:00
|
|
|
|
|
|
|
return groups;
|
|
|
|
}
|
|
|
|
|
1999-08-17 15:56:46 -07:00
|
|
|
EWin **
|
1999-09-08 17:39:43 -07:00
|
|
|
ListWinGroupMembersForEwin(EWin * ewin, int action, char nogroup, int *num)
|
1999-08-17 15:56:46 -07:00
|
|
|
{
|
|
|
|
|
|
|
|
EWin **gwins = NULL;
|
1999-09-08 17:39:43 -07:00
|
|
|
int i, j, k, daddy_says_no_no;
|
|
|
|
char inlist;
|
1999-08-17 15:56:46 -07:00
|
|
|
|
|
|
|
if (ewin)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
if (nogroup)
|
|
|
|
{
|
|
|
|
gwins = Emalloc(sizeof(EWin *));
|
|
|
|
gwins[0] = ewin;
|
|
|
|
*num = 1;
|
|
|
|
return gwins;
|
|
|
|
}
|
|
|
|
|
|
|
|
(*num) = 0;
|
|
|
|
|
|
|
|
for (i = 0; i < ewin->num_groups; i++)
|
|
|
|
{
|
|
|
|
daddy_says_no_no = 0;
|
|
|
|
|
|
|
|
switch (action)
|
|
|
|
{
|
|
|
|
case ACTION_SET_WINDOW_BORDER:
|
|
|
|
if (!ewin->groups[i]->cfg.set_border)
|
|
|
|
daddy_says_no_no = 1;
|
|
|
|
break;
|
|
|
|
case ACTION_ICONIFY:
|
|
|
|
if (!ewin->groups[i]->cfg.iconify)
|
|
|
|
daddy_says_no_no = 1;
|
|
|
|
break;
|
|
|
|
case ACTION_MOVE:
|
|
|
|
if (!ewin->groups[i]->cfg.move)
|
|
|
|
daddy_says_no_no = 1;
|
|
|
|
break;
|
|
|
|
case ACTION_RAISE:
|
|
|
|
case ACTION_LOWER:
|
|
|
|
case ACTION_RAISE_LOWER:
|
|
|
|
if (!ewin->groups[i]->cfg.raise)
|
|
|
|
daddy_says_no_no = 1;
|
|
|
|
break;
|
|
|
|
case ACTION_STICK:
|
|
|
|
if (!ewin->groups[i]->cfg.stick)
|
|
|
|
daddy_says_no_no = 1;
|
|
|
|
break;
|
|
|
|
case ACTION_SHADE:
|
|
|
|
if (!ewin->groups[i]->cfg.shade)
|
|
|
|
daddy_says_no_no = 1;
|
|
|
|
break;
|
|
|
|
case ACTION_KILL:
|
|
|
|
if (!ewin->groups[i]->cfg.kill)
|
|
|
|
daddy_says_no_no = 1;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!daddy_says_no_no)
|
|
|
|
{
|
|
|
|
gwins =
|
|
|
|
Erealloc(gwins,
|
|
|
|
sizeof(EWin *) * (*num +
|
|
|
|
ewin->groups[i]->num_members));
|
|
|
|
/* Check if a window is not already in the group */
|
|
|
|
for (k = 0; k < ewin->groups[i]->num_members; k++)
|
|
|
|
{
|
|
|
|
/* To get consistent behaviour, limit groups to a single desktop for now: */
|
|
|
|
if (ewin->groups[i]->members[k]->desktop ==
|
|
|
|
ewin->desktop)
|
|
|
|
{
|
|
|
|
inlist = 0;
|
|
|
|
for (j = 0; j < (*num); j++)
|
|
|
|
{
|
|
|
|
if (gwins[j] == ewin->groups[i]->members[k])
|
|
|
|
inlist = 1;
|
|
|
|
}
|
|
|
|
/* If we do not have this one yet, add it to the result */
|
|
|
|
if (!inlist)
|
|
|
|
gwins[(*num)++] = ewin->groups[i]->members[k];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* and shrink the result to the correct size. */
|
|
|
|
gwins = Erealloc(gwins, sizeof(EWin *) * (*num));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((*num) == 0)
|
|
|
|
{
|
|
|
|
gwins = Emalloc(sizeof(EWin *));
|
|
|
|
gwins[0] = ewin;
|
|
|
|
*num = 1;
|
|
|
|
}
|
|
|
|
EDBUG_RETURN(gwins);
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
1999-08-17 15:56:46 -07:00
|
|
|
else
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
*num = 0;
|
|
|
|
EDBUG_RETURN(NULL);
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
1999-08-17 15:56:46 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
EWin **
|
|
|
|
ListTransientsFor(Window win, int *num)
|
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
EWin *const *ewins, **lst = NULL;
|
1999-08-17 15:56:46 -07:00
|
|
|
int i, j, n;
|
|
|
|
|
|
|
|
EDBUG(6, "ListTransientsFor");
|
|
|
|
|
2004-04-01 14:41:22 -08:00
|
|
|
ewins = EwinListGetAll(&n);
|
1999-08-17 15:56:46 -07:00
|
|
|
j = 0;
|
|
|
|
for (i = 0; i < n; i++)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
if (win == ewins[i]->client.transient_for)
|
|
|
|
{
|
|
|
|
j++;
|
|
|
|
lst = Erealloc(lst, sizeof(EWin *) * j);
|
|
|
|
lst[j - 1] = ewins[i];
|
|
|
|
}
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
1999-08-17 15:56:46 -07:00
|
|
|
*num = j;
|
|
|
|
EDBUG_RETURN(lst);
|
|
|
|
}
|
|
|
|
|
|
|
|
EWin **
|
|
|
|
ListGroupMembers(Window win, int *num)
|
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
EWin *const *ewins, **lst = NULL;
|
1999-08-17 15:56:46 -07:00
|
|
|
int i, j, n;
|
|
|
|
|
|
|
|
EDBUG(6, "ListGroupMembers");
|
|
|
|
|
2004-04-01 14:41:22 -08:00
|
|
|
ewins = EwinListGetAll(&n);
|
1999-08-17 15:56:46 -07:00
|
|
|
j = 0;
|
|
|
|
for (i = 0; i < n; i++)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
if (win == ewins[i]->client.group)
|
|
|
|
{
|
|
|
|
j++;
|
|
|
|
lst = Erealloc(lst, sizeof(EWin *) * j);
|
|
|
|
lst[j - 1] = ewins[i];
|
|
|
|
}
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
1999-08-17 15:56:46 -07:00
|
|
|
*num = j;
|
|
|
|
EDBUG_RETURN(lst);
|
|
|
|
}
|
|
|
|
|
|
|
|
EWin *
|
|
|
|
FindEwinByDialog(Dialog * d)
|
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
EWin *const *ewins;
|
1999-08-17 15:56:46 -07:00
|
|
|
int i, num;
|
|
|
|
|
1999-10-02 13:36:38 -07:00
|
|
|
EDBUG(6, "FindEwinByDialog");
|
2004-03-26 13:21:47 -08:00
|
|
|
|
2004-04-01 14:41:22 -08:00
|
|
|
ewins = EwinListGetAll(&num);
|
1999-08-17 15:56:46 -07:00
|
|
|
for (i = 0; i < num; i++)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
if (ewins[i]->dialog == d)
|
2004-03-26 13:21:47 -08:00
|
|
|
return ewins[i];
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
2004-03-26 13:21:47 -08:00
|
|
|
|
1999-08-17 15:56:46 -07:00
|
|
|
EDBUG_RETURN(NULL);
|
|
|
|
}
|
|
|
|
|
2004-03-07 00:14:24 -08:00
|
|
|
int
|
1999-10-02 13:36:38 -07:00
|
|
|
FindADialog(void)
|
|
|
|
{
|
2004-03-26 13:21:47 -08:00
|
|
|
EWin *const *ewins;
|
2004-03-07 00:14:24 -08:00
|
|
|
int i, num, n;
|
1999-10-02 13:36:38 -07:00
|
|
|
|
|
|
|
EDBUG(6, "FindADialog");
|
2004-03-26 13:21:47 -08:00
|
|
|
|
2004-04-01 14:41:22 -08:00
|
|
|
ewins = EwinListGetAll(&num);
|
2004-03-07 00:14:24 -08:00
|
|
|
for (i = n = 0; i < num; i++)
|
2000-07-26 11:00:47 -07:00
|
|
|
{
|
2003-05-22 12:15:03 -07:00
|
|
|
if (ewins[i]->dialog)
|
2004-03-07 00:14:24 -08:00
|
|
|
n++;
|
2000-07-26 11:00:47 -07:00
|
|
|
}
|
2004-03-26 13:21:47 -08:00
|
|
|
|
2004-03-07 00:14:24 -08:00
|
|
|
EDBUG_RETURN(n);
|
1999-10-02 13:36:38 -07:00
|
|
|
}
|