X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fclient.c;h=61df2ad3af7a99fa9dedc8418ae71f4569256165;hb=c0568cd7ef9542540b11068c002bb6a8d35f3d84;hp=c5d1daa67be3516e78f78b833eebb08425f5f356;hpb=bdf1662af23289fd5674252f6caaf63728a186c5;p=chaz%2Fopenbox diff --git a/openbox/client.c b/openbox/client.c index c5d1daa6..61df2ad3 100644 --- a/openbox/client.c +++ b/openbox/client.c @@ -1115,8 +1115,8 @@ void client_update_icons(Client *self) /* store the icons */ i = 0; for (j = 0; j < self->nicons; ++j) { - w = self->icons[j].w = data[i++]; - h = self->icons[j].h = data[i++]; + w = self->icons[j].width = data[i++]; + h = self->icons[j].height = data[i++]; self->icons[j].data = g_memdup(&data[i], w * h * sizeof(gulong)); i += w * h; @@ -1126,11 +1126,6 @@ void client_update_icons(Client *self) g_free(data); } - if (self->nicons <= 0) { - self->nicons = 1; - self->icons = g_new0(Icon, 1); - } - if (self->frame) engine_frame_adjust_icon(self->frame); } @@ -1988,3 +1983,28 @@ void client_set_focused(Client *self, gboolean focused) engine_frame_adjust_focus(self->frame); } + +Icon *client_icon(Client *self, int w, int h) +{ + int i; + /* si is the smallest image >= req */ + /* li is the largest image < req */ + unsigned long size, smallest = 0xffffffff, largest = 0, si = 0, li = 0; + + if (!self->nicons) return NULL; + + for (i = 0; i < self->nicons; ++i) { + size = self->icons[i].width * self->icons[i].height; + if (size < smallest && size >= (unsigned)(w * h)) { + smallest = size; + si = i; + } + if (size > largest && size <= (unsigned)(w * h)) { + largest = size; + li = i; + } + } + if (largest == 0) /* didnt find one smaller than the requested size */ + return &self->icons[si]; + return &self->icons[li]; +}