… | |
… | |
791 | if (option (Opt_scrollBar)) |
791 | if (option (Opt_scrollBar)) |
792 | scrollBar.state = SB_STATE_IDLE; /* set existence for size calculations */ |
792 | scrollBar.state = SB_STATE_IDLE; /* set existence for size calculations */ |
793 | |
793 | |
794 | pty = ptytty::create (); |
794 | pty = ptytty::create (); |
795 | |
795 | |
796 | #ifdef HAVE_AFTERIMAGE |
|
|
797 | set_application_name ((char *)rs[Rs_name]); |
|
|
798 | set_output_threshold (OUTPUT_LEVEL_WARNING); |
|
|
799 | #endif |
|
|
800 | |
|
|
801 | // must be called before create_windows, because the latter may call set_icon |
796 | // must be called before create_windows, because the latter may call set_icon |
802 | #ifdef HAVE_PIXBUF |
797 | #ifdef HAVE_PIXBUF |
803 | g_type_init (); |
798 | g_type_init (); |
804 | #endif |
799 | #endif |
805 | |
800 | |
… | |
… | |
835 | |
830 | |
836 | bg_set_root_pixmap (); |
831 | bg_set_root_pixmap (); |
837 | XSelectInput (dpy, display->root, PropertyChangeMask); |
832 | XSelectInput (dpy, display->root, PropertyChangeMask); |
838 | rootwin_ev.start (display, display->root); |
833 | rootwin_ev.start (display, display->root); |
839 | } |
834 | } |
840 | #endif |
|
|
841 | |
|
|
842 | #ifdef BG_IMAGE_FROM_FILE |
|
|
843 | if (rs[Rs_backgroundPixmap]) |
|
|
844 | if (bg_set_file (rs[Rs_backgroundPixmap])) |
|
|
845 | if (!bg_window_position_sensitive ()) |
|
|
846 | update_background (); |
|
|
847 | #endif |
835 | #endif |
848 | } |
836 | } |
849 | #endif |
837 | #endif |
850 | |
838 | |
851 | #if ENABLE_PERL |
839 | #if ENABLE_PERL |
… | |
… | |
1294 | } |
1282 | } |
1295 | |
1283 | |
1296 | void |
1284 | void |
1297 | rxvt_term::set_icon (const char *file) |
1285 | rxvt_term::set_icon (const char *file) |
1298 | { |
1286 | { |
1299 | #ifdef HAVE_AFTERIMAGE |
|
|
1300 | init_asv (); |
|
|
1301 | |
|
|
1302 | ASImage *im = file2ASImage (file, 0xFFFFFFFF, SCREEN_GAMMA, 0, NULL); |
|
|
1303 | if (!im) |
|
|
1304 | { |
|
|
1305 | rxvt_warn ("Loading image icon failed, continuing without.\n"); |
|
|
1306 | return; |
|
|
1307 | } |
|
|
1308 | |
|
|
1309 | unsigned int w = im->width; |
|
|
1310 | unsigned int h = im->height; |
|
|
1311 | |
|
|
1312 | if (!IN_RANGE_INC (w, 1, 16383) || !IN_RANGE_INC (h, 1, 16383)) |
|
|
1313 | { |
|
|
1314 | rxvt_warn ("Icon image too big, continuing without.\n"); |
|
|
1315 | destroy_asimage (&im); |
|
|
1316 | return; |
|
|
1317 | } |
|
|
1318 | |
|
|
1319 | ASImage *result = scale_asimage (asv, im, |
|
|
1320 | w, h, ASA_ARGB32, |
|
|
1321 | 100, ASIMAGE_QUALITY_DEFAULT); |
|
|
1322 | destroy_asimage (&im); |
|
|
1323 | |
|
|
1324 | if (!result) |
|
|
1325 | { |
|
|
1326 | rxvt_warn ("Icon image transformation to ARGB failed, continuing without.\n"); |
|
|
1327 | return; |
|
|
1328 | } |
|
|
1329 | |
|
|
1330 | long *buffer = (long *)malloc ((2 + w * h) * sizeof (long)); |
|
|
1331 | if (buffer) |
|
|
1332 | { |
|
|
1333 | ARGB32 *asbuf = result->alt.argb32; |
|
|
1334 | buffer [0] = w; |
|
|
1335 | buffer [1] = h; |
|
|
1336 | |
|
|
1337 | for (unsigned int i = 0; i < w * h; ++i) |
|
|
1338 | buffer [i + 2] = asbuf [i]; |
|
|
1339 | |
|
|
1340 | XChangeProperty (dpy, parent, xa[XA_NET_WM_ICON], XA_CARDINAL, 32, |
|
|
1341 | PropModeReplace, (const unsigned char *) buffer, 2 + w * h); |
|
|
1342 | free (buffer); |
|
|
1343 | } |
|
|
1344 | else |
|
|
1345 | rxvt_warn ("Memory allocation for icon hint failed, continuing without.\n"); |
|
|
1346 | |
|
|
1347 | destroy_asimage (&result); |
|
|
1348 | #endif |
|
|
1349 | |
|
|
1350 | #ifdef HAVE_PIXBUF |
1287 | #ifdef HAVE_PIXBUF |
1351 | GdkPixbuf *pixbuf = gdk_pixbuf_new_from_file (file, NULL); |
1288 | GdkPixbuf *pixbuf = gdk_pixbuf_new_from_file (file, NULL); |
1352 | if (!pixbuf) |
1289 | if (!pixbuf) |
1353 | { |
1290 | { |
1354 | rxvt_warn ("Loading image icon failed, continuing without.\n"); |
1291 | rxvt_warn ("Loading image icon failed, continuing without.\n"); |