--- rxvt-unicode/src/rxvtimg.C 2012/06/07 08:45:34 1.36 +++ rxvt-unicode/src/rxvtimg.C 2012/06/07 10:19:23 1.39 @@ -418,17 +418,20 @@ rxvt_img * rxvt_img::sub_rect (int x, int y, int width, int height) { - bool need_reify = w < width || h < height; - rxvt_img *img = clone (); img->x += x; img->y += y; - img->w = width; - img->h = height; - if (need_reify) - img->reify (); + if (w != width || h != height) + { + img->w = width; + img->h = height; + + rxvt_img *img2 = img->reify (); + delete img; + img = img2; + } return img; } @@ -528,7 +531,7 @@ { rxvt_img *img2 = clone (); Display *dpy = s->display->dpy; - Picture src = src_picture (); + Picture src = img->src_picture (); Picture dst = XRenderCreatePicture (dpy, img2->pm, img2->format, 0, 0); Picture mask = create_xrender_mask (dpy, img->pm, False);