diff options
author | Matthias Clasen <mclasen@redhat.com> | 2010-06-26 01:06:30 -0400 |
---|---|---|
committer | Matthias Clasen <mclasen@redhat.com> | 2010-06-26 01:09:05 -0400 |
commit | 16ecf558321030a12795cdd0b67ebbdc198d5c43 (patch) | |
tree | c3c4ff539366a54230e56861c7f0ac740ba326f5 /gdk-pixbuf | |
parent | d722adb76abce67984f24a98433c245d86674b5c (diff) | |
download | gtk+-16ecf558321030a12795cdd0b67ebbdc198d5c43.tar.gz |
Make GTK+ use an external gdk-pixbuf
Diffstat (limited to 'gdk-pixbuf')
89 files changed, 0 insertions, 42819 deletions
diff --git a/gdk-pixbuf/ChangeLog b/gdk-pixbuf/ChangeLog deleted file mode 100644 index d8431db13a..0000000000 --- a/gdk-pixbuf/ChangeLog +++ /dev/null @@ -1,6289 +0,0 @@ -=== ChangeLog discontinued === - - With the move to git, GTK+ is switching from a ChangeLog file - to relying on commit messages to provide change history. Please - see README.commits for guidance on the expected message format. - -2009-03-13 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.16.0 === - -2009-03-02 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.15.5 === - -2009-03-01 Matthias Clasen <mclasen@redhat.com> - - Bug 569671 – gdk_pixbuf_new_from_file() can't open - image/x-portable-pixmap - - * gdk-pixbuf-io.c (_gdk_pixbuf_get_module): If pure sniffing - yields uncertain results, try again with the filename. - Patch by Tyler Lawson - -2009-02-17 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.15.4 === - -2009-02-02 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.15.3 === - -2009-01-27 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.15.2 === - -2009-01-23 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.15.1 === - -2009-01-19 Tor Lillqvist <tml@iki.fi> - - Bug 568305 - gdk-pixbuf mishandles BI_BITFIELDS bmps - - * io-bmp.c (OneLine32): Use unsigned variables so that we can - right-shift them without risk of sign extension. Don't "reverse" - the alpha value, actually storing 0xFF-alpha, but use it as such. - -2009-01-12 Tor Lillqvist <tml@iki.fi> - - Bug 164002 - query scripts don't work uninstalled on windows - - * queryloaders.c (main): Use the configure-time PIXBUF_LIBDIR if - the exe is located in a .libs folder, i.e. run in the build - directory through a libtool wrapper script or wrapper executable, - or in the source folder itself. Otherwise continue to infer the - runtime prefix from the exe's location. - -2009-01-12 Tor Lillqvist <tml@iki.fi> - - * queryloaders.c (main): Remove the Win9x code path. It had been - left by mistake. Win9x code is gone from the rest of GTK+ since - 2.12. - -2009-01-07 Matthias Clasen <mclasen@redhat.com> - - Bug 566862 – pixbuf_new_from_file does not autodetect format - - * gdk-pixbuf-io.c (_gdk_pixbuf_get_module): Go back to sniffing - without looking at the filename, to avoid breaking expected - functionality. - -2009-01-01 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.15.0 === - -2008-11-30 Christian Dywan <christian@imendio.com> - - Bug 561186 – GdkPixbuf API type checking needs cleanup - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_write), - (gdk_pixbuf_loader_get_pixbuf), (gdk_pixbuf_loader_get_animation), - (gdk_pixbuf_loader_close), (gdk_pixbuf_loader_get_format): - * gdk-pixbuf-scale.c (gdk_pixbuf_scale), (gdk_pixbuf_composite), - (gdk_pixbuf_composite_color), (gdk_pixbuf_scale_simple), - (gdk_pixbuf_composite_color_simple): - * gdk-pixbuf-simple-anim.c (gdk_pixbuf_simple_anim_add_frame): - * gdk-pixbuf-util.c (gdk_pixbuf_add_alpha), - (gdk_pixbuf_apply_embedded_orientation): - Improve type checking in pixbuf API - -2008-10-13 Matthias Clasen <mclasen@redhat.com> - - Bug 555791 – Natuilus Crashes when opening USB MP3 Player Contents - - * io-tga.c (gdk_pixbuf__tga_stop_load): Don't segfault on - short files. - Problem reported by Pedro Villavicencio - -2008-10-01 Tor Lillqvist <tml@novell.com> - - * io-icns.c: Don't #define _GNU_SOURCE on Windows as it confuses - newest mingw headers. - -2008-09-23 13:28:23 Tim Janik <timj@imendio.com> - - * gdk-pixdata.c: prevent RLE encoding of 1x1 pixel images, since the - encoder comparison operator requires at least 2 pixels, fixes #553374: - Bug 553374 - gdk_pixdata_from_pixbuf fails for some images with use_rle set to TRUE - -2008-09-19 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c: Don't call fill_info if we've already filled - the info from the module file, fixes a small memory leak. - -2008-09-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * io-gdip-utils.c: Fix 2 cases where we leaked a GpImage (#552545) - -2008-09-17 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.14.2 === - -2008-09-13 Tor Lillqvist <tml@novell.com> - - * gdk-pixbuf-io.c: Don't use the deprectated - g_win32_get_package_installation_subdirectory(). Use - g_win32_get_package_installation_directory_of_module() - instead. Also, don't use the deprecated silly - G_WIN32_DLLMAIN_FOR_DLL_NAME() macro, but an explicit minimal - DllMain() that just saves the DLL handle. - -2008-09-07 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_io_init): Plug a small memory - leak in an error path. - -2008-09-06 Matthias Clasen <mclasen@redhat.com> - - Bug 517233 – Calling gdk_pixbuf_loader_close causes "GError set over - the top of a previous GError" warning - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_close): Don't overwrite - errors. Reported by Andrey Tsyvarev - -2008-09-05 Sebastien Bacher <seb128@ubuntu.com> - - * gdk-pixbuf-io.c: (gdk_pixbuf_load_module_unlocked): - bug 550969 - fix a typo which breaks the static build - -2008-09-04 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.14.1 === - -2008-09-04 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c: Fix a deadlock introduced in the previous - commit. - - * gdk-pixbuf-loader.c: Fix the race condition here, too. - -2008-09-04 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.14.0 === - -2008-09-03 Matthias Clasen <mclasen@redhat.com> - - Bug 549711 – Race condition when loading gdk-pixbuf image modules - - * gdk-pixbuf-io.c: Fix a race condition in module loading, - spotted by Chris Lord. - -2008-08-27 Matthias Clasen <mclasen@redhat.com> - - Bug 549322 – Typo in gdk_pixbuf_save_to_buffer docs - - * gdk-pixbuf-io.c (gdk_pixbuf_save_to_buffer): Fix the docs. - Spotted by Cosimo Cecchi. - -2008-08-18 Matthias Clasen <mclasen@redhat.com> - - * ==== Released 2.13.7 === - -2008-08-13 Matthias Clasen <mclasen@redhat.com> - - Bug 532644 – TIFF loader need to exclude CR2 files - - * io-tiff.c: Add a pattern to exclude CR2 files. - Noticed by Hubert Figuire - -2008-08-13 Michael Natterer <mitch@imendio.com> - - * gdk-pixbuf-marshal.list: reorder marshalers for no reason apart - from forcing a rebuild of the header after yesterday's Makefile.am - change. - -2008-08-08 Sven Herzberg <sven@imendio.com> - - Bug 546549 : Better Type Checking - reviewed by: mitch - - * gdk-pixbuf-animation.c: check if a vfunc is implemented before - trying to call into it - -2008-08-06 Sven Herzberg <sven@imendio.com> - - Bug 546549 : Better Type Checking - reviewed by mitch - - * gdk-pixbuf.c (gdk_pixbuf_copy), (gdk_pixbuf_get_colorspace), - (gdk_pixbuf_get_n_channels), (gdk_pixbuf_get_has_alpha), - (gdk_pixbuf_get_bits_per_sample), (gdk_pixbuf_get_pixels), - (gdk_pixbuf_get_width), (gdk_pixbuf_get_height), - (gdk_pixbuf_get_rowstride): use GDK_IS_PIXBUF() and not pixbuf != NULL - in g_return_*() statements - -2008-08-05 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.13.6 === - -2008-08-04 Tor Lillqvist <tml@novell.com> - - * Makefile.am: Pass appropriate -machine flag to lib.exe. - -2008-07-23 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c (_gdk_pixbuf_get_module): Compare two content - types, not content type and mime type. - -2008-07-21 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.13.5 === - -2008-07-18 Federico Mena Quintero <federico@novell.com> - - * queryloaders.c (query_module): Don't do funny casts to avoid - compiler warnings. - -2008-07-15 Matthias Clasen <mclasen@redhat.com> - - Bug 543085 – gdk_pixbuf_saturate_and_pixelate may corrupt memory - - * gdk-pixbuf-utils.c (gdk_pixbuf_saturate_and_pixelate): - Use gdk_pixbuf_copy_area() to copy between pixbufs. - Reported by Andrey Tsyvarev - -2008-07-15 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c: Move the check for wheter to use - GIO for sniffing to configure. - -2008-07-14 Matthias Clasen <mclasen@redhat.com> - - Bug 401985 – Documentation improvement for the - gdk_pixbuf_new_from_file_at_scale() function - - * gdk-pixbuf-io.c: Improve docs for gdk_pixbuf_new_from_file_at_scale(). - Proposed by Juan Manuel Palacios - -2008-07-11 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c: Use GIO for sniffing image types, except - on Win32, where GIO doesn't do any sniffing. - -2008-07-05 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.13.4 === - -2008-06-18 Matthias Clasen <mclasen@redhat.com> - - * io-ico.c: Add image/x-win-bitmap to the supported mimetypes, - since that is what shared-mime-info uses for .cur - -2008-06-13 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.13.3 === - -2008-06-13 Hans Breuer <hans@breuer.org> - - * makefile.msc : updated to allow simple switch between gdiplus- and - former fileformat backends - * io-tiff.c : use g_snprintf - -2008-06-13 Matthias Clasen <mclasen@redhat.com> - - Bug 531960 – crash in eog-image.c:1154: (priv->image != NULL) - - * io-ico.c: Check headers more thorougly. - Patch by Felix Riemann - -2008-06-03 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.13.2 === - -2008-06-02 Behdad Esfahbod <behdad@gnome.org> - - * Makefile.am: Add gdk-pixbuf-features.h to BUILT_SOURCES. - -2008-05-29 Matthias Clasen <mclasen@redhat.com> - - * io-jasper.c: - * io-ico.c: - * io-icns.c: Use the correct INCLUDE_ macros. - -2008-05-29 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.13.1 === - -2008-05-29 Matthias Clasen <mclasen@redhat.com> - - Bug 535453 - gdk_pixbuf_format_get_license returns NULL for - any of the loaders - - * queryloaders.c (write_loader_info): Add the license info - after the description. - - * gdk-pixbuf-io.c (gdk_pixbuf_io_init): Read the license info - from the module file. Reported by Andrey Tsyvarev. - -2008-05-28 Michael Natterer <mitch@imendio.com> - - * gdk-pixbuf.h: define GDK_PIXBUF_H_INSIDE around including all - other headers. - - * gdk-pixbuf-animation.h - * gdk-pixbuf-core.h - * gdk-pixbuf-enum-types.h.template - * gdk-pixbuf-features.h.in - * gdk-pixbuf-io.h - * gdk-pixbuf-loader.h - * gdk-pixbuf-simple-anim.h - * gdk-pixbuf-transform.h: add single-include guards that #error - out if GDK_PIXBUF_DISABLE_SINGLE_INCLUDES is defined and any of - these files is included individually. - - * gdk-pixbuf-private.h: don't incude "gdk-pixbuf-io.h". - - * gdk-pixbuf-csource.c: #define __GTK_H_INSIDE__ around including - "../gtk/gtkversion.h". Ugly but needed in this special case. - -2008-05-27 Tor Lillqvist <tml@novell.com> - - * io-*.c: Use explicit G_MODULE_EXPORT decoration when building - the loader in question as a module. - - * gdk-pixbuf-io.c: Enable included build of the icns and jasper - loaders. - -2008-05-27 Michael Natterer <mitch@imendio.com> - - * gdk-pixbuf.c: put back the #define, but call it - GDK_PIXBUF_C_COMPILATION. - - * gdk-pixbuf-features.h.in: make variable export depend on that - define instead of GDK_PIXBUF_COMPILATION. - -2008-05-27 Michael Natterer <mitch@imendio.com> - - Fix and simplify definition of GDK_PIXBUF_VAR: - - * Makefile.am: add -DGDK_PIXBUF_COMPILATION to INCLUDES. - - * gdk-pixbuf.c: don't #define it here. Remove GDK_PIXBUF_VAR from - the definition of the version variables. - - * gdk-pixbuf-features.h.in: in the !G_PLATFORM_WIN32 case, always - define GDK_PIXBUF_VAR to "extern". Remove redundant #ifndef - GDK_PIXBUF_VAR around the whole block, the header itself already - has include guards. - -2008-05-12 Tor Lillqvist <tml@novell.com> - - Bug 532558 - Cannot build dll when using separate builddir - - * Makefile.am: .def file belongs in $(srcdir). Patch by Marko - Lindqvist. - -2008-05-02 Michael Natterer <mitch@imendio.com> - - * Makefile.am (stamp-gdk-pixbuf-marshal.h): deprecate the entire - gdk-pixbuf-marshal.h since it's installed by accident only and - shouldn't be used by anybody. - -2008-03-21 Tor Lillqvist <tml@novell.com> - - Import the GDI+ gdk-pixbuf loaders for Windows by Dominic - Lachowicz and Alberto Ruiz into the GTK+ tree, from the - gdip-pixbuf-loader module. - - * Makefile.am: Add the bits and pieces for the GDI+ loaders. When - building GDI+ loaders don't build the traditional ones for the - same formats. Always build the traditional PNG loader, though, as - it isn't possible to read and write PNG tEXt chunks through GDI+, - and GIMP at least needs that functionality in the gdk-pixbuf PNG - loader. - - Either build all the GDI+ loaders (except the PNG one) into - libgdk-pixbuf, or build them all as DLLs. I don't see any reason - to enable cherry-picking among them whether to build in or not. - - * io-gdip-animation.c - * io-gdip-animation.h - * io-gdip-bmp.c - * io-gdip-emf.c - * io-gdip-gif.c - * io-gdip-ico.c - * io-gdip-jpeg.c - * io-gdip-native.h - * io-gdip-png.c - * io-gdip-propertytags.h - * io-gdip-tiff.c - * io-gdip-utils.c - * io-gdip-utils.h - * io-gdip-wmf.c: New files. Note that io-gdip-png.c is not - currently used. - - * gdk-pixbuf-io.c: Add the bits and pieces for built-in GDI+ - loaders. - - == ChangeLog from gdip-pixbuf-loaders follows: == - -2008-03-19 Tor Lillqvist <tml@novell.com> - - * src/io-gdip-utils.c: Drop misleading old comment. - - * src/io-gdip-native.h: Fix typo: s/WINGDIAPI/WINGDIPAPI/. - -2008-03-17 Tor Lillqvist <tml@novell.com> - - * src/io-gdip-utils.h (MODULE_ENTRY): Use the more descriptive - INCLUDE_gdiplus instead of INCLUDE_gdi. (Will be used when this is - moved to GTK+ and the gdip loaders are built-in in libgdk-pixbuf.) - Use G_MODULE_EXPORT so that only fill_info and fill_vtable get - exported in the separate loader DLLs case. - - * src/io-gdip-emf.c - * src/io-gdip-ico.c - * src/io-gdip-wmf.c: Use unique type parameters to MODULE_ENTRY so - that we won't get clashes when building all the gdip loaders in to - libgdk-pixbuf. - -2008-03-17 Tor Lillqvist <tml@novell.com> - - * src/Makefile.am: Remove libpixbufloader-gdip.la, and add missing - loaders to loader_LTLIBRARIES. Set loaderdir to use proper GTK+ - binary version using pkg-config. Add final newline. - -2008-03-15 Dominic Lachowicz <domlachowicz@gmail.com> - - * io-gdip.c: Remove - * io-gdip-ico.c: - * io-gdip-wmf.c: - * io-gdip-emf.c: Separate these into their own loaders, so that existing - code that calls "gdk_pixbuf_loader_for_type()" and friends continues - to work as expected. - * Makefile.test: - * Makefile.am: Reflect the above changes - * io-gdip-native.h: - * io-gdip-utils.c: Better error reporting; handle metafiles properly - (loading them as bitmaps doesn't work; you have to load them as a - generic image or metafile and then draw them onto a bitmap) - -2008-03-06 Alberto Ruiz <aruiz@gnome.org> - - * configure.ac: Use the .exe version of the gdk query loaders if the build - is for a windows target. - -2008-03-04 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip-utils.c: More informative error codes, taken from the COM HRESULT - -2008-03-03 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip-native.h: - * src/io-gdip-jpeg.c: Support setting the JPEG's quality, just like GdkPixbuf's - built-in JPEG encoder - * src/io-gdip-png.c: Support setting the PNG's compression level, just like - GdkPixbuf's built-in PNG encoder - -2008-02-25 Tor Lillqvist <tml@novell.com> - - * configure.ac: Move AC_DISABLE_STATIC before AC_PROG_LIBTOOL so - that it works better. - -2008-02-24 Dom Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip-animation.[ch]: Animation class and interator - * src/io-gdip-utils.c: Use animation iter. GDI+ animations now work. - -2008-02-24 Dom Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip-utils.c: Simple animation working; need to use a more sophisticated - animation class - -2008-02-24 Dom Lachowicz <domlachowicz@gmail.com> - - * src/*.c: Change to GTK+-style indentation; stub out some stuff - for animation support - -2008-02-22 Dom Lachowicz <domlachowicz@gmail.com> - - * src/Makefile.am: Build those other libraries using automake too; - track dependencies properly - -2008-02-22 Dom Lachowicz <domlachowicz@gmail.com> - - * src/*.[ch]: Separate out formats that are writable into their - own plugins. The GDI+ loader can now save as BMP, GIF, JPEG, PNG, - or TIFF. Also, some tweaks so that the format plugins can be - statically compiled into GTK+ if we choose to do so. - -2008-02-22 Dom Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip-utils.c (GetEncoderClsid): Add support for BMP, - JPEG, GIF, and TIFF - -2008-02-22 Dom Lachowicz <domlachowicz@gmail.com> - - * src/*.[ch]: Saving images to PNG now works. Conditionally compiled - until I get GdkPixbuf's saving architecture straightened out. - -2008-02-21 Dom Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip-utils.c (io_gdip_init): Make this idempotent - * src/io-gdip.c: Function that fills the GdkPixbufIO vtable. To be used across - various GDI+-based plugins - -2008-02-21 Dom Lachowicz <domlachowicz@gmail.com> - - * src/*.[ch]: If you #define GDIP_TEST_SAVING, you should be able - to save a pixbuf to a PNG via GDI+. WARNING: UNTESTED CODE - -2008-02-21 Dom Lachowicz <domlachowicz@gmail.com> - - * src/*.[ch]: Infrastructure for saving GdkPixbufs to GdkPixbufSaveFunc callbacks. - Should be trivial to write a PNG or JPEG saver now. - -2008-02-20 Tor Lillqvist <tml@novell.com> - - * src/io-gdip-utils.c: Drop the wrapper functions that each call - GetProcAddress(). Instead just use a bunch of function pointers - and initialise them at the same time in io_gdip_init(). - -2008-02-19 Dom Lachowicz <domlachowicz@gmail.com> - - * src/*.[ch]: ARGB isn't pre-multiplied; first stab @ metadata - -2008-02-19 Tor Lillqvist <tml@novell.com> - - * src/io-gdip.c - * src/io-gdip-utils.c - * src/test.c: Use spaces instead of tabs. Use 2-column indentation - offset which was the original intent. Remove trailing whitespace. - -2008-02-19 Tor Lillqvist <tml@novell.com> - - * configure.ac: Use AC_DISABLE_STATIC. It makes no sense to build - a static library of this. - - * autogen.sh: Take ACLOCAL_FLAGS into consideration. - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/*.[ch]: Fix image size (don't need to add + 1); framework - for supporting animations or multi- paged TIFFs - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/*.[ch]: If the source image doesn't have alpha, don't create - an opaque alpha channel in the pixbuf - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/*.c: Whitespace fixes - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip.c: Support pixbuf scaling - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip.c: Fill pixbuf properly; propegate errors. Plugin - now works for non-animations - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip.c: Move initialization to fill_vtable - * src/io-gdip-utils.c: GDI+ functions return Status, not HRESULT, - so we can't use SUCCEEDED() to test if they worked or not - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip.c (gdk_pixbuf__gdip_image_stop_load): Un-premultiply alpha - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip.c (gdk_pixbuf__gdip_image_stop_load): Destroy the - context - * src/io-gdip.c (fill_info): Add support for PNG, GIF, WMF, EMF, TIFF - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip-utils.c (io_gdip_buffer_to_bitmap): Release the IStream - * src/io-gdip.c: Move the init() call to fill_vtable, so that it's - only called once - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip-utils.c: Make GDI+ function pointers static so that - we only load them once - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/test.c: Dispose of the bitmap - * src/io-gdip-utils.[ch]: Add bitmap dispose function - -2008-02-18 Dominic Lachowicz <domlachowicz@gmail.com> - - * src/io-gdip-native.h: The GpImage and GpBitmap structs should be anonymous - - == End of ChangeLog from gdip-pixbuf-loaders == - -2008-03-11 Claudio Saavedra <csaavedra@alumnos.utalca.cl> - - * io-bmp.c: (gdk_pixbuf__bmp_image_stop_load): Set a - GDK_ERROR_CORRUPT_IMAGE error if the loader is closed while - still reading the headers. (#505085) - -2008-03-11 Claudio Saavedra <csaavedra@alumnos.utalca.cl> - - * io-bmp.c: (DecodeHeader): Check for the BMP header magic numbers - before decoding it. (#505085) - -2008-02-16 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.13.0 === - -2008-02-15 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-animation.h: - * gdk-pixbuf.symbols: Fix up export of gdk_pixbuf_non_anim_get_type. - -2008-02-12 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c (at_scale_size_prepared_cb): Don't let - the width or height go below 1. (#516024, Christian Persch) - -2008-02-10 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-scaled-anim.c: Try harder to return pixbufs - of the requested size. (#494515, Mike Morrison) - -2008-01-15 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c (save_to_stream): Handle partial writes. - -2008-01-16 Michael Natterer <mitch@imendio.com> - - * gdk-pixbuf-io.c (save_to_stream): fix signature of this function - and propagate errors from g_output_stream_write(). Return error - also on incomplete writes (which don't generate an error by - themselves). - - Unrelated: - - (gdk_pixbuf_io_init): initialize "builtin_module" on a separate - line to avoid compiler warning in the common case of no built-in - modules. - -2008-01-16 Michael Natterer <mitch@imendio.com> - - * Makefile.am (LDADDS): use $GDK_PIXBUF_DEP_LIBS instead of - $GLIB_LIBS so gio gets pulled in. - -2008-01-15 Matthias Clasen <mclasne@redhat.com> - - * gdk-pixbuf.symbols: - * gdk-pixbuf-core.h: - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_stream): - (gdk_pixbuf_new_from_stream_at_scale): - (gdk_pixbuf_save_to_stream): New stream i/o functions. - -2008-01-14 Michael Natterer <mitch@imendio.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_prepare): cast the return - value of _gdk_pixbuf_scaled_anim_new() to fix incompatible pointer - warning. - -2007-12-09 Matthias Clasen <mclasen@redhat.com> - - * io-jpeg.c: Fix the spinguard logic for big buffers. - (#494667, Ed Catmur) - -2007-11-25 Tor Lillqvist <tml@novell.com> - - * Makefile.am: Fix static build of the icns loader. - -2007-11-25 Bastien Nocera <hadess@hadess.net> - - * Makefile.am: - * io-jasper.c: Add the libjasper JPEG2000 loader - (Closes: #469901) - -2007-11-20 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-animation.c: Use G_DEFINE_TYPE (#469341, - Björn Lindqvist) - -2007-11-20 Bastien Nocera <hadess@hadess.net> - - * io-icns.c: (load_resources): Add support for 512x512 Leopard - icons, using the ic09 iconType - -2007-11-20 Bastien Nocera <hadess@hadess.net> - - * Makefile.am: - * io-icns.c: Add icns (MacOS X icons) loader, based on work by - Lyonel Vincent <lyonel@ezix.org> (Closes: #395738) - -2007-11-10 Matthias Clasen <mclasen@redhat.com> - - * io-jpeg.c: Avoid unaligned accesses that cause - problems on some architectures. (patch by David Miller) - -2007-10-16 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.12.1 === - -2007-10-16 Matthias Clasen <mclasen@redhat.com> - - * io-wbmp.c: Use better magic. (#339877, Bastien Nocera) - -2007-09-13 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.12.0 === - -2007-09-13 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-scaled-anim.c (get_scaled_pixbuf): Don't leak - options. - -2007-09-08 Matthias Clasen <mclasen@redhat.com> - - * io-ani.c: Fix some possible crashes. (#468832, Michal Luczaj) - -2007-09-07 Matthias Clasen <mclasen@redhat.com> - - * io-tga.c (gdk_pixbuf__tga_stop_load): Handle pbuf - being NULL. (#468801, Sebastien Bacher) - -2007-07-21 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.11.6 === - -Sat Jul 7 17:34:33 2007 Tim Janik <timj@gtk.org> - - * gdk-pixbuf-scale.c: docu fixes from Guillaume Cottenceau, #454596. - -2007-07-06 Michael J. Chudobiak <mjc@cvs.gnome.org> - - * io-tiff.c: (tiff_image_parse): Added a comment to explain - the signal used to stop parsing early. - -2007-07-05 Matthias Clasen <mclasen@redhat.com> - - * io-tiff.c: Revert the last change, it was wrong - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_close): Redo the last - change in a different way. - -2007-07-04 Tor Lillqvist <tml@novell.com> - - * pixops/Makefile.am (timescale_LDADD): Use GDK_PIXBUF_DEP_LIBS - instead of GDK_PIXBUF_EXTRA_LIBS here, too. - -2007-07-03 Matthias Clasen <mclasen@redhat.com> - - * io-tiff.c (tiff_image_parse): Always set an error - when returning NULL. (453365, Michael Chudobiak) - -2007-07-03 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_close): Be - more careful when calling g_propagate_error(). (#453365, - Michael Chudobiak) - -2007-07-02 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.11.5 === - -2007-07-02 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf.c (gdk_pixbuf_get_option): Document the - "orientation" option. - - * gdk-pixbuf.symbols: - * gdk-pixbuf-core.h: - * gdk-pixbuf-util.c (gdk_pixbuf_apply_embedded_orientation): - New function to handle Exif orientation information in - tiff and jpeg images. (#439567, Michael Chudobiak) - -2007-06-19 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.11.4 === - -2007-06-15 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.11.3 === - -2007-06-15 Hans Breuer <hans@breuer.org> - - * makefile.msc : updated - * io-jpeg.c : use g_snprintf - -2007-06-12 Behdad Esfahbod <behdad@gnome.org> - - * io-pnm.c (explode_bitmap_into_buf): Fix out-of-bound access. - (#440918, Matthias Kilian) - -2007-06-06 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.11.2 === - -2007-06-04 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.11.1 === - -2007-05-30 Chris Wilson <chris@chris-wilson.co.uk> - - * io-jpeg.c (gdk_pixbuf__jpeg_image_stop_load): - Supply the current GError for fatal_error_handler(). (#441443) - -2007-05-24 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.11.0 === - -2007-05-23 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf.symbols: Add missing scaled-anim entries. - -2007-05-18 Michael J. Chudobiak <mjc@cvs.gnome.org> - - * gdk-pixbuf-scaled-anim.c: (get_scaled_pixbuf): - Preserve pixbuf options when generating a new scaled pixbuf. - - * io-jpeg.c: (get_orientation), (gdk_pixbuf__jpeg_image_load), - (gdk_pixbuf__jpeg_image_load_increment): Read the exif - orientation tag and associate it with the "orientation" pixbuf - option. Renders libexif unnecessary in some applications. - - * io-tiff.c: (tiff_image_parse): Read the tiff orientation tag, - compensate for the partial rotations performed by libtiff, - and generate an "orientation" option for the pixbuf. - -2007-04-29 Matthias Clasen <mclasen@redhat.com> - - * io-jpeg.c: Remove a pointless check from the previous - commit that added a new string. - -2007-04-28 Matthias Clasen <mclasen@redhat.com> - - * io-png.c: - * io-jpeg.c: Accept unknown parameters with a warning - when saving. (#405539, Daniel Atallah) - -2007-04-25 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-simple-anim.c (gdk_pixbuf_simple_anim_add_frame): - Don't double the delay time of the first frame. (#431997, - Bj?rn Lindqvist) - -2007-04-25 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-scaled-anim.c (gdk_pixbuf_scaled_anim_iter_finalize): - Chain up. (#433125, Christian Persch) - -Wed Mar 28 15:27:35 2007 Tim Janik <timj@imendio.com> - - * io-jpeg.c: applied JPEG loader fix from maemo. this fix makes sure - stop_load() doesn't forget about its return value, and it pulls the - check for infinite looping out of an else branch in load_increment() - so it runs unconditionally, fixes #397643. - -2007-03-08 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-scaled-anim.[hc]: Implement an animation - wrapper for scaling animations. - - * gdk-pixbuf-loader.c: Use GdkPixbufScaledAnim to scale - animations. (#335752, Mike Morrison) - - * Makefile.am: Glue. - -2007-03-06 Tor Lillqvist <tml@novell.com> - - * Makefile.am: Further fixes for building on Win32 outside - srcdir. (#413492, Mathias Hasselmann) - -2007-03-05 Matthias Clasen <mclasen@redhat.com> - - * io-tga.c: (gdk_pixbuf__tga_stop_load): Flip rle-encoded - images even if they haven't been completely loaded. (#347106) - -2007-02-27 Felix Riemann <friemann@svn.gnome.org> - - * io-ico.c: (fill_info): Add image/x-ico to supported mime types. - Fixes bug #393599. - -2007-02-16 Matthias Clasen <mclasen@redhat.com> - - * io-png.c: Don't leak in the error path. (#405539, Daniel Atallah) - -2007-02-07 Chris Wilson <chris@chris-wilson.co.uk> - - * io-jpeg.c: (gdk_pixbuf__jpeg_image_load), - (gdk_pixbuf__jpeg_image_load_increment): Set the GError - if the image is zero length. (#405327) - -2007-02-06 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_close): Protect - against stop_load begin broken. (#403255, Lucas Mazzardo Veloso) - -2007-01-21 Matthias Clasen <mclasen@redhat.com> - - * io-gif.c (gdk_pixbuf__gif_image_stop_load): Return an - error if we didn't successfully load a frame. (#394190, - Felix Riemann) - -2007-01-17 Michael Natterer <mitch@imendio.com> - - Patch taken from maemo-gtk: - - * io-png.c (png_text_to_pixbuf_option): don't call g_convert() on - ASCII strings. - - (png_info_callback): set an error when the size_func would scale - the pixbuf away completely. - -2007-01-16 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_write): Just - call gdk_pixbuf_loader_close to close the loader in - the error case. Fixes memory leaks in the error case, - pointed out by David Necas. - -2007-01-04 Matthias Clasen <mclasen@redhat.com> - - * io-bmp.c (OneLine32): Fix a warning - -2006-12-22 Matthias Clasen <mclasen@redhat.com> - - * io-bmp.c (decode_bitmasks): Handle bmps - with more than 8 bits per channel. (#172584, - David Costanzo) - - * io-bmp.c: Handle offsets more carefully. (#172188, - David Costanzo) - - * io-bmp.c: Handle v5 and OS/2 v2 bmps. - - * io-bmp.c: Handle alpha masks in v4 and v5 bmps. - -2006-12-21 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_write): Emit - the closed signal when closing the loader, pointed out - by David Necas. - -2006-12-21 Matthias Clasen <mclasen@redhat.com> - - * io-gif.c (gif_get_lzw): Handle invalid gif animations - a little bit more robustly. (#357974, Vassilis Pandis, - patch by Felix Riemann) - - * gdk-pixbuf-data.c (gdk_pixbuf_new_from_data): - * gdk-pixbuf.c (gdk_pixbuf_new): Remove redundant size - checks, and document that width, height must be > 0. - (#343330, Felix Riemann) - - * Makefile.am: Link against GLib. (#341158, Alexey Rusakov) - -2006-12-19 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_close): Don't - spew a warning if the printer is already closed. - -2006-12-09 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_write): Behave as - documented and close the loader when returning FALSE. - -2006-10-29 Tor Lillqvist <tml@novell.com> - - * pixbufloader_*.def - * Makefile.am (EXTRA_DIST): Remove pixbufloader_*.def, they are - not used. (#365388) They were all identical, and exported just two - symbols, so if somebody needs them for a MSVC build that doesn't - use built-in modules it's trivial to hack makefile.msc to produce - a common .def file for the loaders. The two symbols that need to - be exported are fill_info and fill_vtable. - -2006-10-11 Tor Lillqvist <tml@novell.com> - - Enable having some loaders built-in even if loading the others - dynamically. Have loaders in the same order as in configure.in in - all places where they are handled/listed. - - * Makefile.am: Define the STATIC_FOO_LIB and FOO_LIB macros - conditionally depending on whether said loader is built-in or - not. Use the names libstatic-pixbufloader-foo.la instead of - libpixbufloader-static-foo.la for the built-in ones so that the - "echo libpixbufloader-*.la" won't match them. - - * gdk-pixbuf-io.c: Reorganize code as to plumb the built-in - loaders also if USE_GMODULE. Don't warn about a missing - gdk-pixbuf.loaders file if we have at least one included loader. - - * gdk-pixbuf-private.h - * io-*.c: Don't define a generic MODULE_ENTRY, as we can't use it - in the loaders anyway. Each loader needs to check if INCLUDE_foo - is defined. - -2006-10-08 Matthias Clasen <mclasen@redhat.com> - - * Apply a cleanup patch by Kjartan Maraas (#341812) - -2006-09-06 Matthias Clasen <mclasen@redhat.com> - - * io-pnm.c: Simplify and fix reading of ASCII images. - -2006-08-17 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.10.2 === - -2006-08-16 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_file_at_scale): - Stop loading an animation if the first frame is complete. - (#350911, Christian Neumair) - -2006-07-23 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.10.1 === - -2006-07-16 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_load_module) - (gdk_pixbuf_loader_write, gdk_pixbuf_loader_close) - (gdk_pixbuf_loader_ensure_error): Put the code to protect - against broken loaders that forget to set error in an - auxiliary function and call it in more places. (#346428, - Catmur) - - * io-xbm.c: Fix incremental loading of - xbms. (#346427, Ed Catmur) - Also make the xbm loader accept const variations. - -2006-07-02 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.10.0 === - -2006-06-21 Matthias Clasen <mclasen@redhat.com> - - * pixops/*.S: NetBSD portability fixes. (#346374, - Thomas Klausner) - - * === Released 2.9.4 === - -2006-06-12 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.9.3 === - -2006-06-05 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.9.2 === - -2006-05-16 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.9.1 ==== - -2006-05-04 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.9.0 === - -2006-04-04 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c: - * gdk-pixbuf.c: Use G_DEFINE_TYPE. - - * gdk-pixbuf.c: No point in making the error path fast by - caching quarks. - -2006-03-24 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_write): Remove a - pointless check, pointed out by Kjartan Maraas. - -2006-03-22 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c: Add some documentation about - supported image formats, and how to find out about them. - (#335536, Murray Cumming) - -2006-03-20 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-animation.c: - * gdk-pixbuf-io.c: - * io-xpm.c: - * io-xbm.c: - * io-gif.c: Always save errno to a temporary before making - other calls. (#335179, Morten Welinder) - -2006-03-14 Matthias Clasen <mclasen@redhat.com> - - * io-gif.c (gdk_pixbuf__gif_image_load): Add a shortcut - to stop the gif mainloop after the first frame, if that - is all we are interested in. (#334538) - -2006-03-03 Matthias Clasen <mclasen@redhat.com> - - * io-pnm.c: Support pnm files with maxval > 255. - (#327560, Matthijs Douze) - -2006-03-03 Matthias Clasen <mclasen@redhat.com> - - * io-pcx.c (pcx_load_palette_8): Fix incremental loading - of 8-bit pcx files. (#148518, Magnus Bergmann) - -2006-02-28 Anders Carlsson <andersca@imendio.com> - - * gdk-pixbuf-io.c: - Update documentation now that tiff supports saving. - - * io-tiff.c: - (tiff_load_read): - (tiff_load_write): - (tiff_load_seek): - (tiff_load_close): - (tiff_load_size): - (tiff_load_map_file): - (tiff_load_unmap_file): - (gdk_pixbuf__tiff_image_stop_load): - Rename callback functions that are used during loading. - - (tiff_save_read): - (tiff_save_write): - (tiff_save_seek): - (tiff_save_close): - (tiff_save_size): - (create_save_context): - (free_save_context): - New callback functions which operate on a memory buffer. - - (gdk_pixbuf__tiff_image_save_to_callback): - Implement saving of pixbufs to tiffs. - - (save_to_file_cb): - (gdk_pixbuf__tiff_image_save): - New function that saves a pixbuf to a FILE handle. Uses - save_to_callback. - - (fill_vtable): - Add new functions. - - (fill_info): - Change flags since this module supports writing now. - -2006-02-10 Matthias Clasen <mclasen@redhat.com> - - * io-jpeg.c: - * io-png.c: - * io-pnm.c: - * io-tiff.c: - * io-xbm.c: - * io-xpm.c: Always check for NULL when using callbacks. - (#330563, Benjamin Otte) - -2006-01-18 Matthias Clasen <mclasen@redhat.com> - - * io-gif.c (gdk_pixbuf__gif_image_load_increment): Don't cast - the results of g_new(). (#327423, Morten Welinder) - -2006-01-12 Federico Mena Quintero <federico@ximian.com> - - * gdk-pixbuf-util.c (gdk_pixbuf_saturate_and_pixelate): Clarify - the docs ("darkened/brightened" is not "saturation"). - -Fri Dec 30 00:59:21 2005 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_format_get_license): minor doc edit. - -2005-12-16 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c (_gdk_pixbuf_load_module_unlocked): Use - G_MODULE_BIND_LOCAL when opening modules. - -2005-12-14 Michael Natterer <mitch@imendio.com> - - * io-jpeg.c (gdk_pixbuf__jpeg_image_load_lines): new utility - function which factors out massive code duplication from the - commit below. - -2005-12-14 Michael Natterer <mitch@imendio.com> - - * io-jpeg.c: applied patch from maemo-gtk which avoids the - allocation of an intermediate buffer for non-progressive - jpegs. Fixed bug #305894. - -2005-11-15 Matthias Clasen <mclasen@redhat.com> - - * io-xpm.c: Fix several integer overflows which have been - reported as CVE-2005-3186 and CVE-2005-2975. - -2005-10-12 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_write): Only call - gdk_pixbuf_loader_eat_header_write() when count > 0. (#318589, - Bogdan Nicula) - -2005-10-03 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_new_from_file): - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_file): - * gdk-pixbuf-loader.c: Use a 1k buffer for sniffing image formats, - instead of 128 or 256 bytes. (#317225, Sebastien Bacher, - Dom Lachowicz) - -2005-09-05 Matthias Clasen <mclasen@redhat.com> - - * io-tga.c (parse_rle_data): Remove unused variable - pbuf_count. (#315282, Kjartan Maraas) - -2005-08-31 Matthias Clasen <mclasen@redhat.com> - - * Makefile.am (gdk-pixbuf-enum-types.c): Intern type - names in code generated by glib-mkenums, too. - - * io-ani-animation.c (gdk_pixbuf_ani_anim_iter_get_type) - (gdk_pixbuf_ani_anim_get_type): - * io-gif-animation.c (gdk_pixbuf_gif_anim_get_type) - (gdk_pixbuf_gif_anim_iter_get_type): - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_get_type): - * gdk-pixbuf.c (gdk_pixbuf_get_type): - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_get_type): - Intern type names before registering the type to avoid - unnecessary copies. - -2005-08-30 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c (format_check): Make this work again. - - * io-png.c (png_save_to_callback_write_func): Add a cast - to avoid compiler warnings. - - * pixops/timescale.c (main): Declare src_buf, dest_buf as - unsigned to avoid compiler warnings. - - * gdk-pixbuf-io.h: Declare the prefix and mask members of - GdkPixbufModulePattern as char*, to avoid compiler warnings. - - * io-ani.c (ani_load_chunk): Use g_try_new() in some places. - -2005-08-24 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.8.2 === - - * === Released 2.8.1 === - -2005-08-18 Matthias Clasen <mclasen@redhat.com> - - * io-ico.c (DecodeHeader): Check for overflow in one more - place. (#313818, Tommi Komulainen) - -2005-08-15 Matthias Clasen <mclasen@redhat.com> - - * io-jpeg.c (fatal_error_handler): Pay attention to the - libjpeg error code and report OOM errors as such. (#312674, - Tommi Komulainen) - -2005-08-13 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.8.0 === - -2005-08-07 Matthias Clasen <mclasen@redhat.com> - - * abicheck.sh: Also check exported variables. - -2005-08-02 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.7.5 === - -2005-07-22 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.7.4 === - -2005-07-22 Matthias Clasen <mclasen@redhat.com> - - * queryloaders.c: Accept '*' in masks. (pointed out - by William Jon McCann) - - * gdk-pixbuf-io.c (format_check): Make anchored patterns work - as they did before. (#311011, William Jon McCann) - -2005-07-22 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c (format_check): Interpret patterns where - the first byte of the mask is '*' as unanchored. (#311011) - (gdk_pixbuf_new_from_file): Use the first 256 bytes for - sniffing the file format. - -2005-07-15 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.7.3 === - -2005-07-12 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-i18n.h: - * pixops/*: Add copyright and license information. - -2005-07-09 Tor Lillqvist <tml@novell.com> - - * Makefile.am: Don't use the scripts in build/win32 to compile the - rc file into a resource object file. (This means we lose the - build number increment magic, but I doubt it was that useful - anyway.) Instead use windres directly. To pass the normal .o file - produced by windres through libtool, which would want a .lo file, - pass it directly to the linker using a -Wl option. - - * gdk_pixbuf.rc.in: Replace BUILDNUMBER with 0. - -2005-07-08 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.7.2 === - -2005-07-01 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.7.1 === - -2005-07-01 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_file_at_scale): Allow - -1 for width/height and interpret them as "not constrained". - (#309258, Mark McLoughlin) - -2005-06-26 Tor Lillqvist <tml@novell.com> - - * Makefile.am: Current GNU tools do understand the PRIVATE - keyword, so no need to remove those entries from the import - library. libtool installs the .dll.a import library itself, so no - need to do it here. Do install the .def file. - -2005-06-22 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-i18n.h: Use glib-i18n.h - -2005-06-20 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.7.0 === - -2005-06-15 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf.symbols: - * gdk-pixbuf-simple-anim.h: Add - gdk_pixbuf_simple_anim_iter_get_type() - -2005-06-08 Matthias Clasen <mclasen@redhat.com> - - * io-pnm.c (pnm_read_next_value): Check for overflow. - (#306394, Morten Welinder) - -2005-05-27 Matthias Clasen <mclasen@redhat.com> - - * io-bmp.c: Accept the 108 byte header of BMP v4. (#168799) - -2005-05-25 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf.symbols: - * gdk-pixbuf-simple-anim.[hc]: No need to expose the iter - subclass at all in the headers. - - * Makefile.am: Add new files. - - * gdk-pixbuf.symbols: Add new api. - - * gdk-pixbuf.h: Include gdk-pixbuf-simple-anim.h here. - - * gdk-pixbuf-simple-anim.[hc]: Add a way to construct - simple animations out of pixbufs. (#135161, Dom Lachowicz) - -2005-05-24 Sven Neumann <sven@gimp.org> - - * io-png.c: allow to specify the PNG compression level by passing - a "compression" parameter to the PNG save function (bug #305337). - - * gdk-pixbuf-io.c (gdk_pixbuf_save): document the new parameter. - -2005-04-09 Matthias Clasen <mclasen@redhat.com> - - * Makefile.am: Use $(NM), not nm directly. (#301299, - Nguyen Thai Ngoc Duy) - - * io-bmp.c (gdk_pixbuf__bmp_image_save_to_callback): - Don't overflow the stack. (Jakub Jelinek, Arjan van de Ven) - -2005-04-08 Matthias Clasen <mclasen@redhat.com> - - * io-pcx.c: No debugging output, please. (#173107, - John Ellis) - -2005-04-07 Matthias Clasen <mclasen@redhat.com> - - * io-bmp.c (DecodeColormap): Initialize the colormap to - zero. (#171762, David Costanzo) - -2005-03-30 Matthias Clasen <mclasen@redhat.com> - - * io-bmp.c: Avoid bus errors due to unaligned access. (#168173, - Morten Welinder, Ivan Wong) - -2005-03-29 Matthias Clasen <mclasen@redhat.com> - - * io-tga.c (parse_rle_data): Fix the update areas for incremental - loading of compressed tgas. (#171883, David Costanzo) - -2005-03-27 Matthias Clasen <mclasen@redhat.com> - - * io-bmp.c (DoCompressed): Use the correct update regions for - compressed bmps. (#150664, Owen Taylor, test images provided - by David Costanzo) - -Sun Mar 27 19:59:52 2005 Manish Singh <yosh@gimp.org> - - * io-bmp.c (grow_buffer): reject 0-sized buffers as corrupt header - data. Fixes bug #171707. - -2005-03-25 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-data.c (gdk_pixbuf_new_from_data): Use canonical - property names. - -2005-03-21 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf.c (gdk_pixbuf_class_init): Mark param spec strings - as static. - -2005-03-14 Matthias Clasen <mclasen@redhat.com> - - Make PLT-reduction work with gcc4, and don't include - everything in gdk-pixbuf-alias.h: - - * gdk-pixbuf.symbols: Group symbols by header and source file. - * /makegdkpixbufalias.pl: Protect definitions by the same - preprocessor symbols used to guard the headers. Move - the alias declarations to a separate file which is - produced when calling makegdkpixbufalias.pl -def - * Makefile.am (gdk-pixbuf-aliasdef.c): Add a rule to generate - this file. - * *.c: Include gdk-pixbuf-alias.h after the other headers, - include gdk-pixbuf-aliasdef.c at the bottom. - -2005-03-10 Tor Lillqvist <tml@novell.com> - - * gdk-pixbuf-core.h - * gdk-pixbuf-io.c - * gdk-pixbuf.symbols: Implement DLL ABI stablility for - gdk_pixbuf_save() and gdk_pixbuf_savev(). (#167973) - -2005-03-09 Matthias Clasen <mclasen@redhat.com> - - * io-gif-animation.c (gdk_pixbuf_gif_anim_frame_composite): Fix - a C99ism. (#169741, Morten Welinder) - -2005-03-08 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf.c (gdk_pixbuf_class_init): Use canonical - form of the name when registering properties. - - * gdk-pixbuf.symbols: Add the new attributes here, too. - - * gdk-pixbuf-core.h: Use G_GNUC_NULL_TERMINATED where - appropriate. (#165682, Marc Meissner) - -2005-03-07 Matthias Clasen <mclasen@redhat.com> - - * io-xpm.c: Use a generated table of offsets - into a big const string to avoid relocations - in the rgb color table. (#168901, Tommi Komulainen) - - * gen-color-table.pl: Script to generate the table, - copied from Owen Taylors script by the same name - in Pango. - - * xpm-color-table.h: The generated table. - -2005-03-03 Matthias Clasen <mclasen@redhat.com> - - * io-xpm.c (pixbuf_create_from_xpm): Check the number - of scanned items. (#168906, Morten Welinder) - - Make the gif loader handle oom when loading - animations. (#168857, Tommi Komulainen) - - * io-gif-animation.c (gdk_pixbuf_gif_anim_frame_composite): - Handle oom by returning NULL. - - * io-gif.c (gif_get_lzw): Return an error if composite - returns NULL. - -2005-02-28 Matthias Clasen <mclasen@redhat.com> - - * pixops/*.S: Add .note.GNU-stack sections to Mark these as not - requiring an executable stack. - -2005-02-23 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c: Document BMP saving support. - - * io-bmp.c: Support saving as BMP. (168173, Ivan Wong) - - * io-ico.c: Fix a typo. (#168173, Ivan Wong) - -2005-02-15 Matthias Clasen <mclasen@redhat.com> - - * io-pnm.c (pnm_skip_whitespace): Don't read over the end of - the buffer if '#' appears at the very end. (#167141, Doug Morgan) - -2005-02-05 Hans Breuer <hans@breuer.org> - - * makefile.msc : rule for gdk_pixbuf.def - -2005-02-07 Matthias Clasen <mclasen@redhat.com> - - * io-pnm.c (pnm_read_next_value): Pass in the max number - of bytes to read. - (pnm_read_ascii_scanline): And use it here to enable - parsing of pbm images without whitespace between the - pixels. (#165803, Samuel Hym) - -2005-01-22 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_new_with_type) - (gdk_pixbuf_loader_new_with_mime_type): Close the loader - before unreffing it in the error case. (#164915, Crispin - Flowerday) - -2005-01-12 Owen Taylor <otaylor@redhat.com> - - * Makefile.am: Use grep | head -n 1 instead of grep -m 1 - which doesn't work - with slightly older versions of GNU grep in - install-libtool-import-lib rule. - -2005-01-08 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.6.1 === - -2005-01-04 Matthias Clasen <mclasen@redhat.com> - - * io-bmp.c (DecodeHeader): Error on compressed images with - negative height. Also make uncompressed images with data_offset - != header_size work. (#150664, Owen Taylor) - -2005-01-02 Matthias Clasen <mclasen@redhat.com> - - * pixops/pixops.c (bilinear_box_make_weights): Really fix the - math to make the vectors sum up to 1, making GDK_INTERP_HYPER - work again. (#162703, Dennis Nezic) - -2004-12-27 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_new_from_file) - Avoid deadlock. Pointed out by Callum McKenzie. - -Wed Dec 22 01:17:44 2004 Jonathan Blandford <jrb@redhat.com> - - * queryloaders.c (main): print out the version and binary name in - the header comment. Problem reported by Seth Nickell. - -2004-12-16 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.6.0 === - -Fri Dec 10 13:57:44 2004 Manish Singh <yosh@gimp.org> - - * abicheck.sh: filter out PRIVATE. - -2004-12-05 Tor Lillqvist <tml@iki.fi> - - * gdk-pixbuf-animation.c - * gdk-pixbuf-io.c - * io-xbm.c - * io-xpm.c - * make-inline-pixbuf.c - * queryloaders.c: Use gstdio wrappers. Document that file names - are in the GLib file name encoding. - - * gdk-pixbuf-csource.c - * queryloaders.c: On Windows, convert command line arguments and - environment variable values from locale encoding to UTF-8. - - * queryloaders.c: On Windows, use wide character API when - available. - - * Makefile.am - * gdk-pixbuf-core.h - * gdk-pixbuf-io.c - * gdk-pixbuf-animation.h - * gdk-pixbuf-animation.c: Like in GLib, for DLL ABI stability on - Windows, add binary compatibility versions of functions that take - file names as arguments. They use the system codepage, not GLib - file name encoding (which is UTF-8 on Windows). Use #defines to - make newly compiled code use the "real" functions that use the - GLib file name encoding scheme. - -2004-12-02 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.5.6 === - -2004-11-30 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_iter_get_pixbuf): - Fix a typo in the docs. (#159955, Masao Mutoh) - -2004-11-29 Matthias Clasen <mclasen@redhat.com> - - * Makefile.am (gdk-pixbuf-alias.h): Use the perl found by - configure. (#149826, Morten Welinder) - -Sun Nov 28 12:11:21 2004 Manish Singh <yosh@gimp.org> - - * makegdkpixbufalias.pl: Typo fix, so attributes are really - propagated. - -2004-11-28 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf.symbols: - * Makefile.am: Mark get_type() functions generated by glib-mkenums - as const. - -Thu Nov 25 14:21:37 2004 Manish Singh <yosh@gi,p.org> - - * abicheck.sh: filter out G_GNUC stuff when doing the compare. - -2004-11-23 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-core.h: Don't mark gdk_pixbuf_error_quark() as const, - to be consistent with all the other error_quark functions. - (technically they are const, but since these are called only - in error paths, giving the compiler better optimization - opportunities doesn't matter much) - - * gdk-pixbuf.symbols: Add attribute annotations. - * makegdkpixbufalias.pl: Keep attribute annotations, but strip PRIVATE. - * Makefile.am (gdk_pixbuf.def): Strip attribute annotations, but keep - PRIVATE. - -Mon Nov 15 18:58:22 2004 Manish Singh <yosh@gimp.org> - - * gdk-pixbuf-private.h: _gdk_pixbuf_lock now returns a gboolean. - - * abicheck.sh: don't hardcode lengths for cut, instead split on - the third field. - -2004-11-15 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-animation.c: - * gdk-pixbuf-loader.c: - * gdk-pixbuf-io.c: Be extra careful when locking and handle - the case that the module may initialize the thread system. - - * gdk-pixbuf-io.[hc] (_gdk_pixbuf_lock): Return whether the - lock was actually taken. - - * queryloaders.c (query_module): Set vtable->module before - calling fill_vtable(), since gdk-pixbuf-io.c does does the - same and modules may rely on it. (#158177, Dan Winship) - -2004-11-12 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_io_init): Don't use - _gdk_pixbuf_load_module_unlocked() in the !USE_GMODULE case. - - * === Released 2.5.5 === - -2004-11-12 Matthias Clasen <mclasen@redhat.com> - - Changes to make gdk-pixbuf threadsafe (#157310, #157306, - Colin Walters): - - * gdk-pixbuf-io.h (enum GdkPixbufFormatFlags): Add - GDK_PIXBUF_FORMAT_THREADSAFE to indicate that an image loader - is threadsafe. - - * gdk-pixbuf-io.c (get_file_formats, _gdk_pixbuf_load_module): - Use a lock to make initialization of global data structures - threadsafe. - * gdk-pixbuf-private.h: - * gdk-pixbuf-io.c (_gdk_pixbuf_lock, _gdk_pixbuf_unlock): - Auxiliary functions which use another lock to protect - threadunsafe image loaders. - - * gdk-pixbuf-io.c (gdk_pixbuf_real_save): - (save_to_callback_with_tmp_file): - (gdk_pixbuf_real_save_to_callback): - (gdk_pixbuf_new_from_xpm_data): - (_gdk_pixbuf_generic_image_load): - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_new_from_file): - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_load_module): - (gdk_pixbuf_loader_close): - (gdk_pixbuf_loader_finalize): - Use _gdk_pixbuf_lock() and _gdk_pixbuf_unlock(). - - * io-ani.c, io-bmp.c, io-gif.c, io-ico.c: - * io-jpeg.c, io-pcx.c, io-png.c, io-pnm.c: - * io-ras.c, io-tga.c, io-wbmp.c, io-xbm.c: - * io-xpm.c: Mark as threadsafe. - - * io-tiff.c: Remove pointless locking, mark as - threadunsafe. - -2004-11-10 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-animation.c: - * gdk-pixbuf-io.c: Use g_filename_display_name() instead of - g_filename_to_utf8() when putting filenames in error messages. - -2004-11-04 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf.c (gdk_pixbuf_class_init): Document current - restrictions for property values. (#157409, Matthew H. Plough) - -2004-11-01 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-features.h.in: Break the declaration of the three - version variables, so that gtk-doc can grok it. - -2004-10-29 Hans Breuer <hans@breuer.org> - - * makefile.msc : updated - -2004-10-27 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.5.4 === - -2004-10-27 Matthias Clasen <mclasen@redhat.com> - - * Makefile.am (gdk-pixbuf-alias.h): Fix srcdir != builddir - builds. - -2004-09-19 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.5.3 === - -2004-09-15 Matthias Clasen <mclasen@redhat.com> - - * io-ico.c: - * io-xpm.c: Fix some security issues discovered by Chris Evans. - -Mon Sep 13 19:31:34 2004 Matthias Clasen <maclas@gmx.de> - - * io-jpeg.c (real_save_jpeg): Drop the alpha channel - when saving 4-channel pixbufs. (#152450, Emmanuel Pacaud) - -2004-09-09 Matthias Clasen <mclasen@redhat.com> - - * makegdkpixbufalias.pl: Use the short prefix "IA__" for - aliases instead of the long suffix "__internal_alias". - -2004-09-01 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-core.h: Align argument names with source. - -Thu Aug 26 01:23:16 2004 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-core.h: - * gdk-pixbuf.symbols: - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_file_at_scale): - Add gdk_pixbuf_new_from_file_at_scale(), which is just - like gdk_pixbuf_new_from_file_at_size(), but optionally - ignores the aspect ratio. (#136395, Dom Lachowicz) - -Wed Aug 25 17:23:23 2004 Manish Singh <yosh@gimp.org> - - * io-gif.c: remove unused set_need_recomposite() function. - -2004-08-25 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.5.2 === - - * abicheck.sh: Make work in make distcheck. - -2004-08-25 Matthias Clasen <mclasen@redhat.com> - - * Makefile.am: Use the same prefix when creating - gdk-pixbuf-marshal.c and gdk-pixbuf-marshal.h - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_class_init): _-prefix - the marshalers. - -2004-08-24 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_new_with_mime_type): Use - the correct index and compare correctly, reported by Tommi Komulainen. - (gdk_pixbuf_loader_new_with_mime_type): - - * gdk-pixdata.c (gdk_pixdata_from_pixbuf): Work around bugs in - the runlength encoder by forcing rowstride * height to be - divisible by bpp. (#150882) - -Sun Aug 22 03:20:56 2004 Matthias Clasen <maclas@gmx.de> - - * pixops/pixops.c (pixops_scale_nearest): Fix a mixup in the handling - of dest_channels. (#111922, Christophe Fergeau) - -Fri Aug 20 11:59:10 2004 Owen Taylor <otaylor@redhat.com> - - * io-bmp.c: Fix infinite loop that can occur for bad - image data (#150601, Chris Evans, Manish Singh) - -2004-08-17 Matthias Clasen <mclasen@redhat.com> - - * abicheck.sh: No need for INCLUDE_INTERNAL_SYMBOLS any more. - - * Makefile.am (gdk-pixbuf-alias.h): Don't use cpp to filter the symbols. - - * makegdkpixbufalias.pl: Move the #ifdef processing into the perl script, - and keep the #ifdefs which differentiate between platforms. - - * gdk-pixbuf.symbols: Remove the marshalers. - - * Makefile.am (stamp-gdk-pixbuf-marshal.h): _-prefix the marshalers. - -Thu Aug 12 22:19:12 2004 Matthias Clasen <maclas@gmx.de> - - * io-bmp.c (DecodeHeader): Properly determine the number of - colors in an OS/2 BMP file. (#150003, Jon-Kare Hellan) - -2004-08-12 Matthias Clasen <mclasen@redhat.com> - - * pixops/pixops.c: Remove C99-isms. (#149967, Vincent Noel) - -Wed Aug 11 22:56:55 2004 Matthias Clasen <maclas@gmx.de> - - * abicheck.sh: Check all symbols. - -2004-08-11 Matthias Clasen <mclasen@redhat.com> - - * pixops/pixops.c: Make scaling and compositing functions handle - edge pixels consistently. (#111922, Brian Cameron) - - * pixops/pixops-internal.h: - * pixops/pixops.c: - * pixops/*.S: underscore prefix the mmx implementations, in order - to not export them. - - * gdk-pixbuf.symbols: Remove the mmx pixops implementations. - - * abicheck.sh: No need to define INCLUDE_MMX_SYMBOLS any more. - -Tue Aug 10 23:53:59 2004 Matthias Clasen <maclas@gmx.de> - - Add hidden aliases for exported symbols which are - used internally in order to get rid of many PLT - entries. (#145519, Arjan van de Ven) - - * gdk/Makefile.am: Add rules to generate gdk_pixbuf.def and - gdk-pixbuf-alias.h from gdk-pixbuf.symbols, and make make - check check the abi with abicheck.sh. - - * gdk/gdk-pixbuf.symbols: New file. Definition of the gdk-pixbuf - ABI. The file can be processed by cpp to filter out certain - subsets of symbols. - - * gdk/abicheck.sh: New file. Script to check the actually - symbols exported from libgdk_pibuf.2.0.so against the symbols - found in gdk-pixbuf.symbols. - - * gdk/makegdkpixbufalias.pl: New file. Perl script to generate the - header containing the alias definitions for internally used - exported symbols from a list of symbols. - - * *.c: Include gdk-pixbuf-alias.h - -2004-08-06 Hans Breuer <hans@breuer.org> - - * gdk_pixbuf.def makefile.msc : updated - -Sun Aug 1 23:57:06 2004 Matthias Clasen <maclas@gmx.de> - - * io-pcx.c (pcx_increment_load_data_1): Fix progressive - loading of 8bit pcx files. (#148518, Magnus Bergman) - -2004-08-01 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.5.1 === - -Tue Jul 20 22:23:26 2004 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.h: Remove trailing commas from - enumerations. (#148035) - -Sun Jul 18 20:17:41 2004 Soeren Sandmann <sandmann@daimi.au.dk> - - * === released 2.5.0 == - -Thu Jul 15 19:19:21 2004 Matthias Clasen <maclas@gmx.de> - - * io-png.c (real_save_png): - * gdk-pixbuf-io.c (gdk_pixbuf_io_init): Use 'cannot' instead - of 'can not' in messages. (#144226, Morten Welinder) - -Fri Jul 9 15:38:06 2004 Manish Singh <yosh@gimp.org> - - * gdk-pixbuf-io.c (gdk_pixbuf_format_set_disabled): function doesn't - return a value, so don't use g_return_val_if_fail() - - * gdk-pixbuf-scale.c (gdk_pixbuf_rotate_simple): initialize dest in - the can't happen case, to quiet gcc. - - * io-tiff.c (tifflibversion): enclose in #if TIFFLIB_VERSION >= - 20031226. - -Wed Jul 7 23:53:58 2004 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.h: - * gdk-pixbuf-io.c (gdk_pixbuf_format_is_disabled): - * gdk-pixbuf-io.c (gdk_pixbuf_format_set_disabled): - * gdk-pixbuf-io.c (gdk_pixbuf_format_get_license): - New functions to disable/enable individual loaders and to - obtain license information about loaders. - - * gdk-pixbuf-io.h (GdkPixbufFormat): Add disabled and - license fields. - - * gdk-pixbuf-io.c (_gdk_pixbuf_get_module): - * gdk-pixbuf-io.c (_gdk_pixbuf_get_named_module): Skip - disabled loaders. - - * io-*.c: Add license information in the fill_info - functions. - -2004-07-07 Matthias Clasen <mclasen@redhat.com> - - * gdk-pixbuf-features.h.in: Fix the build. - -2004-07-06 Tor Lillqvist <tml@iki.fi> - - * gdk-pixbuf-features.h.in - * gdk-pixbuf.c: Mark the version variables for proper import and - export from Windows DLLs. Thanks to Laurent Sansonetti for - reporting the problem. - -Sat Jul 3 00:41:44 2004 Matthias Clasen <maclas@gmx.de> - - * pixops/pixops.c (bilinear_box_make_weights): Correct the - math to calculate bilinear weights. (#112412, Brian Cameron) - -Mon Jun 21 00:44:51 2004 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-transform.h: - * gdk-pixbuf-scale.c (gdk_pixbuf_rotate_simple): - * gdk-pixbuf-scale.c (gdk_pixbuf_flip): New functions to - rotate pixbufs by multiples of 90 degrees and to flip them - horizontally or vertically. - -Sun Jun 20 01:06:48 2004 Matthias Clasen <maclas@gmx.de> - - Header reorganization. (#51999, Jeff Franks, reorganization - proposed by Havoc Pennington) - - * gdk-pixbuf.h: This is now an include-only header, and the only - one which applications should directly use. - - * gdk-pixbuf-animation.h: Add animation api from gdk-pixbuf.h. - * gdk-pixbuf-io.h: Add io api from gdk-pixbuf.h. - * gdk-pixbuf-loader.h: Add loader api from gdk-pixbuf.h. - * gdk-pixbuf-transform.h: New header. - * gdk-pixbuf-core.h: New header. - -Sat Jun 19 01:44:12 2004 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-scale.c (gdk_pixbuf_composite): Add a figure which - explains pixbuf compositing. - -2004-06-16 Matthias Clasen <mclasen@redhat.com> - - * io-tiff.c: Make the tiff loader work with both - libtiff 3.5.7 and libtiff 3.6.1. (#135541, Marco Ghirlanda) - -Fri Jun 11 22:02:56 2004 Matthias Clasen <maclas@gmx.de> - - * io-gif.c, io-pnm.c, io-tga.c, io-xpm.c: Don't use - contractions like "don't" or "isn't" in error messages. - It isn't nice to use them in log entries either... - (#137774, Morten Welinder, patch by Alexander Winston) - -Sat Jun 5 00:59:12 2004 Matthias Clasen <maclas@gmx.de> - - Merged from 2.4 - - * gdk-pixbuf-animation.c: - * gdk-pixbuf-io.c: Convert filenames to UTF-8 when embedding - them in error messages. (#143654, Sven Neumann) - -Sun May 16 22:53:47 2004 Matthias Clasen <maclas@gmx.de> - - Merged from 2.4 - - * io-pnm.c (pnm_read_next_value): Don't read integers - partially. (#142584, Kouichirou Hiratsuka) - -2004-05-10 Matthias Clasen <mclasen@redhat.com> - - Merged from 2.4: - - * pixops/timescale.c: - * pixops/pixops.c: - * pixops/pixops.h: - * gdk-pixbuf-scale.c: _-prefix the nonstatic pixops_... - functions. (#142233, Morten Welinder) - -Wed May 5 23:09:48 2004 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.h (GdkPixbufFormatFlags): New format flag - GDK_PIXBUF_FORMAT_SCALABLE to mark scalable formats. - - * gdk-pixbuf.h: - * gdk-pixbuf-io.c (gdk_pixbuf_format_is_scalable): New function. - (#137995, Dom Lachowicz) - -2004-04-30 Matthias Clasen <mclasen@redhat.com> - - * === Released 2.4.1 === - -2004-04-13 Matthias Clasen <mclasen@redhat.com> - - * io-ani.c (gdk_pixbuf__ani_image_load_animation): - * gdk-pixbuf-io.c (gdk_pixbuf_get_file_info) - (_gdk_pixbuf_generic_image_load) - (gdk_pixbuf_new_from_file_at_size): When calling fread() - in a loop, check for ferror() as well as for feof() to - avoid infinite loops on directories. (#137804, Alex Converse) - -Mon Mar 15 15:01:59 2004 Owen Taylor <otaylor@redhat.com> - - * === Released 2.4.0 === - -2004-03-15 Tor Lillqvist <tml@iki.fi> - - * queryloaders.c (main): [Win32] Look up installation prefix at - run-time, replace prefix in PIXBUF_LIBDIR with that. (#106141) - - Merges from stable branch that had been left out. (#136282, J. Ali - Harlow): - - Changes for run-time lookup of installation location on Win32: - - * Makefile.am (INCLUDES): Define GTK_PREFIX as $(prefix). - - * gdk-pixbuf-io.c (get_sysconfdir): New function, look up - installation location at runtime and deduce GTK_SYSCONFDIR - from it. - (get_toplevel): Similar, for the top-level installation directory. - (correct_prefix): Replace compile-time prefix with run-time - prefix. - (get_libdir): Remove, not used any longer. - (gdk_pixbuf_io_init): Call correct_prefix() on Win32. - - * queryloaders.c (query_module): [Win32] Change backslahses into - slashes in path. - -Tue Mar 9 09:33:28 2004 Owen Taylor <otaylor@redhat.com> - - * === Released 2.3.6 === - -2004-03-05 Tor Lillqvist <tml@iki.fi> - - * gdk_pixbuf.def: Add missing entries. Thanks to J. Ali Harlow. - -Fri Mar 5 22:22:25 2004 Matthias Clasen <maclas@gmx.de> - - * io-bmp.c (OneLine32): Don't try to load an alpha channel - from the BMP, since there is no evidence that even 32bit - BMPs have an alpha channel. (#135502) - -Mon Mar 1 19:47:48 2004 Owen Taylor <otaylor@redhat.com> - - * === Released 2.3.5 ==== - -2004-02-28 Hans Breuer <hans@breuer.org> - - * io-tiff.c : include <io.h> for lseek() - * io-xbm.c : use HAVE_UNISTD_H - -Tue Feb 24 14:45:03 2004 Owen Taylor <otaylor@redhat.com> - - * === Released 2.3.3 === - -Sun Feb 22 01:09:55 2004 Matthias Clasen <maclas@gmx.de> - - * io-bmp.c (gdk_pixbuf__bmp_image_begin_load): Remove debugging - code. - -Fri Feb 20 22:25:32 2004 Matthias Clasen <maclas@gmx.de> - - * io-bmp.c (DecodeHeader): Store and sanity-check the clrUsed field - from the header for use in DecodeColormap. - * io-bmp.c (DecodeColormap): Don't read more colormap entries than - the header says are there. (#134235, Kazuho Okui) - -Sun Feb 8 01:07:20 2004 Manish Singh <yosh@gimp.org> - - * gdk-pixbuf-io.c: removed unnecessary G_OBJECT() cast checks. - - * io-jpeg.c: make the return type for to_callback_empty_output_buffer - "boolean", which should be defined by the jpeg headers. The right - return type for this function depends on how the jpeg library - was built (one wonders what happens if different compilers are used). - -2004-01-28 Hans Breuer <hans@breuer.org> - - * gdk_pixbuf.def : updated externals - -Sat Jan 17 23:02:55 2004 Matthias Clasen <maclas@gmx.de> - - The second part of the fix for #114351 (see also - ../Changelog) - - * gdk-pixbuf-i18n.h (P_): Use translation domain gtk20-properties. - -Sat Jan 17 00:01:51 2004 Matthias Clasen <maclas@gmx.de> - - The first part of the fix for #114351 (see also - ../ChangeLog): - - * gdk-pixbuf-i18n.h: Define P_() for property blurbs and nicks. - - * gdk-pixbuf.c: Mark property blurbs and nicks with P_(). - -Thu Jan 8 22:01:14 2004 Matthias Clasen <maclas@gmx.de> - - * queryloaders.c (loader_sanity_check): Don't use bitwise operators - on booleans. (#130923, reported by Telsa Gwynne, fix by Dave Jones) - -2004-01-06 Federico Mena Quintero <federico@ximian.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_save): Escape an ampersand in the - documentation comment, and hack around an empty line in the code - example so that gtk-doc won't put a <para> due to it. - - * gdk-pixbuf.c (gdk_pixbuf_get_pixels): Link to the documentation - section on image data. - -2004-01-06 Federico Mena Quintero <federico@ximian.com> - - * gdk-pixdata.c (gdk_pixbuf_new_from_inline): Fix example in - documentation comment. Fixes #130701. - -Wed Jan 7 02:41:14 2004 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.c (gdk_pixbuf_save_to_bufferv): - * gdk-pixbuf-io.c (gdk_pixbuf_save_to_buffer): - * gdk-pixbuf-io.c (gdk_pixbuf_save_to_callbackv): - * gdk-pixbuf-io.c (gdk_pixbuf_save_to_callback): New public API - to save pixbufs to non-file locations. (#82203, Tim Evans) - - * gdk-pixbuf.h: - * gdk-pixbuf.def: Declare the new public API. - - * gdk-pixbuf-io.h: Add save_to_callback to the module interface. - - * io-jpeg.c: - * io-png.c: Implement save_to_callback. - - * gdk-pixbuf-io.c (gdk_pixbuf_savev): - * gdk-pixbuf-io.c (gdk_pixbuf_save): Update documentation. - - * gdk-pixbuf-io.c (gdk_pixbuf_real_save): Support saving via - image_module->save_to_callback. - - * gdk-pixbuf-io.c (gdk_pixbuf_real_save_to_callback): New generic - save_to_callback function which falls back to image_module->save - on a temp file. - -Wed Jan 7 01:17:36 2004 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_size_func): - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_set_size): - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_init): Make it possible - to call gdk_pixbuf_loader_set_size (loader, 0, 0) by changing - the initial values of priv->width/height to -1. - - * io-tiff.c (tiff_image_parse): - * io-ras.c (RAS2State): - * io-pnm.c (gdk_pixbuf__pnm_image_load_increment): - * io-pcx.c (gdk_pixbuf__pcx_load_increment): - * io-jpeg.c (gdk_pixbuf__jpeg_image_load_increment): - * io-png.c (png_info_callback): - * io-ico.c (DecodeHeader): - * io-bmp.c (DecodeHeader): Call size_func once the size is known, - even if the module can't make use of the scaling information. If - size_func returns 0, don't allocate a pixbuf and return, if - necessary with an error. - - * gdk-pixbuf.h: - * gdk-pixbuf-io.c (gdk_pixbuf_get_file_info): A new function - to determine the type and size of an image file without loading - it completely. (#53725) - -Sun Jan 4 00:44:57 2004 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf.c (gdk_pixbuf_class_init): Turn the pixbuf - attributes into (construct-only, but always readable) - properties. (#130196) - - * gdk-pixbuf-data.c (gdk_pixbuf_new_from_data): Set properties - in g_object_new(). - -Mon Dec 22 01:35:36 2003 Matthias Clasen <maclas@gmx.de> - - * Makefile.am (gdk-pixbuf.loaders): Fix building with - --disable-modules --with-included-loaders, create an - empty gdk-pixbuf.loaders file. (#124496, Arno Charlet, fix - proposed by Owen Taylor) - -Thu Dec 11 01:57:05 2003 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_class_init): Move - the documentation for signals inline, to get proper parameter - documentation. (#128977) - -Sat Nov 15 00:26:19 2003 Matthias Clasen <maclas@gmx.de> - - * queryloaders.c (loader_sanity_check): Check that the mask - is NULL or a string of the same length consisting entirely of - ' ', '!', 'x', 'z', 'n'. - -Mon Nov 10 00:17:52 2003 Matthias Clasen <maclas@gmx.de> - - * Makefile.am (install-data-local): Typo fix in warning. - -Sun Nov 9 23:07:05 2003 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.c (_gdk_pixbuf_generic_image_load): If neither - load nor begin_load are available fall back to load_animation - and use gdk_pixbuf_animation_get_static_image() to obtain a - pixbuf. Inefficient, but at least doesn't crash. - -Sun Nov 9 21:56:20 2003 Matthias Clasen <maclas@gmx.de> - - * queryloaders.c (write_loader_info): New function to write - out the information for a single loader, factored out of - query_module(). - (loader_sanity_check): New function to perform - sanity checks on a loader. - (query_module): Use the new functions. - -Thu Nov 6 00:27:27 2003 Matthias Clasen <maclas@gmx.de> - - * io-pcx.c (gdk_pixbuf__pcx_load_increment): Fold two similar - strings into on. (#126204, Danilo Segan) - -2003-09-19 Matthias Clasen <maclas@gmx.de> - - * io-tga.c (try_preload): Remove a pointless check. - (#122710, Kjartan Maraas) - -Mon Aug 18 10:25:29 2003 Owen Taylor <otaylor@redhat.com> - - * gdk-pixdata.c (gdk_pixdata_to_csource): Add the correct - alignment magic for Sun compiler and for GCC to get - the strings aligned. (Patch from Brian Cameron, #117217) - -2003-08-14 Matthias Clasen <maclas@gmx.de> - - * gdk-pixdata.c (gdk_pixdata_to_csource): Improve doc comment - wording. (#119754, Doug Quale) - -2003-08-03 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf.c (gdk_pixbuf_get_rowstride): - * gdk-pixbuf-data.c (gdk_pixbuf_new_from_data): Clarify misleading - explanation of rowstride. (#119000) - -2003-07-24 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_file_at_size): Preserve the - aspect ratio. (#118145, Owen Taylor) - -2003-07-23 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_file_at_size): Close loader - before unref'ing it. (#118146, Owen Taylor) - -2003-03-01 Hans Breuer <hans@breuer.org> - - * makefile.msc : updated - - * gdk_pixbuf.def : export a bunch of new functions - -2003-07-18 Matthias Clasen <maclas@gmx.de> - - * pixops/pixops.c (correct_total): Split correction into multiple - pieces if no single weight is large enough to apply the unsplit - correction. (#117431, problem reported by Tomas ?gren) - -2003-07-13 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf.h: - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_file_at_size): New function - to load an image from a file at a specified size. (#105326, Dom - Lachowicz) - -2003-07-11 Matthias Clasen <maclas@gmx.de> - - * queryloaders.c (query_module): Handle absolute filenames - properly. (#117170, Jens Elkner) - - * gdk-pixbuf-io.c: Mention that NULL-terminated arrays returned by - gdk_pixbuf_format_get_mime_types() and - gdk_pixbuf_format_get_extensions() must be freed with g_strfreev(). - -2003-07-04 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.c: Document ICO save parameters. - - * io-ico.c: Support saving of ICOs and CURs. Currently, only - single-image ICOs are produced, but the code for multi-image ICOs - is already in place. The saver understands the options "depth" - (can be "32", "24" or "16") and "x_hot"/"y_hot" for hotspot - coordinates of CURs. - -2003-06-28 Matthias Clasen <maclas@gmx.de> - - * io-ico.c (DecodeHeader): Stop discriminating against 32bpp ICOs - a): Use the byte size of the image as a heuristic when selecting - the bitmap to load - this lets us select 32bpp bitmaps which come - after a 8bpp bitmap. - (OneLineTransp): Stop discriminating against 32bpp ICOs b): Don't - overwrite the alpha channel of 32bpp ICOs. - (gdk_pixbuf__ico_image_load_increment): Stop decoding the header - unnecessarily. - -Fri Jun 27 03:56:59 2003 Soeren Sandmann <sandmann@daimi.au.dk> - - * io-gif-animation.c (gdk_pixbuf_gif_anim_frame_composite): Make - it compile with C89 compilers. - -2003-06-23 Matthias Clasen <maclas@gmx.de> - - * io-gif.c (gif_get_frame_info): Remove the pointless refusal to - load images with dubious disposal mode on the first frame. Just - ignore it, as everybody else does. - -2003-06-22 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-loader.[hc] (gdk_pixbuf_loader_new_with_mime_type): - New function to obtain a loader for a specific mime type. - (#105324, Dom Lachowicz) - - * io-gif.c (gif_get_extension): Reset block_count to 0 for all - application extensions, otherwise the data blocks of unknown - extensions are not propertly skipped. - - Second half of the fix for #106962, handle frames extending beyond - the logical screen: - - * io-gif.c (clip_frame): New helper function to clip a rectangle - to the logical screen size of the gif. - (maybe_update): New helper function to call update_func only if - the rectangle is not completely off-bounds. - (gif_get_lzw): Read frames extending outside the logical screen - size, but be careful clip to the logical screen size - when operating on the composite pixbuf and when calling update_func. - (gif_init): Set the animation size to the logical screen size. - (gif_get_frame_info): Don't refuse to load images with frames - extending beyond the logical screen size. - - * io-gif-animation.c (gdk_pixbuf_gif_anim_frame_composite): Be - careful to clip all rectangles to the logical screen size, also - handle the fact that frames may be completely off-bounds. - -2003-06-21 Matthias Clasen <maclas@gmx.de> - - * io-gif.c: Merge from 2.2: Fix update_func() arguments and accept - empty frames. (#106962) - -2003-06-17 Matthias Clasen <maclas@gmx.de> - - * Makefile.am (man_MANS): Removed, man pages are now installed - from docs/reference/gdk-pixbuf. - -2003-06-03 Matthias Clasen <maclas@gmx.de> - - * gdk-pixdata.c (gdk_pixbuf_new_from_inline): Document - data_length == -1, add an example. (#97290) - -2003-06-01 Matthias Clasen <maclas@gmx.de> - - * gdk-pixdata.h (struct _GdkPixdata): Fix misleading documentation - of rowstride. (#113924, Noah Levitt) - -2003-05-27 Matthias Clasen <maclas@gmx.de> - - * io-wbmp.c: Remove dubious bitfields of - unspecified signedness. (#112919, Morten Welinder)gdk-p - - * gdk-pixdata.c (gdk_pixdata_to_csource): Replace all occurances - of g_string_new ("") by g_string_new (NULL). (#106975, Morten - Welinder) - -2003-05-21 Matthias Clasen <maclas@gmx.de> - - * pixbufloader_pcx.def: - * io-pcx.c: A loader for PCX files. (#113035, Josh Beam) - - * gdk-pixbuf-io.c: - * Makefile.am: Add PCX loader. - -2003-05-19 Matthias Clasen <maclas@gmx.de> - - Improve progressive loading from slow sources: (#107368) - - * io-gif-animation.c (gdk_pixbuf_gif_anim_get_iter): Initialize - first_loop_slowness. - (gdk_pixbuf_gif_anim_iter_advance): Don't wrap during loading if - the datasource falls behind the speed of the display. - - * io-gif-animation.h: Add a loading flag to GdkPixbufGifAnim and - first_loop_slowness to GdkPixbufGifAnimIter. - -Wed May 14 18:24:50 2003 Owen Taylor <otaylor@redhat.com> - - * gdk-pixdata.c (gdk_pixdata_deserialize): Add a - (gint32 *) => (guint32 *) cast. (#108615, Rick Jones) - -2003-04-24 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_write): - (gdk_pixbuf_loader_new_with_type): - (gdk_pixbuf_loader_close): - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_file): - (gdk_pixbuf_save): - (gdk_pixbuf_savev): - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_new_from_file): - Add sanity checks for GError handling. (#108345) - -Tue Apr 1 15:33:51 2003 Owen Taylor <otaylor@redhat.com> - - * pixops/pixops.c (make_weights): Exploit the fact that all - our filters are separable to simplify the calculation of - the weight tables. (Based on a patch from Brian Cameron.) - - * pixops/Makefile.am pixbuf-transform-math.ltx: - Add a short article describing how the math in pixops.c - works. - -2003-03-21 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-animation.c (gdk_pixbuf_non_anim_get_type): Add - missing static. (#108614) - - * io-jpeg.c (gdk_pixbuf__jpeg_image_begin_load): - * io-ico.c (gdk_pixbuf__ico_image_stop_load): Add missing static - qualifiers apparently causing problems on some platforms. (#108617) - -2003-03-11 Matthias Clasen <maclas@gmx.de> - - * io-ico.c (DecodeHeader): Calculate LineWidth for 16bpp from - width, like for the other depths. (noticed by Marijn Ros) - -2003-03-08 Matthias Clasen <maclas@gmx.de> - - Bug #107664 continued: - - * io-xpm.c (find_color): Fix 0/FALSE confusion - * gdk-pixbuf.c (gdk_pixbuf_get_has_alpha): Fix -1/gboolean - confusion. - -2003-03-06 Matthias Clasen <maclas@gmx.de> - - * io-gif.c (gif_read): Fix 0/FALSE confusion (#107664, Morten - Welinder) - -2003-02-20 Matthias Clasen <maclas@gmx.de> - - * io-gif-animation.c (gdk_pixbuf_gif_anim_frame_composite): - Always clear the initial frame and "disposed" areas with - transparent pixels, no matter whether the frame has transparency - or not. (#55502) - -2003-02-18 Matthias Clasen <maclas@gmx.de> - - * io-tga.c (pixbuf_flip_row): - (pixbuf_flip_vertically): Auxiliary functions used to implement - support for arbitrary origins. - (parse_data_for_row_pseudocolor): - (parse_data_for_row_truecolor): - (parse_data_for_row_grayscale): - (parse_data_for_row): - (fill_in_context): Remove the check for upper-left origin. - (parse_rle_data): Support arbitrary origins. (#105912) - - * io-tga.c (fread_check): - (fseek_check): - (get_header_from_file): - (get_colormap_from_file): - (get_image_pseudocolor): - (swap_channels_pixbuf): - (get_image_truecolor): - (get_image_grayscale): - (gdk_pixbuf__tga_load): Remove the non-incremental load - implementation, since we have generic_image_load () now. - - (gdk_pixbuf__tga_stop_load): Fix a potential crash discovered by - pixbuf-lowmem. - -2003-02-14 Matthias Clasen <maclas@gmx.de> - - * io-tga.c (try_preload): - (gdk_pixbuf__tga_load): Actually reject images with origin - not in the upper-left corner. (#105912) - -2003-02-06 Matthias Clasen <maclas@gmx.de> - - * queryloaders.c (query_module): Better error message if - module_open() fails. (#105349, Tim Mooney) - -Mon Jan 27 17:10:30 2003 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (gdk-pixbuf.loaders): Rewrite to run - on the .la files rather than looking for .so files. - (#102142, Martin Gansser) - - * Makefile.am: Don't build gdk-pixbuf.loaders when - cross-compiling. - -2003-01-05 Tor Lillqvist <tml@iki.fi> - - * Makefile.am (gdk-pixbuf.loaders): Use @SOEXT@ in the find command. - - * gdk_pixbuf.def: Add gdk_pixbuf_loader_set_size. - -2003-01-03 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_xpm_data): Don't crash if - gdk-pixbuf.loaders file is missing. (#102222) - -2002-12-08 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-animation.h: - * gdk-pixbuf-io.h: Add /*< public|private >*/ markers. - -Sat Dec 7 10:14:05 2002 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (gdk-pixbuf.loaders): Make gdk-pixbuf.loaders - also depend gdk-pixbuf-query-loaders. (#97096, Daniel Elstner) - -2002-12-05 Matthias Clasen <maclas@gmx.de> - - * io-ico.c: Remove leftover debug output. (#100357, Owen Taylor) - -2002-12-04 Bastien Nocera <hadess@hadess.net> - - * io-tiff.c: (tiff_image_parse): use G_BIG_ENDIAN instead of - WORDS_BIGENDIAN which isn't set by configure.in - -2002-11-29 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-animation.c: - * gdk-pixbuf.c: Add deprecation docs. - -2002-11-28 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf/gdk-pixbuf-io.c: - * gdk-pixbuf/gdk-pixbuf-loader.c: - * gdk-pixbuf/gdk-pixbuf.c: Document 2.2 API additions. I'm not - going to list all individual functions here; if you want to see - the list, grep for "Since: 2.2". - -Fri Nov 8 19:06:07 2002 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (gdk-pixbuf.loaders): Make gdk-pixbuf.loaders - file depend on the loaders (#97096, Jeff Waugh) - -Wed Nov 6 15:19:53 2002 Owen Taylor <otaylor@redhat.com> - - * io-gif.c (CHECK_LZW_SP): Fix trailing semicolon on macro, - clean up a bit. - -2002-11-05 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-loader.c: Reindent to follow the gdk-pixbuf indentation. - -Tue Nov 5 14:16:17 2002 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_close): Fix - leaked pixbuf reference (#96823, Morten Welinder) - -2002-10-23 Matthias Clasen <maclas@gmx.de> - - * io-gif.c (lzw_read_byte): Check for stack overflow throughout. - (#91808, Elliot Lee) - -2002-10-21 Matthias Clasen <maclas@gmx.de> - - Support the Netscape application extension for gif animations - (#95060): - - * io-gif-animation.h: - * io-gif-animation.c (gdk_pixbuf_gif_anim_iter_advance): - Add loop count to GdkPixbufGifAnim and use it in the advance - method of GdkPixbufGifAnimIter. - - * io-gif.c (gif_get_extension): Parse Netscape application - extension block and set the animation loop count. - -2002-10-11 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_get_format): Remove - unused variable. - - * gdk-pixbuf-io.h: Remove unused typedef - GdkPixbufModuleGetSignatureFunc. - -2002-10-04 jacob berkman <jacob@ximian.com> - - * queryloaders.c (query_module): make legal C - -2002-10-04 Matthias Clasen <maclas@gmx.de> - - * Makefile.am gdk-pixbuf-animation.c gdk-pixbuf-data.c - gdk-pixbuf-io.c gdk-pixbuf-io.h gdk-pixbuf-loader.c - gdk-pixbuf-loader.h gdk-pixbuf-private.h gdk-pixbuf.h - gdk-pixdata.c io-ani-animation.h io-ani.c io-bmp.c - io-gif-animation.c io-gif-animation.h io-gif.c io-ico.c - io-jpeg.c io-png.c io-pnm.c io-ras.c io-tga.c io-tiff.c - io-wbmp.c io-xbm.c io-xpm.c pixbufloader_ani.def - pixbufloader_bmp.def pixbufloader_gif.def pixbufloader_ico.def - pixbufloader_jpeg.def pixbufloader_png.def - pixbufloader_pnm.def pixbufloader_ras.def pixbufloader_tga.def - pixbufloader_tiff.def pixbufloader_wbmp.def - pixbufloader_xbm.def pixbufloader_xpm.def test-gdk-pixbuf.c - gdk-pixbuf-animation.h queryloaders.c: Support for separately - installed loaders. (#77486) - -Thu Oct 3 18:25:57 2002 Owen Taylor <otaylor@redhat.com> - - * io-jpeg.c (gdk_pixbuf__jpeg_image_save): - Fix memory leak. (#94399) - -Tue Oct 1 17:35:43 2002 Owen Taylor <otaylor@redhat.com> - - * gdkpixdata.c: Patch from Andy Wingo to always - escape ? to avoid accidentally generating trigraphs - in the output (#94631) - -2002-09-28 Tor Lillqvist <tml@iki.fi> - - * pixops/*.S: Don't use .type on Cygwin, either (#91597, Masahiro - Sakai). - -2002-09-27 Federico Mena Quintero <federico@ximian.com> - - * io-ico.c (gdk_pixbuf__ico_image_begin_load): Free the context if - we cannot allocate the HeaderBuf. - -2002-09-27 Federico Mena Quintero <federico@ximian.com> - - * io-bmp.c (OneLine): Fix the update region notification to handle - top-to-bottom and bottom-to-top BMPs correctly. - -2002-09-19 Matthias Clasen <maclas@gmx.de> - - * Revert the previous change; the symbols need to be exported - to be usable from dlopened modules. - -2002-09-18 Matthias Clasen <maclas@gmx.de> - - * io-xpm.c, io-xbm.c, io-ico.c, io-ani.c, io-png.c, - gdk-pixbuf.c, gdk-pixbuf-animation.c, gdk-pixbuf-loader.c, - gdk-pixbuf-private.h: _-prefix gdk_pixbuf_non_anim_new and - gdk_pixbuf_set_option. Adjust all callers. - -2002-09-14 Hans Breuer <hans@breuer.org> - - * pixops/Makefile.am : added makefile.msc to EXTRA_DIST - -2002-09-12 Matthias Clasen <maclas@gmx.de> - - * io-gif-animation.h: - * gdk-pixbuf.h: Move GdkPixbufFrame from the public header to - the gif-animation-specific private header. (#91929) - -2002-09-12 Federico Mena Quintero <federico@ximian.com> - - * io-jpeg.c (gdk_pixbuf__jpeg_image_load): Unref the pixbuf if we - hit an unsupported colorspace. - -2002-09-06 Matthias Clasen <maclas@gmx.de> - - * io-ani.c, io-ani-animation.h, io-ani-animation.c, - pixbufloader_ani.def, Makefile.am, gdk-pixbuf-io.c: New loader, - for .ANI animations. - - * io-xpm.c (pixbuf_create_from_xpm): - * io-xbm.c (gdk_pixbuf__xbm_image_load_real): - * io-ico.c (DecodeHeader): Attach hotspot coordinates to the - pixbuf as options "x_hot" and "y_hot". - -2002-09-04 Matthias Clasen <maclas@gmx.de> - - * io-tga.c (io_buffer_append): - * io-ico.c (DecodeHeader): - * io-bmp.c (grow_buffer): Don't leak memory if g_try_realloc fails. - - * gdk-pixbuf-io.c (pixbuf_check_ico): Fix loading of .CUR files. - (#91826) - -2002-08-25 Tor Lillqvist <tml@iki.fi> - - * Makefile.am (libgdk_pixbuf_2_0_la_DEPENDENCIES): Add - gdk_pixbuf_win32res_lo. (#87101, J. Ali Harlow) - -2002-08-22 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.h: - gdk-pixbuf-io.c (_gdk_pixbuf_generic_image_load): No longer - static, thus _gdk_pixbuf-prefixed. - - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_new_from_file): - Keep this logic in sync with gdk_pixbuf_new_from_file(). (Based - on a patch by Anders Carlsson) - - * io-png.c (gdk_pixbuf__png_image_save): Plug a memory - leak. (#91422, Sven Neumann) - -2002-07-31 Sven Neumann <sven@gimp.org> - - * gdk-pixdata.c (gdk_pixdata_to_csource): free the result of - gdk_pixdata_serialize() (bug #89411). - -Mon Jul 29 23:06:10 2002 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf-scale.c: Fix some warnings by adding - casts to PixopsInterpType. (#85839, David L. Cooper, II.) - -2002-07-16 Matthias Clasen <maclas@gmx.de> - - * io-ras.c (DoCompressed): Avoid unnecessary casting. - -2002-07-07 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.c (generic_image_load): New function for loading - an image from a file either via module->load or incrementally. - (prepared_notify): ModulePreparedNotifyFunc for generic_image_load. - (gdk_pixbuf_new_from_file): Use generic_image_load. - * io-bmp.c, io-ico.c, io-ras.c, io-wbmp.c: Remove trivial - implementations of module->load. (#71266) - - * io-ico.c (DecodeHeader): Correct computation of image height. - (OneLine): Correct update notification. - - Load-at-size functionality (#53726): - - * gdk-pixbuf-io.h (ModuleSizeFunc): New. - (_GdkPixbufModule): Prepend a ModuleSizeFunc to the - begin_load arguments. Adjust all modules. - * gdk-pixbuf-loader.c (struct GdkPixbufLoaderPrivate): Add - fields width, height, size_fixed, need_scale. - (gdk_pixbuf_loader_class_init): Add size_prepared signal. - (gdk_pixbuf_loader_set_size): New function. - (gdk_pixbuf_loader_size_func): ModuleSizeFunc which gets - passed to the module, emits size_prepared. - (gdk_pixbuf_loader_prepare): Call gdk_pixbuf_loader_size_func - if necessary, only emit area_prepared if no separate scaling - is required. - (gdk_pixbuf_loader_update): Only emit area_updated if no - separate scaling is required. - (gdk_pixbuf_loader_load_module): Add size_func as first argument. - (gdk_pixbuf_loader_close): If necessary scale the image - to the desired size and emit area_prepared and area_updated. - * gdk-pixbuf-loader.h (struct _GdkPixbufLoaderClass): Add - size_prepared signal. - (gdk_pixbuf_loader_set_size) New API. - * gdk-pixbuf-marshal.list: Add VOID:INT,INT. - * io-jpeg.c: User cinfo->output_width/height instead of - cinfo->image_width/height throughout when adressing the pixbuf. - (gdk_pixbuf__jpeg_image_load_increment): Call size_func, and - find the nearest possible output size which libjpeg can produce - that is still larger than the desired size. - -2002-07-06 Matthias Clasen <maclas@gmx.de> - - * io-tiff.c (tiff_set_error): Handle global_error == NULL - better. - (tiff_image_parse): Don't trust TIFFRGBAImageBegin to set - the "put" routine. (Fixes #87384) - (gdk_pixbuf__tiff_image_stop_load): Don't call TIFFClose too - early. - -2002-07-02 Matthias Clasen <maclas@gmx.de> - - Miscellaneous bmp loader fixes (#85448, #86286, #86287): - - * io-bmp.c (grow_buffer): New function to avoid crashes - on unchecked reallocs. - (DecodeHeader, DecodeColormap, decode_bitmasks, - DoCompressed): Use grow_buffer instead of g_realloc - throughout. Change signatures where necessary to pass the - errors up. - (OneLine16): Fix loading of 16bpp BI_RGB bmps. - (DoCompressed): Rewritten to properly support BI_RLE4 and - skips and jumps. - - Support for compressed ras images (#84994): - - * io-ras.c (RAS2State): Error on unsupported ras variations. - (OneLine8): Fix colormap indexing. - (OneLine): Call updated_func with proper region. - (DoCompressed): New function, handles compressed ras data. - (gdk_pixbuf__ras_image_load_increment): Handle compressed ras - images. - - Better colorspace support for the jpeg loader (#61211): - - * io-jpeg.c (convert_cmyk_to_rgb): New function. - (gdk_pixbuf__jpeg_image_load, - gdk_pixbuf__jpeg_image_load_increment): Allocate a pixbuf with - alpha for 4-channel jpegs and call convert_cmyk_to_rgb for these. - - All of this needs to be merged to GNOME 1.4 gdk-pixbuf. - -2002-06-28 Sven Neumann <sven@gimp.org> - - * gdk-pixbuf-csource.c (print_blurb): converted a Tab to spaces. - -Thu Jun 13 18:11:11 2002 Owen Taylor <otaylor@redhat.com> - - * pixops/pixops.c: Fix problem where when no alpha was - involved, we scaled rather than composited, but then - went ahead and composited anyways. (#76958, Patch - from Matthias Clasen). Needs to be merged to GNOME - 1.4 gdk-pixbuf. - -2002-06-13 Matthias Clasen <maclas@gmx.de> - - * io-jpeg.c: Use libjpeg in buffered-image mode in order to - incrementally display incrementally loaded progressive jpegs. - -2002-06-07 Federico Mena Quintero <federico@ximian.com> - - * io-bmp.c (lsb_32): - (lsb_16): New functions to fetch 32 or 16-bit little-endian values - starting at a specific memory location. We do this instead of - GINT32_FROM_LE() as the latter is simply dereferences a cast, - which doesn't work on platforms with alignment requirements. - Fixes #84083. - -2002-06-01 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.c (pixbuf_check_xbm): Accept xbms starting - with a C comment - those seem to be not uncommon, e.g. the Gimp - produces them. (#82706) - - * io-xbm.c (read_bitmap_file_data): Don't leak memory on certain - invalid inputs. - (gdk_pixbuf__xbm_image_load_real): Don't leak memory on valid inputs. - -2002-05-22 Tor Lillqvist <tml@iki.fi> - - * gdk-pixbuf-io.c (get_libdir): Use GTK_BINARY_VERSION (and not - GTK_VERSION) in the path to the loaders on Win32, too. - - * Makefile.am: Pass GTK_BINARY_VERSION. - -2002-05-22 Federico Mena Quintero <federico@ximian.com> - - * io-xpm.c (pixbuf_create_from_xpm): Ahem, take the rowstride into - account!!! Fixes #82515. - - [This bug is not present in the GNOME 1.4 branch as its XPM loader - does not use gdk_pixbuf_new(); rather it malloc()s a buffer with - no row padding and then uses gdk_pixbuf_new_from_data() on it.] - - [IMPORTANT: The comment above is to make my life easier when - merging stuff across branches. If you make changes to gdk-pixbuf - in either branch, please include a comment in the ChangeLog that - indicates whether this should be merged into the other branch. - Thanks!] - -2002-05-18 Matthias Clasen <maclas@gmx.de> - - * io-tiff.c (tiff_image_parse): fix packing order on bigendian - systems. (#81702) - -Thu May 16 15:17:30 2002 Owen Taylor <otaylor@redhat.com> - - * pixops/pixops.c: Patch from Matthias Clasen to fix some typos - (#77246) - -Thu May 16 15:02:46 2002 Owen Taylor <otaylor@redhat.com> - - * gdk-pixdata.c (gdk_pixdata_to_csource): Fix 64-bit warning. - (#78258) - -2002-05-07 Michael Natterer <mitch@gimp.org> - - * gdk-pixbuf/Makefile.am: build the static pixbuf loaders - conditionally like the dynamic ones so --without-lib<foo> is - honored when building with --disable-modules. (#66867) - -Sun May 5 02:27:01 2002 Soeren Sandmann <sandmann@daimi.au.dk> - - * Makefile.am (noinst_PROGRAMS): remove test-loaders (moved to - gtk+/tests/) - * test-loaders.c, test-images.h: remove - -2002-04-24 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-io.c (gdk_pixbuf_save): Remove the ISO8859-1 - restriction from the description of png tEXt parameters. - - * io-png.c (png_text_to_pixbuf_option): - (gdk_pixbuf__png_image_save): If libpng supports it, - store and retrieve non-ISO8859-1 text as UTF-8. (#76172) - -2002-04-11 Matthias Clasen <maclas@gmx.de> - - More fixes for #77807: - - * io-tga.c (get_contiguous_pixbuf): Helper function to create - a pixbuf with a contiguous pixel array while being careful about - overflow. - - * io-tga.c (fill_in_context, get_image_pseudocolor, - get_image_truecolor, get_image_grayscale): Use - get_contiguous_pixbuf instead of manually allocating image - storage. - - * io-xpm.c (pixbuf_create_from_xpm): - * io-pnm.c (gdk_pixbuf__pnm_image_load): - * io-jpeg.c (gdk_pixbuf__jpeg_image_load): Use gdk_pixbuf_new - instead of manually allocating image storage. - -2002-04-09 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_load_module): Use - priv->image_module->module_name instead of image_type which may - be NULL. - -2002-04-06 Matthias Clasen <maclas@gmx.de> - - * io-png.c (gdk_pixbuf__png_image_load): Restructured to use - gdk_pixbuf_new instead of manually allocating image storage. This - gives us a good rowstride and overflow checks. (#77807) - -2002-04-05 Matthias Clasen <maclas@gmx.de> - - * io-tiff.c (tiff_image_parse): Avoid allocating an extra copy of - the image by using a TIFFRGBAImage{Begin,Get,End} with suitable - put functions instead of TIFFRGBAImage. And check image dimensions - for overflow. - -2002-04-03 Matthias Clasen <maclas@gmx.de> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_get_type): Fix a doc typo. - -2002-03-29 Matthias Clasen <maclas@gmx.de> - - * io-png.c (png_simple_error_callback): libpng error handlers must - not return to their callers, thus longjmp out. This prevents - annoying stderr output from the default error handler. - -2002-03-27 Matthias Clasen <maclas@gmx.de> - - * io-png.c (gdk_pixbuf__png_image_stop_load): Don't leak info_ptr. - - * io-png.c (gdk_pixbuf__png_image_load): Get rid of unused - end_info. Also call png_read_end to check proper ending of the png - file and catch text chunks after the image data. - -2002-03-27 Matthias Clasen <maclas@gmx.de> - - * io-png.c (gdk_pixbuf__png_image_load, - gdk_pixbuf__png_image_begin_load): Make libpng use g_malloc - instead of system malloc. - -2002-03-26 Matthias Clasen <maclas@gmx.de> - - * io-tiff.c (tiff_image_parse): Don't leak pixbuf on error. - - * io-gif.c (gdk_pixbuf__gif_image_load_increment): Don't leak - context->buf on error. - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_close): Make sure to call - stop_load even for short images to prevent memleaks. - -2002-03-25 Matthias Clasen <maclas@gmx.de> - - * io-png.c (setup_png_transformations): Changed signature to - return success and set a GError parameter, adjusted all callers. - Also work around a possible FPE in libpng and always check that - the new info is sane. - -2002-03-23 Matthias Clasen <maclas@gmx.de> - - * io-wbmp.c (gdk_pixbuf__wbmp_image_load_increment): - context->updated_func is NULL during a nonincremental load. - (gdk_pixbuf__wbmp_image_load): Stop reading after the first error. - -2002-03-18 Matthias Clasen <maclas@gmx.de> - - * io-tga.c: Fix assumptions on rowstride by manually allocating a - contiguous pixel buffer. Catch buffer overruns in RLE-modi. - Support grayscale + alpha (which can be written, but not read (!) - by the Gimp). - -2002-03-15 Matthias Clasen <maclas@gmx.de> - - * io-gif.c (gif_get_frame_info): Catch invalid frame dimensions. - -2002-03-13 Matthias Clasen <maclas@gmx.de> - - * test-images.h: Add valid_ras_test and invalid_bmp_1. - - * test-loaders.c (main): Add random tests for ras and pnm and an - invalid bmp which was a crasher until my 2002-03-12 commit. - - * io-pnm.c (gdk_pixbuf__pnm_image_load_increment): Don't unref the - pixbuf on errors. - - * io-ras.c: Handle some errors. - -2002-03-12 Sven Neumann <sven@gimp.org> - - * gdk-pixbuf.c (gdk_pixbuf_fill): use sequential writes instead of - calling memcpy(). Simpler and potentially faster. (#70332) - -2002-03-12 Matthias Clasen <maclas@gmx.de> - - * io-bmp.c (DecodeHeader): Replace a g_assert_not_reached () - which could actually be reached by a proper error status return. - -2002-03-05 Matthias Clasen <maclas@gmx.de> - - * test-loaders.c, test-images.h: More random tests. - - * io-bmp.c (DecodeHeader): Fail gracefully on OOM here. - -Tue Mar 5 10:39:03 2002 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (loaderdir): Put the modules into the - GTK_BINARY_VERSION directory for consistency with - immodules and theme engines. - -Sat Mar 2 22:11:10 2002 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf-io.c (_gdk_pixbuf_load_module): If we - can't load the module using the g_module_build_path() - filename, try loading it as a .la file. - - * test-loaders.c: Look for modules in current directory - rather than .libs, so we find the right .la files. - - * test-loaders.c: Back out some accidental commits. - -Sat Mar 2 21:28:03 2002 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf.c (gdk_pixbuf_new): Bullet-proof against integer - overflow. - -2002-03-03 Tor Lillqvist <tml@iki.fi> - - * gtk-pixbuf.rc.in: Remove. - - * gdk_pixbuf.rc.in: Name like this instead (wrong name used by - mistake by Hans). - - * makefile.msc: Corresponding changes. - - * Makefile.am: Use gdk_pixbuf.rc on Win32. Distribute it. - -2002-02-28 Matthias Clasen <maclas@gmx.de> - - * pixops/pixops.c (tile_make_weights): Move the call to - correct_total() to the right spot. (#72732) - -Wed Feb 27 18:33:04 2002 Owen Taylor <otaylor@redhat.com> - - * gdk-pixdata.c (gdk_pixdata_to_csource): Use {} not - () to group around string assigned to char[]. (#72767, - Tomas ?gren) - -2002-02-21 Havoc Pennington <hp@pobox.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_load_module): remove - C++-commented debug spew, reported by David L. Cooper - -2002-02-15 Matthias Clasen <maclas@gmx.de> - - * pixops/pixops.c (correct_total): New function to make sure - that the weights sum up to the correct total without introducing - negative weights. - (tile_make_weights, bilinear_make_fast_weights, - bilinear_make_weights): Use correct_total. - -2002-02-10 Matthias Clasen <maclas@gmx.de> - - * test-images.h (tiff1_test_3), test-loaders.c (main): Add a - (#ifdef 0'ed) test provoking a segfault in TIFFReadDirectory(). - - * io-ico.c (DecodeHeader): Check that pixbuf could be allocated. - - * test-images.h (ico_test_2), test-loaders.c (main): Test the - previous change. - - * io-wbmp.c (gdk_pixbuf__wbmp_image_load_increment): Don't write - beyond the end of buffer if width % 8 != 0. - - * io-tga.c (try_preload): Enforce that ctx->hdr->type is one of - the supported types, otherwise parse_data_for_row () will not make - any progress, leading to an infinite loop. - -Mon Feb 11 14:31:53 2002 Owen Taylor <otaylor@redhat.com> - - * pixops/pixops.c (bilinear_make_weights): Fix handing of - overall alpha. - -2002-02-10 Matthias Clasen <maclas@gmx.de> - - * test-loaders.c (main): Enable some tests which should work - now. - - * io-wbmp.c (gdk_pixbuf__wbmp_image_load_increment): Detect - invalid image dimensions and insufficient memory. - - * io-tga.c (try_preload): Detect invalid image dimensions. - (gdk_pixbuf__tga_stop_load): Don't try to unref NULL pointers. - - * io-ico.c (DecodeHeader): Detect some invalid headers and - don't segfault. - -Fri Feb 8 23:11:15 2002 Owen Taylor <otaylor@redhat.com> - - * pixops/pixops.c: Force all weight arrays to sum exactly - to 65535. (Fixes #70971, reported by Federico Mena Quintero) - - * Makefile.am (libgdk_pixbuf_1_3_la_DEPENDENCIES): Add - libpixops.la. - -2002-02-08 Federico Mena Quintero <federico@ximian.com> - - * pixops/pixops.h: Fix comment; PixopsInterpType -> GdkInterpType. - -2002-02-08 Darin Adler <darin@bentspoon.com> - - * io-xbm.c: (next_int): Wean this from <ctype.h>. - -2002-02-01 Matthias Clasen <matthiasc@poet.de> - - * Makefile.am: Build the tga loader as a static library. (#70157) - - * io-ico.c: Merge 16- and 32-bit ico support from the stable - branch. (#61179) - - * io-gif.c: Recomposite all images if the animation size changes - while loading. (#70055) - - * gdk-pixbuf.c (gdk-pixbuf-fill): Make it work for subpixbufs. - (#70055) - -Sat Jan 19 20:49:20 2002 Manish Singh <yosh@gimp.org> - - * io-jpeg.c, io-png.c: Made sure all the error cases involving - jpeg or png load/saves clean themselves up properly. Marked some - variables needed for cleanup volatile so they aren't clobbered by - setjmp. - -Fri Jan 11 18:05:07 2002 Owen Taylor <otaylor@redhat.com> - - * pixops/pixops.c: Fix integer overflow for the values - passed to the pixel functions. (#55148, fix from Michael Hore) - -Fri Jan 11 17:53:58 2002 Owen Taylor <otaylor@redhat.com> - - * pixops/pixops.c (pixops_scale_nearest): Remove meaningless - FIXME. - - * pixops/pixops.c (pixops_process): Comment the computation - of run_end_index and fix some edge cases. - - * pixops/{scale_line_22_33_mmx.S, composite_line_22_4a4_mmx.S: - composite_line_color_22_4a4_mmx.S}: Handle the case where - dest <= dest_end properly. (#52001, fix from Michael Hore) - -Thu Jan 10 16:48:30 2002 Owen Taylor <otaylor@redhat.com> - - * pixops/pixops.c: Replace some hardcoded values with the - SUBSAMPLE constant used elsewhere. (#51033) - -Wed Jan 9 11:29:44 2002 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (s-enum-types-h): Include glib-object.h, - Add G_BEGIN_DECLS/END_DECLS to gdk-pixbuf-enum-types.h. (#68325, - Mikael Hermansson) - - * *.h: G_BEGIN_DECLS cleanups. - -Tue Jan 8 10:58:04 2002 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf-util.c (gdk_pixbuf_saturate_and_pixelate): - - Massive cleanup, make actually legible. - - Fix some clamp-to-range bugs found by Jim Cape (#68231). - - Add a g_return_if_fail() if src and dest alpha don't match. - - Allow for src_rowstride != dest_rowstride. - -2002-01-04 Hans Breuer <hans@breuer.org> - - * gdk_pixbuf.def : don't export functions prefixed - with underscore - - * makefile.msc : use -FImsvc_recommende_pragmas.h - -Thu Jan 3 19:31:58 2002 Owen Taylor <otaylor@redhat.com> - - * pixops/pixops.c (scale_line_22_33): Fix and uncomment - non-MMX version. - - * pixops/pixops.c (pixops_composite_nearest): Remove a - division. - - * pixops/pixops.c (pixops_composite): Add some docs - about the parameters. - - * pixops/README: Add notes about the correct algorithms - for alpha compositing and how to implement them quickly. - -2001-12-29 Tor Lillqvist <tml@iki.fi> - - * Makefile.am (EXTRA_DIST): Add makefile.msc. - -Sat Dec 22 15:31:20 2001 Owen Taylor <otaylor@redhat.com> - - * gdk-pixdata.h: Fix trailing "," in enumeration. - -2001-12-17 Matthias Clasen <matthiasc@poet.de> - - * gdk-pixbuf.c, gdk-pixbuf-io.c, gdk-pixbuf-animation.c, - gdk-pixbuf-data.c, gdk-pixbuf-loader.c, gdk-pixbuf-scale.c, - gdk-pixbuf-util.c, gdk-pixdata.c: Markup fixes. - -2001-12-16 Havoc Pennington <hp@pobox.com> - - * gdk-pixbuf-scale.c: docs enhancements - -2001-12-14 Sebastian Wilhelmi <wilhelmi@ira.uka.de> - - * io-xpm.c: Use g_ascii_strcasecmp() instead of g_strcasecmp(). - -2001-12-13 Sebastian Wilhelmi <wilhelmi@ira.uka.de> - - * gdk-pixbuf-animation.c, gdk-pixbuf-loader.c, gdk-pixpuf.c, - io-gif-animation.c, io-gif.c, io-tiff.c, test-loaders.c: Remove - assorted G_OBJECT casts where unnecessary. - - * gdk-pixbuf-loader.c: Call g_object_ref and g_object_unref - instead of gdk_pixbuf_animation_ref and gdk_pixbuf_animation_unref - resp. - - * gdk-pixbuf-csource.c, io-bmp.c, io-gif-animation.c, io-ico.c, - io-jpeg.c, io-png.c, io-pnm.c, io-ras.c, io-tga.c, io-wbmp.c, - io-xbm.c, io-xpm.c, test-gdk-pixbuf.c: Dito for gdk_pixbuf_ref and - gdk_pixbuf_unref. - - * Makefile.am, pixops/Makefile.am: Compile everything with - -DG_DISABLE_DEPRECATED -DGDK_PIXBUF_DISABLE_DEPRECATED - - * gdk-pixdata.c: Use g_ascii_strup() instead of g_strup(). - - * io-xpm.c: Use g_ascii_strcasecmp() instead of g_strcasecmp(). - -2001-12-12 Matthias Clasen <matthiasc@poet.de> - - * gdk-pixbuf-io.c: Markup fixes. - -2001-12-12 Matthias Clasen <matthiasc@poet.de> - - * Makefile.am (INCLUDES): Define G_LOG_DOMAIN. (#66412) - - * gdk-pixbuf-loader.c, gdk-pixbuf-util.c: Markup fixes. - -2001-12-11 Michael Natterer <mitch@gimp.org> - - * io-png.c: gdk_pixbuf__png_image_save: removed wrong endian - conversion stuff; don't copy RGB pixbufs' lines around before - saving them. - -2001-12-05 Matthias Clasen <matthiasc@poet.de> - - * gdk-pixbuf.h (gdk_pixbuf_ref, gdk_pixbuf_unref, - gdk_pixbuf_animation_ref, gdk_pixbuf_animation_unref): - Deprecate. (#66208) - -Tue Dec 4 11:45:45 2001 Owen Taylor <otaylor@redhat.com> - - * io-xpm.c (pixbuf_create_from_xpm): Fill in color - fields to black for transparent colors since we'll - later initialize pixels from them. (Fixes purify - errors, #66093, HideToshi Tajima) - -2001-11-30 Tor Lillqvist <tml@iki.fi> - - * gdk_pixbuf.def: Add gdk_pixbuf_get_option. - -Fri Nov 30 15:55:34 2001 Owen Taylor <otaylor@redhat.com> - - * gdk-pixdata.c (gdk_pixdata_deserialize): Fix - alignment problem in deserialization, (#65785, - reported by Hidetoshi Tajima) - -2001-11-28 Manish Singh <yosh@gimp.org> - - * gdk-pixbuf/io-bmp.c (gdk_pixbuf__bmp_image_load_increment): Fill - in missing error parameters to DecodeHeader and DecodeColormap. - -2001-11-21 Federico Mena Quintero <federico@ximian.com> - - Fix Ximian bug #12125; merged from gdk-pixbuf stable. - - * gdk-pixbuf/io-bmp.c (gdk_pixbuf__bmp_image_load_increment): Use - a simple state machine instead of a scary if/else chain. - (DecodeHeader): Set the reading state. - (DecodeColormap): Set the reading state. - (decode_bitmasks): New function, decodes the bitmasks for - BI_BITFIELDS coding. - (OneLine32): Handle BI_BITFIELDS coding. - (OneLine16): Likewise. - -2001-11-18 Hans Breuer <hans@breuer.org> - - * io-xpm.c : use g_strcasecmp(), some poor platforms - don't have strcasecmp() - - * makefile.msc : do INCLUDE_png etc. definition here to avoid - my temporary 'gdk-pixbuf-io-include.h' hack - -Sun Nov 18 07:54:22 2001 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf-loader.c: Remove include of gobject/signal.h. - -2001-11-03 Sebastian Wilhelmi <wilhelmi@ira.uka.de> - - * gdk-pixbuf-loader.c, gdk-pixbuf-scale.c: Documentation fixes. - -2001-10-29 Tor Lillqvist <tml@iki.fi> - - * Makefile.am: Use -no-undefined on Win32. Make - libgdk_pixbuf_1_3_la_OBJECTS depend on - gdk-pixbuf-marshal.c. Install import libraries. - - * gdk_pixbuf.def: Update. - - * gdk-pixbuf-io.c: (Win32) Use G_WIN32_DLLMAIN_FOR_DLL_NAME, saves - the actual DLL name of libgdk_pixbuf. - (get_libdir): Use it instead of guessing. - - * io-xbm.c (gdk_pixbuf__xbm_image_begin_load): Use - g_file_open_tmp() insread of mkstemp(). - -2001-10-18 Matthias Clasen <matthiasc@poet.de> - - * io-xbm.c (gdk_pixbuf__xbm_image_load_real): Don't dereference - context when it may be NULL. (#62344) - -2001-10-16 Matthias Clasen <matthiasc@poet.de> - - * gdk-pixdata.c, gdk-pixdata.h: Documentation. - - * gdk-pixbuf-csource.1: Spelling fixes. - -Wed Oct 10 11:52:17 2001 Owen Taylor <otaylor@redhat.com> - - * gdk-pixdata.c gdk-pixbuf.h: Get rid of - GDK_PIXBUF_ERROR_HEADER/PIXEL_CORRUPT and use CORRUPT_IMAGE. - Get rid fo GD_PIXBUF_ERROR_UNKNOWN_FORMAT and use the - existing UKNOWN_TYPE error. (#58308) - - * gdk-pixbuf.h, gdk-pixdata.c: Rename gdk_pixbuf_new_from_stream() - back to gdk_pixbuf_new_from_inline(). Rework docs to try - and be helpful for the common case. (#58308) - -2001-10-05 Sven Neumann <sven@gimp.org> - - * gdk-pixbuf/gdk-pixbuf-io.c - * gdk-pixbuf/gdk-pixbuf-private.h - * gdk-pixbuf/gdk-pixbuf.c - * gdk-pixbuf/gdk-pixbuf.h - * gdk-pixbuf/io-jpeg.c - * gdk-pixbuf/io-png.c: changed GDK_PIXBUF_ERROR_BAD_OPTION_VALUE to - GDK_PIXBUF_ERROR_BAD_OPTION to we can use it for bad keys too. Added - new public API gdk_pixbuf_get_option() to retrieve key/value pairs - set by an image loader. Added support for saving and reading PNG tEXt - chunks in PNG images. - -Tue Oct 2 11:29:50 2001 Owen Taylor <otaylor@redhat.com> - - * gdk-pixdata.c (gdk_pixdata_to_csource): Fix indentation - use a macro to make code a bit more readable. - -2001-10-02 Sven Neumann <sven@gimp.org> - - * gdk-pixdata.c: g_string_printfa => g_string_append_printf. - -Wed Sep 26 18:08:19 2001 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (s-enum-types-h): Fix a typo in the include - guards. (#61254, Skip Montaro) - -2001-09-21 Matthias Clasen <matthiasc@poet.de> - - * io-xpm.c (xpm_extract_color): Rewritten to handle - xpm colormap entries more thoroughly. (#59939) - -2001-09-21 Hans Breuer <hans@breuer.org> - - * gdk-pixbuf.def : updated externals - - * makefile.msc : generate gdk-pixbuf-enum-types.[hc] - -Thu Sep 20 17:22:48 2001 Owen Taylor <otaylor@redhat.com> - - * io-tiff.c (gdk_pixbuf__tiff_image_load): On OSF, apparently fseek() - works in some on-demand way, so the fseek - gdk_pixbuf_new_from_file() doesn't work here since we are using - the raw file descriptor. So, we call lseek() on the fileno(f) - before using it. (#60840). - -2001-09-20 James Henstridge <james@daa.com.au> - - * Makefile.am (gdk-pixbuf-enum-types.c): same change as in pango, - so that flags types are registered as flags rather than enums (not - that there are any flags here at the moment). - -Wed Sep 19 00:28:24 2001 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (gdk_pixbuf_headers): Don't include - gkd-pixbuf-features.h here since is in builddir - and confuses autogen rules. - - * Makefile.am: Don't += variables before they have values, - automake-1.5 doesn't like it. - - * Makefile.am: Fix srcdir != builddir for gdk-pixbuf-enum-types.c. - - * Makefile.am: The whitespace strikes back. - -2001-09-17 Matt Wilson <msw@redhat.com> - - * Makefile.am (libpixbufloader_xbm_la_LDFLAGS): removed duplicate - LDFLAGS definition, use the -avoid-version one. - (libpixbufloader_tga_la_LDFLAGS): likewise - -Mon Sep 17 11:49:02 2001 Owen Taylor <otaylor@redhat.com> - - * pixops/*: Mirror GdkInterpType to PixopsInterpType - to avoid including gdk-pixbuf headers. - -2001-09-16 James Henstridge <james@daa.com.au> - - * .cvsignore: add generated files to ignore list. - - * gdk-pixbuf.h: include gdk-pixbuf-enum-types.h - - * Makefile.am: add rules to build gdk-pixbuf-enum-types.[ch] - -Fri Sep 14 23:22:12 2001 Matthias Clasen <matthiasc@poet.de> - - * io-pnm.c (pnm_read_header): Use GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - not GDK_PIXBUF_ERROR_HEADER_CORRUPT. (#58308) - -Fri Sep 14 22:53:45 2001 Matthias Clasen <matthiasc@poet.de> - - * io-jpeg.c (gdk_pixbuf__jpeg_image_begin_load): Handle - out-of-memory situation better. - - * io-pnm.c: Robustness fixes for pnm loader - - * io-gif.c: Make gif loader survive TEST_RANDOMLY_MODIFY - - * io-xpm.c (parse_color): detect very long color strings - - All of the above from Matthias Clasen <matthiasc@poet.de>, - the remaining from Soeren Sandmann <sandmann@daimi.au.dk>. - - * test-images.h: add tests: - - four valid ppm's, eight invalid (matthiasc@poet.de) - - one invalid xpm (matthiasc@poet.de) - - one valid tga, one invalid (sandmann@daimi.au.dk) - - one invalid tiff (sandmann@daimi.au.dk - - * test-loaders.c: enable tests for ppm, png, gif, tga, tiff, xpm - - * io-tiff.c (gdk_pixbuf__tiff_image_stop_load): TIFFClientOpen can - fail - detect it when it happens - - * io-tga.c (gdk_pixbuf__tga_load_increment): Fail if there is too - much data in file - - * gdk-pixbuf-io.c: moved wbmb check after ico check to avoid false - positives - -Fri Sep 14 00:30:48 2001 Tim Janik <timj@gtk.org> - - * Makefile.am: don't used BUILT_SOURCES to build marshal - files, as in conjunction with stamp files, this can - lead to endless rebuilding loops. - -Tue Sep 4 00:22:07 2001 Owen Taylor <otaylor@redhat.com> - - * Makefile.am: Fix EXTRA_DIST for gdk-pixbuf-csource.1 - -Tue Sep 4 03:09:52 2001 Tim Janik <timj@gtk.org> - - * gdk-pixbuf-csource.1: new file, manual page for - the publically installed gdk-pixbuf-csource utility. - -Thu Aug 30 08:30:03 2001 Matthias Clasen <matthiasc@poet.de> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_close): Propagate - errors from gdk_pixbuf_loader_load_module. - -Thu Aug 30 08:27:37 2001 Matthias Clasen <matthiasc@poet.de> - - * io-png.c (png_row_callback): Check that row_num is valid. - -Tue Aug 28 21:05:26 2001 Matthias Clasen <matthiasc@poet.de> - - * io-bmp.c (OneLine): Emit area_updated signal with proper - area information. (#52002) - -Tue Aug 28 20:03:43 2001 Matthias Clasen <matthiasc@poet.de> - - * test-loaders.c (test_loader): Catch errors at close time. - * test-loaders.c (main): Remove C++ comments. - -2001-08-21 Matthias Clasen <matthiasc@poet.de> - - * Makefile.am, gdk-pixbuf-io.c, pixbufloader_tga.def, - io-tga.c: Add tga loader, patch by Nicola Girardi. (#56067) - -2001-08-20 Matthias Clasen <matthiasc@poet.de> - - * test-images.h, test-loaders.c: Add ico and wbmp tests. - * io-jpeg.c (gdk_pixbuf__jpeg_image_save): Fail with a suitable - error if buffer allocation fails. - * io-ico.c: Make .ICO loader more robust. - All of these are due to sandmann@daimi.au.dk (#50187) - -2001-08-19 Sven Neumann <sven@gimp.org> - - * pixops/pixops.c: applied some simple but effective optimizations - to pixops_composite_nearest() and pixops_composite_color_nearest(). - -2001-08-07 Sven Neumann <sven@gimp.org> - - * gdk-pixbuf.c (gdk_pixbuf_fill): a comment asked to optimize this - function, so that's what I did. - -2001-08-06 Kjartan Maraas <kmaraas@gnome.org> - - * gdk-pixdata.c: Fix a typo. - -2001-07-30 Hans Breuer <hans@breuer.org> - - * pixops/makefile.msc : new file - * makefile.msc : use it to complete the build - -2001-07-20 Hans Breuer <hans@breuer.org> - - * gdk-pixdata.c : don't 'g_tohl (*istream++)', but move - pointer increment out of the macro, because at least one - compiler (msvc 5.0) gets confused otherwise (applies the - wrong increment). - - * gdk_pixbuf.def : updated exports - - * makefile.msc : reflect gdk-pixbuf-csource changes - -2001-07-17 Darin Adler <darin@bentspoon.com> - - * gdk-pixbuf-csource.c: Add missing <stdlib.h> include. - * io-png.c: (setup_png_transformations): Add ifdef so we compile - without warnings with G_DISABLE_CHECKS on. - * io-pnm.c: (gdk_pixbuf__pnm_image_load_increment): Add a missing - const. - * io-wbmp.c: (getin), (get_mbi): Add a missing const. - * io-xbm.c: (gdk_pixbuf__xbm_image_load_real): Get rid of some - unused locals and add an initial value to quiet the compiler's - unintialized variable warning. - * pixops/pixops.c: Put an ifdef around some dead code. - -Thu Jul 5 10:17:15 2001 Owen Taylor <otaylor@redhat.com> - - * pixops/Makefile.am (noinst_LTLIBRARIES): Switch - over to the new include flags AC_SUBST(). (Problem - pointed out by Mikael Hermansson.) - -2001-06-29 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_class_init): fix for - G_DISABLE_COMPAT - -Thu Jun 28 21:54:19 2001 Owen Taylor <otaylor@redhat.com> - - * make-inline-pixbuf.c test-gdk-pixbuf.c test-loaders.c - gdk-pixbuf-csource.c: Fix args to g_type_init (). - -2001-06-28 Havoc Pennington <hp@pobox.com> - - * gdk-pixdata.c: <string.h> - - * gdk-pixbuf-io.c (get_libdir): fix typo in dll name (aren't we - also leaking memory here from g_strdup_printf?) - -Tue Jun 26 09:48:02 2001 Tim Janik <timj@gtk.org> - - * Makefile.am (noinst_PROGRAMS): get rid of make-inline-pixbuf - - * gdk-pixbuf-data.[hc]: provide gdk_pixbuf_new_from_stream() - instead from gdk_pixbuf_new_from_inline(). - - * gdk-pixdata.[hc]: auxillary GdkPixdata structure, public - installed API for applications that need to serialize/deserialize - on their own (gimp, BEAST). - - * gdk-pixbuf/gdk-pixbuf-csource.c: provide publically installed - program that can dump images in CSource format and Pixbuf - stream format. supports RLE encoding, MACRO formatting etc... - invoke with --help. - -Mon Jun 25 00:28:11 2001 Owen Taylor <otaylor@redhat.com> - - * Makefile.am: Actually update timestamps, so rules don't - constantly run. - -2001-06-11 Havoc Pennington <hp@redhat.com> - - * Makefile.am (stamp-gdk-pixbuf-marshal.c): glib_genmarshal - already includes top_builddir - -2001-06-08 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_load_module): remove - bogus g_return_if_fail - - * io-gif.c (gif_get_lzw): if delay time is 0 or smaller than - likely timeout resolution, set it to an arbitrarily-chosen short - delay. - Fixes bug #55953 from warmenhoven@yahoo.com - -2001-06-07 Havoc Pennington <hp@redhat.com> - - * Makefile.am: use Owen's new way of doing stampfiles/generated - sources - -2001-06-07 Havoc Pennington <hp@redhat.com> - - * Makefile.am (gdk-pixbuf-marshal.c): fix up the glib-genmarshal path - -2001-06-05 Havoc Pennington <hp@redhat.com> - - * test-loaders.c (main): use putenv not setenv, reported by - Armin Theissen - -2001-05-08 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf-util.c (gdk_pixbuf_add_alpha): docs fixup, - and fix behavior to still subst color if the original image - had alpha - -2001-06-04 Havoc Pennington <hp@redhat.com> - - * io-pnm.c (pnm_skip_whitespace): patch from Szekeres Istvan, - bug #52560 - -2001-06-01 Havoc Pennington <hp@redhat.com> - - Apply patch from sandmann@daimi.au.dk, with some tweaks. - Makes things a bit more robust, and adds test-loaders.c - which is good for finding further robustness bugs to fix. - - * io-tiff.c: Try to work around libtiff suckiness a bit; - put a giant thread lock on the whole loader, - paranoically check both whether error handlers were called and - also whether functions return false. Handle case where width or - height is 0. Various cleanups. - - * io-png.c (gdk_pixbuf__png_image_stop_load): only unref pixbuf - if it existed - (png_error_callback): apparently libpng expects you to longjmp out - of this thing? - - * io-gif.c (struct _GifContext): remove unused "pixbuf" field - (lzw_read_byte): change "Mail jrb if this fails" g_warning - to a g_set_error() - (gif_get_lzw): check for out-of-memory - (gif_prepare_lzw): catch/report an error - (new_context): use try_malloc, since GifContext is nearly 70K - (gdk_pixbuf__gif_image_load_increment): set context->buf to NULL - so we don't crash later. - - * Makefile.am: Add test-loaders - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_close): handle context == - NULL due to errors - -2001-05-29 Darin Adler <darin@eazel.com> - - * gdk-pixbuf.h: Fix prototype to use "(void)" instead of "()". - -Mon May 28 14:21:35 2001 Jonathan Blandford <jrb@redhat.com> - - * io-bmp.c: Patch from Helmethead <hoshem@mel.comcen.com.au> to - fix up bmp decoder to: - - adds 16 bpp bmp support (bug #53884) - - adds OS/2 1.x format bmp support (bug #54964) - - adds 4 bpp RLE compressed bmp support - - adds 1 bpp colormap support - - fixes negative height (top down) bmp support - -2001-05-25 Hans Breuer <hans@breuer.org> - - * gdk_pixbuf.def : reflect Havoc's recent api change - -Sun May 20 12:53:49 2001 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (libgdk_pixbuf_1_3_la_LDFLAGS): Remove an - excess $(GLIB_LIBS). - -Sun May 13 11:59:11 2001 Owen Taylor <otaylor@redhat.com> - - * Makefile.am: Make modules depend on libgdk_pixbuf.la. - -2001-05-04 Havoc Pennington <hp@redhat.com> - - * pixops/pixops.c (pixops_process): merge fix from stable: Patch - from hoshem@mel.comcen.com.au to fix nonzero X offsets. Fixes - bug #50371. - - * gdk-pixbuf/pixops/pixops.c (pixops_composite_nearest): merge - from stable: Patch from OKADA Mitsuru <m-okada@fjb.co.jp> to fix - confusion of using "src" instead of "p". - (pixops_composite_color_nearest): Use a more accurate (and - correct, to begin with) compositing method. This cures checks - showing through on images with no alpha. - - * gdk-pixbuf.c (gdk_pixbuf_fill): fix bug that left some trailing - bytes unfilled. - - * gdk-pixbuf-io.h: fix UpdatedNotifyFunc to use signed ints - - * gdk-pixbuf-loader.h (struct _GdkPixbufLoaderClass): Change - area_updated signal to use signed ints. Removed animation-related - signals. - - * io-gif.c, io-gif-animation.h, io-gif-animation.c: Massive - rewrite action - - * gdk-pixbuf-animation.c: Add GdkPixbufAnimationIter to abstract - all the pesky details. Remove old frame-based API. Make - GdkPixbufAnimation an abstract base class, derived by the loaders. - -Sun Apr 22 15:51:32 2001 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (LDADDS): Add $(MATH_LIB). - -2001-04-18 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf.c (gdk_pixbuf_fill): Function to fill pixbuf with a - given color. - -Wed Apr 4 01:41:02 2001 Tim Janik <timj@gtk.org> - - * pixops/Makefile.am (noinst_LTLIBRARIES): include $top_srcdir - so we don't try to get <gtk/gtkobject.h> from standard search - paths. - - * Makefile.am (gdk-pixbuf-marshal.c): use deps from srcdir. - add gdk-pixbuf-marshal.list to EXTRA_DIST. - take gdk-pixbuf-marshal.h out of _la sources. - -2001-03-19 Tor Lillqvist <tml@iki.fi> - - * makefile.mingw.in: Handle gdk-pixbuf-marshal.c. - - * gdk_pixbuf.def: Update. - - * pixbufloader_*.def: Just export the fill_vtable functions now. - -2001-03-18 Mike Kestner <mkestner@ameritech.net> - - * make-inline-pixbuf.c (main): Added logic to remove output when - failures occur. - -2001-03-14 Havoc Pennington <hp@redhat.com> - - * Makefile.am (gdk-pixbuf-marshal.c): Use different temporary file - from gdk-pixbuf-marshal.h, fixes parallel makes. - -Thu Mar 1 04:01:57 2001 Tim Janik <timj@gtk.org> - - * test-gdk-pixbuf.c: fixed includes. - -2001-02-18 Havoc Pennington <hp@pobox.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_load_module): prepend underscore - (gdk_pixbuf_get_named_module): prepend underscore - (gdk_pixbuf_get_module): prepend underscore - -2001-02-19 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_load_module): const fix - -2001-02-17 Havoc Pennington <hp@pobox.com> - - * gdk-pixbuf-loader.c (gdk_pixbuf_loader_new_with_type): docs - -2001-02-07 Alexander Larsson <alexl@redhat.com> - - * io-xpm.c (free_buffer): - Use g_free, since the buffer is allocated with g_try_alloc(). - -2001-02-06 Christophe Merlet <redfox@eikonex.org> - - * gdk-pixbuf-data.c: Fixes a minor typo. - -Sun Feb 4 07:59:57 2001 Tim Janik <timj@gtk.org> - - * gdk-pixbuf.h: DOH! don't include glib/gobject.h but glib-object.h, - we finally need the gobject->gruntime rename. - - * *.c: scratched calls to g_type_init(), there's simply no point in - doing that, use gtk_init(). - -2001-02-01 Havoc Pennington <hp@pobox.com> - - * gdk-pixbuf-loader.c, gdk-pixbuf-loader.h: rename "private" field - in struct to "priv" for C++ - -2001-01-31 Havoc Pennington <hp@pobox.com> - - * gdk-pixbuf.c: include glib-object.h instead of gvaluetypes.h - -2001-01-26 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf-io.c (mname): fix included modules case. - -2001-01-22 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_xpm_data): check errors - from gdk_pixbuf_load_module - -2001-01-22 Havoc Pennington <hp@redhat.com> - - * Makefile.am: Add built marshaller files to support - GdkPixbufLoader signals - - * gdk-pixbuf-io.c (gdk_pixbuf_load_module): have - GDK_PIXBUF_MODULEDIR unconditionally replace the compiled-in - module location, rather than acting as a fallback, because we are - using GDK_PIXBUF_MODULEDIR to use gdk-pixbuf before installing it. - - * gdk-pixbuf.h: include gdk-pixbuf-loader.h - - * gdk-pixbuf-loader.h, gdk-pixbuf-loader.c: Move back over here - from gtk, and add error to close(), because stop_load may do - parsing of the image. - - * pixops/have_mmx.S (_pixops_have_mmx): add newline at end of file - - * io-*.c: make individual operations static, and add fill_vtable - functions which are exported. Fix the collection of type warnings - that surfaced, including a number of functions that didn't - properly take a GError and some that weren't - const-correct. Involved adding error handling for a few loaders. - - * gdk-pixbuf-io.h: Add error reporting to stop_load function - - * gdk-pixbuf-io.c (gdk_pixbuf_load_module): change to just look up - a function that fills in the GdkPixbufModule vtable, instead of - looking up all the image functions individually; this means we - can get type safety within modules for the loader functions. - Also it means you don't have to keep the statically compiled and - GModule versions in sync. - - * test-gdk-pixbuf.c (main): remove gdk_pixbuf_init() - - * make-inline-pixbuf.c (main): remove call to gdk_pixbuf_init() - - * gdk-pixbuf.h: nuke gdk_pixbuf_init() - - * gdk-pixbuf-animation.c (gdk_pixbuf_frame_get_type): g_type_init - () here - - * gdk-pixbuf.c (gdk_pixbuf_get_type): g_type_init () here - - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_get_type): - g_type_init() here - -2001-01-20 John Harper <jsh@eazel.com> - - * io-xbm.c: new pixbuf loader, for X bitmap files. Basically a - collision between Xlib's RdBitF.c and io-tiff.c - - * gdk-pixbuf-io.c, Makefile.am, pixbufloader_xbm.def: added - io-xbm.c support - - [ merged from stable gdk-pixbuf module. Untested, but it - compiles, and works fine in the stable module ] - -2001-01-18 Tor Lillqvist <tml@iki.fi> - - * gdk-pixbuf-io.c (get_libdir): (Win32) Use the new - g_win32_get_package_installation_subdirectory() function. No need - to include windows.h. - (gtk_win32_get_installation_directory): Remove this then. - -2001-01-01 Havoc Pennington <hp@redhat.com> - - * Makefile.am (libgdk_pixbuf_1_3_la_LDFLAGS): add - @LIBTOOL_EXPORT_OPTIONS@ - -2000-12-30 Tor Lillqvist <tml@iki.fi> - - * gdk_pixbuf.def: Update. - -2000-12-16 Havoc Pennington <hp@pobox.com> - - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_new_from_file): ref - the pixbuf in the frame, so we can use gdk_pixbuf_frame_free - (gdk_pixbuf_frame_copy): new function - (gdk_pixbuf_frame_free): new function - (gdk_pixbuf_frame_get_type): new function - (GDK_TYPE_PIXBUF_FRAME): macro to get type for GdkPixbufFrame - -Tue Nov 14 11:51:26 2000 Owen Taylor <otaylor@redhat.com> - - * Makefile.am: Add -avoid-version for all modules. - -2000-11-13 Havoc Pennington <hp@redhat.com> - - * io-png.c (png_simple_error_callback): fix error message to not - say "save" since it's used for loading - -2000-11-11 Hans Breuer <Hans@Breuer.Org> - - * gdk-pixbuf-io.c : Fix all function prototype macros for self - contained image handlers (!USE_G_MODULE). Files to save should - be opened in binary mode, fopen(s, "wb"). - - * io-xpm.c : added HAVE_UNISTD_H condition - -2000-11-11 Tor Lillqvist <tml@iki.fi> - - * gdk_pixbuf.def: Add gdk_pixbuf_new_subpixbuf. - - * io-tiff.c (gdk_pixbuf__tiff_image_begin_load): Use - g_file_open_tmp() (just added to GLib) instead of mkstemp() (or - mktemp() and open()). - - * io-xpm.c (gdk_pixbuf__xpm_image_begin_load): Ditto. - -2000-11-01 Havoc Pennington <hp@pobox.com> - - * gdk-pixbuf.c (gdk_pixbuf_new_subpixbuf): New function to create - a pixbuf pointing to a subregion of another pixbuf. - -2000-10-16 Tor Lillqvist <tml@iki.fi> - - * gdk-pixbuf-io.c: Define also m_save (for the non-gmodule case). - -2000-10-16 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_get_module) - (gdk_pixbuf_get_named_module) (gdk_pixbuf_load_module): - add error reporting here also - - * make-inline-pixbuf.c (main): use GError - - * io-xpm.c: include unistd.h - - * gdk-pixbuf-util.c: include string.h - - * io-*.c: add error reporting - - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_new_from_file): add - error reporting - - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_file): Add error reporting - - * gdk-pixbuf-io.h: Add GError** to load_increment and load - methods - - * gdk-pixbuf-io.c (gdk_pixbuf_save) (gdk_pixbuf_savev): return - a G_FILE_ERROR if we fail to write or close the file. - - * gdk-pixbuf.h: remove GDK_PIXBUF_ERROR_IO, instead we'll use - G_FILE_ERROR_*. Rename enum to GdkPixbufError, properly following - the GError naming rules. Add GError** to load functions. - -2000-10-06 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf.h: add GdkPixbufAlphaMode - -2000-10-06 Havoc Pennington <hp@redhat.com> - - This entry is a summary of the merged-in changes from 1.0. - Relevant original ChangeLog entries are spliced in after - this entry; the files they refer to are from the 1.0 - gdk-pixbuf sources. - - * pixops/pixops.c (pixops_composite_nearest): sync a small fix - from 1.0 - - * io-xpm.c (xpm_seek_string): add fscanf error check from 1.0 - Add progressive loader from 1.0 - - * io-tiff.c (gdk_pixbuf__tiff_image_begin_load): mem leak fixes - from 1.0 tree - - * io-pnm.c: new version from 1.0 tree - - * io-jpeg.c (gdk_pixbuf__jpeg_image_load): sync from 1.0, use - malloc not g_malloc - - * io-gif.c (lzw_read_byte): sync from 1.0, change a g_error to - g_warning - (gif_get_next_step): return 0 here, sync from 1.0 - - * gdk-pixbuf-util.c: sync email address change for Cody - Russell - -2000-09-11 Jeffrey Stedfast <fejj@helixcode.com> - - * gdk-pixbuf/io-pnm.c: Pretty much totally rewrote again because - last nights code was still "broken". Should now properly handle - all error conditions gracefully. - -2000-09-10 Jeffrey Stedfast <fejj@helixcode.com> - - * gdk-pixbuf/io-pnm.c: Rewrote. - -2000-09-09 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf/pixops/pixops.c (pixops_composite_nearest): Compute - the correct dest offset. - -2000-08-25 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf/io-xpm.c: #include <unistd.h> - -2000-08-05 Larry Ewing <lewing@helixcode.com> - - * gdk-pixbuf/io-tiff.c: stop leaking context->tempname. - - * gdk-pixbuf/io-xpm.c: same as above. - -2000-07-26 Michael Meeks <michael@helixcode.com> - - * gdk-pixbuf/io-jpeg.c (gdk_pixbuf__jpeg_image_load): make - g_malloc a malloc. - -2000-07-21 Larry Ewing <lewing@helixcode.com> - - * gdk-pixbuf/io-xpm.c: add a fake progressive loader so that - xpm at least supports the progressive interface like the one in - io-tiff.c. This should be reimplemented as an actual progressive - loader. - -2000-07-19 Jonathan Blandford <jrb@redhat.com> - - * demo/pixbuf-demo.c (update_timeout): changed scaling level to - make it look better. - * gdk-pixbuf/testpixbuf.c (update_timeout): Patch from michael - meeks to handle errors better. - -2000-10-07 Tor Lillqvist <tml@iki.fi> - - * gdk_pixbuf.def - * pixbufloader_jpeg.def - * pixbufloader_png.def: Add new entry points. - - * makefile.mingw.in: Use libintl. - -2000-10-06 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_save): s/format/type/g to be - consistent with gdk_pixbuf_loader_new_with_type(). - Return runtime error if a module is missing. - - * gdk-pixbuf.h: add GDK_PIXBUF_ERROR_UNKNOWN_TYPE - -2000-10-05 Havoc Pennington <hp@redhat.com> - - Pixbuf saving, patch from David Welton. - - * Makefile.am (GDK_PIXBUF_LIBS): add INTLLIBS - (libgdk_pixbuf_1_3_la_SOURCES): add gdk-pixbuf-i18n.h - - * gdk-pixbuf-i18n.h: Add _() to gdk-pixbuf - - * io-png.c (gdk_pixbuf__png_image_save): PNG save routine. - - * io-jpeg.c (gdk_pixbuf__jpeg_image_save): JPEG save routine. - - * gdk-pixbuf-io.c (gdk_pixbuf_save): - (gdk_pixbuf_savev): Implement pixbuf saving routines - - * gdk-pixbuf.c (gdk_pixbuf_error_quark): pixbuf error quark - function - - * gdk-pixbuf.h: Add public save routines; add pixbuf error - types - - * gdk-pixbuf-io.h: Add save function to GdkPixbufModule - -2000-10-05 Dan Winship <danw@helixcode.com> - - * io-png.c, io-tiff.c, io-xpm.c: Fix comments to not claim that - all three of these files are the JPEG image loader. (From - gdk-pixbuf module.) - -2000-10-03 Tor Lillqvist <tml@iki.fi> - - * makefile.mingw.in: Add rule for make-inline-pixbuf. Use - gdk-pixbuf's version number in the rule for makefile.mingw itself. - - * gdk_pixbuf.def: Add new entry points. - -2000-09-26 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf-util.c (gdk_pixbuf_saturate_and_pixelate): Add this - function here, instead of putting it in a private GTK+ file. - - * gdk-pixbuf-private.h (GdkPixbufInlineFormat): include an - enum here for the known formats of inlined pixbufs. - Also, #define our file magic here. - -2000-06-23 Havoc Pennington <hp@redhat.com> - - * make-inline-pixbuf.c: Small program that creates C variable - declarations of inline pixbuf data. This can be read - by gdk_pixbuf_new_from_inline. - - * gdk-pixbuf.h (gdk_pixbuf_new_from_inline): New function to read - inline pixbuf data and create a pixbuf from it. - - * gdk-pixbuf-data.c (gdk_pixbuf_new_from_inline): implement here - -2000-09-07 Tor Lillqvist <tml@iki.fi> - - * makefile.mingw.in: Use own version number for gdk-pixbuf DLLs, - like on Unix. - -2000-08-12 Tor Lillqvist <tml@iki.fi> - - * gdk_pixbuf.def: Add missing entry point. - -2000-08-10 Havoc Pennington <hp@redhat.com> - - * Makefile.am (EXTRA_DIST): The *.def files had the wrong names - (s/pixbuf_/pixbufloader_) - -2000-08-02 Tor Lillqvist <tml@iki.fi> - - * io-bmp.c - * io-ico.c - * io-ras.c - * io-tiff.c - * io-wbmp.c: Conditionalise inclusion of <unistd.h>. - - * makefile.mingw.in: List loaders alphabetically. Add the wbmp - one. Fix names of DLLs to have '-' instead of '_'. - -2000-07-31 Elliot Lee <sopwith@redhat.com> - * io-wbmp.c: Some bug fixes - now tested to work. - -2000-07-27 Elliot Lee <sopwith@redhat.com> - - * gdk-pixbuf-io.h, gdk-pixbuf-io.c: Add - gdk_pixbuf_get_named_module() function to facilitate above change - * io-wbmp.c, pixbufloader_wbmp.defs, gdk-pixbuf-io.c, Makefile: - Implement loader for WBMP format. - * io-bmp.c: Don't malloc a temporary buffer - use stack instead. - -2000-07-23 Tor Lillqvist <tml@iki.fi> - - Win32 build setup: - - * makefile.mingw.in - * pixops/makefile.mingw.in - * pixbuf_*.def: New files. - - * Makefile.am - * pixops/Makefile.am: Add them. Add rule to generate makefile.mingw. - - * gdk-pixbuf-io.c (gtk_win32_get_installation_directory): - New function, to get the GTK+ installation directory from - the Windows Registry, where the installation program - for whatever software includes GTK+ has stored it. - - Used to avoid having hardcoding the directory where to look for - loaders. This function is needed by gtk, too, so it should - really be just in one place. Maybe a small static library - one level up from here? - - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_new_from_file) - * gdk-pixbuf-io.c (gdk_pixbuf_new_from_file): - Open file in binary mode. This *is* standard C. (No-op on Unix, - of course.) - - * io-jpeg.c: If we don't HAVE_SIGSETJMP, use normal setjmp(). - - * io-tiff.c: Use g_get_tmp_dir(). If we don't HAVE_MKSTEMP, use - mktemp() and open(). - (gdk_pixbuf__tiff_image_stop_load): g_free() also the tempname. - - * pixops/*.S: The Gas from mingw32 doesn't like the .type - pseudo-op. Conditionalise on __MINGW32__, but probably - should conditionalise on Gas version instead? Or could we - do without .type on all systems? - - * pixops/timescale.c: Use g_get_current_time() - instead of gettimeofday(). - -Sat Jul 22 10:57:22 2000 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (test_gdk_pixbuf_LDADD): Remove -lgmodule - -Tue Jul 11 11:26:42 2000 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf.c: Add <string.h> include. - -Tue Jul 11 06:20:14 2000 Tim Janik <timj@gtk.org> - - * io-gif.c (gdk_pixbuf__gif_image_load_animation): - * gdk-pixbuf-data.c (gdk_pixbuf_new_from_data): - * gdk-pixbuf-animation.c (gdk_pixbuf_animation_new_from_file): - use g_object_new() instead of g_type_create_instance() which - is a private function for fundamental type implementations. - -Thu Jul 6 11:49:47 2000 Owen Taylor <otaylor@redhat.com> - - * Makefile.am (libgdk_pixbuf_la_LDFLAGS): Use GTK+ version - soname scheme for gdk-pixbuf. - -2000-06-21 Havoc Pennington <hp@pobox.com> - - * gdk-pixbuf.c: Convert GdkPixbuf to GObject, leaving it opaque - (i.e. derivation is not allowed, and there are no virtual methods - anyway). - (gdk_pixbuf_preinit): Call g_type_init() here. - (gdk_pixbuf_init): Add a user-friendly init function, for users - of standalone gdk-pixbuf - - * gdk-pixbuf-animation.c: Convert to GObject, in the same - way GdkPixbufAnimation was done. - - * gdk-pixbuf.h: Remove gdk_pixbuf_set_unref_handler() and - gdk_pixbuf_finalize() from API, since these are broken and don't - make sense with new GObject stuff. - -Wed Jun 21 16:02:48 2000 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf-io.c (gdk_pixbuf_load_module): Add feature to - support a GDK_PIXBUF_MODULEDIR env variable as a secondary - load location. - -2000-06-10 Federico Mena Quintero <federico@helixcode.com> - - * demo/pixbuf-demo.c: It was cold and rainy this Saturday morning, - so I needed something to warm my thighs. Running plain infinite - loops on your laptop to make it hot is not very much fun. A demo - of the gdk-pixbuf scaling functions is way better, and looks - prettier, too. - - * configure.in (AC_OUTPUT): Added the demo Makefile. - - * Makefile.am (SUBDIRS): Added the demo directory. - -2000-06-09 Larry Ewing <lewing@helixcode.com> - - * gdk-pixbuf/io-png.c (gdk_pixbuf__png_image_load_increment): - setjmp for the png error handler. It seems setting the error - handling functions does not avoid the jump, and so not calling - setjmp was causing the incremental loader to jump into lala land. - (gdk_pixbuf__png_image_begin_load): setjmp for error handling, I'm - not sure this one is actually required but the docs say it must be - set for every call to a png_* function. - Also changed the comment to reflect the fact that setting the - error handlers does _not_ avoid the longjmp. - -2000-06-06 Larry Ewing <lewing@helixcode.com> - - * gdk-pixbuf/gdk-pixbuf-loader.c (gdk_pixbuf_loader_frame_done): - take frame offest into account when trying to calculate the - animation bbox. Also set the width to the width not the height. - (gdk_pixbuf_loader_animation_done): cycle over the frames to - calculate bbox because now we finally have all the offset - information for each frame. - -2000-06-05 Mathieu Lacage <mathieu@gnome.org> - - * configure.in: add some gtk parameters to the - GDK_PIXBUF_LIB?�?S and GDK_PIXBUG_INCLUDEDIR vars. One more - fight in my crusade for strange prefix compile... - -2000-05-30 Not Zed <NotZed@HelixCode.com> - - * gdk-pixbuf/io-jpeg.c (gdk_pixbuf__jpeg_image_begin_load): - Initialise the error handler exit routine to our own. Note this - means that every function that accesses the jpeg lib on this - object MUST do a setjmp. - (gdk_pixbuf__jpeg_image_stop_load): setjmp before accessing jpeg - lib for handling fatal error. - (gdk_pixbuf__jpeg_image_load_increment): And here too. So now - your applications dont quit if there's a jpeg error! - -2000-05-30 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf.spec.in: Include all the loader libraries. Patch - from Frank de Lange <frank@unternet.org>. - -2000-05-09 Darin Adler <darin@eazel.com> - - * gdk-pixbuf/test-gdk-pixbuf.c: - Fixed includes to get rid of accidental GNOME dependency. - -2000-05-26 Cody Russell <car0969@gamma2.uta.edu> - * Makefile.am: Added gdk-pixbuf.spec to EXTRA_DIST - -2000-05-22 Federico Mena Quintero <federico@helixcode.com> - - * configure.in: Bumped version number to 0.8.0. - - * doc/Makefile.am (content_files): The toplevel gdk-pixbuf.sgml - file was not being distributed. - - * gdk-pixbuf/pixops/Makefile.am (EXTRA_DIST): Added DETAILS. - -2000-05-09 Darin Adler <darin@eazel.com> - - * gdk-pixbuf/gdk-pixbuf-drawable.c: (rgb565lsb), (rgb565msb), - (rgb565alsb), (rgb565amsb), (rgb555lsb), (rgb555msb), (rgb555alsb), - (rgb555amsb), (convert_real_slow): Change all conversion from 16-bit - formats to 32-bit formats to re-use the high bits of the color values - so that white maps to full white. - -Fri May 5 12:16:32 2000 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf/pixops/DETAILS: Add beginnings of file with - detailed information about the structure and algorithms - of pixops so people can fix it instead of breaking it. - -2000-05-04 Darin Adler <darin@eazel.com> - - * gdk-pixbuf/pixops/pixops.c: (pixops_composite_nearest), - (composite_pixel), (composite_line): - * gdk-pixbuf/test-gdk-pixbuf.c: (simple_composite_test_one_type): - Now that Owen explained the algorithm, I think I implemented it - right for the cases where the destination pixbuf is not opaque. - The test does seem to confirm it. - -2000-05-04 Darin Adler <darin@eazel.com> - - * gdk-pixbuf/.cvsignore: - * gdk-pixbuf/Makefile.am: - * gdk-pixbuf/test-gdk-pixbuf.c (store_pixel), (fill_with_pixel), - (load_pixel), (simple_composite_test_one), - (simple_composite_test_one_type), (simple_composite_test), (main): - Added some tests of composite to highlight problems in the old - implementation. These tests run without any user interaction. - Just do "make check". - - * gdk-pixbuf/pixops/pixops.c (pixops_composite_nearest), - (composite_pixel), (composite_line): Fix composite to do a textbook - "A over B" composite. This was clearly the intent, and it was easy - to fix the code to do it. (Note to those that read my earlier tries - at a patch; this version fixes typos that were present in all - my patch attempts. I checked the final version by adding more tests.) - -2000-04-22 05:27:43 2000 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf/pixops/pixops.c (pixops_scale_nearest): Properly - offset y coordinate accordining to render_y0. - - * gdk-pixbuf/gdk-pixbuf-scale.c: Properly handle nonzero - dest_x, dest_y. - -2000-04-22 James Henstridge <james@daa.com.au> - - * gdk-pixbuf.spec.in (%files): moved %{prefix}/bin/* from the main - package to the devel package. The only file installed in bin is - gdk-pixbuf-config, which belongs in -devel. This should allow having - multiple versions of the main gdk-pixbuf package installed. - -2000-04-17 Karl Eichwalder <ke@suse.de> - - * gdk-pixbuf/Makefile.am (INCLUDES): Add $(GNOME_CFLAGS). - Reported by Jens Finke. - -2000-04-14 Tomasz K?�?opczko <kloczek@pld.org.pl> - - * gdk-pixbuf/pixops/makefile.am: $(LIBART_CFLAGS) replaced by - $(GTK_CFLAGS) - now gdk-pixbuf compiles correctly. - -2000-04-13 James Henstridge <james@daa.com.au> - - * configure.in: when performing the configure check to see if - gmodule works, set CFLAGS to GLIB_CFLAGS and LIBS to GLIB_LIBS, - rather than the other way round. Also, call AC_MSG_RESULT in the - even that dynamic modules were not supported. - -2000-04-12 Federico Mena Quintero <federico@helixcode.com> - - This comes from an excellent idea by Tim Janik (timj@gtk.org) to - hook to the last unref operation. - - * gdk-pixbuf/gdk-pixbuf.c (gdk_pixbuf_set_last_unref_handler): New - function to set the last unref handler for a pixbuf. - (gdk_pixbuf_finalize): New function to actually finalize a pixbuf. - It calls the pixbuf's destroy notification function and frees the - GdkPixbuf structure itself. - (gdk_pixbuf_unref): Use the last unref function of the pixbuf if - available. - - * gdk-pixbuf/gdk-pixbuf-private.h (struct _GdkPixbuf): New fields - for the last unref handler and its user data. - - * gdk-pixbuf/gdk-pixbuf-data.c (gdk_pixbuf_new_from_data): Use - g_new0() to allocate the pixbuf. - - * gdk-pixbuf/gdk-pixbuf-loader.c (gdk_pixbuf_loader_class_init): - Fixed the call to gtk_signal_new() for the "frame_done" signal; it - was not specifying the `frame' argument. - - * gdk-pixbuf/gdk-pixbuf-animation.c - (gdk_pixbuf_animation_get_width): Fixed docstring. - (gdk_pixbuf_animation_get_height): Likewise. - (gdk_pixbuf_animation_get_num_frames): Likewise. - (gdk_pixbuf_animation_get_frames): Likewise. - - * doc/gdk-pixbuf-sections.txt: Updated with the new functions and - types. - - * doc/tmpl/gdk-pixbuf.sgml: Added the description for GdkColorspace. - - * doc/tmpl/scaling.sgml: Added the description for GdkInterpType. - - * doc/tmpl/refcounting.sgml: Updated with the information about - the last unref handler. - - * doc/tmpl/*.sgml: Markup tweaks. - - * gdk-pixbuf/Makefile.am (libgnomecanvaspixbuf_la_LDFLAGS): Sigh, - update the libtool version number for libgnomecanvaspixbuf as - well. - (libpixbufloader_*_la_LDFLAGS): The loaders need to be versioned - as well, or the old ones won't work with the new stuff. Also, - renamed the modules as follows. - - * gdk-pixbuf/gdk-pixbuf-io.c (gdk_pixbuf_load_module): Now the - modules are called "libpixbufloader-<format>.so" instead of - "libpixbuf-<format>.so". They needed renaming so that the new - loaders won't overwrite the old ones; even with the versioning - stuff, the new .so symlink to the .so.1.0.0 would overwrite the - old real .so file. - -2000-04-12 Paolo Molaro <lupus@debian.org> - - * .cvsignore, src/.cvsignore: shut up cvs. - -2000-04-11 Federico Mena Quintero <federico@helixcode.com> - - Most of this patch is based on a patch by Havoc Pennington - (hp@redhat.com) to make GdkPixbuf's structures opaque and to - remove the libart dependency. - - * gdk-pixbuf/gdk-pixbuf.h: Removed the public structures. - (GdkColorspace): New enum that for now only contains - GDK_COLORSPACE_RGB. - (GdkPixbufDestroyNotify): New type for the pixbuf's pixels destroy - notification function. - (GdkInterpType): New num with interpolation types. - - * *.[ch]: Replace the libart stuff with our own stuff. - - * pixops/*.[ch]: Likewise. - - * gdk-pixbuf/gdk-pixbuf-private.h: New file with the private - declarations of the GdkPixbuf structures. - - * gdk-pixbuf/gdk-pixbuf.c (gdk_pixbuf_new_from_art_pixbuf): - Removed function. - (gdk_pixbuf_get_format): Constify. - (gdk_pixbuf_get_n_channels): Constify. - (gdk_pixbuf_get_has_alpha): Constify. - (gdk_pixbuf_get_bits_per_sample): Constify. - (gdk_pixbuf_get_pixels): Constify. - (gdk_pixbuf_get_width): Constify. - (gdk_pixbuf_get_height): Constify. - (gdk_pixbuf_get_rowstride): Constify. - - * gdk-pixbuf/gdk-pixbuf.c (gdk_pixbuf_copy): New function to copy - a pixbuf. - - * gdk-pixbuf/gdk-pixbuf-data.c (gdk_pixbuf_new_from_data): Added a - bits_per_sample argument; currently only 8 bits per sample are - supported. - - * gdk-pixbuf/gdk-pixbuf-animation.c (gdk_pixbuf_frame_get_pixbuf): - New accessor. - (gdk_pixbuf_frame_get_x_offset): New accessor. - (gdk_pixbuf_frame_get_y_offset): New accessor. - (gdk_pixbuf_frame_get_delay_time): New accessor. - (gdk_pixbuf_frame_get_action): New accessor. - - * gdk-pixbuf/gdk-pixbuf-render.c - (gdk_pixbuf_render_pixmap_and_mask): Instead of returning a solid - mask rectangle for pixbufs without an alpha channel, set the - *mask_return to NULL. - - * gdk-pixbuf/gdk-pixbuf-util.c (gdk_pixbuf_add_alpha): Constify. - - * gdk-pixbuf/gdk-pixbuf-scale.c: Fix includes. - - * gdk-pixbuf/gdk-pixbuf-scale.c (gdk_pixbuf_scale): Added some - preconditions. Maybe we should also check for the colorspace, - bits per pixel, and such. - (gdk_pixbuf_composite): Likewise. - (gdk_pixbuf_composite_color): Likewise. - (gdk_pixbuf_scale_simple): Likewise, and fail gracefully if we - cannot allocate the new pixbuf. - (gdk_pixbuf_composite_color_simple): Likewise. - - * gdk-pixbuf/gnome-canvas-pixbuf.c (gnome_canvas_pixbuf_render): - Use art_rgb_rgba_affine() or art_rgb_affine() since we no longer - have an ArtPixBuf. - - * gdk-pixbuf/io-bmp.c: Fix includes. - - * gdk-pixbuf/pixops/pixops.c (pixops_scale_nearest): Fixed cast in - an lvalue. - - * TODO: Populated. - - * configure.in: Removed checks for libart. - - * gdk-pixbuf/Makefile.am: Removed references to libart. - (noinst_HEADERS): Added gdk-pixbuf-private.h. - - * gdk-pixbuf/Makefile.am (libgdk_pixbuf_la_LDFLAGS): Incremented - the version number of the libtool library to indicate that this - definitely is not compatible with the old usage. I know you love - me. I know you do. - - * configure.in: Bumped version number to 0.7.0. - - * README: Updated. - - * gdk-pixbuf-config.in (--libs): We no longer require libart. - - * DEPENDS.libgdk_pixbuf: We no longer depend on libart. - - * gdk-pixbuf.spec.in: Updated, but I don't guarantee anything. - -2000-04-06 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/testanimation.c (main): add more info to the - testanimation frames. - -2000-04-04 Ettore Perazzoli <ettore@helixcode.com> - - * gdk-pixbuf/gdk-pixbuf-animation.c - (gdk_pixbuf_animation_get_width): New accessor function. - (gdk_pixbuf_animation_get_height): New accessor function. - (gdk_pixbuf_animation_get_num_frames): New accessor function. - (gdk_pixbuf_animation_get_frames): New accessor function. - -2000-04-01 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf/gdk-pixbuf.c: Reverted Mark's change. The refcount - is private information, and the art_pixbuf will go away soon. - -2000-03-31 Mark Crichton <crichton@gimp.org> - - * gdk-pixbuf/gdk-pixbuf.c: Added gdk_pixbuf_get_refcount - and gdk_pixbuf_get_artpixbuf accessor functions. - -2000-03-29 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf/gdk-pixbuf.c (gdk_pixbuf_get_has_alpha): Return - gboolean instead of int. - -2000-03-29 Radek Doulik <rodo@helixcode.com> - - * gdk-pixbuf/gdk-pixbuf-animation.c - (gdk_pixbuf_animation_new_from_file): same as below - - * gdk-pixbuf/io-gif.c (gif_get_lzw): added update of width and - height in GdkPixbufAnimation - -2000-03-28 Radek Doulik <rodo@helixcode.com> - - * gdk-pixbuf/io-gif.c (gif_get_lzw): test also for - context->frame_done_func and context->anim_done_func to make - progressive animation loading work - - * gdk-pixbuf/gdk-pixbuf-loader.c (gdk_pixbuf_loader_frame_done): - added priv->pixbuf = NULL as pixbuf is now in frame (and to make - gdk_pixbuf_loader_prepare happy) - (gdk_pixbuf_loader_frame_done): update animation bbox - - * gdk-pixbuf/gdk-pixbuf.h: added bbox size (width, height) to - _GdkPixbufAnimation - -2000-03-27 Radek Doulik <rodo@helixcode.com> - - * gdk-pixbuf/io-gif.c (gif_get_lzw): use frame_len and frame_width - instead of width and height - -2000-03-27 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf/pixops/pixops.c: Fix problem with - precendence of >> and & which was keeping composite_color - from working with non-gray images. - -2000-03-08 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/io-gif.c (gdk_pixbuf__gif_image_load): free the context. - (gdk_pixbuf__gif_image_load_animation): free the context. - -2000-03-06 Arjan van de Ven <arjan@fenrus.demon.nl> - - * gdk-pixbuf/io-bmp.c: Fixed to pointer-bugs and a - mis-interpretation of the Microsoft documentation. Now - it can load .BMP files that are not generated by The Gimp - as well. - -2000-03-01 Mark Crichton <crichton@gimp.org> - - * configure.in: Added BUILD_CANVAS_ITEM stuff to (finally) - fix the last auto* build bug (where we have libart, but no - gnome-libs) - - * gdk-pixbuf/Makefile.am: Same. - -2000-02-28 Matt Wilson <msw@redhat.com> - - * gdk-pixbuf/gdk-pixbuf-drawable.c: s/unsigned long/guint32/g, - s/unsigned short/guint16/g, s/unsigned char/guint8/g - -2000-02-26 Federico Mena Quintero <federico@helixcode.com> - - * README: We don't require libgif/ungif nor libXpm. - - * NEWS: This was outdated, so updated it. - -2000-02-25 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf.m4: Use the correct name for - gdk-pixbuf/gdk-pixbuf.h. Thanks to Jacob Berkman for pointing - this out. - -2000-02-21 Federico Mena Quintero <federico@helixcode.com> - - * configure.in (GDK_PIXBUF_MINOR): Bumped version number to 0.6.0. - - * doc/compiling.sgml: New appendix documenting the gdk-pixbuf - library's particular options to configure.in. - - * doc/gdk-pixbuf.sgml: Include compiling.sgml appendix via an - entity. - - * doc/Makefile.am (gdk-pixbuf.html): Added compiling.sgml. - - * gdk-pixbuf/io-ico.c (gdk_pixbuf__ico_image_load_increment): - Fixed typo in prototype name. - - * configure.in: Changed duplicated AC_MSG_CHECKING message to - something more meaningful; now it is "checking whether dynamic - modules work". - - * gdk-pixbuf/pixops/Makefile.am (noinst_PROGRAMS): Do not install - the timescale program. - - Integrated Miguel de Icaza's <miguel@gnu.org> patch for optionally - creating a single static library with all the image format modules - in it. - -2000-02-20 Miguel de Icaza <miguel@gnu.org> - - * gdk-pixbuf/io-xpm.c (gdk_pixbuf__xpm_image_load): Add prefix. - (gdk_pixbuf__xpm_image_load_xpm_data): Add prefix. - - * gdk-pixbuf/io-tiff.c (gdk_pixbuf__tiff_image_load_real): Add prefix. - (gdk_pixbuf__tiff_image_stop_load): Add prefix. - (gdk_pixbuf__tiff_image_load_increment): Add prefix. - (gdk_pixbuf__tiff_image_load): Add prefix. - (gdk_pixbuf__tiff_image_stop_load): Update invocation. - (gdk_pixbuf__tiff_image_begin_load): Add prefix. - - * gdk-pixbuf/io-ras.c (gdk_pixbuf__ras_image_load): Add prefix. - (gdk_pixbuf__ras_image_load): Updated invocation. - (gdk_pixbuf__ras_image_begin_load): Add prefix. - (gdk_pixbuf__ras_image_stop_load): Add prefix. - (gdk_pixbuf__ras_image_load_increment): Add prefix. - - * gdk-pixbuf/io-pnm.c (gdk_pixbuf__pnm_image_begin_load): Add prefix. - (gdk_pixbuf__pnm_image_stop_load): Add prefix. - (gdk_pixbuf__pnm_image_load_increment): Add prefix - (gdk_pixbuf__pnm_image_load): Add prefix. - - * gdk-pixbuf/io-jpeg.c (gdk_pixbuf__jpeg_image_load): Add prefix. - (gdk_pixbuf__jpeg_image_load_increment): Add prefix. - (gdk_pixbuf__jpeg_image_begin_load): Add prefix. - (gdk_pixbuf__jpeg_image_stop_load): Add prefix. - - * gdk-pixbuf/io-ico.c (gdk_pixbuf__ico_image_load): Add prefix. - (gdk_pixbuf__ico_image_load): update invocation. - (gdk_pixbuf__ico_image_load_increment): Add prefix. - (gdk_pixbuf__ico_image_load): update invocation. - (gdk_pixbuf__ico_image_begin_load): Add prefix. - (gdk_pixbuf__ico_image_load): update invocation. - (gdk_pixbuf__ico_image_stop_load): Add prefix. - - * gdk-pixbuf/io-gif.c (gdk_pixbuf__gif_image_load_animation): Add prefix. - (gdk_pixbuf__gif_image_load): Add prefix. - (gdk_pixbuf__gif_image_begin_load): Add prefix. - (gdk_pixbuf__gif_image_load_increment): Add prefix. - (gdk_pixbuf__gif_image_load_animation): Add prefix. - (gdk_pixbuf__gif_image_stop_load): Add prefix. - - * gdk-pixbuf/io-bmp.c (gdk_pixbuf__bmp_image_load): Add prefix. - (gdk_pixbuf__bmp_image_load): Rename function called. - (gdk_pixbuf__bmp_image_load_increment): Add prefix - - * gdk-pixbuf/io-png.c (gdk_pixbuf__png_image_load): Add prefix. - (gdk_pixbuf__png_image_begin_load): Add prefix. - (gdk_pixbuf__png_image_stop_load): Add prefix. - (gdk_pixbuf__png_image_load_increment): Add prefix. - - * gdk-pixbuf/gdk-pixbuf-io.c (file_formats): Make this static. - (gdk_pixbuf_load_module): Load the shared library entry points - using a "gdk_pixbuf__$module_name" prefix. - (pixbuf_module_symbol): Wrapper routine that uses the module - prefix for the modules to load the information. - - * configure.in (GDK_PIXBUF_VERSION): New option --disable-modules - lets the user specify that gdk-pixbuf should link all image loader - code into the library instaed of creating shared library modules. - - (dynworks): Renamed the automake conditional DYNAMIC_MODULES_WORK - to BUILD_DYNAMIC_MODULES. - -2000-02-19 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/io-gif.c (new_context): fix case where initial - colormap entry is Transparent. - -2000-02-19 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf/pixops/pixops.c (scale_pixel): Fix error in - scale factors for non-alpha case. - -2000-02-14 Mark Crichton <crichton@gimp.org> - - * gdk-pixbuf/io-xpm.c (xpm_extract_color): Added check for "g" - color type. Imlib/libXpm handle this, but we didn't. - -2000-02-14 Darin Adler <darin@eazel.com> - - * gdk-pixbuf/testpixbuf.c: Remove now-unnecessary cast. - * .cvsignore: gdk-pixbuf/.cvsignore: More to ignore. - -2000-02-14 Elliot Lee <sopwith@redhat.com> - * gdk-pixbuf/gdk-pixbuf.h, gdk-pixbuf/gdk-pixbuf-data.c: Make - passed-in argument 'const'. - -2000-02-04 Michael Meeks <mmeeks@gnu.org> - - * gdk-pixbuf/io-gif.c (struct _GifContext): add x,y_offset. - (gif_get_frame_info): put the offsets on the context. - (gif_get_lzw): copy them off into the frame. - (new_context): no change required; will 0 offsets by default. - -2000-01-28 Michael Meeks <michael@mejm2.dow.cam.ac.uk> - - * gdk-pixbuf/pixops/pixops.c (pixops_process): const + nasty - un-consting cast. - - * gdk-pixbuf/pixops/pixops.h: const. - - * gdk-pixbuf/gdk-pixbuf-util.c: const. - - * gdk-pixbuf/gdk-pixbuf-scale.c: const. - - * gdk-pixbuf/gdk-pixbuf.h: constify lots of things. - -2000-02-03 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf/gdk-pixbuf-render.c - (gdk_pixbuf_render_threshold_alpha): Added sanity check for width - and height being >= 0. Also, do nothing if either of them is - zero. Thanks to Ettore for pointing this out. - (gdk_pixbuf_render_to_drawable): Likewise. - (gdk_pixbuf_render_to_drawable_alpha): Likewise. - -2000-02-02 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf/io-gif.c (gif_get_lzw): Removed debugging g_print. - Thanks to John Sullivan <sullivan@eazel.com> for the patch. - - * gdk-pixbuf/testpixbuf-drawable.c (configure_cb): Get a new area - of the screen when the window is resized. Thanks to David - N. Welton <davidw@linuxcare.com> for pointing this out. - Misc. cleanups to the rest of the file. - -2000-02-01 Federico Mena Quintero <federico@helixcode.com> - - * doc/tmpl/rendering.sgml: gnome_init() does not call - gdk_rgb_init(), so don't mention that it does in the - documentation. Thanks to Alexander Kruuse <kruuse@home.se> for - pointing this out. - -2000-01-31 Havoc Pennington <hp@redhat.com> - - * gdk-pixbuf/Makefile.am (noinst_PROGRAMS): no testpixbuf-foo target - -Mon Jan 31 12:38:50 2000 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf/pixops/pixops.c (scale_line): Fix from Peter - Wainwright to fix 4a => 4a scaling. - -2000-01-29 Mark Crichton <crichton@gimp.org> - - * gdk-pixbuf-config: Oh dear, we weren't Telsa/Alan proof... - put `libart-config --libs` in instead of -lart_lgpl. - -2000-01-22 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf/io-pnm.c (pnm_read_raw_scanline): Return an error on - invalid pnm type. - (pnm_read_ascii_scanline): Initialize data and mask. - - * gdk-pixbuf/io-xpm.c (pixbuf_create_from_xpm): Initialize - fallbackcolor to keep gcc happy. - - * configure.in: Bumped version number to 0.5.0. - - * gdk-pixbuf/pixops/timescale.c (dump_array): Removed unused variable. - (main): Return 0. - - * gdk-pixbuf/pixops/pixops.c (pixops_composite_color_nearest): Put - parentheses around + in a shift to remove a compiler warning. - (pixops_process): Likewise. - - Patch from Ross Golder <rossigee@bigfoot.com> to create an RPM - specfile: - - * configure.in: Added gdk-pixbuf.spec to AC_OUTPUT. - - * Makefile.am (EXTRA_DIST): Added gdk-pixbuf.spec.in - -2000-01-22 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf/gnome-canvas-pixbuf.c (PixbufPrivate): Removed the - x_set and y_set arguments. Now they are always on and start with - defaults of 0.0 in units. - (gnome_canvas_pixbuf_class_init): Likewise. - (gnome_canvas_pixbuf_set_arg): Likewise. - (gnome_canvas_pixbuf_get_arg): Likewise. - (compute_viewport_affine): Likewise; always use the priv->x and - priv->y fields. - - * doc/tmpl/gnome-canvas-pixbuf.sgml: Modified to reflect the - removal of the x_set/y_set arguments. - -2000-01-21 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf/gdk-pixbuf.c (gdk_pixbuf_ref): Return the same pixbuf - as the input parameter. - - * gdk-pixbuf/gdk-pixbuf-animation.c (gdk_pixbuf_animation_ref): - Return the same animation as the input parameter. - -2000-01-16 Elliot Lee <sopwith@redhat.com> - - * gdk-pixbuf/Makefile.am: Don't link against libgnomecanvaspixbuf.la - -2000-01-16 Federico Mena Quintero <federico@helixcode.com> - - * configure.in: Removed the broken --enable-canvas-pixbuf option. - Added the stuff necessary to substitute the variables in - gnomecanvaspixbufConf.sh.in. - - * gnomecanvaspixbufConf.sh.in: New gnome-config handler for the - tiny gnomecanvaspixbuf library. - - * Makefile.am: Build gnomecanvaspixbufConf.sh. - - * gdk-pixbuf/Makefile.am: Create a libgnomecanvaspixbuf and only - build it if gdk-pixbuf is being built outside of gnome-libs. - - * doc/gdk-pixbuf-sections.txt: Added gdk_pixbuf_render_pixmap_and_mask(). - - * gdk-pixbuf/gdk-pixbuf-render.c - (gdk_pixbuf_render_pixmap_and_mask): Renamed from - gdk_pixbuf_render_pixmap(). Do not create the mask if it is not - needed, and do not use a clipping mask when rendering the pixmap. - Tweaked documentation a little. - - * HACKING: New file with hacking policies for the gdk-pixbuf - module. - - * doc/Makefile.am (tmpl_sources): Added missing backslash. - - * doc/Makefile.am: Use gnomecanvaspixbuf in gnome-config when - scanning for docstrings. - - * gdk-pixbuf/gdk-pixbuf-util.c (gdk_pixbuf_copy_area): Made sanity - checks more stringent. Removed "gint" abominations. Made - documentation consistent with the rest of the functions. - - * doc/gdk-pixbuf-sections.txt: Added gdk_pixbuf_copy_area() to the - utilities section. - -2000-01-14 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/gdk-pixbuf-render.c (gdk_pixbuf_render_pixmap): new - function to let you create a gdk_pixmap from a gdk_pixbuf. - -2000-01-11 Jacob Berkman <jacob@helixcode.com> - - * gdk-pixbuf/pixops/Makefile.am (INCLUDES): added - $LIBART_CFLAGS to $INCLUDES - -2000-01-10 Elliot Lee <sopwith@redhat.com> - - * configure.in, gdk-pixbuf/Makefile.am: Build a libcanvas_pixbuf. - - * configure.in: Define version macros. Generate - gdk-pixbuf/gdk-pixbuf-features.h. Always INSIDE_GNOME. - - * gdk-pixbuf/Makefile.am: Add gdk-pixbuf-features.h - - * gdk-pixbuf/gdk-pixbuf.c: Add definitions of - gdk-pixbuf-features.h declarations, plus some initialization - stubs. - -2000-01-05 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf/pixops/pixops.c: Fixed src_channels/dest_channels - confusion. (Again caught by Tomas Ogren's Purify) - -2000-01-07 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/gdk-pixbuf-xform.c (gdk_pixbuf_rotate): comment out - debugging printing. - - * gdk-pixbuf/gdk-pixbuf-io.c: Added progressive animation loading. - * gdk-pixbuf/gdk-pixbuf-io.h: Added progressive animation loading. - * gdk-pixbuf/gdk-pixbuf-loader.c: Added progressive animation - loading. - * gdk-pixbuf/gdk-pixbuf-loader.h: Added progressive animation - loading. - * gdk-pixbuf/io-gif.c (image_load_increment): I think the - ref-counting mess is finally fixed. Added progressive animation - loading. - (gif_get_lzw): remove memory_leak - - * doc/tmpl/gdk-pixbuf-loader.sgml: much longer long description - added. - -2000-01-05 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf/pixops/pixops.c (pixops_process): Fix computation of - end of run indices. - - * gdk-pixbuf/pixops/pixops.c: Fix double increments when - dest_channels == 4. (Pointed out by Tomas Ogren) - -2000-01-05 Mark Crichton <crichton@gimp.org> - - * gdk-pixbuf/gdk-pixbuf-loader.c (gdk_pixbuf_loader_eat_header_write): - Return 0 if gdk_pixbuf_load_loader_module returns FALSE. - -2000-01-05 Elliot Lee <sopwith@redhat.com> - - * gdk-pixbuf/pixops/Makefile.am: Link with -lm (to get 'ceil' function) - -2000-01-05 Owen Taylor <otaylor@redhat.com> - - * doc/Makefile.am doc/gdk-pixbuf-sections.txt - doc/gdk-pixbuf.sgml doc/tmpl/scaling.sgml: - Added scaling functions into gtk-doc framework. - - * gdk-pixbuf/gdk-pixbuf-scale.c: Documentation fixes. - - * gdk-pixbuf/testpixbuf-scale.c (expose_cb): Simplify a bit. - - * gdk-pixbuf/pixops/pixops.c (pixops_composite_color): Return - immediately if scale_x or scale_y is 0. - -2000-01-05 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf/pixops/timescale.c: quick fix for initializing - arrays in benchmark. - -2000-01-05 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/gdk-pixbuf-io.h: Change the order of the update func - to make it more compatible with the rest of GTK. Added animation - framework for progressive loading. - - * gdk-pixbuf/io-bmp.c (image_begin_load): Modified to handle new - system. - * gdk-pixbuf/io-ico.c (image_begin_load): ditto - * gdk-pixbuf/io-png.c (image_begin_load): ditto - * gdk-pixbuf/io-ras.c (image_begin_load): ditto - * gdk-pixbuf/io-jpeg.c (image_begin_load): ditto - * gdk-pixbuf/io-pnm.c (image_begin_load): ditto - * gdk-pixbuf/io-tiff.c (image_begin_load): ditto - * gdk-pixbuf/io-gif.c (image_begin_load): ditto - -2000-01-05 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf/pixops/README: Added a README with a TODO - and some explainations of the algorithms. - - * gdk-pixbuf/testpixbuf-scale.c: Set a background pixmap of None - to reduce flashing when resizing. - -2000-01-05 Owen Taylor <otaylor@redhat.com> - - * gdk-pixbuf/pixops/: Directory full of pixel data scaling - code that will eventually migrate into libart. - - * configure.in acconfig.h: Add checks for MMX compiler support - - * gdk-pixbuf/gdk-pixbuf.h gdk-pixbuf/gdk-pixbuf-scale.c: - Nice wrapper routines for the code in pixops that operate - on pixbufs instead of raw data. - - * gdk-pixbuf/testpixbuf-scale: Test program for scaling - routines. - -2000-01-05 Jonathan Blandford <jrb@redhat.com> - - * doc/tmpl/animation.sgml: Documentation changes. - -2000-01-01 Federico Mena Quintero <federico@helixcode.com> - - * gdk-pixbuf/gdk-pixbuf.h (GdkPixbufAnimation): Added reference - counting to animations. A web browser may want to share a single - copy of an animated GIF if it appears multiple times in a web - page, for example. - - * gdk-pixbuf/gdk-pixbuf-animation.c: New file. Moved the - animation functions here. - (gdk_pixbuf_animation_new_from_file): Prettified. Return a NULL - animation if the loader does not support multiframe loading and - the single-frame load returned NULL. Check that the filename is - not NULL. Updated inline documentation. - (gdk_pixbuf_animation_ref): New function. - (gdk_pixbuf_animation_unref): New function. - Removed gdk_pixbuf_animation_destroy() in favor of reference - counting. - - * gdk-pixbuf/gdk-pixbuf-io.c (gdk_pixbuf_new_from_file): - Prettified. Made ref_count assertion more paranoid. Check that - the filename is not NULL. - (gdk_pixbuf_get_module): Use guchar * and guint for buffer and - size, respectively. - (gdk_pixbuf_new_from_xpm_data): Changed the "data" argument to - const char **. - - * gdk-pixbuf/io-gif.c (image_load_animation): Create the animation - with a reference count of 1. - - * gdk-pixbuf/Makefile.am (libgdk_pixbuf_la_SOURCES): Added - gdk-pixbuf-animation.c. - - * doc/tmpl/animation.sgml: Populated. It is still missing a - description of the overlay modes. - - * doc/gdk-pixbuf-sections.txt: Added the animation section. Moved - the canvas item section to the end, as it will be moved later to - gnome-libs. - - * doc/gdk-pixbuf.sgml: Added the animation section. - - * doc/Makefile.am (tmpl_sources): Added tmpl/animation.sgml. - -1999-12-26 Peter Teichman <pat@gnu.org> - - * gdk-pixbuf/Makefile.am (libpixbuf_tiff_la_LIBADD): add - $(LIBTIFF) to libpixbuf_tiff_la_LIBADD, proxying for mmarker. - This closes bug #4676. - -1999-12-23 Havoc Pennington <hp@pobox.com> - - * gdk-pixbuf/io-gif.c (image_load): Stuff that should have been - set to NULL here (specifically context->animation) was not being - set to NULL. use g_new0() to alloc the struct. - -1999-12-20 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/io-gif.c: finished work to make animated gifs load - correctly. Progressive loading needs some work, but that all - needs doing from the gdk-pixbuf-loader end, not here. - -1999-12-17 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/gdk-pixbuf-io.c (gdk_pixbuf_animation_new_from_file): - moved the file here. It seems natural to put this function here, - as that's where the gdk_pixbuf_new_from_file function is, but it's - still a little convoluted. The source files might be played with - in a bit. - -1999-12-14 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/gdk-pixbuf-loader.c - (gdk_pixbuf_loader_get_animation): Gets the animation from the - loader. - -1999-12-16 Federico Mena Quintero <federico@redhat.com> - - * doc/tmpl/rendering.sgml: Added notice about initializing GdkRGB - before using the GdkPixbuf rendering functions. Thanks to Joe - Shaw <joe@off.net> for pointing this out. - -1999-12-13 Federico Mena Quintero <federico@redhat.com> - - * gdk-pixbuf/gnome-canvas-pixbuf.c - (gnome_canvas_pixbuf_class_init): Renamed arguments to - width_in_pixels, height_in_pixels, x_in_pixels, y_in_pixels, for - consistency with the new canvas. - (PixbufPrivate): Do the same renaming in the structure fields, for - consistency. - - * doc/tmpl/gnome-canvas-pixbuf.sgml: Updated for new argument names. - -1999-12-12 Federico Mena Quintero <federico@redhat.com> - - * gdk-pixbuf/Makefile.am (libgdk_pixbuf_la_LDFLAGS): Use a - conditional to see whether to link $(GNOME_LIBS) or not. - -1999-12-10 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/gdk-pixbuf-io.h: thinking about the new loading API. - - * gdk-pixbuf/gdk-pixbuf-drawable.c (gdk_pixbuf_get_from_drawable): - make a warning go away. - - * gdk-pixbuf/gdk-pixbuf.h: added new prototypes for animations. - - * gdk-pixbuf/gdk-pixbuf-loader.h: added new prototypes for - animations. - -1999-12-09 Michael Zucchi <zucchi@zedzone.mmc.com.au> - - * gdk-pixbuf/gdk-pixbuf.h: Enable gdk_pixbuf_get_from_drawable() - api call. - - * gdk-pixbuf/gdk-pixbuf-drawable.c (gdk_pixbuf_get_from_drawable): - Filled in body of function. - (rgbconvert): Added GdkColormap parameter, and to all conversion - functions also. - (convert_real_slow): New function - should convert ANY visual/data - format properly, but it aint fast. Used as a fallback when an - optimised routine wont match. - (rgbconvert): Do very specific tests on the data format to verify - properly if the optimised version will do, otherwise use the - fallback function for all other data formats. - - * gdk-pixbuf/Makefile.am: Re-enabled building of - textpixbuf-drawable. - - * gdk-pixbuf/testpixbuf-drawable.c (main): Changed to use - gdk_pixbuf_get_from_drawable(). - -1999-12-08 Arjan van de Ven <arjan@fenrus.demon.nl> - - * gdk-pixbuf/gdk-pixbuf-drawable.c : Fixed the red/green/red - bug on two occasions. - * gdk-pixbuf/io-ras.c: Changed from the custom be32_to_cpu - function to the generic glib one. - -1999-12-08 Federico Mena Quintero <federico@redhat.com> - - * gdk-pixbuf/gdk-pixbuf-drawable.c: Fix includes. - (gdk_pixbuf_get_from_drawable): Implemented the zillion sanity - checks and API definition. The body needs filling in and it needs - to do the Right Thing(tm) for pixmaps plus the given colormap and - windows and their own colormaps. - - * gdk-pixbuf/gdk-pixbuf.h: Added prototype for - gdk_pixbuf_get_from_drawable(). Killed gdk-pixbuf-drawable.h. - - * gdk-pixbuf/Makefile.am: Re-added the gdk-pixbuf-drawable sources. - - * doc/tmpl/from-drawables.sgml: Populated. - - * doc/gdk-pixbuf.sgml: Added the from-drawables section. - - * doc/Makefile.am (tmpl_sources): Added tmpl/from-drawables.sgml. - - * doc/gdk-pixbuf-sections.txt: Added a section for getting pixbufs - from drawables. - -1999-12-07 Federico Mena Quintero <federico@redhat.com> - - * doc/tmpl/gnome-canvas-pixbuf.sgml: Added clarification about - reference counting for GdkPixbuf structures. - -1999-12-07 Martin Baulig <martin@home-of-linux.org> - - * gdk-pixbuf/Makefile.am (testpixbuf_LDADD): Conditionally - include $(GNOME_LIBS) here. - -1999-12-05 Arjan van de Ven <arjan@fenrus.demon.nl> - - Added missing "include <string.h>" to: - * gdk-pixbuf/io-ras.c - * gdk-pixbuf/io-bmp.c - * gdk-pixbuf/io-ico.c - -1999-12-06 Federico Mena Quintero <federico@redhat.com> - - * gdk-pixbuf/gdk-pixbuf-io.c (file_formats): Patch from Arjan to - fix an initializer. - -1999-12-05 Federico Mena Quintero <federico@redhat.com> - - * gdk-pixbuf/Makefile.am (testpixbuf_LDADD): Add back - $(GNOME_LIBS). This must compile outside of gnome-libs. If you - want, send me a patch to do the conditional stuff properly. - Otherwise, please read the GNOME Programming Guidelines, - especially the "CVS policies" section. - -1999-12-05 Jaka Mocnik <jaka.mocnik@kiss.uni-lj.si> - - * gdk-pixbuf/Makefile.am: removed GNOME_LIBS from testpixbuf_LDADD. - -1999-12-05 Arjan van de Ven <arjan@fenrus.demon.nl> - - * gdk-pixbuf/io-ico.c: Bug in palet-size - calculation fixed - -1999-12-04 Arjan van de Ven <arjan@fenrus.demon.nl> - - * gdk-pixbuf/io-bmp.c: Major cleanup, added support for - 32 bpp and 4 bpp (uncompressed) images, fixed 1bpp. - - * gdk-pixbuf/io-ras.c: Minor cleanup, ran through lclint - - * gdk-pixbuf/io-ico.c: Minor cleanup, fixed 1bpp icons, - ran through lclint. - - * gdk-pixbuf/gdk-pixbuf-io.c: Added detection of .CUR files - (Windows Cursor files). These are identical to .ICO files, - except for the signature and 2 extra fields for the hotspot. - -1999-12-03 Federico Mena Quintero <federico@redhat.com> - - * gdk-pixbuf/gnome-canvas-pixbuf.c (gnome_canvas_pixbuf_get_arg): - Removed unused variable `item'. - -1999-12-03 Jonathan Blandford <jrb@redhat.com> - - * gdk-pixbuf/io-gif.c (gif_fill_in_lines): added a comment to - explain this function better. - -1999-12-02 Federico Mena Quintero <federico@redhat.com> - - Source files moved from src/ to gdk-pixbuf/, to be consistent with - other libraries. - - * doc/Makefile.am: Modified for the new source directory. - - * configure.in: Likewise. - - * Makefile.am: Likewise. - - * autogen.sh: Likewise. - - * gdk-pixbuf/Makefile.am: Likewise. - -1999-12-02 Federico Mena Quintero <federico@redhat.com> - - * src/testpixbuf.c: #include <config.h>, and fix includes. - - * src/testpixbuf-drawable.c: #include <config.h>, and fix includes. - - * src/io-xpm.c: Fix includes. - - * src/io-tiff.c: Fix includes. - - * src/io-ras.c: Fix includes, and do not include more stuff than needed. - - * src/io-pnm.c: Fix inlcudes, and do not include more stuff than needed. - - * src/io-png.c: Fix includes. - - * src/io-ico.c: Fix includes, and do not include more stuff than needed. - - * src/io-gif.c: Fix includes, and do not include more stuff than needed. - - * src/io-bmp.c: Fix includes, and do not include more stuff than needed. - - * src/gnome-canvas-pixbuf.c: Fix includes. - - * src/gdk-pixbuf.c: Fix includes. - - * src/gdk-pixbuf-util.c: Fix includes. - - * src/gdk-pixbuf-render.c: Fix includes. - - * src/gdk-pixbuf-io.h: Fix includes. - - * src/gdk-pixbuf-drawable.c: Fix includes. - - * src/gdk-pixbuf-drawable.h: Use angle brackets for the gdk-pixbuf - include files. - - * src/gdk-pixbuf-data.c: Fix includes. - - * src/gdk-pixbuf-loader.c: #include <config.h> - - * src/gdk-pixbuf-loader.h: Use angle brackets for the gdk-pixbuf - include files. - - * src/Makefile.am: Commented out the gdk-pixbuf-drawable stuff, - since it is not finished. - - * src/gdk-pixbuf.h: Removed unused transformation prototypes. - - * src/gdk-pixbuf-util.c: New file with utility and convenience - functions for pixbufs. - - * src/Makefile.am (libgdk_pixbuf_la_SOURCES): Added gdk-pixbuf-util.c. - - * doc/gdk-pixbuf-sections.txt: Added section for utility functions. - - * doc/Makefile.am (tmpl_sources): Added tmpl/util.sgml. - - * doc/gdk-pixbuf.sgml: Added the utilities section. - - * doc/tmpl/util.sgml: Documentation for the utility functions. - -1999-11-29 Owen Taylor <otaylor@redhat.com> - - * src/gdk-pixbuf-render.c (gdk_pixbuf_render_to_drawable_alpha): - Keep the mask around until after we draw ... since - the GC changes aren't flushed to the X server until we - draw, destroying it before that may result in BadPixmap - errors. - -1999-11-30 Havoc Pennington <hp@pobox.com> - - * configure.in: Add AM_CONDITIONAL for inside gnome-libs - - * src/Makefile.am: conditionalize GnomeCanvasPixbuf - -1999-11-29 Federico Mena Quintero <federico@redhat.com> - - * src/Makefile.am: Uncomment the GnomeCanvasPixbuf sources. This - should be made conditional, not blindly commented out. - -1999-11-29 Jonathan Blandford <jrb@redhat.com> - - * src/Makefile.am (ICO_LIB): Added another loader from Arjan to - handle .ico files. Cool. - -1999-11-24 Jonathan Blandford <jrb@redhat.com> - - * src/io-bmp.c (OneLine24): new patch from Arjan to handle - compressed bmps. - -1999-11-24 James Henstridge <james@daa.com.au> - - * configure.in (AC_OUTPUT): altered hack to place the symlink in the - top builddir rather than src. This still builds fine, and does not - get gtk-doc into an infinite loop when trying to find all the source - files. - -1999-11-23 Jonathan Blandford <jrb@redhat.com> - - * Removed #PRAGMA } from headers. Also, make compile if you don't - have it installed, already. - -1999-11-22 Federico Mena Quintero <federico@redhat.com> - - * src/gnome-canvas-pixbuf.c (gnome_canvas_pixbuf_draw): Create the - temporary buffer to the size of the interesction of the bounding - box and the expose area, not the whole expose area. This speeds - up things a lot. - - * src/gdk-pixbuf-render.c (gdk_pixbuf_render_threshold_alpha): Do - not paint black on the mask, since we already cleared it in a - single gdk_draw_rectangle() operation. - -1999-11-22 Raja R Harinath <harinath@cs.umn.edu> - - * configure.in (GDK_PIXBUF_DIR): Fix for srcdir != builddir. - -1999-11-22 Havoc Pennington <hp@pobox.com> - - * src/Makefile.am (GDK_PIXBUF_LIBS): Patch from Paul Fisher - <pnfisher@redhat.com> adds all -lgdk-pixbuf and all other - dependencies to LIBADD variables for loadable modules. Necessary - for a Java dynamic loading thing to be able to figure it out. - -1999-11-22 Havoc Pennington <hp@pobox.com> - - * src/io-png.c (image_load_increment): Call the update_area - callback depending on the number of rows loaded in this increment. - - * src/testpixbuf.c (main): slow down the progressive load demo - -1999-11-16 Havoc Pennington <hp@pobox.com> - - * src/gdk-pixbuf-drawable.h: Get the quotes right on the #include - -1999-11-22 Jonathan Blandford <jrb@redhat.com> - - * configure.in (GDK_PIXBUF_DIR): make the symlink. Does not work - for srcdir != buildir != . Beats me why; I can't figure it out. - AC_OUTPUT_COMMANDS doesn't seem to let me substitute it correctly. - -1999-11-21 Jonathan Blandford <jrb@redhat.com> - - * src/gdk-pixbuf-io.c: added io-bmp from Arjan - <arjan@fenrus.demon.nl> - -1999-11-20 Michael Zucchi <zucchi@zedzone.mmc.com.au> - - * src/gdk-pixbuf-drawable.c (gdk_pixbuf_from_drawable_core): - Rework/reorder of the code. Each case has been separated into - another function; its big but it should be quick. - gdk_pixbuf_rgba_from_drawable() will now return a pixbuf with - opaque alpha information. Not all depths/formats have been - tested, but 8, 15/16 and 24 (alinged 32) should work ok. - -1999-11-17 Larry Ewing <lewing@gimp.org> - - * src/gnome-canvas-pixbuf.c (gnome_canvas_pixbuf_bounds): - implement the bounds method correctly. - (compute_viewport_affine): compute the affine need to fit the - image within the viewport given by the args. - (compute_render_affine): call compute_viewport_affine. - -1999-11-16 Havoc Pennington <hp@pobox.com> - - * src/gdk-pixbuf-drawable.h: Use includes from the current - directory, not the system directory. - -Mon Nov 15 17:18:28 1999 George Lebl <jirka@5z.com> - - * src/testpixbuf-drawable.c: use includes from the current directory - rather then from the system include directory as gdk-pixbuf - includes are not yet installed when this is compiled. - -1999-11-13 Cody Russell <bratsche@dfw.net> - * src/testpixbuf-drawable.c: Added a test program for drawable - code. - - * src/Makefile.am: Build testpixbuf-drawable. - -1999-11-12 Cody Russell <bratsche@dfw.net> - - * src/gdk-pixbuf-drawable.c: Merged in Michael Zucchi's changes. - -1999-11-10 Federico Mena Quintero <federico@redhat.com> - - * doc/tmpl/gdk-pixbuf-loader.sgml: Populated. - - * doc/gdk-pixbuf.signals: Put in the real names of signal - arguments. - - * src/gdk-pixbuf-loader.c: Improved documentation comments. - -1999-11-10 Jonathan Blandford <jrb@redhat.com> - - * src/gdk-pixbuf-loader.c (gdk_pixbuf_loader_close): emit the - closed signal. - - * src/io-ras.c (OneLineMapped_file): Now can handle indexing - correctly. Patch from Arjan to do so. - -1999-11-10 Michael Fulbright <drmike@redhat.com> - - * src/io-pnm.c (pnm_ascii_read_scanline): Fixed loading of ASCII PNM - files. - - * src/testpixbuf.c: Added final queued draw when done loading image. - -1999-11-10 Jonathan Blandford <jrb@redhat.com> - - * src/gdk-pixbuf-io.c (gdk_pixbuf_load_module): removed spurious - print statements. - -1999-11-10 Federico Mena Quintero <federico@redhat.com> - - * src/gdk-pixbuf-io.c (gdk_pixbuf_new_from_xpm_data): Added - documentation. - -1999-11-09 Federico Mena Quintero <federico@redhat.com> - - * src/io-png.c: Fixed some incompatible pointer initializations. - - * src/io-jpeg.c (image_load_increment): Remove unused variable. - -1999-11-09 Michael Fulbright <drmike@redhat.com> - - * src/testpixbuf.c: Fixed it to use timeout to read from file - for progressive loading. Set TBF_KBPS=n, where n is the number of - kilobytes/second to simulate in downloading. n has to be an integer. - - * src/io-jpeg.c: Slight cosmetic cleanup. - - * src/io-pnm.c: Fixed raw PNM loading bug. Also discovered that ASCII - PBM loading has a similar problem and will address tomorrow. - -1999-11-09 Havoc Pennington <hp@pobox.com> - - * src/Makefile.am (libgdk_pixbuf_la_SOURCES): build the - gdk-pixbuf-drawable stuff. - -1999-11-09 Federico Mena Quintero <federico@redhat.com> - - * configure.in: Bumped version number to 0.4. - -1999-11-09 Michael Fulbright <drmike@redhat.com> - - * src/io-pnm.c : Finished progressive PNM loading code. Should handle - all types of PNM files now. - - * src/io-jpeg.c (image_load_increment): Figured out problem with - loading Progressive JPEG's progressively (say that 10 times fast). - Currently for Progressive JPEG's the entire image is loaded before - it is displayed. libjpeg supports a fancier mechanism which I may - implement later. - - With these changes all JPEG formats appear to load properly for me. - -1999-11-08 Jonathan Blandford <jrb@redhat.com> - - * src/io-ras.c (image_load_increment): Final patch from Arjan. - Seems to do progressive loading. - -1999-11-08 Michael Fulbright <drmike@redhat.com> - - * src/io-pnm.c image_load (): Fixed so we do not create a separate - pixel buffer when reading in image - we reuse the pixel data in - the GdkPixbuf structure instead. - -1999-11-08 Michael Fulbright <drmike@redhat.com> - - * src/io-pnm.c pnm_read_ascii_scanline (): Added support for - ASCII PNM files. Note I haven't tested loaded ASCII PBM files because - I can't seem to find a utility to convert into this format. - Next is to add progressive loading support for the PNM format. - -1999-11-07 Federico Mena Quintero <federico@redhat.com> - - * doc/tmpl/gnome-canvas-pixbuf.sgml: Finished detailed explanation - of the width, height, x, and y setting and pixels arguments. - -1999-11-05 Jonathan Blandford <jrb@redhat.com> - - * src/io-ras.c (image_load): third patch. Now it seems to load. - - * src/gdk-pixbuf-io.c: second patch Arjan van de Ven - <arjan@fenrus.demon.nl> to autodetect/load the sunras files. - - * src/io-ras.c (image_load): new file from Arjan van de Ven - <arjan@fenrus.demon.nl> to begin the ras loader. - -1999-11-05 Federico Mena Quintero <federico@redhat.com> - - * doc/gdk-pixbuf-sections.txt: Removed gdk-pixbuf-io, since it is - for internal use only. - - * doc/gdk-pixbuf.sgml: Likewise. - - * doc/tmpl/gnome-canvas-pixbuf.sgml: Finished docs. - -1999-11-05 Michael Fulbright <drmike@redhat.com> - - * src/io-pnm.c: Implemented support for reading raw PBM/PGM/PPM - files from a file. Next step is support for ASCII files, and - then incremental loading. - -1999-11-04 Federico Mena Quintero <federico@redhat.com> - - * Makefile.am: Added doc to SUBDIRS. - -1999-11-04 Michael Fulbright <drmike@redhat.com> - - * src/io-jpeg.c: Prettied up code slightly. - * src/io-pnm.c: Start of pnm loader (from file and progressively). - Doesn't do much yet (will finish tomorrow). - * src/gdk-pixbuf-io.c: Added pnm to structure of known types. - -1999-11-04 Federico Mena Quintero <federico@redhat.com> - - * doc/tmpl/rendering.sgml: Populated. - - * doc/Makefile.am: Added the template files. - -1999-11-04 Havoc Pennington <hp@pobox.com> - - * src/gdk-pixbuf-render.c (gdk_pixbuf_render_to_drawable): In - docs, explain what a dither offset is for. - (gdk_pixbuf_render_to_drawable_alpha): Explain why you would use - this function vs. gdk_pixbuf_render_to_drawable(). - -1999-11-04 Havoc Pennington <hp@pobox.com> - - * configure.in: Use libart-config correctly; find gnome-config - separately. Fix GNOME_LIBS to be correct in "no gnome installed - yet" case. - - * src/Makefile.am: Link to GNOME_LIBS instead of a hardcoded - library list. - - Patch untested in the inside-gnome-libs case, I need to commit - then check out to the gnome-libs I'm using. - -1999-11-04 Michael Fulbright <drmike@redhat.com> - - * src/io-jpeg.c (image_begin_load): Add update_func callback. - * src/io-jpeg.c (image_load_increment): Call updated callback when - new graphic data decoded. - -1999-11-04 Jonathan Blandford <jrb@redhat.com> - - * src/gdk-pixbuf-loader.c (gdk_pixbuf_loader_update): handle the - actual update. - * src/io-png.c (image_begin_load): add a update_func callback. - * src/io-gif.c (image_begin_load): add a update_func callback. - (gif_get_lzw): added the update_func ability - - * src/io-tiff.c (image_begin_load): add a update_func callback. - -1999-11-04 Federico Mena Quintero <federico@redhat.com> - - * doc/tmpl/gdk-pixbuf.sgml: Populated. - - * doc/tmpl/refcounting.sgml: Populated. - - * doc/tmpl/file-loading.sgml: Populated. - - * src/gdk-pixbuf.c: Added documentation comments. - - * src/gdk-pixbuf-io.c (gdk_pixbuf_new_from_file): Added - documentation comments. - - * doc/: Finished integrating the documentation framework. - -1999-11-03 Federico Mena Quintero <federico@redhat.com> - - * configure.in: Removed libgif stuff now that we do not depend on it. - Added the necessary cruft for gtk-doc. - - * src/Makefile.am: Unconditionally build the GIF loader. - -1999-11-03 Jonathan Blandford <jrb@redhat.com> - - * src/io-gif.c (gif_read): renamed ReadOK to gif_read. - Added a lot of comments to the file. - - * src/Makefile.am (libpixbuf_gif_la_LIBADD): Remove dependency on - lib*gif!!!! - -1999-11-03 Michael Fulbright <drmike@redhat.com> - - * src/io-jpeg.c (image_load_increment): Further removal of - bugginess in local buffering code. Handles grayscale jpegs - correctly now. - - * src/io-jpeg.c (image_load_stop): Was freeing local context - for jpeg library before calling jpeg_decompres_finish (). - -1999-11-03 Jonathan Blandford <jrb@redhat.com> - - * src/io-gif.c (image_load_increment): now handle arbitrary buffer - sizes. - (gif_get_lzw): set the transparency to the right val. - -1999-11-03 Federico Mena Quintero <federico@redhat.com> - - * src/gnome-canvas-pixbuf.c (gnome_canvas_pixbuf_init): - Initiailize the x and y fields. - (gnome_canvas_pixbuf_destroy): Queue a redraw upon destruction. - (PixbufPrivate): Renamed need_size_update to need_xform_update. - (recompute_bounding_box): Do not use temporary values. - -1999-11-03 Jonathan Blandford <jrb@redhat.com> - - * src/io-gif.c (set_gif_lzw_clear_code): new state. Fixes - un-compressed gifs. - - * src/gnome-canvas-pixbuf.c (recompute_bounding_box): remove - unneeded x,y,h,w vars. - -1999-11-03 Larry Ewing <lewing@gimp.org> - - * src/gnome-canvas-pixbuf.c (compute_render_affine): adjust - render_affine calculation for x,y offsets. - (gnome_canvas_pixbuf_set_arg): add x,y args. - (gnome_canvas_pixbuf_get_arg): add x,y args. - (recompute_bounding_box): simply code using ArtDrect and the - render_affine. Removed compute_xform_vectors as it was no longer - needed. - -1999-11-03 Federico Mena Quintero <federico@redhat.com> - - * src/gnome-canvas-pixbuf.c (gnome_canvas_pixbuf_point): I'm a - doofus. Return a distance, not a boolean, for opaque images. - - * src/gnome-canvas-pixbuf.c (recompute_bounding_box): Do proper - rounding of bounding box coordinates. - (gnome_canvas_pixbuf_bounds): Implemented the ::bounds() method. - (gnome_canvas_pixbuf_draw): Use the correct alpha threshold value. - -1999-11-03 Jonathan Blandford <jrb@redhat.com> - - * src/io-gif.c (gif_prepare_lzw): s/lwz/lzw/g - -1999-11-03 Michael Fulbright <drmike@redhat.com> - - * src/io-jpg.c (image_load_increment): Fixed code which moved - buffer around as new data comes in to work properly. JPEG progressive - loading should be working now except for grayscale JPEG's, which I - will look into next. - -1999-11-03 <sopwith@redhat.com> - * src/testpixbuf.c: A GtkFunction needs to return a value for - deterministic behaviour. Also put dot printing back in. - -1999-11-03 <jrb@redhat.com> - - * src/io-gif.c (gif_get_extension): Read 'til the next empty block - correctly, now. - -1999-11-02 Cody Russell <bratsche@dfw.net> - * src/gdk-pixbuf-drawable.c: Changed the behavior to return NULL - if part of the requested image is offscreen, rather than clipping - the image. - -1999-11-02 Jonathan Blandford <jrb@redhat.com> - - * src/io-gif.c (gif_fill_in_lines): Fill in the gif's blank areas - for interlacing and progressive loading. - -1999-11-02 Cody Russell <bratsche@dfw.net> - * src/gdk-pixbuf-drawable.c (gdk_pixbuf_from_drawable_core): Now - calls gdk_pixbuf_new_from_art_pixbuf() instead of gdk_pixbuf_new(). - -1999-11-02 Jonathan Blandford <jrb@redhat.com> - - * src/io-gif.c (gif_main_loop): Now progressive gif loading works! - It's a little slow though. )-: - -1999-11-02 Elliot Lee <sopwith@redhat.com> - * src/gdk-pixbuf-loader.[ch], src/gdk-pixbuf-io.h: Make the - arguments to the write/load_increment operations const-correct. - -1999-11-02 Federico Mena Quintero <federico@redhat.com> - - * src/gnome-canvas-pixbuf.c (gnome_canvas_pixbuf_point): - Implemented the ::point() method. We do a simple containment test - instead of a full distance calculation since the canvas is going - to change to that scheme, anyways. - -1999-11-02 Elliot Lee <sopwith@redhat.com> - - * src/testpixbuf.c: Allow using $TBF_READLEN to specify the size - of the chunks that are read from the input file. - -1999-11-02 Larry Ewing <lewing@gimp.org> - - * src/gnome-canvas-pixbuf.c (gnome_canvas_pixbuf_render): add aa - render function. - (gnome_canvas_pixbuf_class_init): add gnome_canvas_pixbuf_render - to class. - -1999-11-02 Federico Mena Quintero <federico@redhat.com> - - * src/gnome-canvas-pixbuf.c (compute_render_affine): Moved the - affine computation code from ::draw() to here, since it is needed - by ::point() as well. - -1999-11-02 Elliot Lee <sopwith@redhat.com> - - * src/gdk-pixbuf-loader.c: Reorganize gdk_pixbuf_loader_write into - three functions, and eliminate duplication of code from write() - and close(). Also fix bug where the 128-byte header was being - written twice. - -1999-11-01 Federico Mena Quintero <federico@redhat.com> - * src/gnome-canvas-pixbuf.c (recompute_bounding_box): Fixed - bounding box computation. - -1999-11-01 Federico Mena Quintero <federico@redhat.com> - - * src/gnome-canvas-pixbuf.c: Start of the pixbuf canvas item. - Drawing affines seem to work. Bounding box is fubared. ::point() - is not implemented. This is a work in progress. - - * src/Makefile.am: Added gnome-canvas-pixbuf.[ch] to the list of - sources. - - * configure.in: Sigh. We need to link in libgnomeui for the - canvas stuff. This mess will disappear when gdk-pixbuf gets - folded into gnome-libs. - -1999-10-30 Jonathan Blandford <jrb@redhat.com> - - * src/io-gif.c: Some more work. Now it generates a gdk_pixbuf of - the right size, at a minimum, even if the image is squished and - the wrong color. - (ReadImage): lets get the offset right. This will let transparent - gifs work. - -1999-10-29 Michael Fulbright <drmike@redhat.com> - - * src/io-jpeg.c: image_load_increment(): Fixed bug when - image width was not a multiple of 4 - always use the - gdk_pixbuf rowstride to increment pointers! - -1999-10-29 Michael Fulbright <drmike@redhat.com> - - * src/io-jpeg.c: Added first cut at progressive jpeg loading. - Currently does not handle either progressive jpeg files (jpeg - files with multiple scans at different quality settings), but - I plan on adding this support soon. These are fairly rare in - my experience, so it shouldn't slow people down too much. - Grayscale jpegs also don't work but that should be easy to fix. - -1999-10-29 Michael Fulbright <drmike@redhat.com> - - * src/testpixbuf.c: Added title to windows so you can identify - progressive and file windows. - -1999-10-29 Michael Fulbright <drmike@redhat.com> - - * src/gdk-pixbuf-loader.c (gdk_pixbuf_loader_write): Actually - load the image handler when we determine the image type. - - * src/gdk-pixbuf-io.[ch] (gdk_pixbuf_load_module): Changed the - previously static function load_image_handler () to - a public function gdk_pixbuf_load_module (). It is needed in - gdk-pixbuf-loader.c to load image handler modules. This function - is different from gdk_pixbuf_get_module (), which only returns - a reference to the required handler, because it actually loads - the handler into memory. Both actions should possibly be combined - in a convenience function since one w/o the other doesn't seem to - make much sense. - -1999-10-28 Jonathan Blandford <jrb@redhat.com> - - * src/gdk-pixbuf-loader.c (gdk_pixbuf_loader_write): don't send a - 0 length buffer. - -1999-10-28 Federico Mena Quintero <federico@redhat.com> - - * src/gdk-pixbuf-render.c (gdk_pixbuf_render_to_drawable): New - function to render a portion of a pixbuf to a drawable. Ignores - alpha information and takes in a GC. - (gdk_pixbuf_render_to_drawable_alpha): New function to render a - portion of a pixbuf to a drawable. It automatically creates a GC - and a clipping mask for alpha pixbufs. - -1999-10-28 Jonathan Blandford <jrb@redhat.com> - - * src/gdk-pixbuf.h: turned convenience macros into convenience - functions so some error checking could be added. - - * src/io-tiff.c (image_load_increment): started work on the tiff - non-incremental loader. - (image_begin_load): Finished the incremental loader. - - * src/io-gif.c (image_load_increment): started work on the gif - incremental loader. - - * src/gdk-pixbuf-io.h: Changed ModuleType to GdkPixbufModule. - -1999-10-27 Federico Mena Quintero <federico@redhat.com> - - * src/gdk-pixbuf-render.c (gdk_pixbuf_render_threshold_alpha): New - function to threshold a pixbuf's alpha channel into a bitmap. - - * src/gdk-pixbuf.c (gdk_pixbuf_new): Fixed so that it will - contemplate future extensions to ArtPixBuf's formats. - - * src/io-png.c (png_info_callback): Use the new API of gdk_pixbuf_new(). - - * src/gdk-pixbuf.h (gdk_pixbuf_get_height): Added some convenience - macros to fetch the ArtPixBuf's fields. - -1999-10-27 Havoc Pennington <hp@pobox.com> - - * src/testpixbuf.c (main): Display the progressive load - - * src/io-png.c (setup_png_transformations): Break transformation - code into separate function - (png_info_callback): Use setup_png_transformations - -1999-10-27 Havoc Pennington <hp@pobox.com> - - * src/gdk-pixbuf-io.c (gdk_pixbuf_new_from_xpm_data): Check - properly whether the XPM module has already been loaded - (gdk_pixbuf_new_from_file): Check properly if loader module - was already loaded (was checking if load symbol was present - in order to decide whether to re-load; should check module != - NULL, then load != NULL) - (image_handler_load): Check in present working directory, - makes it easier to debug for now - (file_formats): This array initializer was seriously on crack, - was assigning a function pointer to a GModule* - - * src/testpixbuf.c (main): Change type of pixbuf_loader to - GdkPixbufLoader* - -1999-10-27 Havoc Pennington <hp@pobox.com> - - * src/gdk-pixbuf-loader.c (gdk_pixbuf_loader_finalize): - Fix typo that prevented compilation - (gdk_pixbuf_loader_destroy): ditto - -1999-10-27 Federico Mena Quintero <federico@redhat.com> - - * src/gdk-pixbuf-loader.c (gdk_pixbuf_loader_new): Return a - GdkPixbufLoader, not a GtkObject. - (gtk_marshal_NONE__INT_INT_INT_INT): Made static. - (gdk_pixbuf_loader_get_type): Documented. - (gdk_pixbuf_loader_class_init): Initialize the parent class - correctly. - (gdk_pixbuf_loader_destroy): Added sanity checks. Call the parent - class destroy function. - (gdk_pixbuf_loader_new): Documented. - (gdk_pixbuf_loader_finalize): Call the parent class finalize - function. - (gdk_pixbuf_loader_write): Use size_t for count. - -1999-10-27 Michael Fulbright <drmike@redhat.com> - - * src/gdk-pixbuf-loader.c (gdk_pixbuf_loader_destroy): Fixed - logic so we only try to close loader if it wasn't previously closed. - -1999-10-27 Michael Fulbright <drmike@redhat.com> - - * src/gdk-pixbuf-loader.c: Made sure image_loader struct member of - pixbuf_loader properly initialized. - - * src/testpixbuf.c: Made sure we cleanup pixbuf_loader properly - when done. - -1999-10-26 Jonathan Blandford <jrb@redhat.com> - - * src/gdk-pixbuf-io.c (image_handler_load): load the vtable fully. - - * src/gdk-pixbuf-loader.c: Finished initial cut at the object. - -1999-10-26 Havoc Pennington <hp@pobox.com> - - * src/gdk-pixbuf-loader.h: fix signals - - * src/gdk-pixbuf-io.h: add new vtable fields - - -1999-10-26 Jonathan Blandford <jrb@redhat.com> - - * src/gdk-pixbuf-loader.h: New Class. Beginning of progrssive - loading. - -1999-10-25 Federico Mena Quintero <federico@redhat.com> - - * configure.in (CFLAGS): Patch from Uwe Koloska - <koloska@Rcs1.urz.tu-dresden.de> to fix a stupid typo of mine. - -1999-10-22 Havoc Pennington <hp@pobox.com> - - * src/io-xpm.c (mem_buffer): Clean up stupid - increment-inside-array-dereference thing - - * src/testpixbuf.c: Add XPM data tests. - - * src/io-xpm.c: Make the XPM data buffer const, fix const - correctness throughout the code. - -1999-10-22 Havoc Pennington <hp@pobox.com> - - * src/gdk-pixbuf.h: Export gdk_pixbuf_new_from_xpm_data() - -1999-10-22 Havoc Pennington <hp@pobox.com> - - * src/io-xpm.c (image_load_xpm_data): Export this symbol for - loading an XPM from memory. - - * src/gdk-pixbuf-io.c (gdk_pixbuf_new_from_xpm_data): New - function, loads pixbuf from xpm data - (image_handler_load): Add g_return_if_fail() to ensure the same - module isn't loaded twice. Add g_module_symbol() to scan for XPM - loader function. - -1999-10-22 Federico Mena Quintero <federico@redhat.com> - - * src/io-png.c (image_load): Patch from Kristian Hogsberg - Kristensen <hogsberg@daimi.au.dk> to avoid allocating extra row - buffers; the rows can be read in directly into the main pixel - buffer. - -1999-10-20 Federico Mena Quintero <federico@redhat.com> - - * src/gdk-pixbuf-io.c (image_handler_load): Free path. - -1999-10-20 Federico Mena Quintero <federico@redhat.com> - - * configure.in: Bumped version number to 0.3. - - * src/Makefile.am (lbgdk_pixbuf_la_LDFLAGS): Added a libtool - version number for the library. - -1999-10-20 Federico Mena Quintero <federico@redhat.com> - - * src/gdk-pixbuf.h (GdkPixbuf): Removed the unref_fn field. Now - all memory management of the buffer is done by libart. - - * src/gdk-pixbuf.c (gdk_pixbuf_unref): Do destruction here. - Removed gdk_pixbuf_destroy, gdk_pixbuf_duplicate. - - * src/gdk-pixbuf-data.c (gdk_pixbuf_new_from_data): Implemented in - terms of the libart functions. Removed the old code. - - * src/gdk-pixbuf-io.c (image_handler_load): Removed the save - symbols. Saving will not be implemented in GdkPixbuf. - - * src/io-gif.c: Removed the saving stub. - (image_load): Fixed memory management to fail gracefully if we run - out of memory while loading the image. Close the gif file when we - are done. This still needs more error handling for the DGif - functions. - - * src/io-jpeg.c (image_load): Some robustness fixes. - - * src/io-png.c: Removed the saving stuff. - (image_load): Some memory management fixes. - - * src/io-tiff.c (image_load): Ditto. - - * src/io-xpm.c (pixbuf_create_from_xpm): Ditto. - -1999-10-18 Havoc Pennington <hp@pobox.com> - - * subautogen.sh: New name for macros/autogen.sh - - * autogen.sh: use subautogen.sh - -1999-10-18 Federico Mena Quintero <federico@redhat.com> - - * src/*: Reindented to use the GNOME Indentation. Renamed - GdkPixBuf to GdkPixbuf, for consistency with the function names - (and it is also easier to type) :-) - -1999-10-18 Havoc Pennington <hp@pobox.com> - - * configure.in: Use AM_PATH_GLIB instead of glib-config directly - - * src/Makefile.am: Re-enable testpixbuf with GTK_CFLAGS/GTK_LIBS - -1999-10-18 Havoc Pennington <hp@pobox.com> - - * Makefile.am (SUBDIRS): Remove "macros" - - * configure.in: Don't use GNOME_INIT, handle case where we are - inside gnome-libs. AM_PATH_GTK for the GIF test - - * src/Makefile.am: Change flags to work without libgnomeui, - comment out testpixbuf for now - -1999-10-18 Federico Mena Quintero <federico@redhat.com> - - * configure.in: Use $GTK_LIBS as the extra libs when checking for - libgif/libungif, as they need the X libraries. Fixes bug #2472. - -1999-10-10 Cody Russell <bratsche@dfw.net> - * src/gdk-pixbuf-drawable.c: core function now determines whether - the requested geometry is on screen or not, and if some is not - then the request is clamped to geometry that is on the screen. - - Changed 'pixbuf' to 'art_pixbuf' in core function. - -1999-10-08 Michael Fulbright <drmike@redhat.com> - - * src/gdk-pixbuf-data.c: Added to load rgb data from const data. - - * src/testpifbuf: Changed test program to display cdrom from rgb data - if no filename given to test program. - -1999-10-07 Cody Russell <bratsche@dfw.net> - * src/gdk-pixbuf-drawable.[ch]: Added. (Actually, Miguel committed - them, but I wrote them). - - * src/gdk-pixbuf-drawable.h: Added a missing ; so things will now - compile. - - * src/Makefile.am: Added gdk-pixbuf-drawable.[ch] to - libgdk_pixbuf_la_SOURCES and libgdk_pixbufinclude_HEADERS. - - * src/gdk-pixbuf-drawable.c: Added #include "gdk-pixbuf-drawable.h" - to fix compilation. - - * src/gdk-pixbuf-drawable.[ch]: Changed functions to return - GdkPixBuf* instead of ArtPixBuf*. - -1999-09-22 Michael Meeks <michael@nuclecu.unam.mx> - - * src/gdk-pixbuf.c (gdk_pixbuf_new): created. - (gdk_pixbuf_scale): use gdk_pixbuf_new + return a new scaled image. - - * src/gdk-pixbuf.h (struct _GdkPixBuf): Re-organise struct, + add - GdkPixBufUnrefFunc + gdk_pixbuf_new. - - * src/io-jpeg.c (image_load): clean to use gdk_pixbuf_new. - - * src/io-xpm.c (_pixbuf_create_from_xpm): ditto. - - * src/io-tiff.c (image_load): ditto + fix leak - - * src/io-png.c (image_load): ditto + add more exit points; monitor.png - crashes this module ( add warning :-) - - * src/io-bmp.c (image_load): ditto. - - * src/io-gif.c (image_load): ditto. - -1999-09-18 Michael Meeks <michael@nuclecu.unam.mx> - - * src/gdk-pixbuf.c (gdk_pixbuf_scale): Hack rgba support in so - it doesn't crash scaling with alpha. - -1999-09-17 Federico Mena Quintero <federico@redhat.com> - - * src/io-bmp.c (image_load): Set the initial ref_count to 1. - - * src/io-gif.c (image_load): Likewise. - - * src/io-jpeg.c (image_load): Likewise. - - * src/io-png.c (image_load): Likewise. - - * src/io-tiff.c (image_load): Likewise. - - * src/io-xpm.c (_pixbuf_create_from_xpm): Likewise. - - * src/gdk-pixbuf-io.c (gdk_pixbuf_load_image): Added an assertion - for the ref_count to be != 0. - - * src/gdk-pixbuf.c (gdk_pixbuf_ref): Be more paranoid with sanity - checking. - (gdk_pixbuf_unref): Fix incorrect sanity check and comparison. - -1999-08-09 Federico Mena Quintero <federico@nuclecu.unam.mx> - - * src/io-png.c (image_save): Fixed compiler warnings. Fixed write - to unallocated memory (row_ptr), and fixed its type as well. Take - into account the ArtPixbuf's rowstride when assigning the row - pointers. - - * src/gdk-pixbuf.c: Fixup includes. - - * src/gdk-pixbuf-io.c: Likewise. - -Sat Jul 31 19:19:47 CEST 1999 - - * src/gdk-pixbuf-io.c: - * src/io-png.c: Fixed two obvious C syntax bugs - -1999-07-29 Mark Crichton <crichton@gimp.org> - - * src/io-png.c (image_save): Added PNG saving function - - * src/gdk-pixbuf-io.c: Changed image_save function format. Now it's - image_save(GdkPixBuf *p, FILE *f, ...) - - -1999-07-26 Michael Zucchi <mzucchi@denr.sa.gov.au> - - * src/Makefile.am (*_LIB): Only build the relevant loaders which - require extra libraries if we actually have those libraries. - -1999-07-23 Richard Hestilow <hestgray@ionet.net> - - * src/gdk-pixbuf.h: Include glib.h as it uses g* datatypes - * gdk_pixbufConf.sh.in: Added for gnome-config - * Makefile.am: - * configure.in: Modified to generate gdk_pixbufConf.sh - -1999-07-20 Mark Crichton <crichton@gimp.org> - - * src/gdk-pixbuf.c (gdk_pixbuf_rotate): Fixed rotation. Now a bbox - calculation needs to be done. - -1999-07-18 Larry Ewing <lewing@gimp.org> - - * src/io-xpm.c: - * src/io-gif.c: - * src/io-png.c: - * src/io-jpeg.c: Fix a few memory leaks in the, most of them in - error cases but one or two in the common case. There are probably - a few small ones left. - -1999-07-18 Mark Crichton <crichton@gimp.org> - - * configure.in: removed version.h. - - * src/gdk-pixbuf-io.c (pixbuf_check_tiff): Minor readability - improvements. - -1999-07-17 Mark Crichton <crichton@gimp.org> - - * src/gdk-pixbuf.c: Removed gdk_pixbuf_free, redundant code. - (gdk_pixbuf_rotate): Added pixbuf rotation code. - (gdk_pixbuf_scale): Changed // comments to /* */ - - * src/gdk-pixbuf.h (gdk_pixbuf_destroy): Added gdk_pixbuf_destroy - function to header. - -1999-07-16 Larry Ewing <lewing@gimp.org> - - * src/testpixbuf.c (expose_func): reverted the expose everything - changes, I'm not sure why these went in. - (config_func): bring this up to date with the new pixbuf_scale - semantics. - - * src/gdk-pixbuf-io.c: added a couple of warnings to the module - loading code so that poeple can diagnose problems better. - - * src/gdk-pixbuf.c (gdk_pixbux_scale): fix the borkedness, also it - no longer allocates a new pixbuf, which make things nicer for the - rest of the code. Unfortunately there is still a problem with - scaling rgba images. - -1999-07-16 Mark Crichton <crichton@gimp.org> - - * src/testpixbuf.c (config_func): ConfigureEvent handler. This - calls gdk_pixbuf_scale. However, something is not working. - N.B.: current pixmap is now stored in user_data with a key of - "pixmap" - - * src/gdk-pixbuf.c (gdk_pixbuf_scale): Implemented scaling function. - Something is still borked, however. - -1999-07-15 Larry Ewing <lewing@gimp.org> - - * src/io-jpeg.c (image_load): add raph@gimp.org's fix to the jpeg - indexing routine - - * src/testpixbuf.c (main): fix up the file routines a little so - that you can load multiple files given the file names - -1999-07-14 Larry Ewing <lewing@gimp.org> - - * src/testpixbuf.c (expose_func): added an almost proper expose - handler for testpixbuf - -1999-07-13 Mark Crichton <crichton@gimp.org> - - * configure.in: Fixed GIF check. Replaced " with ' - * src/gdk-pixbuf.c: More (minor) work on gdk_pixbuf_scale - -1999-07-13 Mark Crichton <crichton@gimp.org> - - * configure.in: I am a bonehead. Added gif-lib check. diff --git a/gdk-pixbuf/Makefile.am b/gdk-pixbuf/Makefile.am deleted file mode 100644 index bb0ac92d32..0000000000 --- a/gdk-pixbuf/Makefile.am +++ /dev/null @@ -1,748 +0,0 @@ -include $(top_srcdir)/Makefile.decl --include $(INTROSPECTION_MAKEFILE) - -INTROSPECTION_GIRS = - -SUBDIRS = pixops - -if PLATFORM_WIN32 -no_undefined = -no-undefined -endif - -if OS_WIN32 -gdk_pixbuf_def = gdk_pixbuf.def -gdk_pixbuf_symbols = -export-symbols $(srcdir)/gdk_pixbuf.def - -gdk_pixbuf_win32_res = gdk_pixbuf-win32-res.o -gdk_pixbuf_win32_res_ldflag = -Wl,gdk_pixbuf-win32-res.o - -libole32 = -lole32 - -gdk_pixbuf-win32-res.o : gdk_pixbuf.rc - $(WINDRES) gdk_pixbuf.rc $@ - -install-def-file: - $(INSTALL) $(srcdir)/gdk_pixbuf.def $(DESTDIR)$(libdir)/gdk_pixbuf-$(GTK_API_VERSION).def -uninstall-def-file: - -rm $(DESTDIR)$(libdir)/gdk_pixbuf-$(GTK_API_VERSION).def -else -install-def-file: -uninstall-def-file: -endif - -if MS_LIB_AVAILABLE -noinst_DATA = gdk_pixbuf-$(GTK_API_VERSION).lib - -gdk_pixbuf-$(GTK_API_VERSION).lib: libgdk_pixbuf-$(GTK_API_VERSION).la gdk_pixbuf.def - lib -machine:@LIB_EXE_MACHINE_FLAG@ -name:libgdk_pixbuf-$(GTK_API_VERSION)-@LT_CURRENT_MINUS_AGE@.dll -def:gdk_pixbuf.def -out:$@ - -install-ms-lib: - $(INSTALL) gdk_pixbuf-$(GTK_API_VERSION).lib $(DESTDIR)$(libdir) - -uninstall-ms-lib: - -rm $(DESTDIR)$(libdir)/gdk_pixbuf-$(GTK_API_VERSION).lib -else -install-ms-lib: -uninstall-ms-lib: -endif - -# This places the generated .def file in srcdir, since it is expected to be there. -# (The one from a tarball is) -gdk_pixbuf.def: gdk-pixbuf.symbols - (echo -e EXPORTS; $(CPP) -P -DINCLUDE_VARIABLES -DG_OS_WIN32 -DALL_FILES - <$(srcdir)/gdk-pixbuf.symbols | sed -e '/^$$/d' -e 's/^/ /' -e 's/G_GNUC_[^ ]*//g') > $(srcdir)/gdk_pixbuf.def - -gdk-pixbuf-alias.h: gdk-pixbuf.symbols - $(PERL) $(srcdir)/makegdkpixbufalias.pl < $(srcdir)/gdk-pixbuf.symbols > gdk-pixbuf-alias.h - -gdk-pixbuf-aliasdef.c: gdk-pixbuf.symbols - $(PERL) $(srcdir)/makegdkpixbufalias.pl -def < $(srcdir)/gdk-pixbuf.symbols > gdk-pixbuf-aliasdef.c - -if OS_LINUX -TESTS = abicheck.sh pltcheck.sh -endif - -lib_LTLIBRARIES = \ - libgdk_pixbuf-3.0.la - -loaderdir = $(libdir)/gtk-3.0/$(GTK_BINARY_VERSION)/loaders - -module_libs = libgdk_pixbuf-$(GTK_API_VERSION).la $(GDK_PIXBUF_DEP_LIBS) - -# -# The PNG loader -# -libstatic_pixbufloader_png_la_SOURCES = io-png.c -libpixbufloader_png_la_SOURCES = io-png.c -libpixbufloader_png_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_png_la_LIBADD = $(LIBPNG) $(module_libs) - -# -# The BMP loader -# -libstatic_pixbufloader_bmp_la_SOURCES = io-bmp.c -libpixbufloader_bmp_la_SOURCES = io-bmp.c -libpixbufloader_bmp_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_bmp_la_LIBADD = $(module_libs) - -# -# The WBMP loader -# -libstatic_pixbufloader_wbmp_la_SOURCES = io-wbmp.c -libpixbufloader_wbmp_la_SOURCES = io-wbmp.c -libpixbufloader_wbmp_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_wbmp_la_LIBADD = $(module_libs) - -# -# The GIF loader -# -libstatic_pixbufloader_gif_la_SOURCES = io-gif.c io-gif-animation.c io-gif-animation.h -libpixbufloader_gif_la_SOURCES = io-gif.c io-gif-animation.c io-gif-animation.h -libpixbufloader_gif_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_gif_la_LIBADD = $(module_libs) - -# -# The ICO loader -# -libstatic_pixbufloader_ico_la_SOURCES = io-ico.c -libpixbufloader_ico_la_SOURCES = io-ico.c -libpixbufloader_ico_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_ico_la_LIBADD = $(module_libs) - -# -# The ANI loader -# -libstatic_pixbufloader_ani_la_SOURCES = io-ani.c io-ani-animation.c io-ani-animation.h -libpixbufloader_ani_la_SOURCES = io-ani.c io-ani-animation.c io-ani-animation.h -libpixbufloader_ani_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_ani_la_LIBADD = $(module_libs) - -# -# The JPEG loader -# -libstatic_pixbufloader_jpeg_la_SOURCES = io-jpeg.c -libpixbufloader_jpeg_la_SOURCES = io-jpeg.c -libpixbufloader_jpeg_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_jpeg_la_LIBADD = $(LIBJPEG) $(module_libs) - -# -# The PNM loader -# -libstatic_pixbufloader_pnm_la_SOURCES = io-pnm.c -libpixbufloader_pnm_la_SOURCES = io-pnm.c -libpixbufloader_pnm_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_pnm_la_LIBADD = $(module_libs) - -# -# The RAS loader -# -libstatic_pixbufloader_ras_la_SOURCES = io-ras.c -libpixbufloader_ras_la_SOURCES = io-ras.c -libpixbufloader_ras_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_ras_la_LIBADD = $(module_libs) - -# -# The TIFF loader -# -libstatic_pixbufloader_tiff_la_SOURCES = io-tiff.c -libpixbufloader_tiff_la_SOURCES = io-tiff.c -libpixbufloader_tiff_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_tiff_la_LIBADD = $(LIBTIFF) $(module_libs) - -# -# The XPM loader -# -libstatic_pixbufloader_xpm_la_SOURCES = io-xpm.c -libpixbufloader_xpm_la_SOURCES = io-xpm.c -libpixbufloader_xpm_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_xpm_la_LIBADD = $(module_libs) - -# -# The XBM loader -# -libstatic_pixbufloader_xbm_la_SOURCES = io-xbm.c -libpixbufloader_xbm_la_SOURCES = io-xbm.c -libpixbufloader_xbm_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_xbm_la_LIBADD = $(module_libs) - -# -# The TGA loader -# -libstatic_pixbufloader_tga_la_SOURCES = io-tga.c -libpixbufloader_tga_la_SOURCES = io-tga.c -libpixbufloader_tga_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_tga_la_LIBADD = $(module_libs) - -# -# The .icns loader -# -libstatic_pixbufloader_icns_la_SOURCES = io-icns.c -libpixbufloader_icns_la_SOURCES = io-icns.c -libpixbufloader_icns_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_icns_la_LIBADD = $(module_libs) - -# -# The PCX loader -# -libstatic_pixbufloader_pcx_la_SOURCES = io-pcx.c -libpixbufloader_pcx_la_SOURCES = io-pcx.c -libpixbufloader_pcx_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_pcx_la_LIBADD = $(module_libs) - -# -# The JPEG2000 loader -# -libstatic_pixbufloader_jasper_la_SOURCES = io-jasper.c -libpixbufloader_jasper_la_SOURCES = io-jasper.c -libpixbufloader_jasper_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_jasper_la_LIBADD = $(LIBJASPER) $(module_libs) - -# -# The QTIF loader -# -libstatic_pixbufloader_qtif_la_SOURCES = io-qtif.c -libpixbufloader_qtif_la_SOURCES = io-qtif.c -libpixbufloader_qtif_la_LDFLAGS = -avoid-version -module $(no_undefined) -libpixbufloader_qtif_la_LIBADD = $(module_libs) - -if BUILD_GDIPLUS_LOADERS - -if INCLUDE_GDIPLUS - -# When building the GDI+ loader statically, we put the "common" objects -# only in one of the archives to avoid duplicate definitions - -STATIC_GDIPLUS_LIBS = \ - libstatic-pixbufloader-gdip-ico.la \ - libstatic-pixbufloader-gdip-wmf.la \ - libstatic-pixbufloader-gdip-emf.la \ - libstatic-pixbufloader-gdip-bmp.la \ - libstatic-pixbufloader-gdip-gif.la \ - libstatic-pixbufloader-gdip-jpeg.la \ - libstatic-pixbufloader-gdip-tiff.la - -libstatic_pixbufloader_gdip_ico_la_SOURCES = \ - io-gdip-native.h \ - io-gdip-propertytags.h \ - io-gdip-utils.h \ - io-gdip-utils.c \ - io-gdip-animation.c \ - io-gdip-animation.h \ - io-gdip-ico.c - -libstatic_pixbufloader_gdip_wmf_la_SOURCES = \ - io-gdip-wmf.c - -libstatic_pixbufloader_gdip_emf_la_SOURCES = \ - io-gdip-emf.c - -libstatic_pixbufloader_gdip_bmp_la_SOURCES = \ - io-gdip-bmp.c - -libstatic_pixbufloader_gdip_gif_la_SOURCES = \ - io-gdip-gif.c - -libstatic_pixbufloader_gdip_jpeg_la_SOURCES = \ - io-gdip-jpeg.c - -libstatic_pixbufloader_gdip_tiff_la_SOURCES = \ - io-gdip-tiff.c - -else - -GDIPLUS_LIBS = \ - libpixbufloader-gdip-ico.la \ - libpixbufloader-gdip-wmf.la \ - libpixbufloader-gdip-emf.la \ - libpixbufloader-gdip-bmp.la \ - libpixbufloader-gdip-gif.la \ - libpixbufloader-gdip-jpeg.la \ - libpixbufloader-gdip-tiff.la - -libpixbufloader_gdip_ico_la_LDFLAGS = -avoid-version -module -no-undefined -libpixbufloader_gdip_ico_la_SOURCES = \ - io-gdip-native.h \ - io-gdip-propertytags.h \ - io-gdip-utils.h \ - io-gdip-utils.c \ - io-gdip-animation.c \ - io-gdip-animation.h \ - io-gdip-ico.c -libpixbufloader_gdip_ico_la_LIBADD = $(module_libs) $(libole32) - -libpixbufloader_gdip_wmf_la_LDFLAGS = -avoid-version -module -no-undefined -libpixbufloader_gdip_wmf_la_SOURCES = \ - io-gdip-native.h \ - io-gdip-propertytags.h \ - io-gdip-utils.h \ - io-gdip-utils.c \ - io-gdip-animation.c \ - io-gdip-animation.h \ - io-gdip-wmf.c -libpixbufloader_gdip_wmf_la_LIBADD = $(module_libs) $(libole32) - -libpixbufloader_gdip_emf_la_LDFLAGS = -avoid-version -module -no-undefined -libpixbufloader_gdip_emf_la_SOURCES = \ - io-gdip-native.h \ - io-gdip-propertytags.h \ - io-gdip-utils.h \ - io-gdip-utils.c \ - io-gdip-animation.c \ - io-gdip-animation.h \ - io-gdip-emf.c -libpixbufloader_gdip_emf_la_LIBADD = $(module_libs) $(libole32) - -libpixbufloader_gdip_bmp_la_LDFLAGS = -avoid-version -module -no-undefined -libpixbufloader_gdip_bmp_la_SOURCES = \ - io-gdip-native.h \ - io-gdip-propertytags.h \ - io-gdip-utils.h \ - io-gdip-utils.c \ - io-gdip-animation.c \ - io-gdip-animation.h \ - io-gdip-bmp.c -libpixbufloader_gdip_bmp_la_LIBADD = $(module_libs) $(libole32) - -libpixbufloader_gdip_gif_la_LDFLAGS = -avoid-version -module -no-undefined -libpixbufloader_gdip_gif_la_SOURCES = \ - io-gdip-native.h \ - io-gdip-propertytags.h \ - io-gdip-utils.h \ - io-gdip-utils.c \ - io-gdip-animation.c \ - io-gdip-animation.h \ - io-gdip-gif.c -libpixbufloader_gdip_gif_la_LIBADD = $(module_libs) $(libole32) - -libpixbufloader_gdip_jpeg_la_LDFLAGS = -avoid-version -module -no-undefined -libpixbufloader_gdip_jpeg_la_SOURCES = \ - io-gdip-native.h \ - io-gdip-propertytags.h \ - io-gdip-utils.h \ - io-gdip-utils.c \ - io-gdip-animation.c \ - io-gdip-animation.h \ - io-gdip-jpeg.c -libpixbufloader_gdip_jpeg_la_LIBADD = $(module_libs) $(libole32) - -libpixbufloader_gdip_tiff_la_LDFLAGS = -avoid-version -module -no-undefined -libpixbufloader_gdip_tiff_la_SOURCES = \ - io-gdip-native.h \ - io-gdip-propertytags.h \ - io-gdip-utils.h \ - io-gdip-utils.c \ - io-gdip-animation.c \ - io-gdip-animation.h \ - io-gdip-tiff.c -libpixbufloader_gdip_tiff_la_LIBADD = $(module_libs) $(libole32) - -endif - -else - -# Loaders that aren't built if we build the GDI+ loader - -if INCLUDE_BMP -STATIC_BMP_LIB = libstatic-pixbufloader-bmp.la -else -BMP_LIB = libpixbufloader-bmp.la -endif - -if INCLUDE_GIF -STATIC_GIF_LIB = libstatic-pixbufloader-gif.la -else -GIF_LIB = libpixbufloader-gif.la -endif - -if INCLUDE_ICO -STATIC_ICO_LIB = libstatic-pixbufloader-ico.la -else -ICO_LIB = libpixbufloader-ico.la -endif - -if HAVE_JPEG -if INCLUDE_JPEG -STATIC_JPEG_LIB = libstatic-pixbufloader-jpeg.la -else -JPEG_LIB = libpixbufloader-jpeg.la -endif -endif - -if HAVE_TIFF -if INCLUDE_TIFF -STATIC_TIFF_LIB = libstatic-pixbufloader-tiff.la -else -TIFF_LIB = libpixbufloader-tiff.la -endif -endif - -# End of loaders not built if building GDI+ loader -endif - -if HAVE_PNG -if INCLUDE_PNG -STATIC_PNG_LIB = libstatic-pixbufloader-png.la -else -PNG_LIB = libpixbufloader-png.la -endif -endif - -if INCLUDE_WBMP -STATIC_WBMP_LIB = libstatic-pixbufloader-wbmp.la -else -WBMP_LIB = libpixbufloader-wbmp.la -endif - -if INCLUDE_ANI -STATIC_ANI_LIB = libstatic-pixbufloader-ani.la -else -ANI_LIB = libpixbufloader-ani.la -endif - -if INCLUDE_PNM -STATIC_PNM_LIB = libstatic-pixbufloader-pnm.la -else -PNM_LIB = libpixbufloader-pnm.la -endif - -if INCLUDE_RAS -STATIC_RAS_LIB = libstatic-pixbufloader-ras.la -else -RAS_LIB = libpixbufloader-ras.la -endif - -if INCLUDE_XPM -STATIC_XPM_LIB = libstatic-pixbufloader-xpm.la -else -XPM_LIB = libpixbufloader-xpm.la -endif - -if INCLUDE_XBM -STATIC_XBM_LIB = libstatic-pixbufloader-xbm.la -else -XBM_LIB = libpixbufloader-xbm.la -endif - -if INCLUDE_TGA -STATIC_TGA_LIB = libstatic-pixbufloader-tga.la -else -TGA_LIB = libpixbufloader-tga.la -endif - -if INCLUDE_PCX -STATIC_PCX_LIB = libstatic-pixbufloader-pcx.la -else -PCX_LIB = libpixbufloader-pcx.la -endif - -if INCLUDE_ICNS -STATIC_ICNS_LIB = libstatic-pixbufloader-icns.la -else -ICNS_LIB = libpixbufloader-icns.la -endif - -if HAVE_JASPER -if INCLUDE_JASPER -STATIC_JASPER_LIB = libstatic-pixbufloader-jasper.la -else -JASPER_LIB = libpixbufloader-jasper.la -endif -endif - -if INCLUDE_QTIF -STATIC_QTIF_LIB = libstatic-pixbufloader-qtif.la -else -QTIF_LIB = libpixbufloader-qtif.la -endif - -if BUILD_DYNAMIC_MODULES - -loader_LTLIBRARIES = \ - $(PNG_LIB) \ - $(BMP_LIB) \ - $(WBMP_LIB) \ - $(GIF_LIB) \ - $(ICO_LIB) \ - $(ANI_LIB) \ - $(JPEG_LIB) \ - $(PNM_LIB) \ - $(RAS_LIB) \ - $(TIFF_LIB) \ - $(XPM_LIB) \ - $(XBM_LIB) \ - $(TGA_LIB) \ - $(ICNS_LIB) \ - $(PCX_LIB) \ - $(JASPER_LIB) \ - $(QTIF_LIB) \ - $(GDIPLUS_LIBS) - - -endif - -noinst_LTLIBRARIES = \ - $(STATIC_PNG_LIB) \ - $(STATIC_BMP_LIB) \ - $(STATIC_WBMP_LIB) \ - $(STATIC_GIF_LIB) \ - $(STATIC_ICO_LIB) \ - $(STATIC_ANI_LIB) \ - $(STATIC_JPEG_LIB) \ - $(STATIC_PNM_LIB) \ - $(STATIC_RAS_LIB) \ - $(STATIC_TIFF_LIB) \ - $(STATIC_XPM_LIB) \ - $(STATIC_XBM_LIB) \ - $(STATIC_TGA_LIB) \ - $(STATIC_ICNS_LIB) \ - $(STATIC_PCX_LIB) \ - $(STATIC_JASPER_LIB) \ - $(STATIC_QTIF_LIB) \ - $(STATIC_GDIPLUS_LIBS) - -builtin_objs = @INCLUDED_LOADER_OBJ@ - - -DEPS = libgdk_pixbuf-$(GTK_API_VERSION).la -INCLUDES = \ - -DG_LOG_DOMAIN=\"GdkPixbuf\" \ - -DGDK_PIXBUF_COMPILATION \ - -I$(top_srcdir) -I$(top_builddir) \ - -I$(top_srcdir)/gdk-pixbuf \ - -I$(top_builddir)/gdk-pixbuf \ - -DGTK_LIBDIR=\"$(libdir)\" \ - -DGTK_VERSION=\"$(GTK_VERSION)\" \ - -DGTK_BINARY_VERSION=\"$(GTK_BINARY_VERSION)\" \ - -DGTK_PREFIX=\"$(prefix)\" \ - $(INCLUDED_LOADER_DEFINE) \ - $(GTK_DEBUG_FLAGS) \ - $(GDK_PIXBUF_DEP_CFLAGS) \ - -DGDK_PIXBUF_ENABLE_BACKEND - -AM_CPPFLAGS = "-DPIXBUF_LIBDIR=\"$(loaderdir)\"" "-DBUILT_MODULES_DIR=\"$(srcdir)/.libs\"" -LDADDS = libgdk_pixbuf-$(GTK_API_VERSION).la $(GDK_PIXBUF_DEP_LIBS) - -noinst_PROGRAMS = test-gdk-pixbuf -test_gdk_pixbuf_LDADD = $(LDADDS) - -bin_PROGRAMS = gdk-pixbuf-csource-3.0 gdk-pixbuf-query-loaders-3.0 -gdk_pixbuf_csource_3_0_SOURCES = gdk-pixbuf-csource.c -gdk_pixbuf_csource_3_0_LDADD = $(LDADDS) - -gdk_pixbuf_query_loaders_3_0_DEPENDENCIES = $(DEPS) -gdk_pixbuf_query_loaders_3_0_LDADD = $(LDADDS) - -gdk_pixbuf_query_loaders_3_0_SOURCES = queryloaders.c - - -# -# The GdkPixBuf library -# -libgdk_pixbufincludedir = $(includedir)/gtk-3.0/gdk-pixbuf -libgdk_pixbuf_3_0_la_SOURCES = \ - gdk-pixbuf-i18n.h \ - gdk-pixbuf.c \ - gdk-pixbuf-animation.c \ - gdk-pixbuf-data.c \ - gdk-pixbuf-io.c \ - gdk-pixbuf-loader.c \ - gdk-pixbuf-scale.c \ - gdk-pixbuf-simple-anim.c \ - gdk-pixbuf-scaled-anim.c \ - gdk-pixbuf-util.c \ - gdk-pixdata.c \ - gdk-pixbuf-enum-types.c - -libgdk_pixbuf_3_0_la_LDFLAGS = \ - $(gdk_pixbuf_win32_res_ldflag) \ - -version-info $(LT_VERSION_INFO) \ - $(LIBTOOL_EXPORT_OPTIONS) \ - $(no_undefined) \ - $(gdk_pixbuf_symbols) - - -libgdk_pixbuf_3_0_la_LIBADD = pixops/libpixops.la $(builtin_objs) $(GDK_PIXBUF_DEP_LIBS) $(libole32) -libgdk_pixbuf_3_0_la_DEPENDENCIES = pixops/libpixops.la $(builtin_objs) $(gdk_pixbuf_def) $(gdk_pixbuf_win32_res) - -gdk_pixbuf_headers = \ - gdk-pixbuf.h \ - gdk-pixbuf-core.h \ - gdk-pixbuf-transform.h \ - gdk-pixbuf-io.h \ - gdk-pixbuf-animation.h \ - gdk-pixbuf-simple-anim.h \ - gdk-pixbuf-loader.h - -libgdk_pixbufinclude_HEADERS = \ - $(gdk_pixbuf_headers) \ - gdk-pixbuf-enum-types.h \ - gdk-pixbuf-marshal.h \ - gdk-pixbuf-features.h \ - gdk-pixdata.h - -noinst_HEADERS = \ - gdk-pixbuf-alias.h \ - gdk-pixbuf-private.h \ - gdk-pixbuf-scaled-anim.h \ - xpm-color-table.h - -BUILT_SOURCES = \ - gdk-pixbuf-alias.h \ - gdk-pixbuf-aliasdef.c \ - gdk-pixbuf-enum-types.h \ - gdk-pixbuf-enum-types.c \ - gdk-pixbuf-marshal.h \ - gdk-pixbuf-marshal.c \ - gdk-pixbuf-features.h - -CLEANFILES = -MAINTAINERCLEANFILES = \ - gdk-pixbuf-aliasdef.c \ - gdk-pixbuf-enum-types.h \ - gdk-pixbuf-enum-types.c \ - gdk-pixbuf-marshal.h \ - gdk-pixbuf-marshal.c \ - loaders.cache - -# -# gdk-pixbuf-enum-types.h -# -gdk-pixbuf-enum-types.h: s-enum-types-h - @true - -s-enum-types-h: @REBUILD@ $(gdk_pixbuf_headers) gdk-pixbuf-enum-types.h.template - ( cd $(srcdir) && $(GLIB_MKENUMS) --template gdk-pixbuf-enum-types.h.template \ - $(gdk_pixbuf_headers) ) > tmp-gdk-pixbuf-enum-types.h \ - && (cmp -s tmp-gdk-pixbuf-enum-types.h gdk-pixbuf-enum-types.h || cp tmp-gdk-pixbuf-enum-types.h gdk-pixbuf-enum-types.h ) \ - && rm -f tmp-gdk-pixbuf-enum-types.h \ - && echo timestamp > $(@F) - -CLEANFILES += tmp-gdk-pixbuf-enum-types.h -MAINTAINERCLEANFILES += s-enum-types-h - -# -# gdk-pixbuf-enum-types.c -# -gdk-pixbuf-enum-types.c: @REBUILD@ $(gdk_pixbuf_headers) gdk-pixbuf-enum-types.c.template - (cd $(srcdir) && $(GLIB_MKENUMS) --template gdk-pixbuf-enum-types.c.template \ - $(gdk_pixbuf_headers)) > gdk-pixbuf-enum-types.c - -# -# gdk-pixbuf-marshal.h -# -gdk-pixbuf-marshal.h: @REBUILD@ stamp-gdk-pixbuf-marshal.h - @true - -stamp-gdk-pixbuf-marshal.h: @REBUILD@ $(srcdir)/gdk-pixbuf-marshal.list - echo "#if !defined(GDK_PIXBUF_DISABLE_DEPRECATED) || defined(GDK_PIXBUF_COMPILATION)" > xgen-gmh \ - && $(GLIB_GENMARSHAL) --prefix=_gdk_pixbuf_marshal $(srcdir)/gdk-pixbuf-marshal.list --header >> xgen-gmh \ - && echo "#endif /* !GDK_PIXBUF_DISABLE_DEPRECATED || GDK_PIXBUF_COMPILATION */" >> xgen-gmh \ - && (cmp -s xgen-gmh gdk-pixbuf-marshal.h || cp xgen-gmh gdk-pixbuf-marshal.h) \ - && rm -f xgen-gmh xgen-gmh~ \ - && echo timestamp > $(@F) - -CLEANFILES += xgen-gmh -MAINTAINERCLEANFILES += stamp-gdk-pixbuf-marshal.h - -# -# gdk-pixbuf-marshal.c -# -$(srcdir)/gdk-pixbuf-marshal.c: @REBUILD@ $(srcdir)/gdk-pixbuf-marshal.list - (echo -e "#include <gdk-pixbuf/gdk-pixbuf.h>\n#include \"gdk-pixbuf-alias.h\"" | $(GLIB_GENMARSHAL) --prefix=_gdk_pixbuf_marshal $(srcdir)/gdk-pixbuf-marshal.list --body ) >> xgen-gmc \ - && cp xgen-gmc gdk-pixbuf-marshal.c \ - && rm -f xgen-gmc xgen-gmc~ - -CLEANFILES += xgen-gmc - -# if srcdir!=builddir, clean out maintainer-clean files from builddir -# this allows dist to pass. -distclean-local: - if test $(srcdir) != .; then \ - rm -f $(MAINTAINERCLEANFILES); \ - fi - -EXTRA_DIST += \ - gdk-pixbuf-csource.1 \ - makefile.msc \ - gdk-pixbuf.symbols \ - makegdkpixbufalias.pl \ - abicheck.sh \ - pltcheck.sh \ - gdk_pixbuf.def \ - gdk_pixbuf.rc \ - gdk-pixbuf-marshal.c \ - gdk-pixbuf-marshal.list \ - gdk-pixbuf-enum-types.c.template \ - gdk-pixbuf-enum-types.h.template \ - gen-color-table.pl - -if HAVE_INTROSPECTION - -GdkPixbuf-3.0.gir: libgdk_pixbuf-3.0.la Makefile -GdkPixbuf_3_0_gir_SCANNERFLAGS = --strip-prefix=Gdk -GdkPixbuf_3_0_gir_INCLUDES = GModule-2.0 Gio-2.0 -GdkPixbuf_3_0_gir_LIBS = libgdk_pixbuf-3.0.la -GdkPixbuf_3_0_gir_CFLAGS = $(INCLUDES) -GdkPixbuf_3_0_gir_FILES = \ - $(addprefix $(srcdir)/,$(libgdk_pixbufinclude_HEADERS)) \ - $(addprefix $(srcdir)/,$(libgdk_pixbuf_3_0_la_SOURCES)) -INTROSPECTION_GIRS += GdkPixbuf-3.0.gir - -girdir = $(datadir)/gir-1.0 -gir_DATA = $(INTROSPECTION_GIRS) - -typelibsdir = $(libdir)/girepository-1.0 -typelibs_DATA = $(INTROSPECTION_GIRS:.gir=.typelib) - -CLEANFILES += $(gir_DATA) $(typelibs_DATA) -endif - -if CROSS_COMPILING -RUN_QUERY_LOADER_TEST=false -else -RUN_QUERY_LOADER_TEST=test -z "$(DESTDIR)" -endif - -# Running this if cross compiling or if DESTDIR is set is going to -# not work at all, so skip it -# We use install-data-hook here to workaround a bug in automake and/or libtool -# that makes the install target for the loader libraries a dependency on -# install-data-am, and not install-exec-am. We need to ensure this gets run -# after the libraries are installed in their final locations. -install-data-hook: install-ms-lib install-def-file - @if $(RUN_QUERY_LOADER_TEST) ; then \ - $(mkinstalldirs) $(DESTDIR)$(libdir)/gtk-3.0/3.0.0 ; \ - $(top_builddir)/gdk-pixbuf/gdk-pixbuf-query-loaders-3.0 > $(DESTDIR)$(libdir)/gtk-3.0/3.0.0/loaders.cache ; \ - else \ - echo "***" ; \ - echo "*** Warning: loaders.cache not built" ; \ - echo "***" ; \ - echo "*** Generate this file manually on host" ; \ - echo "*** system using gdk-pixbuf-query-loaders-3.0" ; \ - echo "***" ; \ - fi - -uninstall-local: uninstall-ms-lib uninstall-def-file - rm -f $(DESTDIR)$(libdir)/gtk-3.0/3.0.0/loaders.cache - -if CROSS_COMPILING -else -all-local: loaders.cache -endif - -if BUILD_DYNAMIC_MODULES -loaders.cache: $(loader_LTLIBRARIES) gdk-pixbuf-query-loaders-3.0$(EXEEXT) - LOADERS=`echo libpixbufloader-*.la` ; \ - if test "x$$LOADERS" != 'xlibpixbufloader-*.la' ; then \ - echo "Writing a loaders.cache file to use when running examples before installing gdk-pixbuf."; \ - $(top_builddir)/gdk-pixbuf/gdk-pixbuf-query-loaders-3.0 $$LOADERS > ./loaders.cache ;\ - else \ - echo "No dynamic modules found; will use only static modules for uninstalled example programs."; \ - touch loaders.cache; \ - fi -else -loaders.cache: - echo "No dynamic modules found; will use only static modules for uninstalled example programs."; \ - touch loaders.cache; -endif - --include $(top_srcdir)/git.mk diff --git a/gdk-pixbuf/abicheck.sh b/gdk-pixbuf/abicheck.sh deleted file mode 100755 index b6b47ab454..0000000000 --- a/gdk-pixbuf/abicheck.sh +++ /dev/null @@ -1,5 +0,0 @@ -#! /bin/sh - -cpp -DINCLUDE_VARIABLES -P -DALL_FILES ${srcdir:-.}/gdk-pixbuf.symbols | sed -e '/^$/d' -e 's/ G_GNUC.*$//' -e 's/ PRIVATE$//' | sort > expected-abi -nm -D -g --defined-only .libs/libgdk_pixbuf-3.0.so | cut -d ' ' -f 3 | egrep -v '^(__bss_start|_edata|_end)' | sort > actual-abi -diff -u expected-abi actual-abi && rm -f expected-abi actual-abi diff --git a/gdk-pixbuf/gdk-pixbuf-animation.c b/gdk-pixbuf/gdk-pixbuf-animation.c deleted file mode 100644 index 6d5e835963..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-animation.c +++ /dev/null @@ -1,704 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Simple animation support - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Jonathan Blandford <jrb@redhat.com> - * Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <errno.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" -#include "gdk-pixbuf-i18n.h" -#include "gdk-pixbuf-animation.h" -#include "gdk-pixbuf-alias.h" - -#include <glib/gstdio.h> - -typedef struct _GdkPixbufNonAnim GdkPixbufNonAnim; -typedef struct _GdkPixbufNonAnimClass GdkPixbufNonAnimClass; - -#define GDK_TYPE_PIXBUF_NON_ANIM (gdk_pixbuf_non_anim_get_type ()) -#define GDK_PIXBUF_NON_ANIM(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_NON_ANIM, GdkPixbufNonAnim)) -#define GDK_IS_PIXBUF_NON_ANIM(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_NON_ANIM)) - -#define GDK_PIXBUF_NON_ANIM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_NON_ANIM, GdkPixbufNonAnimClass)) -#define GDK_IS_PIXBUF_NON_ANIM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_NON_ANIM)) -#define GDK_PIXBUF_NON_ANIM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_NON_ANIM, GdkPixbufNonAnimClass)) - -/* Private part of the GdkPixbufNonAnim structure */ -struct _GdkPixbufNonAnim { - GdkPixbufAnimation parent_instance; - - GdkPixbuf *pixbuf; -}; - -struct _GdkPixbufNonAnimClass { - GdkPixbufAnimationClass parent_class; - -}; - - -typedef struct _GdkPixbufNonAnimIter GdkPixbufNonAnimIter; -typedef struct _GdkPixbufNonAnimIterClass GdkPixbufNonAnimIterClass; - - -#define GDK_TYPE_PIXBUF_NON_ANIM_ITER (gdk_pixbuf_non_anim_iter_get_type ()) -#define GDK_PIXBUF_NON_ANIM_ITER(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_NON_ANIM_ITER, GdkPixbufNonAnimIter)) -#define GDK_IS_PIXBUF_NON_ANIM_ITER(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_NON_ANIM_ITER)) - -#define GDK_PIXBUF_NON_ANIM_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_NON_ANIM_ITER, GdkPixbufNonAnimIterClass)) -#define GDK_IS_PIXBUF_NON_ANIM_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_NON_ANIM_ITER)) -#define GDK_PIXBUF_NON_ANIM_ITER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_NON_ANIM_ITER, GdkPixbufNonAnimIterClass)) - -struct _GdkPixbufNonAnimIter { - GdkPixbufAnimationIter parent_instance; - - GdkPixbufNonAnim *non_anim; -}; - -struct _GdkPixbufNonAnimIterClass { - GdkPixbufAnimationIterClass parent_class; - -}; - -static GType gdk_pixbuf_non_anim_iter_get_type (void) G_GNUC_CONST; - -G_DEFINE_TYPE (GdkPixbufAnimation, gdk_pixbuf_animation, G_TYPE_OBJECT); - -static void -gdk_pixbuf_animation_class_init (GdkPixbufAnimationClass *klass) -{ -} - -static void -gdk_pixbuf_animation_init (GdkPixbufAnimation *animation) -{ -} - -/** - * gdk_pixbuf_animation_new_from_file: - * @filename: Name of file to load, in the GLib file name encoding - * @error: return location for error - * - * Creates a new animation by loading it from a file. The file format is - * detected automatically. If the file's format does not support multi-frame - * images, then an animation with a single frame will be created. Possible errors - * are in the #GDK_PIXBUF_ERROR and #G_FILE_ERROR domains. - * - * Return value: A newly-created animation with a reference count of 1, or %NULL - * if any of several error conditions ocurred: the file could not be opened, - * there was no loader for the file's format, there was not enough memory to - * allocate the image buffer, or the image file contained invalid data. - **/ -GdkPixbufAnimation * -gdk_pixbuf_animation_new_from_file (const char *filename, - GError **error) -{ - GdkPixbufAnimation *animation; - int size; - FILE *f; - guchar buffer [1024]; - GdkPixbufModule *image_module; - gchar *display_name; - gboolean locked = FALSE; - - g_return_val_if_fail (filename != NULL, NULL); - g_return_val_if_fail (error == NULL || *error == NULL, NULL); - - display_name = g_filename_display_name (filename); - f = g_fopen (filename, "rb"); - if (!f) { - gint save_errno = errno; - g_set_error (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Failed to open file '%s': %s"), - display_name, - g_strerror (save_errno)); - g_free (display_name); - return NULL; - } - - size = fread (&buffer, 1, sizeof (buffer), f); - - if (size == 0) { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Image file '%s' contains no data"), - display_name); - g_free (display_name); - fclose (f); - return NULL; - } - - image_module = _gdk_pixbuf_get_module (buffer, size, filename, error); - if (!image_module) { - g_free (display_name); - fclose (f); - return NULL; - } - - if (image_module->module == NULL) - if (!_gdk_pixbuf_load_module (image_module, error)) { - g_free (display_name); - fclose (f); - return NULL; - } - - if (image_module->load_animation == NULL) { - GdkPixbuf *pixbuf; - - /* Keep this logic in sync with gdk_pixbuf_new_from_file() */ - - fseek (f, 0, SEEK_SET); - pixbuf = _gdk_pixbuf_generic_image_load (image_module, f, error); - fclose (f); - - if (pixbuf == NULL && error != NULL && *error == NULL) { - /* I don't trust these crufty longjmp()'ing image libs - * to maintain proper error invariants, and I don't - * want user code to segfault as a result. We need to maintain - * the invariant that error gets set if NULL is returned. - */ - - g_warning ("Bug! gdk-pixbuf loader '%s' didn't set an error on failure.", - image_module->module_name); - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Failed to load image '%s': reason not known, probably a corrupt image file"), - display_name); - } - - if (pixbuf == NULL) { - g_free (display_name); - animation = NULL; - goto out_unlock; - } - - animation = gdk_pixbuf_non_anim_new (pixbuf); - - g_object_unref (pixbuf); - } else { - locked = _gdk_pixbuf_lock (image_module); - - fseek (f, 0, SEEK_SET); - animation = (* image_module->load_animation) (f, error); - - if (animation == NULL && error != NULL && *error == NULL) { - /* I don't trust these crufty longjmp()'ing - * image libs to maintain proper error - * invariants, and I don't want user code to - * segfault as a result. We need to maintain - * the invariant that error gets set if NULL - * is returned. - */ - - g_warning ("Bug! gdk-pixbuf loader '%s' didn't set an error on failure.", - image_module->module_name); - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Failed to load animation '%s': reason not known, probably a corrupt animation file"), - display_name); - } - - fclose (f); - } - - g_free (display_name); - - out_unlock: - if (locked) - _gdk_pixbuf_unlock (image_module); - return animation; -} - -#ifdef G_OS_WIN32 - -#undef gdk_pixbuf_animation_new_from_file - -GdkPixbufAnimation * -gdk_pixbuf_animation_new_from_file (const char *filename, - GError **error) -{ - gchar *utf8_filename = - g_locale_to_utf8 (filename, -1, NULL, NULL, error); - GdkPixbufAnimation *retval; - - if (utf8_filename == NULL) - return NULL; - - retval = gdk_pixbuf_animation_new_from_file_utf8 (utf8_filename, error); - - g_free (utf8_filename); - - return retval; -} - -#endif - -/** - * gdk_pixbuf_animation_is_static_image: - * @animation: a #GdkPixbufAnimation - * - * If you load a file with gdk_pixbuf_animation_new_from_file() and it turns - * out to be a plain, unanimated image, then this function will return - * %TRUE. Use gdk_pixbuf_animation_get_static_image() to retrieve - * the image. - * - * Return value: %TRUE if the "animation" was really just an image - **/ -gboolean -gdk_pixbuf_animation_is_static_image (GdkPixbufAnimation *animation) -{ - g_return_val_if_fail (GDK_IS_PIXBUF_ANIMATION (animation), FALSE); - - return GDK_PIXBUF_ANIMATION_GET_CLASS (animation)->is_static_image (animation); -} - -/** - * gdk_pixbuf_animation_get_static_image: - * @animation: a #GdkPixbufAnimation - * - * If an animation is really just a plain image (has only one frame), - * this function returns that image. If the animation is an animation, - * this function returns a reasonable thing to display as a static - * unanimated image, which might be the first frame, or something more - * sophisticated. If an animation hasn't loaded any frames yet, this - * function will return %NULL. - * - * Return value: unanimated image representing the animation - **/ -GdkPixbuf* -gdk_pixbuf_animation_get_static_image (GdkPixbufAnimation *animation) -{ - g_return_val_if_fail (GDK_IS_PIXBUF_ANIMATION (animation), NULL); - - return GDK_PIXBUF_ANIMATION_GET_CLASS (animation)->get_static_image (animation); -} - -/** - * gdk_pixbuf_animation_get_width: - * @animation: An animation. - * - * Queries the width of the bounding box of a pixbuf animation. - * - * Return value: Width of the bounding box of the animation. - **/ -int -gdk_pixbuf_animation_get_width (GdkPixbufAnimation *animation) -{ - int width; - - g_return_val_if_fail (GDK_IS_PIXBUF_ANIMATION (animation), 0); - - width = 0; - GDK_PIXBUF_ANIMATION_GET_CLASS (animation)->get_size (animation, - &width, NULL); - - - return width; -} - -/** - * gdk_pixbuf_animation_get_height: - * @animation: An animation. - * - * Queries the height of the bounding box of a pixbuf animation. - * - * Return value: Height of the bounding box of the animation. - **/ -int -gdk_pixbuf_animation_get_height (GdkPixbufAnimation *animation) -{ - int height; - - g_return_val_if_fail (GDK_IS_PIXBUF_ANIMATION (animation), 0); - - height = 0; - GDK_PIXBUF_ANIMATION_GET_CLASS (animation)->get_size (animation, - NULL, &height); - - - return height; -} - - -/** - * gdk_pixbuf_animation_get_iter: - * @animation: a #GdkPixbufAnimation - * @start_time: time when the animation starts playing - * - * Get an iterator for displaying an animation. The iterator provides - * the frames that should be displayed at a given time. - * It should be freed after use with g_object_unref(). - * - * @start_time would normally come from g_get_current_time(), and - * marks the beginning of animation playback. After creating an - * iterator, you should immediately display the pixbuf returned by - * gdk_pixbuf_animation_iter_get_pixbuf(). Then, you should install a - * timeout (with g_timeout_add()) or by some other mechanism ensure - * that you'll update the image after - * gdk_pixbuf_animation_iter_get_delay_time() milliseconds. Each time - * the image is updated, you should reinstall the timeout with the new, - * possibly-changed delay time. - * - * As a shortcut, if @start_time is %NULL, the result of - * g_get_current_time() will be used automatically. - * - * To update the image (i.e. possibly change the result of - * gdk_pixbuf_animation_iter_get_pixbuf() to a new frame of the animation), - * call gdk_pixbuf_animation_iter_advance(). - * - * If you're using #GdkPixbufLoader, in addition to updating the image - * after the delay time, you should also update it whenever you - * receive the area_updated signal and - * gdk_pixbuf_animation_iter_on_currently_loading_frame() returns - * %TRUE. In this case, the frame currently being fed into the loader - * has received new data, so needs to be refreshed. The delay time for - * a frame may also be modified after an area_updated signal, for - * example if the delay time for a frame is encoded in the data after - * the frame itself. So your timeout should be reinstalled after any - * area_updated signal. - * - * A delay time of -1 is possible, indicating "infinite." - * - * Return value: an iterator to move over the animation - **/ -GdkPixbufAnimationIter* -gdk_pixbuf_animation_get_iter (GdkPixbufAnimation *animation, - const GTimeVal *start_time) -{ - GTimeVal val; - - g_return_val_if_fail (GDK_IS_PIXBUF_ANIMATION (animation), NULL); - - - if (start_time) - val = *start_time; - else - g_get_current_time (&val); - - return GDK_PIXBUF_ANIMATION_GET_CLASS (animation)->get_iter (animation, &val); -} - -G_DEFINE_TYPE (GdkPixbufAnimationIter, gdk_pixbuf_animation_iter, G_TYPE_OBJECT); - -static void -gdk_pixbuf_animation_iter_class_init (GdkPixbufAnimationIterClass *klass) -{ -} - -static void -gdk_pixbuf_animation_iter_init (GdkPixbufAnimationIter *iter) -{ -} - -/** - * gdk_pixbuf_animation_iter_get_delay_time: - * @iter: an animation iterator - * - * Gets the number of milliseconds the current pixbuf should be displayed, - * or -1 if the current pixbuf should be displayed forever. g_timeout_add() - * conveniently takes a timeout in milliseconds, so you can use a timeout - * to schedule the next update. - * - * Return value: delay time in milliseconds (thousandths of a second) - **/ -int -gdk_pixbuf_animation_iter_get_delay_time (GdkPixbufAnimationIter *iter) -{ - g_return_val_if_fail (GDK_IS_PIXBUF_ANIMATION_ITER (iter), -1); - g_return_val_if_fail (GDK_PIXBUF_ANIMATION_ITER_GET_CLASS (iter)->get_delay_time, -1); - - return GDK_PIXBUF_ANIMATION_ITER_GET_CLASS (iter)->get_delay_time (iter); -} - -/** - * gdk_pixbuf_animation_iter_get_pixbuf: - * @iter: an animation iterator - * - * Gets the current pixbuf which should be displayed; the pixbuf will - * be the same size as the animation itself - * (gdk_pixbuf_animation_get_width(), gdk_pixbuf_animation_get_height()). - * This pixbuf should be displayed for - * gdk_pixbuf_animation_iter_get_delay_time() milliseconds. The caller - * of this function does not own a reference to the returned pixbuf; - * the returned pixbuf will become invalid when the iterator advances - * to the next frame, which may happen anytime you call - * gdk_pixbuf_animation_iter_advance(). Copy the pixbuf to keep it - * (don't just add a reference), as it may get recycled as you advance - * the iterator. - * - * Return value: the pixbuf to be displayed - **/ -GdkPixbuf* -gdk_pixbuf_animation_iter_get_pixbuf (GdkPixbufAnimationIter *iter) -{ - g_return_val_if_fail (GDK_IS_PIXBUF_ANIMATION_ITER (iter), NULL); - g_return_val_if_fail (GDK_PIXBUF_ANIMATION_ITER_GET_CLASS (iter)->get_pixbuf, NULL); - - return GDK_PIXBUF_ANIMATION_ITER_GET_CLASS (iter)->get_pixbuf (iter); -} - -/** - * gdk_pixbuf_animation_iter_on_currently_loading_frame: - * @iter: a #GdkPixbufAnimationIter - * - * Used to determine how to respond to the area_updated signal on - * #GdkPixbufLoader when loading an animation. area_updated is emitted - * for an area of the frame currently streaming in to the loader. So if - * you're on the currently loading frame, you need to redraw the screen for - * the updated area. - * - * Return value: %TRUE if the frame we're on is partially loaded, or the last frame - **/ -gboolean -gdk_pixbuf_animation_iter_on_currently_loading_frame (GdkPixbufAnimationIter *iter) -{ - g_return_val_if_fail (GDK_IS_PIXBUF_ANIMATION_ITER (iter), FALSE); - g_return_val_if_fail (GDK_PIXBUF_ANIMATION_ITER_GET_CLASS (iter)->on_currently_loading_frame, FALSE); - - return GDK_PIXBUF_ANIMATION_ITER_GET_CLASS (iter)->on_currently_loading_frame (iter); -} - -/** - * gdk_pixbuf_animation_iter_advance: - * @iter: a #GdkPixbufAnimationIter - * @current_time: current time - * - * Possibly advances an animation to a new frame. Chooses the frame based - * on the start time passed to gdk_pixbuf_animation_get_iter(). - * - * @current_time would normally come from g_get_current_time(), and - * must be greater than or equal to the time passed to - * gdk_pixbuf_animation_get_iter(), and must increase or remain - * unchanged each time gdk_pixbuf_animation_iter_get_pixbuf() is - * called. That is, you can't go backward in time; animations only - * play forward. - * - * As a shortcut, pass %NULL for the current time and g_get_current_time() - * will be invoked on your behalf. So you only need to explicitly pass - * @current_time if you're doing something odd like playing the animation - * at double speed. - * - * If this function returns %FALSE, there's no need to update the animation - * display, assuming the display had been rendered prior to advancing; - * if %TRUE, you need to call gdk_animation_iter_get_pixbuf() and update the - * display with the new pixbuf. - * - * Returns: %TRUE if the image may need updating - * - **/ -gboolean -gdk_pixbuf_animation_iter_advance (GdkPixbufAnimationIter *iter, - const GTimeVal *current_time) -{ - GTimeVal val; - - g_return_val_if_fail (GDK_IS_PIXBUF_ANIMATION_ITER (iter), FALSE); - g_return_val_if_fail (GDK_PIXBUF_ANIMATION_ITER_GET_CLASS (iter)->advance, FALSE); - - if (current_time) - val = *current_time; - else - g_get_current_time (&val); - - return GDK_PIXBUF_ANIMATION_ITER_GET_CLASS (iter)->advance (iter, &val); -} - -static void gdk_pixbuf_non_anim_finalize (GObject *object); -static gboolean gdk_pixbuf_non_anim_is_static_image (GdkPixbufAnimation *animation); -static GdkPixbuf* gdk_pixbuf_non_anim_get_static_image (GdkPixbufAnimation *animation); -static void gdk_pixbuf_non_anim_get_size (GdkPixbufAnimation *anim, - int *width, - int *height); -static GdkPixbufAnimationIter* gdk_pixbuf_non_anim_get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time); - -G_DEFINE_TYPE (GdkPixbufNonAnim, gdk_pixbuf_non_anim, GDK_TYPE_PIXBUF_ANIMATION); - -static void -gdk_pixbuf_non_anim_class_init (GdkPixbufNonAnimClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - GdkPixbufAnimationClass *anim_class = GDK_PIXBUF_ANIMATION_CLASS (klass); - - object_class->finalize = gdk_pixbuf_non_anim_finalize; - - anim_class->is_static_image = gdk_pixbuf_non_anim_is_static_image; - anim_class->get_static_image = gdk_pixbuf_non_anim_get_static_image; - anim_class->get_size = gdk_pixbuf_non_anim_get_size; - anim_class->get_iter = gdk_pixbuf_non_anim_get_iter; -} - -static void -gdk_pixbuf_non_anim_init (GdkPixbufNonAnim *non_anim) -{ -} - -static void -gdk_pixbuf_non_anim_finalize (GObject *object) -{ - GdkPixbufNonAnim *non_anim = GDK_PIXBUF_NON_ANIM (object); - - if (non_anim->pixbuf) - g_object_unref (non_anim->pixbuf); - - G_OBJECT_CLASS (gdk_pixbuf_non_anim_parent_class)->finalize (object); -} - -GdkPixbufAnimation* -gdk_pixbuf_non_anim_new (GdkPixbuf *pixbuf) -{ - GdkPixbufNonAnim *non_anim; - - non_anim = g_object_new (GDK_TYPE_PIXBUF_NON_ANIM, NULL); - - non_anim->pixbuf = pixbuf; - - if (pixbuf) - g_object_ref (pixbuf); - - return GDK_PIXBUF_ANIMATION (non_anim); -} - -static gboolean -gdk_pixbuf_non_anim_is_static_image (GdkPixbufAnimation *animation) -{ - - return TRUE; -} - -static GdkPixbuf* -gdk_pixbuf_non_anim_get_static_image (GdkPixbufAnimation *animation) -{ - GdkPixbufNonAnim *non_anim; - - non_anim = GDK_PIXBUF_NON_ANIM (animation); - - return non_anim->pixbuf; -} - -static void -gdk_pixbuf_non_anim_get_size (GdkPixbufAnimation *anim, - int *width, - int *height) -{ - GdkPixbufNonAnim *non_anim; - - non_anim = GDK_PIXBUF_NON_ANIM (anim); - - if (width) - *width = gdk_pixbuf_get_width (non_anim->pixbuf); - - if (height) - *height = gdk_pixbuf_get_height (non_anim->pixbuf); -} - -static GdkPixbufAnimationIter* -gdk_pixbuf_non_anim_get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time) -{ - GdkPixbufNonAnimIter *iter; - - iter = g_object_new (GDK_TYPE_PIXBUF_NON_ANIM_ITER, NULL); - - iter->non_anim = GDK_PIXBUF_NON_ANIM (anim); - - g_object_ref (iter->non_anim); - - return GDK_PIXBUF_ANIMATION_ITER (iter); -} - -static void gdk_pixbuf_non_anim_iter_finalize (GObject *object); -static int gdk_pixbuf_non_anim_iter_get_delay_time (GdkPixbufAnimationIter *iter); -static GdkPixbuf* gdk_pixbuf_non_anim_iter_get_pixbuf (GdkPixbufAnimationIter *iter); -static gboolean gdk_pixbuf_non_anim_iter_on_currently_loading_frame (GdkPixbufAnimationIter *iter); -static gboolean gdk_pixbuf_non_anim_iter_advance (GdkPixbufAnimationIter *iter, - const GTimeVal *current_time); - -G_DEFINE_TYPE (GdkPixbufNonAnimIter, - gdk_pixbuf_non_anim_iter, - GDK_TYPE_PIXBUF_ANIMATION_ITER); - -static void -gdk_pixbuf_non_anim_iter_class_init (GdkPixbufNonAnimIterClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - GdkPixbufAnimationIterClass *anim_iter_class = - GDK_PIXBUF_ANIMATION_ITER_CLASS (klass); - - object_class->finalize = gdk_pixbuf_non_anim_iter_finalize; - - anim_iter_class->get_delay_time = gdk_pixbuf_non_anim_iter_get_delay_time; - anim_iter_class->get_pixbuf = gdk_pixbuf_non_anim_iter_get_pixbuf; - anim_iter_class->on_currently_loading_frame = gdk_pixbuf_non_anim_iter_on_currently_loading_frame; - anim_iter_class->advance = gdk_pixbuf_non_anim_iter_advance; -} - -static void -gdk_pixbuf_non_anim_iter_init (GdkPixbufNonAnimIter *non_iter) -{ -} - -static void -gdk_pixbuf_non_anim_iter_finalize (GObject *object) -{ - GdkPixbufNonAnimIter *iter = GDK_PIXBUF_NON_ANIM_ITER (object); - - g_object_unref (iter->non_anim); - - G_OBJECT_CLASS (gdk_pixbuf_non_anim_iter_parent_class)->finalize (object); -} - -static int -gdk_pixbuf_non_anim_iter_get_delay_time (GdkPixbufAnimationIter *iter) -{ - return -1; /* show only frame forever */ -} - -static GdkPixbuf* -gdk_pixbuf_non_anim_iter_get_pixbuf (GdkPixbufAnimationIter *iter) -{ - return GDK_PIXBUF_NON_ANIM_ITER (iter)->non_anim->pixbuf; -} - - -static gboolean -gdk_pixbuf_non_anim_iter_on_currently_loading_frame (GdkPixbufAnimationIter *iter) -{ - return TRUE; -} - -static gboolean -gdk_pixbuf_non_anim_iter_advance (GdkPixbufAnimationIter *iter, - const GTimeVal *current_time) -{ - - /* Advancing never requires a refresh */ - return FALSE; -} - -#define __GDK_PIXBUF_ANIMATION_C__ -#include "gdk-pixbuf-aliasdef.c" diff --git a/gdk-pixbuf/gdk-pixbuf-animation.h b/gdk-pixbuf/gdk-pixbuf-animation.h deleted file mode 100644 index a67e3c9073..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-animation.h +++ /dev/null @@ -1,146 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Animation support - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#if !defined (GDK_PIXBUF_H_INSIDE) && !defined (GDK_PIXBUF_COMPILATION) -#error "Only <gdk-pixbuf/gdk-pixbuf.h> can be included directly." -#endif - -#ifndef GDK_PIXBUF_ANIMATION_H -#define GDK_PIXBUF_ANIMATION_H - -#include <glib-object.h> -#include <gdk-pixbuf/gdk-pixbuf-core.h> - -G_BEGIN_DECLS - -/* Animation support */ - -typedef struct _GdkPixbufAnimation GdkPixbufAnimation; -typedef struct _GdkPixbufAnimationIter GdkPixbufAnimationIter; - -#define GDK_TYPE_PIXBUF_ANIMATION (gdk_pixbuf_animation_get_type ()) -#define GDK_PIXBUF_ANIMATION(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_ANIMATION, GdkPixbufAnimation)) -#define GDK_IS_PIXBUF_ANIMATION(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_ANIMATION)) - -#define GDK_TYPE_PIXBUF_ANIMATION_ITER (gdk_pixbuf_animation_iter_get_type ()) -#define GDK_PIXBUF_ANIMATION_ITER(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_ANIMATION_ITER, GdkPixbufAnimationIter)) -#define GDK_IS_PIXBUF_ANIMATION_ITER(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_ANIMATION_ITER)) - -GType gdk_pixbuf_animation_get_type (void) G_GNUC_CONST; - -#ifdef G_OS_WIN32 -#define gdk_pixbuf_animation_new_from_file gdk_pixbuf_animation_new_from_file_utf8 -#endif - -GdkPixbufAnimation *gdk_pixbuf_animation_new_from_file (const char *filename, - GError **error); - -int gdk_pixbuf_animation_get_width (GdkPixbufAnimation *animation); -int gdk_pixbuf_animation_get_height (GdkPixbufAnimation *animation); -gboolean gdk_pixbuf_animation_is_static_image (GdkPixbufAnimation *animation); -GdkPixbuf *gdk_pixbuf_animation_get_static_image (GdkPixbufAnimation *animation); - -GdkPixbufAnimationIter *gdk_pixbuf_animation_get_iter (GdkPixbufAnimation *animation, - const GTimeVal *start_time); -GType gdk_pixbuf_animation_iter_get_type (void) G_GNUC_CONST; -int gdk_pixbuf_animation_iter_get_delay_time (GdkPixbufAnimationIter *iter); -GdkPixbuf *gdk_pixbuf_animation_iter_get_pixbuf (GdkPixbufAnimationIter *iter); -gboolean gdk_pixbuf_animation_iter_on_currently_loading_frame (GdkPixbufAnimationIter *iter); -gboolean gdk_pixbuf_animation_iter_advance (GdkPixbufAnimationIter *iter, - const GTimeVal *current_time); - - -#ifdef GDK_PIXBUF_ENABLE_BACKEND - - - -typedef struct _GdkPixbufAnimationClass GdkPixbufAnimationClass; - -#define GDK_PIXBUF_ANIMATION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_ANIMATION, GdkPixbufAnimationClass)) -#define GDK_IS_PIXBUF_ANIMATION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_ANIMATION)) -#define GDK_PIXBUF_ANIMATION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_ANIMATION, GdkPixbufAnimationClass)) - -/* Private part of the GdkPixbufAnimation structure */ -struct _GdkPixbufAnimation { - GObject parent_instance; - -}; - -struct _GdkPixbufAnimationClass { - GObjectClass parent_class; - - /*< public >*/ - - gboolean (*is_static_image) (GdkPixbufAnimation *anim); - - GdkPixbuf* (*get_static_image) (GdkPixbufAnimation *anim); - - void (*get_size) (GdkPixbufAnimation *anim, - int *width, - int *height); - - GdkPixbufAnimationIter* (*get_iter) (GdkPixbufAnimation *anim, - const GTimeVal *start_time); - -}; - - - -typedef struct _GdkPixbufAnimationIterClass GdkPixbufAnimationIterClass; - -#define GDK_PIXBUF_ANIMATION_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_ANIMATION_ITER, GdkPixbufAnimationIterClass)) -#define GDK_IS_PIXBUF_ANIMATION_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_ANIMATION_ITER)) -#define GDK_PIXBUF_ANIMATION_ITER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_ANIMATION_ITER, GdkPixbufAnimationIterClass)) - -struct _GdkPixbufAnimationIter { - GObject parent_instance; - -}; - -struct _GdkPixbufAnimationIterClass { - GObjectClass parent_class; - - /*< public >*/ - - int (*get_delay_time) (GdkPixbufAnimationIter *iter); - - GdkPixbuf* (*get_pixbuf) (GdkPixbufAnimationIter *iter); - - gboolean (*on_currently_loading_frame) (GdkPixbufAnimationIter *iter); - - gboolean (*advance) (GdkPixbufAnimationIter *iter, - const GTimeVal *current_time); -}; - - -GType gdk_pixbuf_non_anim_get_type (void) G_GNUC_CONST; -GdkPixbufAnimation* gdk_pixbuf_non_anim_new (GdkPixbuf *pixbuf); - -#endif /* GDK_PIXBUF_ENABLE_BACKEND */ - -G_END_DECLS - -#endif /* GDK_PIXBUF_ANIMATION_H */ diff --git a/gdk-pixbuf/gdk-pixbuf-core.h b/gdk-pixbuf/gdk-pixbuf-core.h deleted file mode 100644 index 4ea16934c3..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-core.h +++ /dev/null @@ -1,260 +0,0 @@ -/* GdkPixbuf library - GdkPixbuf data structure - * - * Copyright (C) 2003 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#if !defined (GDK_PIXBUF_H_INSIDE) && !defined (GDK_PIXBUF_COMPILATION) -#error "Only <gdk-pixbuf/gdk-pixbuf.h> can be included directly." -#endif - -#ifndef GDK_PIXBUF_CORE_H -#define GDK_PIXBUF_CORE_H - -#include <glib.h> -#include <glib-object.h> -#include <gio/gio.h> - -G_BEGIN_DECLS - -/* Alpha compositing mode */ -typedef enum -{ - GDK_PIXBUF_ALPHA_BILEVEL, - GDK_PIXBUF_ALPHA_FULL -} GdkPixbufAlphaMode; - -/* Color spaces; right now only RGB is supported. - * Note that these values are encoded in inline pixbufs - * as ints, so don't reorder them - */ -typedef enum { - GDK_COLORSPACE_RGB -} GdkColorspace; - -/* All of these are opaque structures */ -typedef struct _GdkPixbuf GdkPixbuf; - -#define GDK_TYPE_PIXBUF (gdk_pixbuf_get_type ()) -#define GDK_PIXBUF(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF, GdkPixbuf)) -#define GDK_IS_PIXBUF(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF)) - - -/* Handler that must free the pixel array */ -typedef void (* GdkPixbufDestroyNotify) (guchar *pixels, gpointer data); - -#define GDK_PIXBUF_ERROR gdk_pixbuf_error_quark () - -typedef enum { - /* image data hosed */ - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - /* no mem to load image */ - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - /* bad option passed to save routine */ - GDK_PIXBUF_ERROR_BAD_OPTION, - /* unsupported image type (sort of an ENOSYS) */ - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - /* unsupported operation (load, save) for image type */ - GDK_PIXBUF_ERROR_UNSUPPORTED_OPERATION, - GDK_PIXBUF_ERROR_FAILED -} GdkPixbufError; - -GQuark gdk_pixbuf_error_quark (void); - - - -GType gdk_pixbuf_get_type (void) G_GNUC_CONST; - -/* GdkPixbuf accessors */ - -GdkColorspace gdk_pixbuf_get_colorspace (const GdkPixbuf *pixbuf); -int gdk_pixbuf_get_n_channels (const GdkPixbuf *pixbuf); -gboolean gdk_pixbuf_get_has_alpha (const GdkPixbuf *pixbuf); -int gdk_pixbuf_get_bits_per_sample (const GdkPixbuf *pixbuf); -guchar *gdk_pixbuf_get_pixels (const GdkPixbuf *pixbuf); -int gdk_pixbuf_get_width (const GdkPixbuf *pixbuf); -int gdk_pixbuf_get_height (const GdkPixbuf *pixbuf); -int gdk_pixbuf_get_rowstride (const GdkPixbuf *pixbuf); - - - -/* Create a blank pixbuf with an optimal rowstride and a new buffer */ -GdkPixbuf *gdk_pixbuf_new (GdkColorspace colorspace, gboolean has_alpha, int bits_per_sample, - int width, int height); - -/* Copy a pixbuf */ - -GdkPixbuf *gdk_pixbuf_copy (const GdkPixbuf *pixbuf); - -/* Create a pixbuf which points to the pixels of another pixbuf */ -GdkPixbuf *gdk_pixbuf_new_subpixbuf (GdkPixbuf *src_pixbuf, - int src_x, - int src_y, - int width, - int height); - -/* Simple loading */ - -#ifdef G_OS_WIN32 -/* DLL ABI stability hack. */ -#define gdk_pixbuf_new_from_file gdk_pixbuf_new_from_file_utf8 -#define gdk_pixbuf_new_from_file_at_size gdk_pixbuf_new_from_file_at_size_utf8 -#define gdk_pixbuf_new_from_file_at_scale gdk_pixbuf_new_from_file_at_scale_utf8 -#endif - -GdkPixbuf *gdk_pixbuf_new_from_file (const char *filename, - GError **error); -GdkPixbuf *gdk_pixbuf_new_from_file_at_size (const char *filename, - int width, - int height, - GError **error); -GdkPixbuf *gdk_pixbuf_new_from_file_at_scale (const char *filename, - int width, - int height, - gboolean preserve_aspect_ratio, - GError **error); - -GdkPixbuf *gdk_pixbuf_new_from_data (const guchar *data, - GdkColorspace colorspace, - gboolean has_alpha, - int bits_per_sample, - int width, int height, - int rowstride, - GdkPixbufDestroyNotify destroy_fn, - gpointer destroy_fn_data); - -GdkPixbuf *gdk_pixbuf_new_from_xpm_data (const char **data); -GdkPixbuf* gdk_pixbuf_new_from_inline (gint data_length, - const guint8 *data, - gboolean copy_pixels, - GError **error); - -/* Mutations */ -void gdk_pixbuf_fill (GdkPixbuf *pixbuf, - guint32 pixel); - -/* Saving */ - -#ifdef G_OS_WIN32 -/* DLL ABI stability hack. */ -#define gdk_pixbuf_save gdk_pixbuf_save_utf8 -#define gdk_pixbuf_savev gdk_pixbuf_savev_utf8 -#endif - -gboolean gdk_pixbuf_save (GdkPixbuf *pixbuf, - const char *filename, - const char *type, - GError **error, - ...) G_GNUC_NULL_TERMINATED; - -gboolean gdk_pixbuf_savev (GdkPixbuf *pixbuf, - const char *filename, - const char *type, - char **option_keys, - char **option_values, - GError **error); - -/* Saving to a callback function */ - -typedef gboolean (*GdkPixbufSaveFunc) (const gchar *buf, - gsize count, - GError **error, - gpointer data); - -gboolean gdk_pixbuf_save_to_callback (GdkPixbuf *pixbuf, - GdkPixbufSaveFunc save_func, - gpointer user_data, - const char *type, - GError **error, - ...) G_GNUC_NULL_TERMINATED; - -gboolean gdk_pixbuf_save_to_callbackv (GdkPixbuf *pixbuf, - GdkPixbufSaveFunc save_func, - gpointer user_data, - const char *type, - char **option_keys, - char **option_values, - GError **error); - -/* Saving into a newly allocated char array */ - -gboolean gdk_pixbuf_save_to_buffer (GdkPixbuf *pixbuf, - gchar **buffer, - gsize *buffer_size, - const char *type, - GError **error, - ...) G_GNUC_NULL_TERMINATED; - -gboolean gdk_pixbuf_save_to_bufferv (GdkPixbuf *pixbuf, - gchar **buffer, - gsize *buffer_size, - const char *type, - char **option_keys, - char **option_values, - GError **error); - -GdkPixbuf *gdk_pixbuf_new_from_stream (GInputStream *stream, - GCancellable *cancellable, - GError **error); - -GdkPixbuf *gdk_pixbuf_new_from_stream_at_scale (GInputStream *stream, - gint width, - gint height, - gboolean preserve_aspect_ratio, - GCancellable *cancellable, - GError **error); - -gboolean gdk_pixbuf_save_to_stream (GdkPixbuf *pixbuf, - GOutputStream *stream, - const char *type, - GCancellable *cancellable, - GError **error, - ...); - -/* Adding an alpha channel */ -GdkPixbuf *gdk_pixbuf_add_alpha (const GdkPixbuf *pixbuf, gboolean substitute_color, - guchar r, guchar g, guchar b); - -/* Copy an area of a pixbuf onto another one */ -void gdk_pixbuf_copy_area (const GdkPixbuf *src_pixbuf, - int src_x, int src_y, - int width, int height, - GdkPixbuf *dest_pixbuf, - int dest_x, int dest_y); - -/* Brighten/darken and optionally make it pixelated-looking */ -void gdk_pixbuf_saturate_and_pixelate (const GdkPixbuf *src, - GdkPixbuf *dest, - gfloat saturation, - gboolean pixelate); - -/* Transform an image to agree with its embedded orientation option / tag */ -GdkPixbuf *gdk_pixbuf_apply_embedded_orientation (GdkPixbuf *src); - -G_CONST_RETURN gchar * gdk_pixbuf_get_option (GdkPixbuf *pixbuf, - const gchar *key); - - -G_END_DECLS - - -#endif /* GDK_PIXBUF_CORE_H */ diff --git a/gdk-pixbuf/gdk-pixbuf-csource.1 b/gdk-pixbuf/gdk-pixbuf-csource.1 deleted file mode 100644 index d992921b6d..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-csource.1 +++ /dev/null @@ -1,91 +0,0 @@ -.TH GDK-PIXBUF-CSOURCE 1 "04 Sep 2001" -.SH NAME -gdk-pixbuf-csource \- C code generation utility for GdkPixbuf images -.SH SYNOPSIS - -\fBgdk-pixbuf-csource\fP [\fIoptions\fP] [\fIimage\fP] -.br -\fBgdk-pixbuf-csource\fP [\fIoptions\fP] \fI--build-list\fP [[\fIname image\fP]...] - -.SH DESCRIPTION -\fBgdk-pixbuf-csource\fP is a small utility that generates C code containing -images, useful for compiling images directly into programs. - -.SH INVOCATION - -\fBgdk-pixbuf-csource\fP either takes as input one image file name to generate code -for, or, using the \fI--build-list\fP option, a list of (\fIname\fP, \fIimage\fP) -pairs to generate code for a list of images into named variables. - -.SS Options -.TP -\fI--stream -Generate pixbuf data stream (a single string containing a serialized -GdkPixdata structure in network byte order). - -.TP -\fI--struct -Generate GdkPixdata structure (needs the GdkPixdata structure definition from -gdk-pixdata.h). - -.TP -\fI--macros -Generate *_ROWSTRIDE, *_WIDTH, *_HEIGHT, *_BYTES_PER_PIXEL and -*_RLE_PIXEL_DATA or *_PIXEL_DATA macro definitions for the image. - -.TP -\fI--rle -Enables run-length encoding for the generated pixel data (default). - -.TP -\fI--raw -Disables run-length encoding for the generated pixel data. - -.TP -\fI--extern -Generate extern symbols. - -.TP -\fI--static -Generate static symbols (default). - -.TP -\fI--decoder -Provide a *_RUN_LENGTH_DECODE(image_buf, rle_data, size, bpp) macro definition -to decode run-length encoded image data. - -.TP -\fI--name=identifier -Specifies the identifier name (prefix) for the generated variables or -macros (useful only if \fI--build-list\fP was not specified). - -.TP -\fI--build-list -Enables (\fIname\fP, \fIimage\fP) pair parsing mode. - -.TP -\fI-h, --help\fP -Print brief help and exit. - -.TP -\fI-v, --version\fP -Print version and exit. - -.TP -\fI--g-fatal-warnings -Make warnings fatal (causes the program to abort). - -.PP - -.SH SEE ALSO -The \fIGdkPixbuf\fP documentation, shipped with the \fIGtk+\fP distribution, -available from \fIhttp://www.gtk.org\fP. - -.SH BUGS -None known yet. - -.SH AUTHOR -.B gdk-pixbuf-csource -was written by Tim Janik <timj@gtk.org>. -.PP -This manual page was provided by Tim Janik <timj@gtk.org>. diff --git a/gdk-pixbuf/gdk-pixbuf-csource.c b/gdk-pixbuf/gdk-pixbuf-csource.c deleted file mode 100644 index c9b0d4f238..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-csource.c +++ /dev/null @@ -1,304 +0,0 @@ -/* Gdk-Pixbuf-CSource - GdkPixbuf based image CSource generator - * Copyright (C) 1999, 2001 Tim Janik - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ -#include "config.h" - -#define __GTK_H_INSIDE__ -#include "../gtk/gtkversion.h" /* versioning */ -#undef __GTK_H_INSIDE__ -#include "gdk-pixbuf.h" -#include "gdk-pixdata.h" -#include <glib/gprintf.h> -#include <stdlib.h> -#include <string.h> - - -/* --- defines --- */ -#undef G_LOG_DOMAIN -#define G_LOG_DOMAIN "Gdk-Pixbuf-CSource" -#define PRG_NAME "gdk-pixbuf-csource-3.0" -#define PKG_NAME "GTK+" -#define PKG_HTTP_HOME "http://www.gtk.org" - - -/* --- prototypes --- */ -static void parse_args (gint *argc_p, - gchar ***argv_p); -static void print_blurb (FILE *bout, - gboolean print_help); - - -/* --- variables --- */ -static guint gen_type = GDK_PIXDATA_DUMP_PIXDATA_STREAM; -static guint gen_ctype = GDK_PIXDATA_DUMP_GTYPES | GDK_PIXDATA_DUMP_STATIC | GDK_PIXDATA_DUMP_CONST; -static gboolean use_rle = TRUE; -static gboolean with_decoder = FALSE; -static gchar *image_name = "my_pixbuf"; -static gboolean build_list = FALSE; - - -/* --- functions --- */ -static void -print_csource (FILE *f_out, - GdkPixbuf *pixbuf) -{ - GdkPixdata pixdata; - gpointer free_me; - GString *gstring; - - free_me = gdk_pixdata_from_pixbuf (&pixdata, pixbuf, use_rle); - gstring = gdk_pixdata_to_csource (&pixdata, image_name, - gen_type | gen_ctype | - (with_decoder ? GDK_PIXDATA_DUMP_RLE_DECODER : 0)); - - g_fprintf (f_out, "%s\n", gstring->str); - - g_free (free_me); -} - -int -main (int argc, - char *argv[]) -{ - GdkPixbuf *pixbuf; - GError *error = NULL; - gchar *infilename; - - /* initialize glib/GdkPixbuf */ - g_type_init (); - - /* parse args and do fast exits */ - parse_args (&argc, &argv); - - if (!build_list) - { - if (argc != 2) - { - print_blurb (stderr, TRUE); - return 1; - } - -#ifdef G_OS_WIN32 - infilename = g_locale_to_utf8 (argv[1], -1, NULL, NULL, NULL); -#else - infilename = argv[1]; -#endif - - pixbuf = gdk_pixbuf_new_from_file (infilename, &error); - if (!pixbuf) - { - g_fprintf (stderr, "failed to load \"%s\": %s\n", - argv[1], - error->message); - g_error_free (error); - return 1; - } - - print_csource (stdout, pixbuf); - g_object_unref (pixbuf); - } - else /* parse name, file pairs */ - { - gchar **p = argv + 1; - guint j = argc - 1; - gboolean toggle = FALSE; - - while (j--) - { -#ifdef G_OS_WIN32 - infilename = g_locale_to_utf8 (*p, -1, NULL, NULL, NULL); -#else - infilename = *p; -#endif - - if (!toggle) - { - image_name = infilename; - p++; - } - else - { - pixbuf = gdk_pixbuf_new_from_file (infilename, &error); - if (!pixbuf) - { - g_fprintf (stderr, "failed to load \"%s\": %s\n", - *p, - error->message); - g_error_free (error); - return 1; - } - print_csource (stdout, pixbuf); - g_object_unref (pixbuf); - p++; - } - toggle = !toggle; - } - } - - return 0; -} - -static void -parse_args (gint *argc_p, - gchar ***argv_p) -{ - guint argc = *argc_p; - gchar **argv = *argv_p; - guint i, e; - - for (i = 1; i < argc; i++) - { - if (strcmp ("--macros", argv[i]) == 0) - { - gen_type = GDK_PIXDATA_DUMP_MACROS; - argv[i] = NULL; - } - else if (strcmp ("--struct", argv[i]) == 0) - { - gen_type = GDK_PIXDATA_DUMP_PIXDATA_STRUCT; - argv[i] = NULL; - } - else if (strcmp ("--stream", argv[i]) == 0) - { - gen_type = GDK_PIXDATA_DUMP_PIXDATA_STREAM; - argv[i] = NULL; - } - else if (strcmp ("--rle", argv[i]) == 0) - { - use_rle = TRUE; - argv[i] = NULL; - } - else if (strcmp ("--raw", argv[i]) == 0) - { - use_rle = FALSE; - argv[i] = NULL; - } - else if (strcmp ("--extern", argv[i]) == 0) - { - gen_ctype &= ~GDK_PIXDATA_DUMP_STATIC; - argv[i] = NULL; - } - else if (strcmp ("--static", argv[i]) == 0) - { - gen_ctype |= GDK_PIXDATA_DUMP_STATIC; - argv[i] = NULL; - } - else if (strcmp ("--decoder", argv[i]) == 0) - { - with_decoder = TRUE; - argv[i] = NULL; - } - else if ((strcmp ("--name", argv[i]) == 0) || - (strncmp ("--name=", argv[i], 7) == 0)) - { - gchar *equal = argv[i] + 6; - - if (*equal == '=') - image_name = g_strdup (equal + 1); - else if (i + 1 < argc) - { - image_name = g_strdup (argv[i + 1]); - argv[i] = NULL; - i += 1; - } - argv[i] = NULL; - } - else if (strcmp ("--build-list", argv[i]) == 0) - { - build_list = TRUE; - argv[i] = NULL; - } - else if (strcmp ("-h", argv[i]) == 0 || - strcmp ("--help", argv[i]) == 0) - { - print_blurb (stderr, TRUE); - argv[i] = NULL; - exit (0); - } - else if (strcmp ("-v", argv[i]) == 0 || - strcmp ("--version", argv[i]) == 0) - { - print_blurb (stderr, FALSE); - argv[i] = NULL; - exit (0); - } - else if (strcmp (argv[i], "--g-fatal-warnings") == 0) - { - GLogLevelFlags fatal_mask; - - fatal_mask = g_log_set_always_fatal (G_LOG_FATAL_MASK); - fatal_mask |= G_LOG_LEVEL_WARNING | G_LOG_LEVEL_CRITICAL; - g_log_set_always_fatal (fatal_mask); - - argv[i] = NULL; - } - } - - e = 0; - for (i = 1; i < argc; i++) - { - if (e) - { - if (argv[i]) - { - argv[e++] = argv[i]; - argv[i] = NULL; - } - } - else if (!argv[i]) - e = i; - } - if (e) - *argc_p = e; -} - -static void -print_blurb (FILE *bout, - gboolean print_help) -{ - if (!print_help) - { - g_fprintf (bout, "%s version ", PRG_NAME); - g_fprintf (bout, "%d.%d.%d", GTK_MAJOR_VERSION, GTK_MINOR_VERSION, GTK_MICRO_VERSION); - g_fprintf (bout, "\n"); - g_fprintf (bout, "%s comes with ABSOLUTELY NO WARRANTY.\n", PRG_NAME); - g_fprintf (bout, "You may redistribute copies of %s under the terms of\n", PRG_NAME); - g_fprintf (bout, "the GNU Lesser General Public License which can be found in the\n"); - g_fprintf (bout, "%s source package. Sources, examples and contact\n", PKG_NAME); - g_fprintf (bout, "information are available at %s\n", PKG_HTTP_HOME); - } - else - { - g_fprintf (bout, "Usage: %s [options] [image]\n", PRG_NAME); - g_fprintf (bout, " %s [options] --build-list [[name image]...]\n", PRG_NAME); - g_fprintf (bout, " --stream generate pixbuf data stream\n"); - g_fprintf (bout, " --struct generate GdkPixdata structure\n"); - g_fprintf (bout, " --macros generate image size/pixel macros\n"); - g_fprintf (bout, " --rle use one byte run-length-encoding\n"); - g_fprintf (bout, " --raw provide raw image data copy\n"); - g_fprintf (bout, " --extern generate extern symbols\n"); - g_fprintf (bout, " --static generate static symbols\n"); - g_fprintf (bout, " --decoder provide rle decoder\n"); - g_fprintf (bout, " --name=identifier C macro/variable name\n"); - g_fprintf (bout, " --build-list parse (name, image) pairs\n"); - g_fprintf (bout, " -h, --help show this help message\n"); - g_fprintf (bout, " -v, --version print version informations\n"); - g_fprintf (bout, " --g-fatal-warnings make warnings fatal (abort)\n"); - } -} - diff --git a/gdk-pixbuf/gdk-pixbuf-data.c b/gdk-pixbuf/gdk-pixbuf-data.c deleted file mode 100644 index 800d64d2a6..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-data.c +++ /dev/null @@ -1,83 +0,0 @@ -/* GdkPixbuf library - Image creation from in-memory buffers - * - * Copyright (C) 1999 The Free Software Foundation - * - * Author: Federico Mena-Quintero <federico@gimp.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include "gdk-pixbuf.h" -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-alias.h" -#include <stdlib.h> -#include <string.h> - - - -/** - * gdk_pixbuf_new_from_data: - * @data: Image data in 8-bit/sample packed format - * @colorspace: Colorspace for the image data - * @has_alpha: Whether the data has an opacity channel - * @bits_per_sample: Number of bits per sample - * @width: Width of the image in pixels, must be > 0 - * @height: Height of the image in pixels, must be > 0 - * @rowstride: Distance in bytes between row starts - * @destroy_fn: Function used to free the data when the pixbuf's reference count - * drops to zero, or %NULL if the data should not be freed - * @destroy_fn_data: Closure data to pass to the destroy notification function - * - * Creates a new #GdkPixbuf out of in-memory image data. Currently only RGB - * images with 8 bits per sample are supported. - * - * Return value: A newly-created #GdkPixbuf structure with a reference count of 1. - **/ -GdkPixbuf * -gdk_pixbuf_new_from_data (const guchar *data, GdkColorspace colorspace, gboolean has_alpha, - int bits_per_sample, int width, int height, int rowstride, - GdkPixbufDestroyNotify destroy_fn, gpointer destroy_fn_data) -{ - GdkPixbuf *pixbuf; - - /* Only 8-bit/sample RGB buffers are supported for now */ - - g_return_val_if_fail (data != NULL, NULL); - g_return_val_if_fail (colorspace == GDK_COLORSPACE_RGB, NULL); - g_return_val_if_fail (bits_per_sample == 8, NULL); - g_return_val_if_fail (width > 0, NULL); - g_return_val_if_fail (height > 0, NULL); - - pixbuf = g_object_new (GDK_TYPE_PIXBUF, - "colorspace", colorspace, - "n-channels", has_alpha ? 4 : 3, - "bits-per-sample", bits_per_sample, - "has-alpha", has_alpha ? TRUE : FALSE, - "width", width, - "height", height, - "rowstride", rowstride, - "pixels", data, - NULL); - - pixbuf->destroy_fn = destroy_fn; - pixbuf->destroy_fn_data = destroy_fn_data; - - return pixbuf; -} - -#define __GDK_PIXBUF_DATA_C__ -#include "gdk-pixbuf-aliasdef.c" diff --git a/gdk-pixbuf/gdk-pixbuf-enum-types.c.template b/gdk-pixbuf/gdk-pixbuf-enum-types.c.template deleted file mode 100644 index 8496c13a57..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-enum-types.c.template +++ /dev/null @@ -1,38 +0,0 @@ -/*** BEGIN file-header ***/ -#include <gdk-pixbuf/gdk-pixbuf.h> -#include "gdk-pixbuf-alias.h" - -/*** END file-header ***/ - -/*** BEGIN file-production ***/ -/* enumerations from "@filename@" */ -/*** END file-production ***/ - -/*** BEGIN value-header ***/ -GType -@enum_name@_get_type (void) -{ - static GType etype = 0; - - if (G_UNLIKELY(etype == 0)) { - static const G@Type@Value values[] = { -/*** END value-header ***/ - -/*** BEGIN value-production ***/ - { @VALUENAME@, "@VALUENAME@", "@valuenick@" }, -/*** END value-production ***/ - -/*** BEGIN value-tail ***/ - { 0, NULL, NULL } - }; - etype = g_@type@_register_static (g_intern_static_string ("@EnumName@"), values); - } - return etype; -} - -/*** END value-tail ***/ - -/*** BEGIN file-tail ***/ -#define __GDK_PIXBUF_ENUM_TYPES_C__ -#include "gdk-pixbuf-aliasdef.c" -/*** END file-tail ***/ diff --git a/gdk-pixbuf/gdk-pixbuf-enum-types.h.template b/gdk-pixbuf/gdk-pixbuf-enum-types.h.template deleted file mode 100644 index 3989980b03..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-enum-types.h.template +++ /dev/null @@ -1,28 +0,0 @@ -/*** BEGIN file-header ***/ -#if !defined (GDK_PIXBUF_H_INSIDE) && !defined (GDK_PIXBUF_COMPILATION) -#error "Only <gdk-pixbuf/gdk-pixbuf.h> can be included directly." -#endif - -#ifndef __GDK_PIXBUF_ENUM_TYPES_H__ -#define __GDK_PIXBUF_ENUM_TYPES_H__ - -#include <glib-object.h> - -G_BEGIN_DECLS -/*** END file-header ***/ - -/*** BEGIN file-production ***/ - -/* enumerations from "@filename@" */ -/*** END file-production ***/ - -/*** BEGIN value-header ***/ -GType @enum_name@_get_type (void) G_GNUC_CONST; -#define @ENUMPREFIX@_TYPE_@ENUMSHORT@ (@enum_name@_get_type ()) -/*** END value-header ***/ - -/*** BEGIN file-tail ***/ -G_END_DECLS - -#endif /* __GDK_PIXBUF_ENUM_TYPES_H__ */ -/*** END file-tail ***/ diff --git a/gdk-pixbuf/gdk-pixbuf-features.h.in b/gdk-pixbuf/gdk-pixbuf-features.h.in deleted file mode 100644 index ec5f647ed0..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-features.h.in +++ /dev/null @@ -1,39 +0,0 @@ -#if !defined (GDK_PIXBUF_H_INSIDE) && !defined (GDK_PIXBUF_COMPILATION) -#error "Only <gdk-pixbuf/gdk-pixbuf.h> can be included directly." -#endif - -#ifndef GDK_PIXBUF_FEATURES_H -#define GDK_PIXBUF_FEATURES_H 1 - -#define GDK_PIXBUF_MAJOR (@GDK_PIXBUF_MAJOR@) -#define GDK_PIXBUF_MINOR (@GDK_PIXBUF_MINOR@) -#define GDK_PIXBUF_MICRO (@GDK_PIXBUF_MICRO@) -#define GDK_PIXBUF_VERSION "@GDK_PIXBUF_VERSION@" - -/* We prefix variable declarations so they can - * properly get exported/imported from Windows DLLs. - */ -#ifdef G_PLATFORM_WIN32 -# ifdef GDK_PIXBUF_STATIC_COMPILATION -# define GDK_PIXBUF_VAR extern -# else /* !GDK_PIXBUF_STATIC_COMPILATION */ -# ifdef GDK_PIXBUF_C_COMPILATION -# ifdef DLL_EXPORT -# define GDK_PIXBUF_VAR __declspec(dllexport) -# else /* !DLL_EXPORT */ -# define GDK_PIXBUF_VAR extern -# endif /* !DLL_EXPORT */ -# else /* !GDK_PIXBUF_C_COMPILATION */ -# define GDK_PIXBUF_VAR extern __declspec(dllimport) -# endif /* !GDK_PIXBUF_C_COMPILATION */ -# endif /* !GDK_PIXBUF_STATIC_COMPILATION */ -#else /* !G_PLATFORM_WIN32 */ -# define GDK_PIXBUF_VAR extern -#endif /* !G_PLATFORM_WIN32 */ - -GDK_PIXBUF_VAR const guint gdk_pixbuf_major_version; -GDK_PIXBUF_VAR const guint gdk_pixbuf_minor_version; -GDK_PIXBUF_VAR const guint gdk_pixbuf_micro_version; -GDK_PIXBUF_VAR const char *gdk_pixbuf_version; - -#endif /* GDK_PIXBUF_FEATURES_H */ diff --git a/gdk-pixbuf/gdk-pixbuf-i18n.h b/gdk-pixbuf/gdk-pixbuf-i18n.h deleted file mode 100644 index fcd5e8b51a..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-i18n.h +++ /dev/null @@ -1,32 +0,0 @@ -/* GdkPixbuf library - Internationalization - * - * Copyright (C) 2000 Havoc Pennington - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ -#ifndef __GDKPIXBUFINTL_H__ -#define __GDKPIXBUFINTL_H__ - -#include "config.h" -#include <glib/gi18n-lib.h> - -#ifdef ENABLE_NLS -#define P_(String) dgettext(GETTEXT_PACKAGE "-properties",String) -#else -#define P_(String) (String) -#endif - -#endif diff --git a/gdk-pixbuf/gdk-pixbuf-io.c b/gdk-pixbuf/gdk-pixbuf-io.c deleted file mode 100644 index bd6a78722c..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-io.c +++ /dev/null @@ -1,2678 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* GdkPixbuf library - Main loading interface. - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" - -#include <stdlib.h> -#include <stdio.h> -#include <string.h> -#include <errno.h> -#ifdef HAVE_UNISTD_H -#include <unistd.h> -#endif - -#include <glib.h> -#include <gio/gio.h> - -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" -#include "gdk-pixbuf-loader.h" -#include "gdk-pixbuf-alias.h" - -#include <glib/gstdio.h> - -#ifdef G_OS_WIN32 -#define STRICT -#include <windows.h> -#undef STRICT -#endif - -#define SNIFF_BUFFER_SIZE 4096 -#define LOAD_BUFFER_SIZE 65536 - -#ifndef GDK_PIXBUF_USE_GIO_MIME -static gint -format_check (GdkPixbufModule *module, guchar *buffer, int size) -{ - int i, j; - gchar m; - GdkPixbufModulePattern *pattern; - gboolean anchored; - guchar *prefix; - gchar *mask; - - for (pattern = module->info->signature; pattern->prefix; pattern++) { - if (pattern->mask && pattern->mask[0] == '*') { - prefix = (guchar *)pattern->prefix + 1; - mask = pattern->mask + 1; - anchored = FALSE; - } - else { - prefix = (guchar *)pattern->prefix; - mask = pattern->mask; - anchored = TRUE; - } - for (i = 0; i < size; i++) { - for (j = 0; i + j < size && prefix[j] != 0; j++) { - m = mask ? mask[j] : ' '; - if (m == ' ') { - if (buffer[i + j] != prefix[j]) - break; - } - else if (m == '!') { - if (buffer[i + j] == prefix[j]) - break; - } - else if (m == 'z') { - if (buffer[i + j] != 0) - break; - } - else if (m == 'n') { - if (buffer[i + j] == 0) - break; - } - } - - if (prefix[j] == 0) - return pattern->relevance; - - if (anchored) - break; - } - } - return 0; -} -#endif - -G_LOCK_DEFINE_STATIC (init_lock); -G_LOCK_DEFINE_STATIC (threadunsafe_loader_lock); - -gboolean -_gdk_pixbuf_lock (GdkPixbufModule *image_module) -{ - if (g_threads_got_initialized && - !(image_module->info->flags & GDK_PIXBUF_FORMAT_THREADSAFE)) { - G_LOCK (threadunsafe_loader_lock); - - return TRUE; - } - - return FALSE; -} - -void -_gdk_pixbuf_unlock (GdkPixbufModule *image_module) -{ - if (!(image_module->info->flags & GDK_PIXBUF_FORMAT_THREADSAFE)) { - G_UNLOCK (threadunsafe_loader_lock); - } -} - -static GSList *file_formats = NULL; - -static void gdk_pixbuf_io_init (void); - -static GSList * -get_file_formats (void) -{ - G_LOCK (init_lock); - if (file_formats == NULL) - gdk_pixbuf_io_init (); - G_UNLOCK (init_lock); - - return file_formats; -} - - -#ifdef USE_GMODULE - -static gboolean -scan_string (const char **pos, GString *out) -{ - const char *p = *pos, *q = *pos; - char *tmp, *tmp2; - gboolean quoted; - - while (g_ascii_isspace (*p)) - p++; - - if (!*p) - return FALSE; - else if (*p == '"') { - p++; - quoted = FALSE; - for (q = p; (*q != '"') || quoted; q++) { - if (!*q) - return FALSE; - quoted = (*q == '\\') && !quoted; - } - - tmp = g_strndup (p, q - p); - tmp2 = g_strcompress (tmp); - g_string_truncate (out, 0); - g_string_append (out, tmp2); - g_free (tmp); - g_free (tmp2); - } - - q++; - *pos = q; - - return TRUE; -} - -static gboolean -scan_int (const char **pos, int *out) -{ - int i = 0; - char buf[32]; - const char *p = *pos; - - while (g_ascii_isspace (*p)) - p++; - - if (*p < '0' || *p > '9') - return FALSE; - - while ((*p >= '0') && (*p <= '9') && i < sizeof (buf)) { - buf[i] = *p; - i++; - p++; - } - - if (i == sizeof (buf)) - return FALSE; - else - buf[i] = '\0'; - - *out = atoi (buf); - - *pos = p; - - return TRUE; -} - -static gboolean -skip_space (const char **pos) -{ - const char *p = *pos; - - while (g_ascii_isspace (*p)) - p++; - - *pos = p; - - return !(*p == '\0'); -} - -#ifdef G_OS_WIN32 - -/* DllMain function needed to tuck away the gdk-pixbuf DLL handle */ - -static HMODULE gdk_pixbuf_dll; - -BOOL WINAPI -DllMain (HINSTANCE hinstDLL, - DWORD fdwReason, - LPVOID lpvReserved) -{ - switch (fdwReason) { - case DLL_PROCESS_ATTACH: - gdk_pixbuf_dll = (HMODULE) hinstDLL; - break; - } - - return TRUE; -} - -static char * -get_toplevel (void) -{ - static char *toplevel = NULL; - - if (toplevel == NULL) - toplevel = g_win32_get_package_installation_directory_of_module (gdk_pixbuf_dll); - - return toplevel; -} - -static char * -get_sysconfdir (void) -{ - static char *sysconfdir = NULL; - - if (sysconfdir == NULL) - sysconfdir = g_build_filename (get_toplevel (), "etc", NULL); - - return sysconfdir; -} - -#undef GTK_SYSCONFDIR -#define GTK_SYSCONFDIR get_sysconfdir() - -static void -correct_prefix (gchar **path) -{ - if (strncmp (*path, GTK_PREFIX "/", strlen (GTK_PREFIX "/")) == 0 || - strncmp (*path, GTK_PREFIX "\\", strlen (GTK_PREFIX "\\")) == 0) - { - gchar *tem = NULL; - if (strlen(*path) > 5 && strncmp (*path - 5, ".libs", 5) == 0) - { - /* We are being run from inside the build tree, and shouldn't mess about. */ - return; - } - - /* This is an entry put there by gdk-pixbuf-query-loaders on the - * packager's system. On Windows a prebuilt GTK+ package can be - * installed in a random location. The gdk-pixbuf.loaders file - * distributed in such a package contains paths from the package - * builder's machine. Replace the build-time prefix with the - * installation prefix on this machine. - */ - tem = *path; - *path = g_strconcat (get_toplevel (), tem + strlen (GTK_PREFIX), NULL); - g_free (tem); - } -} - -#endif /* G_OS_WIN32 */ - -static gchar * -gdk_pixbuf_get_module_file (void) -{ - gchar *result = g_strdup (g_getenv ("GDK_PIXBUF_MODULE_FILE")); - - if (!result) - result = g_build_filename (GTK_LIBDIR, "gtk-3.0", GTK_BINARY_VERSION, "loaders.cache", NULL); - - return result; -} - -#endif /* USE_GMODULE */ - - -static gboolean -gdk_pixbuf_load_module_unlocked (GdkPixbufModule *image_module, - GError **error); - -static void -gdk_pixbuf_io_init (void) -{ -#ifdef USE_GMODULE - GIOChannel *channel; - gchar *line_buf; - gsize term; - GString *tmp_buf = g_string_new (NULL); - gboolean have_error = FALSE; - GdkPixbufModule *module = NULL; - gchar *filename = gdk_pixbuf_get_module_file (); - int flags; - int n_patterns = 0; - GdkPixbufModulePattern *pattern; - GError *error = NULL; -#endif - GdkPixbufModule *builtin_module ; - - /* initialize on separate line to avoid compiler warnings in the - * common case of no compiled-in modules. - */ - builtin_module = NULL; - -#define load_one_builtin_module(format) \ - builtin_module = g_new0 (GdkPixbufModule, 1); \ - builtin_module->module_name = #format; \ - if (gdk_pixbuf_load_module_unlocked (builtin_module, NULL)) \ - file_formats = g_slist_prepend (file_formats, builtin_module);\ - else \ - g_free (builtin_module) - -#ifdef INCLUDE_ani - load_one_builtin_module (ani); -#endif -#ifdef INCLUDE_png - load_one_builtin_module (png); -#endif -#ifdef INCLUDE_bmp - load_one_builtin_module (bmp); -#endif -#ifdef INCLUDE_wbmp - load_one_builtin_module (wbmp); -#endif -#ifdef INCLUDE_gif - load_one_builtin_module (gif); -#endif -#ifdef INCLUDE_ico - load_one_builtin_module (ico); -#endif -#ifdef INCLUDE_jpeg - load_one_builtin_module (jpeg); -#endif -#ifdef INCLUDE_pnm - load_one_builtin_module (pnm); -#endif -#ifdef INCLUDE_ras - load_one_builtin_module (ras); -#endif -#ifdef INCLUDE_tiff - load_one_builtin_module (tiff); -#endif -#ifdef INCLUDE_xpm - load_one_builtin_module (xpm); -#endif -#ifdef INCLUDE_xbm - load_one_builtin_module (xbm); -#endif -#ifdef INCLUDE_tga - load_one_builtin_module (tga); -#endif -#ifdef INCLUDE_pcx - load_one_builtin_module (pcx); -#endif -#ifdef INCLUDE_icns - load_one_builtin_module (icns); -#endif -#ifdef INCLUDE_jasper - load_one_builtin_module (jasper); -#endif -#ifdef INCLUDE_qtif - load_one_builtin_module (qtif); -#endif -#ifdef INCLUDE_gdiplus - /* We don't bother having the GDI+ loaders individually selectable - * for building in or not. - */ - load_one_builtin_module (ico); - load_one_builtin_module (wmf); - load_one_builtin_module (emf); - load_one_builtin_module (bmp); - load_one_builtin_module (gif); - load_one_builtin_module (jpeg); - load_one_builtin_module (tiff); -#endif -#ifdef INCLUDE_gdip_png - /* Except the gdip-png loader which normally isn't built at all even */ - load_one_builtin_module (png); -#endif - -#undef load_one_builtin_module - -#ifdef USE_GMODULE - channel = g_io_channel_new_file (filename, "r", &error); - if (!channel) { - /* Don't bother warning if we have some built-in loaders */ - if (file_formats == NULL) - g_warning ("Cannot open pixbuf loader module file '%s': %s", - filename, error->message); - g_string_free (tmp_buf, TRUE); - g_free (filename); - return; - } - - while (!have_error && g_io_channel_read_line (channel, &line_buf, NULL, &term, NULL) == G_IO_STATUS_NORMAL) { - const char *p; - - p = line_buf; - - line_buf[term] = 0; - - if (!skip_space (&p)) { - /* Blank line marking the end of a module - */ - if (module && *p != '#') { -#ifdef G_OS_WIN32 - correct_prefix (&module->module_path); -#endif - file_formats = g_slist_prepend (file_formats, module); - module = NULL; - } - - goto next_line; - } - - if (*p == '#') - goto next_line; - - if (!module) { - /* Read a module location - */ - module = g_new0 (GdkPixbufModule, 1); - n_patterns = 0; - - if (!scan_string (&p, tmp_buf)) { - g_warning ("Error parsing loader info in '%s'\n %s", - filename, line_buf); - have_error = TRUE; - } - module->module_path = g_strdup (tmp_buf->str); - } - else if (!module->module_name) { - module->info = g_new0 (GdkPixbufFormat, 1); - if (!scan_string (&p, tmp_buf)) { - g_warning ("Error parsing loader info in '%s'\n %s", - filename, line_buf); - have_error = TRUE; - } - module->info->name = g_strdup (tmp_buf->str); - module->module_name = module->info->name; - - if (!scan_int (&p, &flags)) { - g_warning ("Error parsing loader info in '%s'\n %s", - filename, line_buf); - have_error = TRUE; - } - module->info->flags = flags; - - if (!scan_string (&p, tmp_buf)) { - g_warning ("Error parsing loader info in '%s'\n %s", - filename, line_buf); - have_error = TRUE; - } - if (tmp_buf->str[0] != 0) - module->info->domain = g_strdup (tmp_buf->str); - - if (!scan_string (&p, tmp_buf)) { - g_warning ("Error parsing loader info in '%s'\n %s", - filename, line_buf); - have_error = TRUE; - } - module->info->description = g_strdup (tmp_buf->str); - - if (scan_string (&p, tmp_buf)) { - module->info->license = g_strdup (tmp_buf->str); - } - } - else if (!module->info->mime_types) { - int n = 1; - module->info->mime_types = g_new0 (gchar*, 1); - while (scan_string (&p, tmp_buf)) { - if (tmp_buf->str[0] != 0) { - module->info->mime_types = - g_realloc (module->info->mime_types, (n + 1) * sizeof (gchar*)); - module->info->mime_types[n - 1] = g_strdup (tmp_buf->str); - module->info->mime_types[n] = NULL; - n++; - } - } - } - else if (!module->info->extensions) { - int n = 1; - module->info->extensions = g_new0 (gchar*, 1); - while (scan_string (&p, tmp_buf)) { - if (tmp_buf->str[0] != 0) { - module->info->extensions = - g_realloc (module->info->extensions, (n + 1) * sizeof (gchar*)); - module->info->extensions[n - 1] = g_strdup (tmp_buf->str); - module->info->extensions[n] = NULL; - n++; - } - } - } - else { - n_patterns++; - module->info->signature = (GdkPixbufModulePattern *) - g_realloc (module->info->signature, (n_patterns + 1) * sizeof (GdkPixbufModulePattern)); - pattern = module->info->signature + n_patterns; - pattern->prefix = NULL; - pattern->mask = NULL; - pattern->relevance = 0; - pattern--; - if (!scan_string (&p, tmp_buf)) - goto context_error; - pattern->prefix = g_strdup (tmp_buf->str); - - if (!scan_string (&p, tmp_buf)) - goto context_error; - if (*tmp_buf->str) - pattern->mask = g_strdup (tmp_buf->str); - else - pattern->mask = NULL; - - if (!scan_int (&p, &pattern->relevance)) - goto context_error; - - goto next_line; - - context_error: - g_free (pattern->prefix); - g_free (pattern->mask); - g_free (pattern); - g_warning ("Error parsing loader info in '%s'\n %s", - filename, line_buf); - have_error = TRUE; - } - next_line: - g_free (line_buf); - } - g_string_free (tmp_buf, TRUE); - g_io_channel_unref (channel); - g_free (filename); -#endif -} - - -#define module(type) \ - extern void _gdk_pixbuf__##type##_fill_info (GdkPixbufFormat *info); \ - extern void _gdk_pixbuf__##type##_fill_vtable (GdkPixbufModule *module) - -module (png); -module (jpeg); -module (gif); -module (ico); -module (ani); -module (ras); -module (xpm); -module (tiff); -module (pnm); -module (bmp); -module (wbmp); -module (xbm); -module (tga); -module (pcx); -module (icns); -module (jasper); -module (qtif); -module (gdip_ico); -module (gdip_wmf); -module (gdip_emf); -module (gdip_bmp); -module (gdip_gif); -module (gdip_jpeg); -module (gdip_png); -module (gdip_tiff); - -#undef module - -/* actually load the image handler - gdk_pixbuf_get_module only get a */ -/* reference to the module to load, it doesn't actually load it */ -/* perhaps these actions should be combined in one function */ -static gboolean -gdk_pixbuf_load_module_unlocked (GdkPixbufModule *image_module, - GError **error) -{ - GdkPixbufModuleFillInfoFunc fill_info = NULL; - GdkPixbufModuleFillVtableFunc fill_vtable = NULL; - - if (image_module->module != NULL) - return TRUE; - -#define try_module(format,id) \ - if (fill_info == NULL && \ - strcmp (image_module->module_name, #format) == 0) { \ - fill_info = _gdk_pixbuf__##id##_fill_info; \ - fill_vtable = _gdk_pixbuf__##id##_fill_vtable; \ - } -#ifdef INCLUDE_png - try_module (png,png); -#endif -#ifdef INCLUDE_bmp - try_module (bmp,bmp); -#endif -#ifdef INCLUDE_wbmp - try_module (wbmp,wbmp); -#endif -#ifdef INCLUDE_gif - try_module (gif,gif); -#endif -#ifdef INCLUDE_ico - try_module (ico,ico); -#endif -#ifdef INCLUDE_ani - try_module (ani,ani); -#endif -#ifdef INCLUDE_jpeg - try_module (jpeg,jpeg); -#endif -#ifdef INCLUDE_pnm - try_module (pnm,pnm); -#endif -#ifdef INCLUDE_ras - try_module (ras,ras); -#endif -#ifdef INCLUDE_tiff - try_module (tiff,tiff); -#endif -#ifdef INCLUDE_xpm - try_module (xpm,xpm); -#endif -#ifdef INCLUDE_xbm - try_module (xbm,xbm); -#endif -#ifdef INCLUDE_tga - try_module (tga,tga); -#endif -#ifdef INCLUDE_pcx - try_module (pcx,pcx); -#endif -#ifdef INCLUDE_icns - try_module (icns,icns); -#endif -#ifdef INCLUDE_jasper - try_module (jasper,jasper); -#endif -#ifdef INCLUDE_qtif - try_module (qtif,qtif); -#endif -#ifdef INCLUDE_gdiplus - try_module (ico,gdip_ico); - try_module (wmf,gdip_wmf); - try_module (emf,gdip_emf); - try_module (bmp,gdip_bmp); - try_module (gif,gdip_gif); - try_module (jpeg,gdip_jpeg); - try_module (tiff,gdip_tiff); -#endif -#ifdef INCLUDE_gdip_png - try_module (png,gdip_png); -#endif - -#undef try_module - - if (fill_vtable) { - image_module->module = (void *) 1; - (* fill_vtable) (image_module); - if (image_module->info == NULL) { - image_module->info = g_new0 (GdkPixbufFormat, 1); - (* fill_info) (image_module->info); - } - return TRUE; - } - else -#ifdef USE_GMODULE - { - char *path; - GModule *module; - gpointer sym; - - path = image_module->module_path; - module = g_module_open (path, G_MODULE_BIND_LAZY | G_MODULE_BIND_LOCAL); - - if (!module) { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Unable to load image-loading module: %s: %s"), - path, g_module_error ()); - return FALSE; - } - - image_module->module = module; - - if (g_module_symbol (module, "fill_vtable", &sym)) { - fill_vtable = (GdkPixbufModuleFillVtableFunc) sym; - (* fill_vtable) (image_module); - return TRUE; - } else { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Image-loading module %s does not export the proper interface; perhaps it's from a different GTK version?"), - path); - return FALSE; - } - } -#else - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("Image type '%s' is not supported"), - image_module->module_name); - return FALSE; -#endif /* !USE_GMODULE */ -} - - -gboolean -_gdk_pixbuf_load_module (GdkPixbufModule *image_module, - GError **error) -{ - gboolean ret; - gboolean locked = FALSE; - - /* be extra careful, maybe the module initializes - * the thread system - */ - if (g_threads_got_initialized) { - G_LOCK (init_lock); - locked = TRUE; - } - - ret = gdk_pixbuf_load_module_unlocked (image_module, error); - - if (locked) - G_UNLOCK (init_lock); - - return ret; -} - - - -GdkPixbufModule * -_gdk_pixbuf_get_named_module (const char *name, - GError **error) -{ - GSList *modules; - - for (modules = get_file_formats (); modules; modules = g_slist_next (modules)) { - GdkPixbufModule *module = (GdkPixbufModule *)modules->data; - - if (module->info->disabled) - continue; - - if (!strcmp (name, module->module_name)) - return module; - } - - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("Image type '%s' is not supported"), - name); - - return NULL; -} - -GdkPixbufModule * -_gdk_pixbuf_get_module (guchar *buffer, guint size, - const gchar *filename, - GError **error) -{ - GSList *modules; - - GdkPixbufModule *selected = NULL; - gchar *display_name = NULL; -#ifdef GDK_PIXBUF_USE_GIO_MIME - gchar *mime_type; - gchar **mimes; - gchar *type; - gint j; - gboolean uncertain; - - mime_type = g_content_type_guess (NULL, buffer, size, &uncertain); - if (uncertain) - mime_type = g_content_type_guess (filename, buffer, size, NULL); - - for (modules = get_file_formats (); modules; modules = g_slist_next (modules)) { - GdkPixbufModule *module = (GdkPixbufModule *)modules->data; - GdkPixbufFormat *info = module->info; - - if (info->disabled) - continue; - - mimes = info->mime_types; - for (j = 0; mimes[j] != NULL; j++) { - type = g_content_type_from_mime_type (mimes[j]); - if (g_ascii_strcasecmp (type, mime_type) == 0) { - g_free (type); - selected = module; - break; - } - g_free (type); - } - } - g_free (mime_type); -#else - gint score, best = 0; - - for (modules = get_file_formats (); modules; modules = g_slist_next (modules)) { - GdkPixbufModule *module = (GdkPixbufModule *)modules->data; - - if (module->info->disabled) - continue; - - score = format_check (module, buffer, size); - if (score > best) { - best = score; - selected = module; - } - if (score >= 100) - break; - } -#endif - - if (selected != NULL) - return selected; - - if (filename) - { - display_name = g_filename_display_name (filename); - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("Couldn't recognize the image file format for file '%s'"), - display_name); - g_free (display_name); - } - else - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("Unrecognized image file format")); - - - return NULL; -} - - -static void -prepared_notify (GdkPixbuf *pixbuf, - GdkPixbufAnimation *anim, - gpointer user_data) -{ - if (pixbuf != NULL) - g_object_ref (pixbuf); - *((GdkPixbuf **)user_data) = pixbuf; -} - -GdkPixbuf * -_gdk_pixbuf_generic_image_load (GdkPixbufModule *module, - FILE *f, - GError **error) -{ - guchar buffer[LOAD_BUFFER_SIZE]; - size_t length; - GdkPixbuf *pixbuf = NULL; - GdkPixbufAnimation *animation = NULL; - gpointer context; - gboolean locked; - - locked = _gdk_pixbuf_lock (module); - - if (module->load != NULL) { - pixbuf = (* module->load) (f, error); - } else if (module->begin_load != NULL) { - - context = module->begin_load (NULL, prepared_notify, NULL, &pixbuf, error); - - if (!context) - goto out; - - while (!feof (f) && !ferror (f)) { - length = fread (buffer, 1, sizeof (buffer), f); - if (length > 0) - if (!module->load_increment (context, buffer, length, error)) { - module->stop_load (context, NULL); - if (pixbuf != NULL) { - g_object_unref (pixbuf); - pixbuf = NULL; - } - goto out; - } - } - - if (!module->stop_load (context, error)) { - if (pixbuf != NULL) { - g_object_unref (pixbuf); - pixbuf = NULL; - } - } - } else if (module->load_animation != NULL) { - animation = (* module->load_animation) (f, error); - if (animation != NULL) { - pixbuf = gdk_pixbuf_animation_get_static_image (animation); - - g_object_ref (pixbuf); - g_object_unref (animation); - } - } - - out: - if (locked) - _gdk_pixbuf_unlock (module); - return pixbuf; -} - -/** - * gdk_pixbuf_new_from_file: - * @filename: Name of file to load, in the GLib file name encoding - * @error: Return location for an error - * - * Creates a new pixbuf by loading an image from a file. The file format is - * detected automatically. If %NULL is returned, then @error will be set. - * Possible errors are in the #GDK_PIXBUF_ERROR and #G_FILE_ERROR domains. - * - * Return value: A newly-created pixbuf with a reference count of 1, or %NULL if - * any of several error conditions occurred: the file could not be opened, - * there was no loader for the file's format, there was not enough memory to - * allocate the image buffer, or the image file contained invalid data. - **/ -GdkPixbuf * -gdk_pixbuf_new_from_file (const char *filename, - GError **error) -{ - GdkPixbuf *pixbuf; - int size; - FILE *f; - guchar buffer[SNIFF_BUFFER_SIZE]; - GdkPixbufModule *image_module; - gchar *display_name; - - g_return_val_if_fail (filename != NULL, NULL); - g_return_val_if_fail (error == NULL || *error == NULL, NULL); - - display_name = g_filename_display_name (filename); - - f = g_fopen (filename, "rb"); - if (!f) { - gint save_errno = errno; - g_set_error (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Failed to open file '%s': %s"), - display_name, - g_strerror (save_errno)); - g_free (display_name); - return NULL; - } - - size = fread (&buffer, 1, sizeof (buffer), f); - if (size == 0) { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Image file '%s' contains no data"), - display_name); - g_free (display_name); - fclose (f); - return NULL; - } - - image_module = _gdk_pixbuf_get_module (buffer, size, filename, error); - if (image_module == NULL) { - g_free (display_name); - fclose (f); - return NULL; - } - - if (!_gdk_pixbuf_load_module (image_module, error)) { - g_free (display_name); - fclose (f); - return NULL; - } - - fseek (f, 0, SEEK_SET); - pixbuf = _gdk_pixbuf_generic_image_load (image_module, f, error); - fclose (f); - - if (pixbuf == NULL && error != NULL && *error == NULL) { - - /* I don't trust these crufty longjmp()'ing image libs - * to maintain proper error invariants, and I don't - * want user code to segfault as a result. We need to maintain - * the invariant that error gets set if NULL is returned. - */ - - g_warning ("Bug! gdk-pixbuf loader '%s' didn't set an error on failure.", image_module->module_name); - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Failed to load image '%s': reason not known, probably a corrupt image file"), - display_name); - } else if (error != NULL && *error != NULL) { - - /* Add the filename to the error message */ - GError *e = *error; - gchar *old; - - old = e->message; - e->message = g_strdup_printf (_("Failed to load image '%s': %s"), - display_name, - old); - g_free (old); - } - - g_free (display_name); - return pixbuf; -} - -#ifdef G_OS_WIN32 - -#undef gdk_pixbuf_new_from_file -GdkPixbuf * -gdk_pixbuf_new_from_file (const char *filename, - GError **error) -{ - gchar *utf8_filename = - g_locale_to_utf8 (filename, -1, NULL, NULL, error); - GdkPixbuf *retval; - - if (utf8_filename == NULL) - return NULL; - - retval = gdk_pixbuf_new_from_file_utf8 (utf8_filename, error); - - g_free (utf8_filename); - - return retval; -} -#endif - - -/** - * gdk_pixbuf_new_from_file_at_size: - * @filename: Name of file to load, in the GLib file name encoding - * @width: The width the image should have or -1 to not constrain the width - * @height: The height the image should have or -1 to not constrain the height - * @error: Return location for an error - * - * Creates a new pixbuf by loading an image from a file. - * The file format is detected automatically. If %NULL is returned, then - * @error will be set. Possible errors are in the #GDK_PIXBUF_ERROR and - * #G_FILE_ERROR domains. - * - * The image will be scaled to fit in the requested size, preserving - * the image's aspect ratio. Note that the returned pixbuf may be smaller - * than @width x @height, if the aspect ratio requires it. To load - * and image at the requested size, regardless of aspect ratio, use - * gdk_pixbuf_new_from_file_at_scale(). - * - * Return value: A newly-created pixbuf with a reference count of 1, or - * %NULL if any of several error conditions occurred: the file could not - * be opened, there was no loader for the file's format, there was not - * enough memory to allocate the image buffer, or the image file contained - * invalid data. - * - * Since: 2.4 - **/ -GdkPixbuf * -gdk_pixbuf_new_from_file_at_size (const char *filename, - int width, - int height, - GError **error) -{ - return gdk_pixbuf_new_from_file_at_scale (filename, - width, height, - TRUE, error); -} - -#ifdef G_OS_WIN32 - -#undef gdk_pixbuf_new_from_file_at_size - -GdkPixbuf * -gdk_pixbuf_new_from_file_at_size (const char *filename, - int width, - int height, - GError **error) -{ - gchar *utf8_filename = - g_locale_to_utf8 (filename, -1, NULL, NULL, error); - GdkPixbuf *retval; - - if (utf8_filename == NULL) - return NULL; - - retval = gdk_pixbuf_new_from_file_at_size_utf8 (utf8_filename, - width, height, - error); - - g_free (utf8_filename); - - return retval; -} -#endif - -typedef struct { - gint width; - gint height; - gboolean preserve_aspect_ratio; -} AtScaleData; - -static void -at_scale_size_prepared_cb (GdkPixbufLoader *loader, - int width, - int height, - gpointer data) -{ - AtScaleData *info = data; - - g_return_if_fail (width > 0 && height > 0); - - if (info->preserve_aspect_ratio && - (info->width > 0 || info->height > 0)) { - if (info->width < 0) - { - width = width * (double)info->height/(double)height; - height = info->height; - } - else if (info->height < 0) - { - height = height * (double)info->width/(double)width; - width = info->width; - } - else if ((double)height * (double)info->width > - (double)width * (double)info->height) { - width = 0.5 + (double)width * (double)info->height / (double)height; - height = info->height; - } else { - height = 0.5 + (double)height * (double)info->width / (double)width; - width = info->width; - } - } else { - if (info->width > 0) - width = info->width; - if (info->height > 0) - height = info->height; - } - - width = MAX (width, 1); - height = MAX (height, 1); - - gdk_pixbuf_loader_set_size (loader, width, height); -} - -/** - * gdk_pixbuf_new_from_file_at_scale: - * @filename: Name of file to load, in the GLib file name encoding - * @width: The width the image should have or -1 to not constrain the width - * @height: The height the image should have or -1 to not constrain the height - * @preserve_aspect_ratio: %TRUE to preserve the image's aspect ratio - * @error: Return location for an error - * - * Creates a new pixbuf by loading an image from a file. The file format is - * detected automatically. If %NULL is returned, then @error will be set. - * Possible errors are in the #GDK_PIXBUF_ERROR and #G_FILE_ERROR domains. - * The image will be scaled to fit in the requested size, optionally preserving - * the image's aspect ratio. - * - * When preserving the aspect ratio, a @width of -1 will cause the image - * to be scaled to the exact given height, and a @height of -1 will cause - * the image to be scaled to the exact given width. When not preserving - * aspect ratio, a @width or @height of -1 means to not scale the image - * at all in that dimension. Negative values for @width and @height are - * allowed since 2.8. - * - * Return value: A newly-created pixbuf with a reference count of 1, or %NULL - * if any of several error conditions occurred: the file could not be opened, - * there was no loader for the file's format, there was not enough memory to - * allocate the image buffer, or the image file contained invalid data. - * - * Since: 2.6 - **/ -GdkPixbuf * -gdk_pixbuf_new_from_file_at_scale (const char *filename, - int width, - int height, - gboolean preserve_aspect_ratio, - GError **error) -{ - - GdkPixbufLoader *loader; - GdkPixbuf *pixbuf; - guchar buffer[LOAD_BUFFER_SIZE]; - int length; - FILE *f; - AtScaleData info; - GdkPixbufAnimation *animation; - GdkPixbufAnimationIter *iter; - gboolean has_frame; - - g_return_val_if_fail (filename != NULL, NULL); - g_return_val_if_fail (width > 0 || width == -1, NULL); - g_return_val_if_fail (height > 0 || height == -1, NULL); - - f = g_fopen (filename, "rb"); - if (!f) { - gint save_errno = errno; - gchar *display_name = g_filename_display_name (filename); - g_set_error (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Failed to open file '%s': %s"), - display_name, - g_strerror (save_errno)); - g_free (display_name); - return NULL; - } - - loader = gdk_pixbuf_loader_new (); - - info.width = width; - info.height = height; - info.preserve_aspect_ratio = preserve_aspect_ratio; - - g_signal_connect (loader, "size-prepared", - G_CALLBACK (at_scale_size_prepared_cb), &info); - - has_frame = FALSE; - while (!has_frame && !feof (f) && !ferror (f)) { - length = fread (buffer, 1, sizeof (buffer), f); - if (length > 0) - if (!gdk_pixbuf_loader_write (loader, buffer, length, error)) { - gdk_pixbuf_loader_close (loader, NULL); - fclose (f); - g_object_unref (loader); - return NULL; - } - - animation = gdk_pixbuf_loader_get_animation (loader); - if (animation) { - iter = gdk_pixbuf_animation_get_iter (animation, NULL); - if (!gdk_pixbuf_animation_iter_on_currently_loading_frame (iter)) { - has_frame = TRUE; - } - g_object_unref (iter); - } - } - - fclose (f); - - if (!gdk_pixbuf_loader_close (loader, error) && !has_frame) { - g_object_unref (loader); - return NULL; - } - - pixbuf = gdk_pixbuf_loader_get_pixbuf (loader); - - if (!pixbuf) { - gchar *display_name = g_filename_display_name (filename); - g_object_unref (loader); - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Failed to load image '%s': reason not known, probably a corrupt image file"), - display_name); - g_free (display_name); - return NULL; - } - - g_object_ref (pixbuf); - - g_object_unref (loader); - - return pixbuf; -} - -#ifdef G_OS_WIN32 - -#undef gdk_pixbuf_new_from_file_at_scale - -GdkPixbuf * -gdk_pixbuf_new_from_file_at_scale (const char *filename, - int width, - int height, - gboolean preserve_aspect_ratio, - GError **error) -{ - gchar *utf8_filename = - g_locale_to_utf8 (filename, -1, NULL, NULL, error); - GdkPixbuf *retval; - - if (utf8_filename == NULL) - return NULL; - - retval = gdk_pixbuf_new_from_file_at_scale_utf8 (utf8_filename, - width, height, - preserve_aspect_ratio, - error); - - g_free (utf8_filename); - - return retval; -} -#endif - - -static GdkPixbuf * -load_from_stream (GdkPixbufLoader *loader, - GInputStream *stream, - GCancellable *cancellable, - GError **error) -{ - GdkPixbuf *pixbuf; - gssize n_read; - guchar buffer[LOAD_BUFFER_SIZE]; - gboolean res; - - res = TRUE; - while (1) { - n_read = g_input_stream_read (stream, - buffer, - sizeof (buffer), - cancellable, - error); - if (n_read < 0) { - res = FALSE; - error = NULL; /* Ignore further errors */ - break; - } - - if (n_read == 0) - break; - - if (!gdk_pixbuf_loader_write (loader, - buffer, - n_read, - error)) { - res = FALSE; - error = NULL; - break; - } - } - - if (!gdk_pixbuf_loader_close (loader, error)) { - res = FALSE; - error = NULL; - } - - pixbuf = NULL; - if (res) { - pixbuf = gdk_pixbuf_loader_get_pixbuf (loader); - if (pixbuf) - g_object_ref (pixbuf); - } - - return pixbuf; -} - - -/** - * gdk_pixbuf_new_from_stream_at_scale: - * @stream: a #GInputStream to load the pixbuf from - * @width: The width the image should have or -1 to not constrain the width - * @height: The height the image should have or -1 to not constrain the height - * @preserve_aspect_ratio: %TRUE to preserve the image's aspect ratio - * @cancellable: optional #GCancellable object, %NULL to ignore - * @error: Return location for an error - * - * Creates a new pixbuf by loading an image from an input stream. - * - * The file format is detected automatically. If %NULL is returned, then - * @error will be set. The @cancellable can be used to abort the operation - * from another thread. If the operation was cancelled, the error - * %GIO_ERROR_CANCELLED will be returned. Other possible errors are in - * the #GDK_PIXBUF_ERROR and %G_IO_ERROR domains. - * - * The image will be scaled to fit in the requested size, optionally - * preserving the image's aspect ratio. When preserving the aspect ratio, - * a @width of -1 will cause the image to be scaled to the exact given - * height, and a @height of -1 will cause the image to be scaled to the - * exact given width. When not preserving aspect ratio, a @width or - * @height of -1 means to not scale the image at all in that dimension. - * - * The stream is not closed. - * - * Return value: A newly-created pixbuf, or %NULL if any of several error - * conditions occurred: the file could not be opened, the image format is - * not supported, there was not enough memory to allocate the image buffer, - * the stream contained invalid data, or the operation was cancelled. - * - * Since: 2.14 - */ -GdkPixbuf * -gdk_pixbuf_new_from_stream_at_scale (GInputStream *stream, - gint width, - gint height, - gboolean preserve_aspect_ratio, - GCancellable *cancellable, - GError **error) -{ - GdkPixbufLoader *loader; - GdkPixbuf *pixbuf; - AtScaleData info; - - loader = gdk_pixbuf_loader_new (); - - info.width = width; - info.height = height; - info.preserve_aspect_ratio = preserve_aspect_ratio; - - g_signal_connect (loader, "size-prepared", - G_CALLBACK (at_scale_size_prepared_cb), &info); - - pixbuf = load_from_stream (loader, stream, cancellable, error); - g_object_unref (loader); - - return pixbuf; -} - -/** - * gdk_pixbuf_new_from_stream: - * @stream: a #GInputStream to load the pixbuf from - * @cancellable: optional #GCancellable object, %NULL to ignore - * @error: Return location for an error - * - * Creates a new pixbuf by loading an image from an input stream. - * - * The file format is detected automatically. If %NULL is returned, then - * @error will be set. The @cancellable can be used to abort the operation - * from another thread. If the operation was cancelled, the error - * %GIO_ERROR_CANCELLED will be returned. Other possible errors are in - * the #GDK_PIXBUF_ERROR and %G_IO_ERROR domains. - * - * The stream is not closed. - * - * Return value: A newly-created pixbuf, or %NULL if any of several error - * conditions occurred: the file could not be opened, the image format is - * not supported, there was not enough memory to allocate the image buffer, - * the stream contained invalid data, or the operation was cancelled. - * - * Since: 2.14 - **/ -GdkPixbuf * -gdk_pixbuf_new_from_stream (GInputStream *stream, - GCancellable *cancellable, - GError **error) -{ - GdkPixbuf *pixbuf; - GdkPixbufLoader *loader; - - loader = gdk_pixbuf_loader_new (); - pixbuf = load_from_stream (loader, stream, cancellable, error); - g_object_unref (loader); - - return pixbuf; -} - -static void -info_cb (GdkPixbufLoader *loader, - int width, - int height, - gpointer data) -{ - struct { - GdkPixbufFormat *format; - int width; - int height; - } *info = data; - - g_return_if_fail (width > 0 && height > 0); - - info->format = gdk_pixbuf_loader_get_format (loader); - info->width = width; - info->height = height; - - gdk_pixbuf_loader_set_size (loader, 0, 0); -} - -/** - * gdk_pixbuf_get_file_info: - * @filename: The name of the file to identify. - * @width: Return location for the width of the image, or %NULL - * @height: Return location for the height of the image, or %NULL - * - * Parses an image file far enough to determine its format and size. - * - * Returns: A #GdkPixbufFormat describing the image format of the file - * or %NULL if the image format wasn't recognized. The return value - * is owned by GdkPixbuf and should not be freed. - * - * Since: 2.4 - **/ -GdkPixbufFormat * -gdk_pixbuf_get_file_info (const gchar *filename, - gint *width, - gint *height) -{ - GdkPixbufLoader *loader; - guchar buffer[SNIFF_BUFFER_SIZE]; - int length; - FILE *f; - struct { - GdkPixbufFormat *format; - gint width; - gint height; - } info; - - g_return_val_if_fail (filename != NULL, NULL); - - f = g_fopen (filename, "rb"); - if (!f) - return NULL; - - loader = gdk_pixbuf_loader_new (); - - info.format = NULL; - info.width = -1; - info.height = -1; - - g_signal_connect (loader, "size-prepared", G_CALLBACK (info_cb), &info); - - while (!feof (f) && !ferror (f)) { - length = fread (buffer, 1, sizeof (buffer), f); - if (length > 0) { - if (!gdk_pixbuf_loader_write (loader, buffer, length, NULL)) - break; - } - if (info.format != NULL) - break; - } - - fclose (f); - gdk_pixbuf_loader_close (loader, NULL); - g_object_unref (loader); - - if (width) - *width = info.width; - if (height) - *height = info.height; - - return info.format; -} - -/** - * gdk_pixbuf_new_from_xpm_data: - * @data: Pointer to inline XPM data. - * - * Creates a new pixbuf by parsing XPM data in memory. This data is commonly - * the result of including an XPM file into a program's C source. - * - * Return value: A newly-created pixbuf with a reference count of 1. - **/ -GdkPixbuf * -gdk_pixbuf_new_from_xpm_data (const char **data) -{ - GdkPixbuf *(* load_xpm_data) (const char **data); - GdkPixbuf *pixbuf; - GError *error = NULL; - GdkPixbufModule *xpm_module; - gboolean locked; - - g_return_val_if_fail (data != NULL, NULL); - - xpm_module = _gdk_pixbuf_get_named_module ("xpm", &error); - if (xpm_module == NULL) { - g_warning ("Error loading XPM image loader: %s", error->message); - g_error_free (error); - return NULL; - } - - if (!_gdk_pixbuf_load_module (xpm_module, &error)) { - g_warning ("Error loading XPM image loader: %s", error->message); - g_error_free (error); - return NULL; - } - - locked = _gdk_pixbuf_lock (xpm_module); - - if (xpm_module->load_xpm_data == NULL) { - g_warning ("gdk-pixbuf XPM module lacks XPM data capability"); - pixbuf = NULL; - } else { - load_xpm_data = xpm_module->load_xpm_data; - pixbuf = (* load_xpm_data) (data); - } - - if (locked) - _gdk_pixbuf_unlock (xpm_module); - return pixbuf; -} - -static void -collect_save_options (va_list opts, - gchar ***keys, - gchar ***vals) -{ - gchar *key; - gchar *val; - gchar *next; - gint count; - - count = 0; - *keys = NULL; - *vals = NULL; - - next = va_arg (opts, gchar*); - while (next) - { - key = next; - val = va_arg (opts, gchar*); - - ++count; - - /* woo, slow */ - *keys = g_realloc (*keys, sizeof(gchar*) * (count + 1)); - *vals = g_realloc (*vals, sizeof(gchar*) * (count + 1)); - - (*keys)[count-1] = g_strdup (key); - (*vals)[count-1] = g_strdup (val); - - (*keys)[count] = NULL; - (*vals)[count] = NULL; - - next = va_arg (opts, gchar*); - } -} - -static gboolean -save_to_file_callback (const gchar *buf, - gsize count, - GError **error, - gpointer data) -{ - FILE *filehandle = data; - gsize n; - - n = fwrite (buf, 1, count, filehandle); - if (n != count) { - gint save_errno = errno; - g_set_error (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Error writing to image file: %s"), - g_strerror (save_errno)); - return FALSE; - } - return TRUE; -} - -static gboolean -gdk_pixbuf_real_save (GdkPixbuf *pixbuf, - FILE *filehandle, - const char *type, - gchar **keys, - gchar **values, - GError **error) -{ - gboolean ret; - GdkPixbufModule *image_module = NULL; - gboolean locked; - - image_module = _gdk_pixbuf_get_named_module (type, error); - - if (image_module == NULL) - return FALSE; - - if (!_gdk_pixbuf_load_module (image_module, error)) - return FALSE; - - locked = _gdk_pixbuf_lock (image_module); - - if (image_module->save) { - /* save normally */ - ret = (* image_module->save) (filehandle, pixbuf, - keys, values, - error); - } else if (image_module->save_to_callback) { - /* save with simple callback */ - ret = (* image_module->save_to_callback) (save_to_file_callback, - filehandle, pixbuf, - keys, values, - error); - } else { - /* can't save */ - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNSUPPORTED_OPERATION, - _("This build of gdk-pixbuf does not support saving the image format: %s"), - type); - ret = FALSE; - } - - if (locked) - _gdk_pixbuf_unlock (image_module); - return ret; -} - -#define TMP_FILE_BUF_SIZE 4096 - -static gboolean -save_to_callback_with_tmp_file (GdkPixbufModule *image_module, - GdkPixbuf *pixbuf, - GdkPixbufSaveFunc save_func, - gpointer user_data, - gchar **keys, - gchar **values, - GError **error) -{ - int fd; - FILE *f = NULL; - gboolean retval = FALSE; - gchar *buf = NULL; - gsize n; - gchar *filename = NULL; - gboolean locked; - - buf = g_try_malloc (TMP_FILE_BUF_SIZE); - if (buf == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to save image to callback")); - goto end; - } - - fd = g_file_open_tmp ("gdkpixbuf-save-tmp.XXXXXX", &filename, error); - if (fd == -1) - goto end; - f = fdopen (fd, "wb+"); - if (f == NULL) { - gint save_errno = errno; - g_set_error_literal (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Failed to open temporary file")); - goto end; - } - - locked = _gdk_pixbuf_lock (image_module); - retval = (image_module->save) (f, pixbuf, keys, values, error); - if (locked) - _gdk_pixbuf_unlock (image_module); - if (!retval) - goto end; - - rewind (f); - for (;;) { - n = fread (buf, 1, TMP_FILE_BUF_SIZE, f); - if (n > 0) { - if (!save_func (buf, n, error, user_data)) - goto end; - } - if (n != TMP_FILE_BUF_SIZE) - break; - } - if (ferror (f)) { - gint save_errno = errno; - g_set_error_literal (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Failed to read from temporary file")); - goto end; - } - retval = TRUE; - - end: - /* cleanup and return retval */ - if (f) - fclose (f); - if (filename) { - g_unlink (filename); - g_free (filename); - } - g_free (buf); - - return retval; -} - -static gboolean -gdk_pixbuf_real_save_to_callback (GdkPixbuf *pixbuf, - GdkPixbufSaveFunc save_func, - gpointer user_data, - const char *type, - gchar **keys, - gchar **values, - GError **error) -{ - gboolean ret; - GdkPixbufModule *image_module = NULL; - gboolean locked; - - image_module = _gdk_pixbuf_get_named_module (type, error); - - if (image_module == NULL) - return FALSE; - - if (!_gdk_pixbuf_load_module (image_module, error)) - return FALSE; - - locked = _gdk_pixbuf_lock (image_module); - - if (image_module->save_to_callback) { - /* save normally */ - ret = (* image_module->save_to_callback) (save_func, user_data, - pixbuf, keys, values, - error); - } else if (image_module->save) { - /* use a temporary file */ - ret = save_to_callback_with_tmp_file (image_module, pixbuf, - save_func, user_data, - keys, values, - error); - } else { - /* can't save */ - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNSUPPORTED_OPERATION, - _("This build of gdk-pixbuf does not support saving the image format: %s"), - type); - ret = FALSE; - } - - if (locked) - _gdk_pixbuf_unlock (image_module); - return ret; -} - - -/** - * gdk_pixbuf_save: - * @pixbuf: a #GdkPixbuf. - * @filename: name of file to save. - * @type: name of file format. - * @error: (allow-none): return location for error, or %NULL - * @Varargs: list of key-value save options - * - * Saves pixbuf to a file in format @type. By default, "jpeg", "png", "ico" - * and "bmp" are possible file formats to save in, but more formats may be - * installed. The list of all writable formats can be determined in the - * following way: - * - * |[ - * void add_if_writable (GdkPixbufFormat *data, GSList **list) - * { - * if (gdk_pixbuf_format_is_writable (data)) - * *list = g_slist_prepend (*list, data); - * } - * - * GSList *formats = gdk_pixbuf_get_formats (); - * GSList *writable_formats = NULL; - * g_slist_foreach (formats, add_if_writable, &writable_formats); - * g_slist_free (formats); - * ]| - * - * If @error is set, %FALSE will be returned. Possible errors include - * those in the #GDK_PIXBUF_ERROR domain and those in the #G_FILE_ERROR domain. - * - * The variable argument list should be %NULL-terminated; if not empty, - * it should contain pairs of strings that modify the save - * parameters. For example: - * <informalexample><programlisting> - * gdk_pixbuf_save (pixbuf, handle, "jpeg", &error, - * "quality", "100", NULL); - * </programlisting></informalexample> - * - * Currently only few parameters exist. JPEG images can be saved with a - * "quality" parameter; its value should be in the range [0,100]. - * - * Text chunks can be attached to PNG images by specifying parameters of - * the form "tEXt::key", where key is an ASCII string of length 1-79. - * The values are UTF-8 encoded strings. The PNG compression level can - * be specified using the "compression" parameter; it's value is in an - * integer in the range of [0,9]. - * - * ICC color profiles can also be embedded into PNG and TIFF images. - * The "icc-profile" value should be the complete ICC profile encoded - * into base64. - * - * <informalexample><programlisting> - * gchar *contents; - * gchar *contents_encode; - * gsize length; - * g_file_get_contents ("/home/hughsie/.color/icc/L225W.icm", &contents, &length, NULL); - * contents_encode = g_base64_encode ((const guchar *) contents, length); - * gdk_pixbuf_save (pixbuf, handle, "png", &error, - * "icc-profile", contents_encode, - * NULL); - * </programlisting></informalexample> - * - * TIFF images recognize a "compression" option which acceps an integer value. - * Among the codecs are 1 None, 2 Huffman, 5 LZW, 7 JPEG and 8 Deflate, see - * the libtiff documentation and tiff.h for all supported codec values. - * - * ICO images can be saved in depth 16, 24, or 32, by using the "depth" - * parameter. When the ICO saver is given "x_hot" and "y_hot" parameters, - * it produces a CUR instead of an ICO. - * - * Return value: whether an error was set - **/ - -gboolean -gdk_pixbuf_save (GdkPixbuf *pixbuf, - const char *filename, - const char *type, - GError **error, - ...) -{ - gchar **keys = NULL; - gchar **values = NULL; - va_list args; - gboolean result; - - g_return_val_if_fail (error == NULL || *error == NULL, FALSE); - - va_start (args, error); - - collect_save_options (args, &keys, &values); - - va_end (args); - - result = gdk_pixbuf_savev (pixbuf, filename, type, - keys, values, - error); - - g_strfreev (keys); - g_strfreev (values); - - return result; -} - -#ifdef G_OS_WIN32 - -#undef gdk_pixbuf_save - -gboolean -gdk_pixbuf_save (GdkPixbuf *pixbuf, - const char *filename, - const char *type, - GError **error, - ...) -{ - char *utf8_filename; - gchar **keys = NULL; - gchar **values = NULL; - va_list args; - gboolean result; - - g_return_val_if_fail (error == NULL || *error == NULL, FALSE); - - utf8_filename = g_locale_to_utf8 (filename, -1, NULL, NULL, error); - - if (utf8_filename == NULL) - return FALSE; - - va_start (args, error); - - collect_save_options (args, &keys, &values); - - va_end (args); - - result = gdk_pixbuf_savev_utf8 (pixbuf, utf8_filename, type, - keys, values, - error); - - g_free (utf8_filename); - - g_strfreev (keys); - g_strfreev (values); - - return result; -} - -#endif - -/** - * gdk_pixbuf_savev: - * @pixbuf: a #GdkPixbuf. - * @filename: name of file to save. - * @type: name of file format. - * @option_keys: name of options to set, %NULL-terminated - * @option_values: values for named options - * @error: (allow-none): return location for error, or %NULL - * - * Saves pixbuf to a file in @type, which is currently "jpeg", "png", "tiff", "ico" or "bmp". - * If @error is set, %FALSE will be returned. - * See gdk_pixbuf_save () for more details. - * - * Return value: whether an error was set - **/ - -gboolean -gdk_pixbuf_savev (GdkPixbuf *pixbuf, - const char *filename, - const char *type, - char **option_keys, - char **option_values, - GError **error) -{ - FILE *f = NULL; - gboolean result; - - g_return_val_if_fail (filename != NULL, FALSE); - g_return_val_if_fail (type != NULL, FALSE); - g_return_val_if_fail (error == NULL || *error == NULL, FALSE); - - f = g_fopen (filename, "wb"); - - if (f == NULL) { - gint save_errno = errno; - gchar *display_name = g_filename_display_name (filename); - g_set_error (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Failed to open '%s' for writing: %s"), - display_name, - g_strerror (save_errno)); - g_free (display_name); - return FALSE; - } - - - result = gdk_pixbuf_real_save (pixbuf, f, type, - option_keys, option_values, - error); - - - if (!result) { - g_return_val_if_fail (error == NULL || *error != NULL, FALSE); - fclose (f); - g_unlink (filename); - return FALSE; - } - - if (fclose (f) < 0) { - gint save_errno = errno; - gchar *display_name = g_filename_display_name (filename); - g_set_error (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Failed to close '%s' while writing image, all data may not have been saved: %s"), - display_name, - g_strerror (save_errno)); - g_free (display_name); - return FALSE; - } - - return TRUE; -} - -#ifdef G_OS_WIN32 - -#undef gdk_pixbuf_savev - -gboolean -gdk_pixbuf_savev (GdkPixbuf *pixbuf, - const char *filename, - const char *type, - char **option_keys, - char **option_values, - GError **error) -{ - char *utf8_filename; - gboolean retval; - - g_return_val_if_fail (filename != NULL, FALSE); - - utf8_filename = g_locale_to_utf8 (filename, -1, NULL, NULL, error); - - if (utf8_filename == NULL) - return FALSE; - - retval = gdk_pixbuf_savev_utf8 (pixbuf, utf8_filename, type, - option_keys, option_values, error); - - g_free (utf8_filename); - - return retval; -} - -#endif - -/** - * gdk_pixbuf_save_to_callback: - * @pixbuf: a #GdkPixbuf. - * @save_func: a function that is called to save each block of data that - * the save routine generates. - * @user_data: user data to pass to the save function. - * @type: name of file format. - * @error: (allow-none): return location for error, or %NULL - * @Varargs: list of key-value save options - * - * Saves pixbuf in format @type by feeding the produced data to a - * callback. Can be used when you want to store the image to something - * other than a file, such as an in-memory buffer or a socket. - * If @error is set, %FALSE will be returned. Possible errors - * include those in the #GDK_PIXBUF_ERROR domain and whatever the save - * function generates. - * - * See gdk_pixbuf_save() for more details. - * - * Return value: whether an error was set - * - * Since: 2.4 - **/ -gboolean -gdk_pixbuf_save_to_callback (GdkPixbuf *pixbuf, - GdkPixbufSaveFunc save_func, - gpointer user_data, - const char *type, - GError **error, - ...) -{ - gchar **keys = NULL; - gchar **values = NULL; - va_list args; - gboolean result; - - g_return_val_if_fail (error == NULL || *error == NULL, FALSE); - - va_start (args, error); - - collect_save_options (args, &keys, &values); - - va_end (args); - - result = gdk_pixbuf_save_to_callbackv (pixbuf, save_func, user_data, - type, keys, values, - error); - - g_strfreev (keys); - g_strfreev (values); - - return result; -} - -/** - * gdk_pixbuf_save_to_callbackv: - * @pixbuf: a #GdkPixbuf. - * @save_func: a function that is called to save each block of data that - * the save routine generates. - * @user_data: user data to pass to the save function. - * @type: name of file format. - * @option_keys: name of options to set, %NULL-terminated - * @option_values: values for named options - * @error: (allow-none): return location for error, or %NULL - * - * Saves pixbuf to a callback in format @type, which is currently "jpeg", - * "png", "tiff", "ico" or "bmp". If @error is set, %FALSE will be returned. See - * gdk_pixbuf_save_to_callback () for more details. - * - * Return value: whether an error was set - * - * Since: 2.4 - **/ -gboolean -gdk_pixbuf_save_to_callbackv (GdkPixbuf *pixbuf, - GdkPixbufSaveFunc save_func, - gpointer user_data, - const char *type, - char **option_keys, - char **option_values, - GError **error) -{ - gboolean result; - - - g_return_val_if_fail (save_func != NULL, FALSE); - g_return_val_if_fail (type != NULL, FALSE); - g_return_val_if_fail (error == NULL || *error == NULL, FALSE); - - result = gdk_pixbuf_real_save_to_callback (pixbuf, - save_func, user_data, type, - option_keys, option_values, - error); - - if (!result) { - g_return_val_if_fail (error == NULL || *error != NULL, FALSE); - return FALSE; - } - - return TRUE; -} - -/** - * gdk_pixbuf_save_to_buffer: - * @pixbuf: a #GdkPixbuf. - * @buffer: location to receive a pointer to the new buffer. - * @buffer_size: location to receive the size of the new buffer. - * @type: name of file format. - * @error: (allow-none): return location for error, or %NULL - * @Varargs: list of key-value save options - * - * Saves pixbuf to a new buffer in format @type, which is currently "jpeg", - * "png", "tiff", "ico" or "bmp". This is a convenience function that uses - * gdk_pixbuf_save_to_callback() to do the real work. Note that the buffer - * is not nul-terminated and may contain embedded nuls. - * If @error is set, %FALSE will be returned and @buffer will be set to - * %NULL. Possible errors include those in the #GDK_PIXBUF_ERROR - * domain. - * - * See gdk_pixbuf_save() for more details. - * - * Return value: whether an error was set - * - * Since: 2.4 - **/ -gboolean -gdk_pixbuf_save_to_buffer (GdkPixbuf *pixbuf, - gchar **buffer, - gsize *buffer_size, - const char *type, - GError **error, - ...) -{ - gchar **keys = NULL; - gchar **values = NULL; - va_list args; - gboolean result; - - g_return_val_if_fail (error == NULL || *error == NULL, FALSE); - - va_start (args, error); - - collect_save_options (args, &keys, &values); - - va_end (args); - - result = gdk_pixbuf_save_to_bufferv (pixbuf, buffer, buffer_size, - type, keys, values, - error); - - g_strfreev (keys); - g_strfreev (values); - - return result; -} - -struct SaveToBufferData { - gchar *buffer; - gsize len, max; -}; - -static gboolean -save_to_buffer_callback (const gchar *data, - gsize count, - GError **error, - gpointer user_data) -{ - struct SaveToBufferData *sdata = user_data; - gchar *new_buffer; - gsize new_max; - - if (sdata->len + count > sdata->max) { - new_max = MAX (sdata->max*2, sdata->len + count); - new_buffer = g_try_realloc (sdata->buffer, new_max); - if (!new_buffer) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to save image into a buffer")); - return FALSE; - } - sdata->buffer = new_buffer; - sdata->max = new_max; - } - memcpy (sdata->buffer + sdata->len, data, count); - sdata->len += count; - return TRUE; -} - -/** - * gdk_pixbuf_save_to_bufferv: - * @pixbuf: a #GdkPixbuf. - * @buffer: location to receive a pointer to the new buffer. - * @buffer_size: location to receive the size of the new buffer. - * @type: name of file format. - * @option_keys: name of options to set, %NULL-terminated - * @option_values: values for named options - * @error: (allow-none): return location for error, or %NULL - * - * Saves pixbuf to a new buffer in format @type, which is currently "jpeg", - * "tiff", "png", "ico" or "bmp". See gdk_pixbuf_save_to_buffer() - * for more details. - * - * Return value: whether an error was set - * - * Since: 2.4 - **/ -gboolean -gdk_pixbuf_save_to_bufferv (GdkPixbuf *pixbuf, - gchar **buffer, - gsize *buffer_size, - const char *type, - char **option_keys, - char **option_values, - GError **error) -{ - static const gint initial_max = 1024; - struct SaveToBufferData sdata; - - *buffer = NULL; - *buffer_size = 0; - - sdata.buffer = g_try_malloc (initial_max); - sdata.max = initial_max; - sdata.len = 0; - if (!sdata.buffer) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to save image into a buffer")); - return FALSE; - } - - if (!gdk_pixbuf_save_to_callbackv (pixbuf, - save_to_buffer_callback, &sdata, - type, option_keys, option_values, - error)) { - g_free (sdata.buffer); - return FALSE; - } - - *buffer = sdata.buffer; - *buffer_size = sdata.len; - return TRUE; -} - -typedef struct { - GOutputStream *stream; - GCancellable *cancellable; -} SaveToStreamData; - -static gboolean -save_to_stream (const gchar *buffer, - gsize count, - GError **error, - gpointer data) -{ - SaveToStreamData *sdata = (SaveToStreamData *)data; - gsize remaining; - gssize written; - GError *my_error = NULL; - - remaining = count; - written = 0; - while (remaining > 0) { - buffer += written; - remaining -= written; - written = g_output_stream_write (sdata->stream, - buffer, remaining, - sdata->cancellable, - &my_error); - if (written < 0) { - if (!my_error) { - g_set_error_literal (error, - G_IO_ERROR, 0, - _("Error writing to image stream")); - } - else { - g_propagate_error (error, my_error); - } - return FALSE; - } - } - - return TRUE; -} - -/** - * gdk_pixbuf_save_to_stream: - * @pixbuf: a #GdkPixbuf - * @stream: a #GOutputStream to save the pixbuf to - * @type: name of file format - * @cancellable: optional #GCancellable object, %NULL to ignore - * @error: (allow-none): return location for error, or %NULL - * @Varargs: list of key-value save options - * - * Saves @pixbuf to an output stream. - * - * Supported file formats are currently "jpeg", "tiff", "png", "ico" or - * "bmp". See gdk_pixbuf_save_to_buffer() for more details. - * - * The @cancellable can be used to abort the operation from another - * thread. If the operation was cancelled, the error %GIO_ERROR_CANCELLED - * will be returned. Other possible errors are in the #GDK_PIXBUF_ERROR - * and %G_IO_ERROR domains. - * - * The stream is not closed. - * - * Returns: %TRUE if the pixbuf was saved successfully, %FALSE if an - * error was set. - * - * Since: 2.14 - */ -gboolean -gdk_pixbuf_save_to_stream (GdkPixbuf *pixbuf, - GOutputStream *stream, - const char *type, - GCancellable *cancellable, - GError **error, - ...) -{ - gboolean res; - gchar **keys = NULL; - gchar **values = NULL; - va_list args; - SaveToStreamData data; - - va_start (args, error); - collect_save_options (args, &keys, &values); - va_end (args); - - data.stream = stream; - data.cancellable = cancellable; - - res = gdk_pixbuf_save_to_callbackv (pixbuf, save_to_stream, - &data, type, - keys, values, - error); - - g_strfreev (keys); - g_strfreev (values); - - return res; -} - -/** - * gdk_pixbuf_format_get_name: - * @format: a #GdkPixbufFormat - * - * Returns the name of the format. - * - * Return value: the name of the format. - * - * Since: 2.2 - */ -gchar * -gdk_pixbuf_format_get_name (GdkPixbufFormat *format) -{ - g_return_val_if_fail (format != NULL, NULL); - - return g_strdup (format->name); -} - -/** - * gdk_pixbuf_format_get_description: - * @format: a #GdkPixbufFormat - * - * Returns a description of the format. - * - * Return value: a description of the format. - * - * Since: 2.2 - */ -gchar * -gdk_pixbuf_format_get_description (GdkPixbufFormat *format) -{ - gchar *domain; - const gchar *description; - g_return_val_if_fail (format != NULL, NULL); - - if (format->domain != NULL) - domain = format->domain; - else - domain = GETTEXT_PACKAGE; - description = g_dgettext (domain, format->description); - - return g_strdup (description); -} - -/** - * gdk_pixbuf_format_get_mime_types: - * @format: a #GdkPixbufFormat - * - * Returns the mime types supported by the format. - * - * Return value: a %NULL-terminated array of mime types which must be freed with - * g_strfreev() when it is no longer needed. - * - * Since: 2.2 - */ -gchar ** -gdk_pixbuf_format_get_mime_types (GdkPixbufFormat *format) -{ - g_return_val_if_fail (format != NULL, NULL); - - return g_strdupv (format->mime_types); -} - -/** - * gdk_pixbuf_format_get_extensions: - * @format: a #GdkPixbufFormat - * - * Returns the filename extensions typically used for files in the - * given format. - * - * Return value: a %NULL-terminated array of filename extensions which must be - * freed with g_strfreev() when it is no longer needed. - * - * Since: 2.2 - */ -gchar ** -gdk_pixbuf_format_get_extensions (GdkPixbufFormat *format) -{ - g_return_val_if_fail (format != NULL, NULL); - - return g_strdupv (format->extensions); -} - -/** - * gdk_pixbuf_format_is_writable: - * @format: a #GdkPixbufFormat - * - * Returns whether pixbufs can be saved in the given format. - * - * Return value: whether pixbufs can be saved in the given format. - * - * Since: 2.2 - */ -gboolean -gdk_pixbuf_format_is_writable (GdkPixbufFormat *format) -{ - g_return_val_if_fail (format != NULL, FALSE); - - return (format->flags & GDK_PIXBUF_FORMAT_WRITABLE) != 0; -} - -/** - * gdk_pixbuf_format_is_scalable: - * @format: a #GdkPixbufFormat - * - * Returns whether this image format is scalable. If a file is in a - * scalable format, it is preferable to load it at the desired size, - * rather than loading it at the default size and scaling the - * resulting pixbuf to the desired size. - * - * Return value: whether this image format is scalable. - * - * Since: 2.6 - */ -gboolean -gdk_pixbuf_format_is_scalable (GdkPixbufFormat *format) -{ - g_return_val_if_fail (format != NULL, FALSE); - - return (format->flags & GDK_PIXBUF_FORMAT_SCALABLE) != 0; -} - -/** - * gdk_pixbuf_format_is_disabled: - * @format: a #GdkPixbufFormat - * - * Returns whether this image format is disabled. See - * gdk_pixbuf_format_set_disabled(). - * - * Return value: whether this image format is disabled. - * - * Since: 2.6 - */ -gboolean -gdk_pixbuf_format_is_disabled (GdkPixbufFormat *format) -{ - g_return_val_if_fail (format != NULL, FALSE); - - return format->disabled; -} - -/** - * gdk_pixbuf_format_set_disabled: - * @format: a #GdkPixbufFormat - * @disabled: %TRUE to disable the format @format - * - * Disables or enables an image format. If a format is disabled, - * gdk-pixbuf won't use the image loader for this format to load - * images. Applications can use this to avoid using image loaders - * with an inappropriate license, see gdk_pixbuf_format_get_license(). - * - * Since: 2.6 - */ -void -gdk_pixbuf_format_set_disabled (GdkPixbufFormat *format, - gboolean disabled) -{ - g_return_if_fail (format != NULL); - - format->disabled = disabled != FALSE; -} - -/** - * gdk_pixbuf_format_get_license: - * @format: a #GdkPixbufFormat - * - * Returns information about the license of the image loader for the format. The - * returned string should be a shorthand for a wellknown license, e.g. "LGPL", - * "GPL", "QPL", "GPL/QPL", or "other" to indicate some other license. This - * string should be freed with g_free() when it's no longer needed. - * - * Returns: a string describing the license of @format. - * - * Since: 2.6 - */ -gchar* -gdk_pixbuf_format_get_license (GdkPixbufFormat *format) -{ - g_return_val_if_fail (format != NULL, NULL); - - return g_strdup (format->license); -} - -GdkPixbufFormat * -_gdk_pixbuf_get_format (GdkPixbufModule *module) -{ - g_return_val_if_fail (module != NULL, NULL); - - return module->info; -} - -/** - * gdk_pixbuf_get_formats: - * - * Obtains the available information about the image formats supported - * by GdkPixbuf. - * - * Returns: A list of #GdkPixbufFormat<!-- -->s describing the supported - * image formats. The list should be freed when it is no longer needed, - * but the structures themselves are owned by #GdkPixbuf and should not be - * freed. - * - * Since: 2.2 - */ -GSList * -gdk_pixbuf_get_formats (void) -{ - GSList *result = NULL; - GSList *modules; - - for (modules = get_file_formats (); modules; modules = g_slist_next (modules)) { - GdkPixbufModule *module = (GdkPixbufModule *)modules->data; - GdkPixbufFormat *info = _gdk_pixbuf_get_format (module); - result = g_slist_prepend (result, info); - } - - return result; -} - - -#define __GDK_PIXBUF_IO_C__ -#include "gdk-pixbuf-aliasdef.c" diff --git a/gdk-pixbuf/gdk-pixbuf-io.h b/gdk-pixbuf/gdk-pixbuf-io.h deleted file mode 100644 index a6e07ca623..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-io.h +++ /dev/null @@ -1,172 +0,0 @@ -/* GdkPixbuf library - Io handling. This is an internal header for - * GdkPixbuf. You should never use it unless you are doing development for - * GdkPixbuf itself. - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * Jonathan Blandford <jrb@redhat.com> - * Michael Fulbright <drmike@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#if !defined (GDK_PIXBUF_H_INSIDE) && !defined (GDK_PIXBUF_COMPILATION) -#error "Only <gdk-pixbuf/gdk-pixbuf.h> can be included directly." -#endif - -#ifndef GDK_PIXBUF_IO_H -#define GDK_PIXBUF_IO_H - -#include <stdio.h> -#include <glib.h> -#include <gmodule.h> -#include <gdk-pixbuf/gdk-pixbuf-core.h> -#include <gdk-pixbuf/gdk-pixbuf-animation.h> - -G_BEGIN_DECLS - -typedef struct _GdkPixbufFormat GdkPixbufFormat; - -GSList *gdk_pixbuf_get_formats (void); -gchar *gdk_pixbuf_format_get_name (GdkPixbufFormat *format); -gchar *gdk_pixbuf_format_get_description (GdkPixbufFormat *format); -gchar **gdk_pixbuf_format_get_mime_types (GdkPixbufFormat *format); -gchar **gdk_pixbuf_format_get_extensions (GdkPixbufFormat *format); -gboolean gdk_pixbuf_format_is_writable (GdkPixbufFormat *format); -gboolean gdk_pixbuf_format_is_scalable (GdkPixbufFormat *format); -gboolean gdk_pixbuf_format_is_disabled (GdkPixbufFormat *format); -void gdk_pixbuf_format_set_disabled (GdkPixbufFormat *format, - gboolean disabled); -gchar *gdk_pixbuf_format_get_license (GdkPixbufFormat *format); - -GdkPixbufFormat *gdk_pixbuf_get_file_info (const gchar *filename, - gint *width, - gint *height); - -#ifdef GDK_PIXBUF_ENABLE_BACKEND - - - -typedef void (* GdkPixbufModuleSizeFunc) (gint *width, - gint *height, - gpointer user_data); - -typedef void (* GdkPixbufModulePreparedFunc) (GdkPixbuf *pixbuf, - GdkPixbufAnimation *anim, - gpointer user_data); -typedef void (* GdkPixbufModuleUpdatedFunc) (GdkPixbuf *pixbuf, - int x, - int y, - int width, - int height, - gpointer user_data); - -typedef struct _GdkPixbufModulePattern GdkPixbufModulePattern; -struct _GdkPixbufModulePattern { - char *prefix; - char *mask; - int relevance; -}; - -typedef struct _GdkPixbufModule GdkPixbufModule; -struct _GdkPixbufModule { - char *module_name; - char *module_path; - GModule *module; - GdkPixbufFormat *info; - - GdkPixbuf *(* load) (FILE *f, - GError **error); - GdkPixbuf *(* load_xpm_data) (const char **data); - - /* Incremental loading */ - - gpointer (* begin_load) (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepare_func, - GdkPixbufModuleUpdatedFunc update_func, - gpointer user_data, - GError **error); - gboolean (* stop_load) (gpointer context, - GError **error); - gboolean (* load_increment) (gpointer context, - const guchar *buf, - guint size, - GError **error); - - /* Animation loading */ - GdkPixbufAnimation *(* load_animation) (FILE *f, - GError **error); - - /* Saving */ - gboolean (* save) (FILE *f, - GdkPixbuf *pixbuf, - gchar **param_keys, - gchar **param_values, - GError **error); - - gboolean (*save_to_callback) (GdkPixbufSaveFunc save_func, - gpointer user_data, - GdkPixbuf *pixbuf, - gchar **option_keys, - gchar **option_values, - GError **error); - - /*< private >*/ - void (*_reserved1) (void); - void (*_reserved2) (void); - void (*_reserved3) (void); - void (*_reserved4) (void); - void (*_reserved5) (void); - -}; - -typedef void (* GdkPixbufModuleFillVtableFunc) (GdkPixbufModule *module); -typedef void (* GdkPixbufModuleFillInfoFunc) (GdkPixbufFormat *info); - -/* key/value pairs that can be attached by the pixbuf loader */ - -gboolean gdk_pixbuf_set_option (GdkPixbuf *pixbuf, - const gchar *key, - const gchar *value); - -typedef enum /*< skip >*/ -{ - GDK_PIXBUF_FORMAT_WRITABLE = 1 << 0, - GDK_PIXBUF_FORMAT_SCALABLE = 1 << 1, - GDK_PIXBUF_FORMAT_THREADSAFE = 1 << 2 -} GdkPixbufFormatFlags; - -struct _GdkPixbufFormat { - gchar *name; - GdkPixbufModulePattern *signature; - gchar *domain; - gchar *description; - gchar **mime_types; - gchar **extensions; - guint32 flags; - gboolean disabled; - gchar *license; -}; - - -#endif /* GDK_PIXBUF_ENABLE_BACKEND */ - -G_END_DECLS - -#endif /* GDK_PIXBUF_IO_H */ diff --git a/gdk-pixbuf/gdk-pixbuf-loader.c b/gdk-pixbuf/gdk-pixbuf-loader.c deleted file mode 100644 index 6b7b547971..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-loader.c +++ /dev/null @@ -1,789 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Progressive loader object - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * Jonathan Blandford <jrb@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <string.h> - -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-animation.h" -#include "gdk-pixbuf-scaled-anim.h" -#include "gdk-pixbuf-io.h" -#include "gdk-pixbuf-loader.h" -#include "gdk-pixbuf-marshal.h" -#include "gdk-pixbuf-alias.h" - -enum { - SIZE_PREPARED, - AREA_PREPARED, - AREA_UPDATED, - CLOSED, - LAST_SIGNAL -}; - - -static void gdk_pixbuf_loader_finalize (GObject *loader); - -static guint pixbuf_loader_signals[LAST_SIGNAL] = { 0 }; - -/* Internal data */ - -#define LOADER_HEADER_SIZE 1024 - -typedef struct -{ - GdkPixbufAnimation *animation; - gboolean closed; - gboolean holds_threadlock; - guchar header_buf[LOADER_HEADER_SIZE]; - gint header_buf_offset; - GdkPixbufModule *image_module; - gpointer context; - gint width; - gint height; - gboolean size_fixed; - gboolean needs_scale; -} GdkPixbufLoaderPrivate; - -G_DEFINE_TYPE (GdkPixbufLoader, gdk_pixbuf_loader, G_TYPE_OBJECT) - -static void -gdk_pixbuf_loader_class_init (GdkPixbufLoaderClass *class) -{ - GObjectClass *object_class; - - object_class = (GObjectClass *) class; - - object_class->finalize = gdk_pixbuf_loader_finalize; - - /** - * GdkPixbufLoader::size-prepared: - * @loader: the object which received the signal. - * @width: the original width of the image - * @height: the original height of the image - * - * This signal is emitted when the pixbuf loader has been fed the - * initial amount of data that is required to figure out the size - * of the image that it will create. Applications can call - * gdk_pixbuf_loader_set_size() in response to this signal to set - * the desired size to which the image should be scaled. - */ - pixbuf_loader_signals[SIZE_PREPARED] = - g_signal_new ("size-prepared", - G_TYPE_FROM_CLASS (object_class), - G_SIGNAL_RUN_LAST, - G_STRUCT_OFFSET (GdkPixbufLoaderClass, size_prepared), - NULL, NULL, - _gdk_pixbuf_marshal_VOID__INT_INT, - G_TYPE_NONE, 2, - G_TYPE_INT, - G_TYPE_INT); - - /** - * GdkPixbufLoader::area-prepared: - * @loader: the object which received the signal. - * - * This signal is emitted when the pixbuf loader has allocated the - * pixbuf in the desired size. After this signal is emitted, - * applications can call gdk_pixbuf_loader_get_pixbuf() to fetch - * the partially-loaded pixbuf. - */ - pixbuf_loader_signals[AREA_PREPARED] = - g_signal_new ("area-prepared", - G_TYPE_FROM_CLASS (object_class), - G_SIGNAL_RUN_LAST, - G_STRUCT_OFFSET (GdkPixbufLoaderClass, area_prepared), - NULL, NULL, - _gdk_pixbuf_marshal_VOID__VOID, - G_TYPE_NONE, 0); - - /** - * GdkPixbufLoader::area-updated: - * @loader: the object which received the signal. - * @x: X offset of upper-left corner of the updated area. - * @y: Y offset of upper-left corner of the updated area. - * @width: Width of updated area. - * @height: Height of updated area. - * - * This signal is emitted when a significant area of the image being - * loaded has been updated. Normally it means that a complete - * scanline has been read in, but it could be a different area as - * well. Applications can use this signal to know when to repaint - * areas of an image that is being loaded. - */ - pixbuf_loader_signals[AREA_UPDATED] = - g_signal_new ("area-updated", - G_TYPE_FROM_CLASS (object_class), - G_SIGNAL_RUN_LAST, - G_STRUCT_OFFSET (GdkPixbufLoaderClass, area_updated), - NULL, NULL, - _gdk_pixbuf_marshal_VOID__INT_INT_INT_INT, - G_TYPE_NONE, 4, - G_TYPE_INT, - G_TYPE_INT, - G_TYPE_INT, - G_TYPE_INT); - - /** - * GdkPixbufLoader::closed: - * @loader: the object which received the signal. - * - * This signal is emitted when gdk_pixbuf_loader_close() is called. - * It can be used by different parts of an application to receive - * notification when an image loader is closed by the code that - * drives it. - */ - pixbuf_loader_signals[CLOSED] = - g_signal_new ("closed", - G_TYPE_FROM_CLASS (object_class), - G_SIGNAL_RUN_LAST, - G_STRUCT_OFFSET (GdkPixbufLoaderClass, closed), - NULL, NULL, - _gdk_pixbuf_marshal_VOID__VOID, - G_TYPE_NONE, 0); -} - -static void -gdk_pixbuf_loader_init (GdkPixbufLoader *loader) -{ - GdkPixbufLoaderPrivate *priv; - - priv = g_new0 (GdkPixbufLoaderPrivate, 1); - priv->width = -1; - priv->height = -1; - - loader->priv = priv; -} - -static void -gdk_pixbuf_loader_finalize (GObject *object) -{ - GdkPixbufLoader *loader; - GdkPixbufLoaderPrivate *priv = NULL; - - loader = GDK_PIXBUF_LOADER (object); - priv = loader->priv; - - if (!priv->closed) { - g_warning ("GdkPixbufLoader finalized without calling gdk_pixbuf_loader_close() - this is not allowed. You must explicitly end the data stream to the loader before dropping the last reference."); - if (priv->holds_threadlock) { - _gdk_pixbuf_unlock (priv->image_module); - } - } - if (priv->animation) - g_object_unref (priv->animation); - - g_free (priv); - - G_OBJECT_CLASS (gdk_pixbuf_loader_parent_class)->finalize (object); -} - -/** - * gdk_pixbuf_loader_set_size: - * @loader: A pixbuf loader. - * @width: The desired width of the image being loaded. - * @height: The desired height of the image being loaded. - * - * Causes the image to be scaled while it is loaded. The desired - * image size can be determined relative to the original size of - * the image by calling gdk_pixbuf_loader_set_size() from a - * signal handler for the ::size-prepared signal. - * - * Attempts to set the desired image size are ignored after the - * emission of the ::size-prepared signal. - * - * Since: 2.2 - */ -void -gdk_pixbuf_loader_set_size (GdkPixbufLoader *loader, - gint width, - gint height) -{ - GdkPixbufLoaderPrivate *priv; - - g_return_if_fail (GDK_IS_PIXBUF_LOADER (loader)); - g_return_if_fail (width >= 0 && height >= 0); - - priv = GDK_PIXBUF_LOADER (loader)->priv; - - if (!priv->size_fixed) - { - priv->width = width; - priv->height = height; - } -} - -static void -gdk_pixbuf_loader_size_func (gint *width, gint *height, gpointer loader) -{ - GdkPixbufLoaderPrivate *priv = GDK_PIXBUF_LOADER (loader)->priv; - - /* allow calling gdk_pixbuf_loader_set_size() before the signal */ - if (priv->width == -1 && priv->height == -1) - { - priv->width = *width; - priv->height = *height; - } - - g_signal_emit (loader, pixbuf_loader_signals[SIZE_PREPARED], 0, *width, *height); - priv->size_fixed = TRUE; - - *width = priv->width; - *height = priv->height; -} - -static void -gdk_pixbuf_loader_prepare (GdkPixbuf *pixbuf, - GdkPixbufAnimation *anim, - gpointer loader) -{ - GdkPixbufLoaderPrivate *priv = GDK_PIXBUF_LOADER (loader)->priv; - g_return_if_fail (pixbuf != NULL); - - if (!priv->size_fixed) - { - /* Defend against lazy loaders which don't call size_func */ - gint width = gdk_pixbuf_get_width (pixbuf); - gint height = gdk_pixbuf_get_height (pixbuf); - - gdk_pixbuf_loader_size_func (&width, &height, loader); - } - - priv->needs_scale = FALSE; - if (priv->width > 0 && priv->height > 0 && - (priv->width != gdk_pixbuf_get_width (pixbuf) || - priv->height != gdk_pixbuf_get_height (pixbuf))) - priv->needs_scale = TRUE; - - if (anim) - g_object_ref (anim); - else - anim = gdk_pixbuf_non_anim_new (pixbuf); - - if (priv->needs_scale) { - priv->animation = GDK_PIXBUF_ANIMATION (_gdk_pixbuf_scaled_anim_new (anim, - (double) priv->width / gdk_pixbuf_get_width (pixbuf), - (double) priv->height / gdk_pixbuf_get_height (pixbuf), - 1.0)); - g_object_unref (anim); - } - else - priv->animation = anim; - - if (!priv->needs_scale) - g_signal_emit (loader, pixbuf_loader_signals[AREA_PREPARED], 0); -} - -static void -gdk_pixbuf_loader_update (GdkPixbuf *pixbuf, - gint x, - gint y, - gint width, - gint height, - gpointer loader) -{ - GdkPixbufLoaderPrivate *priv = GDK_PIXBUF_LOADER (loader)->priv; - - if (!priv->needs_scale) - g_signal_emit (loader, - pixbuf_loader_signals[AREA_UPDATED], - 0, - x, y, - /* sanity check in here. Defend against an errant loader */ - MIN (width, gdk_pixbuf_animation_get_width (priv->animation)), - MIN (height, gdk_pixbuf_animation_get_height (priv->animation))); -} - -/* Defense against broken loaders; DO NOT take this as a GError example! */ -static void -gdk_pixbuf_loader_ensure_error (GdkPixbufLoader *loader, - GError **error) -{ - GdkPixbufLoaderPrivate *priv = loader->priv; - - if (error == NULL || *error != NULL) - return; - - g_warning ("Bug! loader '%s' didn't set an error on failure", - priv->image_module->module_name); - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Internal error: Image loader module '%s' failed to" - " complete an operation, but didn't give a reason for" - " the failure"), - priv->image_module->module_name); -} - -static gint -gdk_pixbuf_loader_load_module (GdkPixbufLoader *loader, - const char *image_type, - GError **error) -{ - GdkPixbufLoaderPrivate *priv = loader->priv; - - if (image_type) - { - priv->image_module = _gdk_pixbuf_get_named_module (image_type, - error); - } - else - { - priv->image_module = _gdk_pixbuf_get_module (priv->header_buf, - priv->header_buf_offset, - NULL, - error); - } - - if (priv->image_module == NULL) - return 0; - - if (!_gdk_pixbuf_load_module (priv->image_module, error)) - return 0; - - if (priv->image_module->module == NULL) - return 0; - - if ((priv->image_module->begin_load == NULL) || - (priv->image_module->stop_load == NULL) || - (priv->image_module->load_increment == NULL)) - { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNSUPPORTED_OPERATION, - _("Incremental loading of image type '%s' is not supported"), - priv->image_module->module_name); - - return 0; - } - - if (!priv->holds_threadlock) { - priv->holds_threadlock = _gdk_pixbuf_lock (priv->image_module); - } - - priv->context = priv->image_module->begin_load (gdk_pixbuf_loader_size_func, - gdk_pixbuf_loader_prepare, - gdk_pixbuf_loader_update, - loader, - error); - - if (priv->context == NULL) - { - gdk_pixbuf_loader_ensure_error (loader, error); - return 0; - } - - if (priv->header_buf_offset - && priv->image_module->load_increment (priv->context, priv->header_buf, priv->header_buf_offset, error)) - return priv->header_buf_offset; - - return 0; -} - -static int -gdk_pixbuf_loader_eat_header_write (GdkPixbufLoader *loader, - const guchar *buf, - gsize count, - GError **error) -{ - gint n_bytes; - GdkPixbufLoaderPrivate *priv = loader->priv; - - n_bytes = MIN(LOADER_HEADER_SIZE - priv->header_buf_offset, count); - memcpy (priv->header_buf + priv->header_buf_offset, buf, n_bytes); - - priv->header_buf_offset += n_bytes; - - if (priv->header_buf_offset >= LOADER_HEADER_SIZE) - { - if (gdk_pixbuf_loader_load_module (loader, NULL, error) == 0) - return 0; - } - - return n_bytes; -} - -/** - * gdk_pixbuf_loader_write: - * @loader: A pixbuf loader. - * @buf: Pointer to image data. - * @count: Length of the @buf buffer in bytes. - * @error: return location for errors - * - * This will cause a pixbuf loader to parse the next @count bytes of - * an image. It will return %TRUE if the data was loaded successfully, - * and %FALSE if an error occurred. In the latter case, the loader - * will be closed, and will not accept further writes. If %FALSE is - * returned, @error will be set to an error from the #GDK_PIXBUF_ERROR - * or #G_FILE_ERROR domains. - * - * Return value: %TRUE if the write was successful, or %FALSE if the loader - * cannot parse the buffer. - **/ -gboolean -gdk_pixbuf_loader_write (GdkPixbufLoader *loader, - const guchar *buf, - gsize count, - GError **error) -{ - GdkPixbufLoaderPrivate *priv; - - g_return_val_if_fail (GDK_IS_PIXBUF_LOADER (loader), FALSE); - - g_return_val_if_fail (buf != NULL, FALSE); - g_return_val_if_fail (error == NULL || *error == NULL, FALSE); - - priv = loader->priv; - - /* we expect it's not to be closed */ - g_return_val_if_fail (priv->closed == FALSE, FALSE); - - if (count > 0 && priv->image_module == NULL) - { - gint eaten; - - eaten = gdk_pixbuf_loader_eat_header_write (loader, buf, count, error); - if (eaten <= 0) - goto fail; - - count -= eaten; - buf += eaten; - } - - if (count > 0 && priv->image_module->load_increment) - { - if (!priv->image_module->load_increment (priv->context, buf, count, - error)) - goto fail; - } - - return TRUE; - - fail: - gdk_pixbuf_loader_ensure_error (loader, error); - gdk_pixbuf_loader_close (loader, NULL); - - return FALSE; -} - -/** - * gdk_pixbuf_loader_new: - * - * Creates a new pixbuf loader object. - * - * Return value: A newly-created pixbuf loader. - **/ -GdkPixbufLoader * -gdk_pixbuf_loader_new (void) -{ - return g_object_new (GDK_TYPE_PIXBUF_LOADER, NULL); -} - -/** - * gdk_pixbuf_loader_new_with_type: - * @image_type: name of the image format to be loaded with the image - * @error: (allow-none): return location for an allocated #GError, or %NULL to ignore errors - * - * Creates a new pixbuf loader object that always attempts to parse - * image data as if it were an image of type @image_type, instead of - * identifying the type automatically. Useful if you want an error if - * the image isn't the expected type, for loading image formats - * that can't be reliably identified by looking at the data, or if - * the user manually forces a specific type. - * - * The list of supported image formats depends on what image loaders - * are installed, but typically "png", "jpeg", "gif", "tiff" and - * "xpm" are among the supported formats. To obtain the full list of - * supported image formats, call gdk_pixbuf_format_get_name() on each - * of the #GdkPixbufFormat structs returned by gdk_pixbuf_get_formats(). - * - * Return value: A newly-created pixbuf loader. - **/ -GdkPixbufLoader * -gdk_pixbuf_loader_new_with_type (const char *image_type, - GError **error) -{ - GdkPixbufLoader *retval; - GError *tmp; - g_return_val_if_fail (error == NULL || *error == NULL, NULL); - - retval = g_object_new (GDK_TYPE_PIXBUF_LOADER, NULL); - - tmp = NULL; - gdk_pixbuf_loader_load_module (retval, image_type, &tmp); - if (tmp != NULL) - { - g_propagate_error (error, tmp); - gdk_pixbuf_loader_close (retval, NULL); - g_object_unref (retval); - return NULL; - } - - return retval; -} - -/** - * gdk_pixbuf_loader_new_with_mime_type: - * @mime_type: the mime type to be loaded - * @error: (allow-none): return location for an allocated #GError, or %NULL to ignore errors - * - * Creates a new pixbuf loader object that always attempts to parse - * image data as if it were an image of mime type @mime_type, instead of - * identifying the type automatically. Useful if you want an error if - * the image isn't the expected mime type, for loading image formats - * that can't be reliably identified by looking at the data, or if - * the user manually forces a specific mime type. - * - * The list of supported mime types depends on what image loaders - * are installed, but typically "image/png", "image/jpeg", "image/gif", - * "image/tiff" and "image/x-xpixmap" are among the supported mime types. - * To obtain the full list of supported mime types, call - * gdk_pixbuf_format_get_mime_types() on each of the #GdkPixbufFormat - * structs returned by gdk_pixbuf_get_formats(). - * - * Return value: A newly-created pixbuf loader. - * Since: 2.4 - **/ -GdkPixbufLoader * -gdk_pixbuf_loader_new_with_mime_type (const char *mime_type, - GError **error) -{ - const char * image_type = NULL; - char ** mimes; - - GdkPixbufLoader *retval; - GError *tmp; - - GSList * formats; - GdkPixbufFormat *info; - int i, j, length; - - formats = gdk_pixbuf_get_formats (); - length = g_slist_length (formats); - - for (i = 0; i < length && image_type == NULL; i++) { - info = (GdkPixbufFormat *)g_slist_nth_data (formats, i); - mimes = info->mime_types; - - for (j = 0; mimes[j] != NULL; j++) - if (g_ascii_strcasecmp (mimes[j], mime_type) == 0) { - image_type = info->name; - break; - } - } - - g_slist_free (formats); - - retval = g_object_new (GDK_TYPE_PIXBUF_LOADER, NULL); - - tmp = NULL; - gdk_pixbuf_loader_load_module (retval, image_type, &tmp); - if (tmp != NULL) - { - g_propagate_error (error, tmp); - gdk_pixbuf_loader_close (retval, NULL); - g_object_unref (retval); - return NULL; - } - - return retval; -} - -/** - * gdk_pixbuf_loader_get_pixbuf: - * @loader: A pixbuf loader. - * - * Queries the #GdkPixbuf that a pixbuf loader is currently creating. - * In general it only makes sense to call this function after the - * "area-prepared" signal has been emitted by the loader; this means - * that enough data has been read to know the size of the image that - * will be allocated. If the loader has not received enough data via - * gdk_pixbuf_loader_write(), then this function returns %NULL. The - * returned pixbuf will be the same in all future calls to the loader, - * so simply calling g_object_ref() should be sufficient to continue - * using it. Additionally, if the loader is an animation, it will - * return the "static image" of the animation - * (see gdk_pixbuf_animation_get_static_image()). - * - * Return value: The #GdkPixbuf that the loader is creating, or %NULL if not - * enough data has been read to determine how to create the image buffer. - **/ -GdkPixbuf * -gdk_pixbuf_loader_get_pixbuf (GdkPixbufLoader *loader) -{ - GdkPixbufLoaderPrivate *priv; - - g_return_val_if_fail (GDK_IS_PIXBUF_LOADER (loader), NULL); - - priv = loader->priv; - - if (priv->animation) - return gdk_pixbuf_animation_get_static_image (priv->animation); - else - return NULL; -} - -/** - * gdk_pixbuf_loader_get_animation: - * @loader: A pixbuf loader - * - * Queries the #GdkPixbufAnimation that a pixbuf loader is currently creating. - * In general it only makes sense to call this function after the "area-prepared" - * signal has been emitted by the loader. If the loader doesn't have enough - * bytes yet (hasn't emitted the "area-prepared" signal) this function will - * return %NULL. - * - * Return value: The #GdkPixbufAnimation that the loader is loading, or %NULL if - not enough data has been read to determine the information. -**/ -GdkPixbufAnimation * -gdk_pixbuf_loader_get_animation (GdkPixbufLoader *loader) -{ - GdkPixbufLoaderPrivate *priv; - - g_return_val_if_fail (GDK_IS_PIXBUF_LOADER (loader), NULL); - - priv = loader->priv; - - return priv->animation; -} - -/** - * gdk_pixbuf_loader_close: - * @loader: A pixbuf loader. - * @error: (allow-none): return location for a #GError, or %NULL to ignore errors - * - * Informs a pixbuf loader that no further writes with - * gdk_pixbuf_loader_write() will occur, so that it can free its - * internal loading structures. Also, tries to parse any data that - * hasn't yet been parsed; if the remaining data is partial or - * corrupt, an error will be returned. If %FALSE is returned, @error - * will be set to an error from the #GDK_PIXBUF_ERROR or #G_FILE_ERROR - * domains. If you're just cancelling a load rather than expecting it - * to be finished, passing %NULL for @error to ignore it is - * reasonable. - * - * Returns: %TRUE if all image data written so far was successfully - passed out via the update_area signal - **/ -gboolean -gdk_pixbuf_loader_close (GdkPixbufLoader *loader, - GError **error) -{ - GdkPixbufLoaderPrivate *priv; - gboolean retval = TRUE; - - g_return_val_if_fail (GDK_IS_PIXBUF_LOADER (loader), TRUE); - g_return_val_if_fail (error == NULL || *error == NULL, TRUE); - - priv = loader->priv; - - if (priv->closed) - return TRUE; - - /* We have less the LOADER_HEADER_SIZE bytes in the image. - * Flush it, and keep going. - */ - if (priv->image_module == NULL) - { - GError *tmp = NULL; - gdk_pixbuf_loader_load_module (loader, NULL, &tmp); - if (tmp != NULL) - { - g_propagate_error (error, tmp); - retval = FALSE; - } - } - - if (priv->image_module && priv->image_module->stop_load && priv->context) - { - GError *tmp = NULL; - if (!priv->image_module->stop_load (priv->context, &tmp) || tmp) - { - /* don't call gdk_pixbuf_loader_ensure_error() - * here, since we might not get an error in the - * gdk_pixbuf_get_file_info() case - */ - if (tmp) { - if (error && *error == NULL) - g_propagate_error (error, tmp); - else - g_error_free (tmp); - } - retval = FALSE; - } - } - - priv->closed = TRUE; - if (priv->image_module && priv->holds_threadlock) { - _gdk_pixbuf_unlock (priv->image_module); - priv->holds_threadlock = FALSE; - } - - if (priv->needs_scale) - { - - g_signal_emit (loader, pixbuf_loader_signals[AREA_PREPARED], 0); - g_signal_emit (loader, pixbuf_loader_signals[AREA_UPDATED], 0, - 0, 0, priv->width, priv->height); - } - - - g_signal_emit (loader, pixbuf_loader_signals[CLOSED], 0); - - return retval; -} - -/** - * gdk_pixbuf_loader_get_format: - * @loader: A pixbuf loader. - * - * Obtains the available information about the format of the - * currently loading image file. - * - * Returns: A #GdkPixbufFormat or %NULL. The return value is owned - * by GdkPixbuf and should not be freed. - * - * Since: 2.2 - */ -GdkPixbufFormat * -gdk_pixbuf_loader_get_format (GdkPixbufLoader *loader) -{ - GdkPixbufLoaderPrivate *priv; - - g_return_val_if_fail (GDK_IS_PIXBUF_LOADER (loader), NULL); - - priv = loader->priv; - - if (priv->image_module) - return _gdk_pixbuf_get_format (priv->image_module); - else - return NULL; -} - - -#define __GDK_PIXBUF_LOADER_C__ -#include "gdk-pixbuf-aliasdef.c" - diff --git a/gdk-pixbuf/gdk-pixbuf-loader.h b/gdk-pixbuf/gdk-pixbuf-loader.h deleted file mode 100644 index de4c53763b..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-loader.h +++ /dev/null @@ -1,102 +0,0 @@ -/* GdkPixbuf library - Progressive loader object - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * Jonathan Blandford <jrb@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#if !defined (GDK_PIXBUF_H_INSIDE) && !defined (GDK_PIXBUF_COMPILATION) -#error "Only <gdk-pixbuf/gdk-pixbuf.h> can be included directly." -#endif - -#ifndef GDK_PIXBUF_LOADER_H -#define GDK_PIXBUF_LOADER_H - -#include <glib.h> -#include <glib-object.h> -#include <gdk-pixbuf/gdk-pixbuf-core.h> -#include <gdk-pixbuf/gdk-pixbuf-animation.h> -#include <gdk-pixbuf/gdk-pixbuf-io.h> - -G_BEGIN_DECLS - -#define GDK_TYPE_PIXBUF_LOADER (gdk_pixbuf_loader_get_type ()) -#define GDK_PIXBUF_LOADER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GDK_TYPE_PIXBUF_LOADER, GdkPixbufLoader)) -#define GDK_PIXBUF_LOADER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_LOADER, GdkPixbufLoaderClass)) -#define GDK_IS_PIXBUF_LOADER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GDK_TYPE_PIXBUF_LOADER)) -#define GDK_IS_PIXBUF_LOADER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_LOADER)) -#define GDK_PIXBUF_LOADER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_LOADER, GdkPixbufLoaderClass)) - - -typedef struct _GdkPixbufLoader GdkPixbufLoader; -struct _GdkPixbufLoader -{ - GObject parent_instance; - - /*< private >*/ - gpointer priv; -}; - -typedef struct _GdkPixbufLoaderClass GdkPixbufLoaderClass; -struct _GdkPixbufLoaderClass -{ - GObjectClass parent_class; - - void (*size_prepared) (GdkPixbufLoader *loader, - int width, - int height); - - void (*area_prepared) (GdkPixbufLoader *loader); - - /* Last known frame needs a redraw for x, y, width, height */ - void (*area_updated) (GdkPixbufLoader *loader, - int x, - int y, - int width, - int height); - - void (*closed) (GdkPixbufLoader *loader); -}; - -GType gdk_pixbuf_loader_get_type (void) G_GNUC_CONST; -GdkPixbufLoader * gdk_pixbuf_loader_new (void); -GdkPixbufLoader * gdk_pixbuf_loader_new_with_type (const char *image_type, - GError **error); -GdkPixbufLoader * gdk_pixbuf_loader_new_with_mime_type (const char *mime_type, - GError **error); -void gdk_pixbuf_loader_set_size (GdkPixbufLoader *loader, - int width, - int height); -gboolean gdk_pixbuf_loader_write (GdkPixbufLoader *loader, - const guchar *buf, - gsize count, - GError **error); -GdkPixbuf * gdk_pixbuf_loader_get_pixbuf (GdkPixbufLoader *loader); -GdkPixbufAnimation * gdk_pixbuf_loader_get_animation (GdkPixbufLoader *loader); -gboolean gdk_pixbuf_loader_close (GdkPixbufLoader *loader, - GError **error); -GdkPixbufFormat *gdk_pixbuf_loader_get_format (GdkPixbufLoader *loader); - -G_END_DECLS - -#endif - - diff --git a/gdk-pixbuf/gdk-pixbuf-marshal.list b/gdk-pixbuf/gdk-pixbuf-marshal.list deleted file mode 100644 index a43f7ce69c..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-marshal.list +++ /dev/null @@ -1,28 +0,0 @@ -# see glib-genmarshal(1) for a detailed description of the file format, -# possible parameter types are: -# VOID indicates no return type, or no extra -# parameters. if VOID is used as the parameter -# list, no additional parameters may be present. -# BOOLEAN for boolean types (gboolean) -# CHAR for signed char types (gchar) -# UCHAR for unsigned char types (guchar) -# INT for signed integer types (gint) -# UINT for unsigned integer types (guint) -# LONG for signed long integer types (glong) -# ULONG for unsigned long integer types (gulong) -# ENUM for enumeration types (gint) -# FLAGS for flag enumeration types (guint) -# FLOAT for single-precision float types (gfloat) -# DOUBLE for double-precision float types (gdouble) -# STRING for string types (gchar*) -# PARAM for GParamSpec or derived types (GParamSpec*) -# BOXED for boxed (anonymous but reference counted) types (GBoxed*) -# POINTER for anonymous pointer types (gpointer) -# OBJECT for GObject or derived types (GObject*) -# NONE deprecated alias for VOID -# BOOL deprecated alias for BOOLEAN - -VOID:VOID -VOID:INT,INT -VOID:INT,INT,INT,INT -VOID:POINTER diff --git a/gdk-pixbuf/gdk-pixbuf-private.h b/gdk-pixbuf/gdk-pixbuf-private.h deleted file mode 100644 index c0220d36e5..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-private.h +++ /dev/null @@ -1,102 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Private declarations - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#ifndef GDK_PIXBUF_PRIVATE_H -#define GDK_PIXBUF_PRIVATE_H - -#include "gdk-pixbuf.h" -#include "gdk-pixbuf-i18n.h" -#include <stdio.h> - - - -typedef struct _GdkPixbufClass GdkPixbufClass; - -#define GDK_PIXBUF_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF, GdkPixbufClass)) -#define GDK_IS_PIXBUF_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF)) -#define GDK_PIXBUF_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF, GdkPixbufClass)) - -/* Private part of the GdkPixbuf structure */ -struct _GdkPixbuf { - GObject parent_instance; - - /* Color space */ - GdkColorspace colorspace; - - /* Number of channels, alpha included */ - int n_channels; - - /* Bits per channel */ - int bits_per_sample; - - /* Size */ - int width, height; - - /* Offset between rows */ - int rowstride; - - /* The pixel array */ - guchar *pixels; - - /* Destroy notification function; it is supposed to free the pixel array */ - GdkPixbufDestroyNotify destroy_fn; - - /* User data for the destroy notification function */ - gpointer destroy_fn_data; - - /* Do we have an alpha channel? */ - guint has_alpha : 1; -}; - -struct _GdkPixbufClass { - GObjectClass parent_class; - -}; - -#ifdef GDK_PIXBUF_ENABLE_BACKEND - -gboolean _gdk_pixbuf_lock (GdkPixbufModule *image_module); -void _gdk_pixbuf_unlock (GdkPixbufModule *image_module); - -GdkPixbufModule *_gdk_pixbuf_get_module (guchar *buffer, guint size, - const gchar *filename, - GError **error); -GdkPixbufModule *_gdk_pixbuf_get_named_module (const char *name, - GError **error); -gboolean _gdk_pixbuf_load_module (GdkPixbufModule *image_module, - GError **error); - -GdkPixbuf *_gdk_pixbuf_generic_image_load (GdkPixbufModule *image_module, - FILE *f, - GError **error); - -GdkPixbufFormat *_gdk_pixbuf_get_format (GdkPixbufModule *image_module); - -#endif /* GDK_PIXBUF_ENABLE_BACKEND */ - -#endif /* GDK_PIXBUF_PRIVATE_H */ - - diff --git a/gdk-pixbuf/gdk-pixbuf-scale.c b/gdk-pixbuf/gdk-pixbuf-scale.c deleted file mode 100644 index 694a8cb6ec..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-scale.c +++ /dev/null @@ -1,463 +0,0 @@ -/* GdkPixbuf library - Scaling and compositing functions - * - * Copyright (C) 1999 The Free Software Foundation - * - * Author: Owen Taylor <otaylor@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <math.h> -#include <string.h> -#include "gdk-pixbuf-private.h" -#include "pixops/pixops.h" -#include "gdk-pixbuf-alias.h" - - - -/** - * gdk_pixbuf_scale: - * @src: a #GdkPixbuf - * @dest: the #GdkPixbuf into which to render the results - * @dest_x: the left coordinate for region to render - * @dest_y: the top coordinate for region to render - * @dest_width: the width of the region to render - * @dest_height: the height of the region to render - * @offset_x: the offset in the X direction (currently rounded to an integer) - * @offset_y: the offset in the Y direction (currently rounded to an integer) - * @scale_x: the scale factor in the X direction - * @scale_y: the scale factor in the Y direction - * @interp_type: the interpolation type for the transformation. - * - * Creates a transformation of the source image @src by scaling by - * @scale_x and @scale_y then translating by @offset_x and @offset_y, - * then renders the rectangle (@dest_x, @dest_y, @dest_width, - * @dest_height) of the resulting image onto the destination image - * replacing the previous contents. - * - * Try to use gdk_pixbuf_scale_simple() first, this function is - * the industrial-strength power tool you can fall back to if - * gdk_pixbuf_scale_simple() isn't powerful enough. - * - * If the source rectangle overlaps the destination rectangle on the - * same pixbuf, it will be overwritten during the scaling which - * results in rendering artifacts. - **/ -void -gdk_pixbuf_scale (const GdkPixbuf *src, - GdkPixbuf *dest, - int dest_x, - int dest_y, - int dest_width, - int dest_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - GdkInterpType interp_type) -{ - g_return_if_fail (GDK_IS_PIXBUF (src)); - g_return_if_fail (GDK_IS_PIXBUF (dest)); - g_return_if_fail (dest_x >= 0 && dest_x + dest_width <= dest->width); - g_return_if_fail (dest_y >= 0 && dest_y + dest_height <= dest->height); - - offset_x = floor (offset_x + 0.5); - offset_y = floor (offset_y + 0.5); - - _pixops_scale (dest->pixels, dest->width, dest->height, dest->rowstride, - dest->n_channels, dest->has_alpha, src->pixels, src->width, - src->height, src->rowstride, src->n_channels, src->has_alpha, - dest_x, dest_y, dest_width, dest_height, offset_x, offset_y, - scale_x, scale_y, (PixopsInterpType)interp_type); -} - -/** - * gdk_pixbuf_composite: - * @src: a #GdkPixbuf - * @dest: the #GdkPixbuf into which to render the results - * @dest_x: the left coordinate for region to render - * @dest_y: the top coordinate for region to render - * @dest_width: the width of the region to render - * @dest_height: the height of the region to render - * @offset_x: the offset in the X direction (currently rounded to an integer) - * @offset_y: the offset in the Y direction (currently rounded to an integer) - * @scale_x: the scale factor in the X direction - * @scale_y: the scale factor in the Y direction - * @interp_type: the interpolation type for the transformation. - * @overall_alpha: overall alpha for source image (0..255) - * - * Creates a transformation of the source image @src by scaling by - * @scale_x and @scale_y then translating by @offset_x and @offset_y. - * This gives an image in the coordinates of the destination pixbuf. - * The rectangle (@dest_x, @dest_y, @dest_width, @dest_height) - * is then composited onto the corresponding rectangle of the - * original destination image. - * - * When the destination rectangle contains parts not in the source - * image, the data at the edges of the source image is replicated - * to infinity. - * - * <figure id="pixbuf-composite-diagram"> - * <title>Compositing of pixbufs</title> - * <graphic fileref="composite.png" format="PNG"/> - * </figure> - **/ -void -gdk_pixbuf_composite (const GdkPixbuf *src, - GdkPixbuf *dest, - int dest_x, - int dest_y, - int dest_width, - int dest_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - GdkInterpType interp_type, - int overall_alpha) -{ - g_return_if_fail (GDK_IS_PIXBUF (src)); - g_return_if_fail (GDK_IS_PIXBUF (dest)); - g_return_if_fail (dest_x >= 0 && dest_x + dest_width <= dest->width); - g_return_if_fail (dest_y >= 0 && dest_y + dest_height <= dest->height); - g_return_if_fail (overall_alpha >= 0 && overall_alpha <= 255); - - offset_x = floor (offset_x + 0.5); - offset_y = floor (offset_y + 0.5); - - _pixops_composite (dest->pixels, dest->width, dest->height, dest->rowstride, - dest->n_channels, dest->has_alpha, src->pixels, - src->width, src->height, src->rowstride, src->n_channels, - src->has_alpha, dest_x, dest_y, dest_width, dest_height, - offset_x, offset_y, scale_x, scale_y, - (PixopsInterpType)interp_type, overall_alpha); -} - -/** - * gdk_pixbuf_composite_color: - * @src: a #GdkPixbuf - * @dest: the #GdkPixbuf into which to render the results - * @dest_x: the left coordinate for region to render - * @dest_y: the top coordinate for region to render - * @dest_width: the width of the region to render - * @dest_height: the height of the region to render - * @offset_x: the offset in the X direction (currently rounded to an integer) - * @offset_y: the offset in the Y direction (currently rounded to an integer) - * @scale_x: the scale factor in the X direction - * @scale_y: the scale factor in the Y direction - * @interp_type: the interpolation type for the transformation. - * @overall_alpha: overall alpha for source image (0..255) - * @check_x: the X offset for the checkboard (origin of checkboard is at -@check_x, -@check_y) - * @check_y: the Y offset for the checkboard - * @check_size: the size of checks in the checkboard (must be a power of two) - * @color1: the color of check at upper left - * @color2: the color of the other check - * - * Creates a transformation of the source image @src by scaling by - * @scale_x and @scale_y then translating by @offset_x and @offset_y, - * then composites the rectangle (@dest_x ,@dest_y, @dest_width, - * @dest_height) of the resulting image with a checkboard of the - * colors @color1 and @color2 and renders it onto the destination - * image. - * - * See gdk_pixbuf_composite_color_simple() for a simpler variant of this - * function suitable for many tasks. - * - **/ -void -gdk_pixbuf_composite_color (const GdkPixbuf *src, - GdkPixbuf *dest, - int dest_x, - int dest_y, - int dest_width, - int dest_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - GdkInterpType interp_type, - int overall_alpha, - int check_x, - int check_y, - int check_size, - guint32 color1, - guint32 color2) -{ - g_return_if_fail (GDK_IS_PIXBUF (src)); - g_return_if_fail (GDK_IS_PIXBUF (dest)); - g_return_if_fail (dest_x >= 0 && dest_x + dest_width <= dest->width); - g_return_if_fail (dest_y >= 0 && dest_y + dest_height <= dest->height); - g_return_if_fail (overall_alpha >= 0 && overall_alpha <= 255); - - offset_x = floor (offset_x + 0.5); - offset_y = floor (offset_y + 0.5); - - _pixops_composite_color (dest->pixels, dest_width, dest_height, - dest->rowstride, dest->n_channels, dest->has_alpha, - src->pixels, src->width, src->height, - src->rowstride, src->n_channels, src->has_alpha, - dest_x, dest_y, dest_width, dest_height, offset_x, - offset_y, scale_x, scale_y, - (PixopsInterpType)interp_type, overall_alpha, - check_x, check_y, check_size, color1, color2); -} - -/** - * gdk_pixbuf_scale_simple: - * @src: a #GdkPixbuf - * @dest_width: the width of destination image - * @dest_height: the height of destination image - * @interp_type: the interpolation type for the transformation. - * - * Create a new #GdkPixbuf containing a copy of @src scaled to - * @dest_width x @dest_height. Leaves @src unaffected. @interp_type - * should be #GDK_INTERP_NEAREST if you want maximum speed (but when - * scaling down #GDK_INTERP_NEAREST is usually unusably ugly). The - * default @interp_type should be #GDK_INTERP_BILINEAR which offers - * reasonable quality and speed. - * - * You can scale a sub-portion of @src by creating a sub-pixbuf - * pointing into @src; see gdk_pixbuf_new_subpixbuf(). - * - * For more complicated scaling/compositing see gdk_pixbuf_scale() - * and gdk_pixbuf_composite(). - * - * Return value: the new #GdkPixbuf, or %NULL if not enough memory could be - * allocated for it. - **/ -GdkPixbuf * -gdk_pixbuf_scale_simple (const GdkPixbuf *src, - int dest_width, - int dest_height, - GdkInterpType interp_type) -{ - GdkPixbuf *dest; - - g_return_val_if_fail (GDK_IS_PIXBUF (src), NULL); - g_return_val_if_fail (dest_width > 0, NULL); - g_return_val_if_fail (dest_height > 0, NULL); - - dest = gdk_pixbuf_new (GDK_COLORSPACE_RGB, src->has_alpha, 8, dest_width, dest_height); - if (!dest) - return NULL; - - gdk_pixbuf_scale (src, dest, 0, 0, dest_width, dest_height, 0, 0, - (double) dest_width / src->width, - (double) dest_height / src->height, - interp_type); - - return dest; -} - -/** - * gdk_pixbuf_composite_color_simple: - * @src: a #GdkPixbuf - * @dest_width: the width of destination image - * @dest_height: the height of destination image - * @interp_type: the interpolation type for the transformation. - * @overall_alpha: overall alpha for source image (0..255) - * @check_size: the size of checks in the checkboard (must be a power of two) - * @color1: the color of check at upper left - * @color2: the color of the other check - * - * Creates a new #GdkPixbuf by scaling @src to @dest_width x - * @dest_height and compositing the result with a checkboard of colors - * @color1 and @color2. - * - * Return value: the new #GdkPixbuf, or %NULL if not enough memory could be - * allocated for it. - **/ -GdkPixbuf * -gdk_pixbuf_composite_color_simple (const GdkPixbuf *src, - int dest_width, - int dest_height, - GdkInterpType interp_type, - int overall_alpha, - int check_size, - guint32 color1, - guint32 color2) -{ - GdkPixbuf *dest; - - g_return_val_if_fail (GDK_IS_PIXBUF (src), NULL); - g_return_val_if_fail (dest_width > 0, NULL); - g_return_val_if_fail (dest_height > 0, NULL); - g_return_val_if_fail (overall_alpha >= 0 && overall_alpha <= 255, NULL); - - dest = gdk_pixbuf_new (GDK_COLORSPACE_RGB, src->has_alpha, 8, dest_width, dest_height); - if (!dest) - return NULL; - - gdk_pixbuf_composite_color (src, dest, 0, 0, dest_width, dest_height, 0, 0, - (double) dest_width / src->width, - (double) dest_height / src->height, - interp_type, overall_alpha, 0, 0, check_size, color1, color2); - - return dest; -} - -#define OFFSET(pb, x, y) ((x) * (pb)->n_channels + (y) * (pb)->rowstride) - -/** - * gdk_pixbuf_rotate_simple: - * @src: a #GdkPixbuf - * @angle: the angle to rotate by - * - * Rotates a pixbuf by a multiple of 90 degrees, and returns the - * result in a new pixbuf. - * - * Returns: the new #GdkPixbuf, or %NULL if not enough memory could be - * allocated for it. - * - * Since: 2.6 - */ -GdkPixbuf * -gdk_pixbuf_rotate_simple (const GdkPixbuf *src, - GdkPixbufRotation angle) -{ - GdkPixbuf *dest; - guchar *p, *q; - gint x, y; - - switch (angle % 360) - { - case 0: - dest = gdk_pixbuf_copy (src); - break; - case 90: - dest = gdk_pixbuf_new (src->colorspace, - src->has_alpha, - src->bits_per_sample, - src->height, - src->width); - if (!dest) - return NULL; - - for (y = 0; y < src->height; y++) - { - for (x = 0; x < src->width; x++) - { - p = src->pixels + OFFSET (src, x, y); - q = dest->pixels + OFFSET (dest, y, src->width - x - 1); - memcpy (q, p, dest->n_channels); - } - } - break; - case 180: - dest = gdk_pixbuf_new (src->colorspace, - src->has_alpha, - src->bits_per_sample, - src->width, - src->height); - if (!dest) - return NULL; - - for (y = 0; y < src->height; y++) - { - for (x = 0; x < src->width; x++) - { - p = src->pixels + OFFSET (src, x, y); - q = dest->pixels + OFFSET (dest, src->width - x - 1, src->height - y - 1); - memcpy (q, p, dest->n_channels); - } - } - break; - case 270: - dest = gdk_pixbuf_new (src->colorspace, - src->has_alpha, - src->bits_per_sample, - src->height, - src->width); - if (!dest) - return NULL; - - for (y = 0; y < src->height; y++) - { - for (x = 0; x < src->width; x++) - { - p = src->pixels + OFFSET (src, x, y); - q = dest->pixels + OFFSET (dest, src->height - y - 1, x); - memcpy (q, p, dest->n_channels); - } - } - break; - default: - dest = NULL; - g_warning ("gdk_pixbuf_rotate_simple() can only rotate " - "by multiples of 90 degrees"); - g_assert_not_reached (); - } - - return dest; -} - -/** - * gdk_pixbuf_flip: - * @src: a #GdkPixbuf - * @horizontal: %TRUE to flip horizontally, %FALSE to flip vertically - * - * Flips a pixbuf horizontally or vertically and returns the - * result in a new pixbuf. - * - * Returns: the new #GdkPixbuf, or %NULL if not enough memory could be - * allocated for it. - * - * Since: 2.6 - */ -GdkPixbuf * -gdk_pixbuf_flip (const GdkPixbuf *src, - gboolean horizontal) -{ - GdkPixbuf *dest; - guchar *p, *q; - gint x, y; - - dest = gdk_pixbuf_new (src->colorspace, - src->has_alpha, - src->bits_per_sample, - src->width, - src->height); - if (!dest) - return NULL; - - if (!horizontal) /* flip vertical */ - { - for (y = 0; y < dest->height; y++) - { - p = src->pixels + OFFSET (src, 0, y); - q = dest->pixels + OFFSET (dest, 0, dest->height - y - 1); - memcpy (q, p, dest->rowstride); - } - } - else /* flip horizontal */ - { - for (y = 0; y < dest->height; y++) - { - for (x = 0; x < dest->width; x++) - { - p = src->pixels + OFFSET (src, x, y); - q = dest->pixels + OFFSET (dest, dest->width - x - 1, y); - memcpy (q, p, dest->n_channels); - } - } - } - - return dest; -} - -#define __GDK_PIXBUF_SCALE_C__ -#include "gdk-pixbuf-aliasdef.c" diff --git a/gdk-pixbuf/gdk-pixbuf-scaled-anim.c b/gdk-pixbuf/gdk-pixbuf-scaled-anim.c deleted file mode 100644 index 06d1cc087d..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-scaled-anim.c +++ /dev/null @@ -1,286 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Simple transformations of animations - * - * Copyright (C) Red Hat, Inc - * - * Authors: Matthias Clasen <mclasen@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - * - */ - -#include <glib.h> - -#include "gdk-pixbuf.h" -#include "gdk-pixbuf-io.h" -#include "gdk-pixbuf-scaled-anim.h" -#include "gdk-pixbuf-alias.h" - - -struct _GdkPixbufScaledAnimClass -{ - GdkPixbufAnimationClass parent_class; -}; - -struct _GdkPixbufScaledAnim -{ - GdkPixbufAnimation parent_instance; - - GdkPixbufAnimation *anim; - gdouble xscale; - gdouble yscale; - gdouble tscale; - - GdkPixbuf *current; -}; - -struct _GdkPixbufScaledAnimIterClass -{ - GdkPixbufAnimationClass parent_class; -}; - -struct _GdkPixbufScaledAnimIter -{ - GdkPixbufAnimationIter parent_instance; - - GdkPixbufScaledAnim *scaled; - GdkPixbufAnimationIter *iter; -}; - -typedef struct _GdkPixbufScaledAnimIter GdkPixbufScaledAnimIter; -typedef struct _GdkPixbufScaledAnimIterClass GdkPixbufScaledAnimIterClass; - -GdkPixbufScaledAnim * -_gdk_pixbuf_scaled_anim_new (GdkPixbufAnimation *anim, - gdouble xscale, - gdouble yscale, - gdouble tscale) -{ - GdkPixbufScaledAnim *scaled; - - scaled = g_object_new (GDK_TYPE_PIXBUF_SCALED_ANIM, NULL); - - scaled->anim = g_object_ref (anim); - scaled->xscale = xscale; - scaled->yscale = yscale; - scaled->tscale = tscale; - - return scaled; -} - -G_DEFINE_TYPE (GdkPixbufScaledAnim, gdk_pixbuf_scaled_anim, GDK_TYPE_PIXBUF_ANIMATION); - -static void -gdk_pixbuf_scaled_anim_init (GdkPixbufScaledAnim *scaled) -{ - scaled->xscale = 1.0; - scaled->yscale = 1.0; - scaled->tscale = 1.0; -} - -static void -gdk_pixbuf_scaled_anim_finalize (GObject *object) -{ - GdkPixbufScaledAnim *scaled = (GdkPixbufScaledAnim *)object; - - if (scaled->anim) { - g_object_unref (scaled->anim); - scaled->anim = NULL; - } - - if (scaled->current) { - g_object_unref (scaled->current); - scaled->current = NULL; - } - - G_OBJECT_CLASS (gdk_pixbuf_scaled_anim_parent_class)->finalize (object); -} - -static gboolean -is_static_image (GdkPixbufAnimation *anim) -{ - GdkPixbufScaledAnim *scaled = (GdkPixbufScaledAnim *)anim; - - return gdk_pixbuf_animation_is_static_image (scaled->anim); -} - -static GdkPixbuf * -get_scaled_pixbuf (GdkPixbufScaledAnim *scaled, - GdkPixbuf *pixbuf) -{ - GQuark quark; - gchar **options; - - if (scaled->current) - g_object_unref (scaled->current); - - /* Preserve the options associated with the original pixbuf - (if present), mostly so that client programs can use the - "orientation" option (if present) to rotate the image - appropriately. gdk_pixbuf_scale_simple (and most other - gdk transform operations) does not preserve the attached - options when returning a new pixbuf. */ - - quark = g_quark_from_static_string ("gdk_pixbuf_options"); - options = g_object_get_qdata (G_OBJECT (pixbuf), quark); - - /* Get a new scaled pixbuf */ - scaled->current = gdk_pixbuf_scale_simple (pixbuf, - (int) (gdk_pixbuf_get_width (pixbuf) * scaled->xscale + .5), - (int) (gdk_pixbuf_get_height (pixbuf) * scaled->yscale + .5), - GDK_INTERP_BILINEAR); - - /* Copy the original pixbuf options to the scaled pixbuf */ - if (options && scaled->current) - g_object_set_qdata_full (G_OBJECT (scaled->current), quark, - g_strdupv (options), (GDestroyNotify) g_strfreev); - - return scaled->current; -} - -static GdkPixbuf * -get_static_image (GdkPixbufAnimation *anim) -{ - GdkPixbufScaledAnim *scaled = (GdkPixbufScaledAnim *)anim; - GdkPixbuf *pixbuf; - - pixbuf = gdk_pixbuf_animation_get_static_image (scaled->anim); - return get_scaled_pixbuf (scaled, pixbuf); -} - -static void -get_size (GdkPixbufAnimation *anim, - int *width, - int *height) -{ - GdkPixbufScaledAnim *scaled = (GdkPixbufScaledAnim *)anim; - - GDK_PIXBUF_ANIMATION_GET_CLASS (scaled->anim)->get_size (scaled->anim, width, height); - if (width) - *width = (int)(*width * scaled->xscale + .5); - if (height) - *height = (int)(*height * scaled->yscale + .5); -} - -static GdkPixbufAnimationIter * -get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time) -{ - GdkPixbufScaledAnim *scaled = (GdkPixbufScaledAnim *)anim; - GdkPixbufScaledAnimIter *iter; - - iter = g_object_new (GDK_TYPE_PIXBUF_SCALED_ANIM_ITER, NULL); - - iter->scaled = g_object_ref (scaled); - iter->iter = gdk_pixbuf_animation_get_iter (scaled->anim, start_time); - - return (GdkPixbufAnimationIter*)iter; -} - -static void -gdk_pixbuf_scaled_anim_class_init (GdkPixbufScaledAnimClass *klass) -{ - GObjectClass *object_class; - GdkPixbufAnimationClass *anim_class; - - object_class = G_OBJECT_CLASS (klass); - anim_class = GDK_PIXBUF_ANIMATION_CLASS (klass); - - object_class->finalize = gdk_pixbuf_scaled_anim_finalize; - - anim_class->is_static_image = is_static_image; - anim_class->get_static_image = get_static_image; - anim_class->get_size = get_size; - anim_class->get_iter = get_iter; -} - - -G_DEFINE_TYPE (GdkPixbufScaledAnimIter, gdk_pixbuf_scaled_anim_iter, GDK_TYPE_PIXBUF_ANIMATION_ITER); - -static void -gdk_pixbuf_scaled_anim_iter_init (GdkPixbufScaledAnimIter *iter) -{ -} - -static int -get_delay_time (GdkPixbufAnimationIter *iter) -{ - GdkPixbufScaledAnimIter *scaled = (GdkPixbufScaledAnimIter *)iter; - int delay; - - delay = gdk_pixbuf_animation_iter_get_delay_time (scaled->iter); - delay = (int)(delay * scaled->scaled->tscale); - - return delay; -} - -static GdkPixbuf * -get_pixbuf (GdkPixbufAnimationIter *iter) -{ - GdkPixbufScaledAnimIter *scaled = (GdkPixbufScaledAnimIter *)iter; - GdkPixbuf *pixbuf; - - pixbuf = gdk_pixbuf_animation_iter_get_pixbuf (scaled->iter); - return get_scaled_pixbuf (scaled->scaled, pixbuf); -} - -static gboolean -on_currently_loading_frame (GdkPixbufAnimationIter *iter) -{ - GdkPixbufScaledAnimIter *scaled = (GdkPixbufScaledAnimIter *)iter; - - return gdk_pixbuf_animation_iter_on_currently_loading_frame (scaled->iter); -} - -static gboolean -advance (GdkPixbufAnimationIter *iter, - const GTimeVal *current_time) -{ - GdkPixbufScaledAnimIter *scaled = (GdkPixbufScaledAnimIter *)iter; - - return gdk_pixbuf_animation_iter_advance (scaled->iter, current_time); -} - -static void -gdk_pixbuf_scaled_anim_iter_finalize (GObject *object) -{ - GdkPixbufScaledAnimIter *iter = (GdkPixbufScaledAnimIter *)object; - - g_object_unref (iter->iter); - g_object_unref (iter->scaled); - - G_OBJECT_CLASS (gdk_pixbuf_scaled_anim_iter_parent_class)->finalize (object); -} - -static void -gdk_pixbuf_scaled_anim_iter_class_init (GdkPixbufScaledAnimIterClass *klass) -{ - GObjectClass *object_class; - GdkPixbufAnimationIterClass *anim_iter_class; - - object_class = G_OBJECT_CLASS (klass); - anim_iter_class = GDK_PIXBUF_ANIMATION_ITER_CLASS (klass); - - object_class->finalize = gdk_pixbuf_scaled_anim_iter_finalize; - - anim_iter_class->get_delay_time = get_delay_time; - anim_iter_class->get_pixbuf = get_pixbuf; - anim_iter_class->on_currently_loading_frame = on_currently_loading_frame; - anim_iter_class->advance = advance; -} - -#define __GDK_PIXBUF_SCALED_ANIM_C__ -#include "gdk-pixbuf-aliasdef.c" diff --git a/gdk-pixbuf/gdk-pixbuf-scaled-anim.h b/gdk-pixbuf/gdk-pixbuf-scaled-anim.h deleted file mode 100644 index 58c38c5cba..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-scaled-anim.h +++ /dev/null @@ -1,47 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Simple transformations of animations - * - * Copyright (C) 2007 Red Hat, Inc - * - * Authors: Matthias Clasen <mclasen@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#ifndef GDK_PIXBUF_SCALED_ANIM_H -#define GDK_PIXBUF_SCALED_ANIM_H - -#include <gdk-pixbuf/gdk-pixbuf-animation.h> - -G_BEGIN_DECLS - -#define GDK_TYPE_PIXBUF_SCALED_ANIM (gdk_pixbuf_scaled_anim_get_type ()) -#define GDK_TYPE_PIXBUF_SCALED_ANIM_ITER (gdk_pixbuf_scaled_anim_iter_get_type ()) - -typedef struct _GdkPixbufScaledAnim GdkPixbufScaledAnim; -typedef struct _GdkPixbufScaledAnimClass GdkPixbufScaledAnimClass; - -GType gdk_pixbuf_scaled_anim_get_type (void) G_GNUC_CONST; -GType gdk_pixbuf_scaled_anim_iter_get_type (void) G_GNUC_CONST; - -GdkPixbufScaledAnim *_gdk_pixbuf_scaled_anim_new (GdkPixbufAnimation *anim, - gdouble xscale, - gdouble yscale, - gdouble tscale); - -G_END_DECLS - -#endif /* GDK_PIXBUF_SCALED_ANIM_H */ diff --git a/gdk-pixbuf/gdk-pixbuf-simple-anim.c b/gdk-pixbuf/gdk-pixbuf-simple-anim.c deleted file mode 100644 index 24d7ba48dd..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-simple-anim.c +++ /dev/null @@ -1,553 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Simple frame-based animations - * - * Copyright (C) Dom Lachowicz - * - * Authors: Dom Lachowicz <cinamod@hotmail.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - * - * Based on code originally by: - * Jonathan Blandford <jrb@redhat.com> - * Havoc Pennington <hp@redhat.com> - */ - -#include "config.h" -#include <glib.h> - -#define GDK_PIXBUF_C_COMPILATION -#include "gdk-pixbuf.h" -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" -#include "gdk-pixbuf-simple-anim.h" -#include "gdk-pixbuf-alias.h" - -struct _GdkPixbufSimpleAnimClass -{ - GdkPixbufAnimationClass parent_class; -}; - -/* Private part of the GdkPixbufSimpleAnim structure */ -struct _GdkPixbufSimpleAnim -{ - GdkPixbufAnimation parent_instance; - - gint n_frames; - - gfloat rate; - gint total_time; - - GList *frames; - - gint width; - gint height; - - gboolean loop; -}; - - -typedef struct _GdkPixbufSimpleAnimIter GdkPixbufSimpleAnimIter; -typedef struct _GdkPixbufSimpleAnimIterClass GdkPixbufSimpleAnimIterClass; - -#define GDK_TYPE_PIXBUF_SIMPLE_ANIM_ITER (gdk_pixbuf_simple_anim_iter_get_type ()) -#define GDK_PIXBUF_SIMPLE_ANIM_ITER(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_SIMPLE_ANIM_ITER, GdkPixbufSimpleAnimIter)) -#define GDK_IS_PIXBUF_SIMPLE_ANIM_ITER(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_SIMPLE_ANIM_ITER)) - -#define GDK_PIXBUF_SIMPLE_ANIM_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_SIMPLE_ANIM_ITER, GdkPixbufSimpleAnimIterClass)) -#define GDK_IS_PIXBUF_SIMPLE_ANIM_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_SIMPLE_ANIM_ITER)) -#define GDK_PIXBUF_SIMPLE_ANIM_ITER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_SIMPLE_ANIM_ITER, GdkPixbufSimpleAnimIterClass)) - -GType gdk_pixbuf_simple_anim_iter_get_type (void) G_GNUC_CONST; - - -struct _GdkPixbufSimpleAnimIterClass -{ - GdkPixbufAnimationIterClass parent_class; -}; - -struct _GdkPixbufSimpleAnimIter -{ - GdkPixbufAnimationIter parent_instance; - - GdkPixbufSimpleAnim *simple_anim; - - GTimeVal start_time; - GTimeVal current_time; - - gint position; - - GList *current_frame; -}; - -typedef struct _GdkPixbufFrame GdkPixbufFrame; -struct _GdkPixbufFrame -{ - GdkPixbuf *pixbuf; - gint delay_time; - gint elapsed; -}; - -static void gdk_pixbuf_simple_anim_finalize (GObject *object); - -static gboolean is_static_image (GdkPixbufAnimation *animation); -static GdkPixbuf *get_static_image (GdkPixbufAnimation *animation); - -static void get_size (GdkPixbufAnimation *anim, - gint *width, - gint *height); -static GdkPixbufAnimationIter *get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time); - - -static void gdk_pixbuf_simple_anim_set_property (GObject *object, - guint prop_id, - const GValue *value, - GParamSpec *pspec); -static void gdk_pixbuf_simple_anim_get_property (GObject *object, - guint prop_id, - GValue *value, - GParamSpec *pspec); - -enum -{ - PROP_0, - PROP_LOOP -}; - -G_DEFINE_TYPE (GdkPixbufSimpleAnim, gdk_pixbuf_simple_anim, GDK_TYPE_PIXBUF_ANIMATION) - -static void -gdk_pixbuf_simple_anim_init (GdkPixbufSimpleAnim *anim) -{ -} - -static void -gdk_pixbuf_simple_anim_class_init (GdkPixbufSimpleAnimClass *klass) -{ - GObjectClass *object_class; - GdkPixbufAnimationClass *anim_class; - - object_class = G_OBJECT_CLASS (klass); - anim_class = GDK_PIXBUF_ANIMATION_CLASS (klass); - - object_class->set_property = gdk_pixbuf_simple_anim_set_property; - object_class->get_property = gdk_pixbuf_simple_anim_get_property; - object_class->finalize = gdk_pixbuf_simple_anim_finalize; - - anim_class->is_static_image = is_static_image; - anim_class->get_static_image = get_static_image; - anim_class->get_size = get_size; - anim_class->get_iter = get_iter; - - /** - * GdkPixbufSimpleAnim:loop: - * - * Whether the animation should loop when it reaches the end. - * - * Since: 2.18 - */ - g_object_class_install_property (object_class, - PROP_LOOP, - g_param_spec_boolean ("loop", - P_("Loop"), - P_("Whether the animation should loop when it reaches the end"), - FALSE, - G_PARAM_READWRITE)); -} - -static void -gdk_pixbuf_simple_anim_finalize (GObject *object) -{ - GdkPixbufSimpleAnim *anim; - GList *l; - GdkPixbufFrame *frame; - - anim = GDK_PIXBUF_SIMPLE_ANIM (object); - - for (l = anim->frames; l; l = l->next) { - frame = l->data; - g_object_unref (frame->pixbuf); - g_free (frame); - } - - g_list_free (anim->frames); - - G_OBJECT_CLASS (gdk_pixbuf_simple_anim_parent_class)->finalize (object); -} - -static gboolean -is_static_image (GdkPixbufAnimation *animation) -{ - GdkPixbufSimpleAnim *anim; - - anim = GDK_PIXBUF_SIMPLE_ANIM (animation); - - return (anim->frames != NULL && anim->frames->next == NULL); -} - -static GdkPixbuf * -get_static_image (GdkPixbufAnimation *animation) -{ - GdkPixbufSimpleAnim *anim; - - anim = GDK_PIXBUF_SIMPLE_ANIM (animation); - - if (anim->frames == NULL) - return NULL; - else - return ((GdkPixbufFrame *)anim->frames->data)->pixbuf; -} - -static void -get_size (GdkPixbufAnimation *animation, - gint *width, - gint *height) -{ - GdkPixbufSimpleAnim *anim; - - anim = GDK_PIXBUF_SIMPLE_ANIM (animation); - - if (width) - *width = anim->width; - - if (height) - *height = anim->height; -} - -static void -iter_clear (GdkPixbufSimpleAnimIter *iter) -{ - iter->current_frame = NULL; -} - -static void -iter_restart (GdkPixbufSimpleAnimIter *iter) -{ - iter_clear (iter); - - iter->current_frame = iter->simple_anim->frames; -} - -static GdkPixbufAnimationIter * -get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time) -{ - GdkPixbufSimpleAnimIter *iter; - - iter = g_object_new (GDK_TYPE_PIXBUF_SIMPLE_ANIM_ITER, NULL); - - iter->simple_anim = GDK_PIXBUF_SIMPLE_ANIM (anim); - - g_object_ref (iter->simple_anim); - - iter_restart (iter); - - iter->start_time = *start_time; - iter->current_time = *start_time; - - return GDK_PIXBUF_ANIMATION_ITER (iter); -} - -static void gdk_pixbuf_simple_anim_iter_finalize (GObject *object); - -static gint get_delay_time (GdkPixbufAnimationIter *iter); -static GdkPixbuf *get_pixbuf (GdkPixbufAnimationIter *iter); -static gboolean on_currently_loading_frame (GdkPixbufAnimationIter *iter); -static gboolean advance (GdkPixbufAnimationIter *iter, - const GTimeVal *current_time); - -G_DEFINE_TYPE (GdkPixbufSimpleAnimIter, gdk_pixbuf_simple_anim_iter, GDK_TYPE_PIXBUF_ANIMATION_ITER) - -static void -gdk_pixbuf_simple_anim_iter_init (GdkPixbufSimpleAnimIter *iter) -{ -} - -static void -gdk_pixbuf_simple_anim_iter_class_init (GdkPixbufSimpleAnimIterClass *klass) -{ - GObjectClass *object_class; - GdkPixbufAnimationIterClass *anim_iter_class; - - object_class = G_OBJECT_CLASS (klass); - anim_iter_class = GDK_PIXBUF_ANIMATION_ITER_CLASS (klass); - - object_class->finalize = gdk_pixbuf_simple_anim_iter_finalize; - - anim_iter_class->get_delay_time = get_delay_time; - anim_iter_class->get_pixbuf = get_pixbuf; - anim_iter_class->on_currently_loading_frame = on_currently_loading_frame; - anim_iter_class->advance = advance; -} - -static void -gdk_pixbuf_simple_anim_iter_finalize (GObject *object) -{ - GdkPixbufSimpleAnimIter *iter; - - iter = GDK_PIXBUF_SIMPLE_ANIM_ITER (object); - iter_clear (iter); - - g_object_unref (iter->simple_anim); - - G_OBJECT_CLASS (gdk_pixbuf_simple_anim_iter_parent_class)->finalize (object); -} - -static gboolean -advance (GdkPixbufAnimationIter *anim_iter, - const GTimeVal *current_time) -{ - GdkPixbufSimpleAnimIter *iter; - gint elapsed; - gint loop_count; - GList *tmp; - GList *old; - - iter = GDK_PIXBUF_SIMPLE_ANIM_ITER (anim_iter); - - iter->current_time = *current_time; - - /* We use milliseconds for all times */ - elapsed = (((iter->current_time.tv_sec - iter->start_time.tv_sec) * G_USEC_PER_SEC + - iter->current_time.tv_usec - iter->start_time.tv_usec)) / 1000; - - if (elapsed < 0) { - /* Try to compensate; probably the system clock - * was set backwards - */ - iter->start_time = iter->current_time; - elapsed = 0; - } - - g_assert (iter->simple_anim->total_time > 0); - - /* See how many times we've already played the full animation, - * and subtract time for that. - */ - loop_count = elapsed / iter->simple_anim->total_time; - elapsed = elapsed % iter->simple_anim->total_time; - - iter->position = elapsed; - - /* Now move to the proper frame */ - if (loop_count < 1 || iter->simple_anim->loop) - tmp = iter->simple_anim->frames; - else - tmp = NULL; - - while (tmp != NULL) { - GdkPixbufFrame *frame = tmp->data; - - if (iter->position >= frame->elapsed && - iter->position < (frame->elapsed + frame->delay_time)) - break; - - tmp = tmp->next; - } - - old = iter->current_frame; - - iter->current_frame = tmp; - - return iter->current_frame != old; -} - -static gint -get_delay_time (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufFrame *frame; - GdkPixbufSimpleAnimIter *iter; - - iter = GDK_PIXBUF_SIMPLE_ANIM_ITER (anim_iter); - - if (iter->current_frame) { - frame = iter->current_frame->data; - return frame->delay_time - (iter->position - frame->elapsed); - } - else { - return -1; /* show last frame forever */ - } -} - -static GdkPixbuf * -get_pixbuf (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufSimpleAnimIter *iter; - GdkPixbufFrame *frame; - - iter = GDK_PIXBUF_SIMPLE_ANIM_ITER (anim_iter); - - if (iter->current_frame) - frame = iter->current_frame->data; - else if (g_list_length (iter->simple_anim->frames) > 0) - frame = g_list_last (iter->simple_anim->frames)->data; - else - frame = NULL; - - if (frame == NULL) - return NULL; - - return frame->pixbuf; -} - -static gboolean -on_currently_loading_frame (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufSimpleAnimIter *iter; - - iter = GDK_PIXBUF_SIMPLE_ANIM_ITER (anim_iter); - - return iter->current_frame == NULL || iter->current_frame->next == NULL; -} - -/** - * gdk_pixbuf_simple_anim_new: - * @width: the width of the animation - * @height: the height of the animation - * @rate: the speed of the animation, in frames per second - * - * Creates a new, empty animation. - * - * Returns: a newly allocated #GdkPixbufSimpleAnim - * - * Since: 2.8 - */ -GdkPixbufSimpleAnim * -gdk_pixbuf_simple_anim_new (gint width, - gint height, - gfloat rate) -{ - GdkPixbufSimpleAnim *anim; - - anim = g_object_new (GDK_TYPE_PIXBUF_SIMPLE_ANIM, NULL); - anim->width = width; - anim->height = height; - anim->rate = rate; - - return anim; -} - -/** - * gdk_pixbuf_simple_anim_add_frame: - * @animation: a #GdkPixbufSimpleAnim - * @pixbuf: the pixbuf to add - * - * Adds a new frame to @animation. The @pixbuf must - * have the dimensions specified when the animation - * was constructed. - * - * Since: 2.8 - */ -void -gdk_pixbuf_simple_anim_add_frame (GdkPixbufSimpleAnim *animation, - GdkPixbuf *pixbuf) -{ - GdkPixbufFrame *frame; - int nframe = 0; - - g_return_if_fail (GDK_IS_PIXBUF_SIMPLE_ANIM (animation)); - g_return_if_fail (GDK_IS_PIXBUF (pixbuf)); - - nframe = g_list_length (animation->frames); - - frame = g_new0 (GdkPixbufFrame, 1); - frame->delay_time = (gint) (1000 / animation->rate); - frame->elapsed = (gint) (frame->delay_time * nframe); - animation->total_time += frame->delay_time; - frame->pixbuf = g_object_ref (pixbuf); - - animation->frames = g_list_append (animation->frames, frame); -} - -static void -gdk_pixbuf_simple_anim_get_property (GObject *object, - guint prop_id, - GValue *value, - GParamSpec *pspec) -{ - GdkPixbufSimpleAnim *animation = GDK_PIXBUF_SIMPLE_ANIM (object); - - switch (prop_id) { - case PROP_LOOP: - g_value_set_boolean (value, - gdk_pixbuf_simple_anim_get_loop (animation)); - break; - default: - G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); - break; - } -} - -static void -gdk_pixbuf_simple_anim_set_property (GObject *object, - guint prop_id, - const GValue *value, - GParamSpec *pspec) -{ - GdkPixbufSimpleAnim *animation = GDK_PIXBUF_SIMPLE_ANIM (object); - - switch (prop_id) { - case PROP_LOOP: - gdk_pixbuf_simple_anim_set_loop (animation, - g_value_get_boolean (value)); - break; - default: - G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); - break; - } -} - -/** - * gdk_pixbuf_simple_anim_set_loop: - * @animation: a #GdkPixbufSimpleAnim - * @loop: whether to loop the animation - * - * Sets whether @animation should loop indefinitely when it reaches the end. - * - * Since: 2.18 - **/ -void -gdk_pixbuf_simple_anim_set_loop (GdkPixbufSimpleAnim *animation, - gboolean loop) -{ - g_return_if_fail (GDK_IS_PIXBUF_SIMPLE_ANIM (animation)); - - if (loop != animation->loop) { - animation->loop = loop; - g_object_notify (G_OBJECT (animation), "loop"); - } -} - -/** - * gdk_pixbuf_simple_anim_get_loop: - * @animation: a #GdkPixbufSimpleAnim - * - * Gets whether @animation should loop indefinitely when it reaches the end. - * - * Returns: %TRUE if the animation loops forever, %FALSE otherwise - * - * Since: 2.18 - **/ -gboolean -gdk_pixbuf_simple_anim_get_loop (GdkPixbufSimpleAnim *animation) -{ - g_return_val_if_fail (GDK_IS_PIXBUF_SIMPLE_ANIM (animation), FALSE); - - return animation->loop; -} - -#define __GDK_PIXBUF_SIMPLE_ANIM_C__ -#include "gdk-pixbuf-aliasdef.c" diff --git a/gdk-pixbuf/gdk-pixbuf-simple-anim.h b/gdk-pixbuf/gdk-pixbuf-simple-anim.h deleted file mode 100644 index fe364bec5e..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-simple-anim.h +++ /dev/null @@ -1,61 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Simple frame-based animations - * - * Copyright (C) 2004 Dom Lachowicz - * - * Authors: Dom Lachowicz <cinamod@hotmail.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#if !defined (GDK_PIXBUF_H_INSIDE) && !defined (GDK_PIXBUF_COMPILATION) -#error "Only <gdk-pixbuf/gdk-pixbuf.h> can be included directly." -#endif - -#ifndef GDK_PIXBUF_SIMPLE_ANIM_H -#define GDK_PIXBUF_SIMPLE_ANIM_H - -#include <gdk-pixbuf/gdk-pixbuf-animation.h> - -G_BEGIN_DECLS - -typedef struct _GdkPixbufSimpleAnim GdkPixbufSimpleAnim; -typedef struct _GdkPixbufSimpleAnimClass GdkPixbufSimpleAnimClass; - -#define GDK_TYPE_PIXBUF_SIMPLE_ANIM (gdk_pixbuf_simple_anim_get_type ()) -#define GDK_PIXBUF_SIMPLE_ANIM(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_SIMPLE_ANIM, GdkPixbufSimpleAnim)) -#define GDK_IS_PIXBUF_SIMPLE_ANIM(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_SIMPLE_ANIM)) - -#define GDK_PIXBUF_SIMPLE_ANIM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_SIMPLE_ANIM, GdkPixbufSimpleAnimClass)) -#define GDK_IS_PIXBUF_SIMPLE_ANIM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_SIMPLE_ANIM)) -#define GDK_PIXBUF_SIMPLE_ANIM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_SIMPLE_ANIM, GdkPixbufSimpleAnimClass)) - -GType gdk_pixbuf_simple_anim_get_type (void) G_GNUC_CONST; -GType gdk_pixbuf_simple_anim_iter_get_type (void) G_GNUC_CONST; - -GdkPixbufSimpleAnim *gdk_pixbuf_simple_anim_new (gint width, - gint height, - gfloat rate); -void gdk_pixbuf_simple_anim_add_frame (GdkPixbufSimpleAnim *animation, - GdkPixbuf *pixbuf); -void gdk_pixbuf_simple_anim_set_loop (GdkPixbufSimpleAnim *animation, - gboolean loop); -gboolean gdk_pixbuf_simple_anim_get_loop (GdkPixbufSimpleAnim *animation); - -G_END_DECLS - - -#endif /* GDK_PIXBUF_SIMPLE_ANIM_H */ diff --git a/gdk-pixbuf/gdk-pixbuf-transform.h b/gdk-pixbuf/gdk-pixbuf-transform.h deleted file mode 100644 index 57ced64d08..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-transform.h +++ /dev/null @@ -1,119 +0,0 @@ -/* GdkPixbuf library - transformations - * - * Copyright (C) 2003 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#if !defined (GDK_PIXBUF_H_INSIDE) && !defined (GDK_PIXBUF_COMPILATION) -#error "Only <gdk-pixbuf/gdk-pixbuf.h> can be included directly." -#endif - -#ifndef GDK_PIXBUF_TRANSFORM_H -#define GDK_PIXBUF_TRANSFORM_H - -#include <glib.h> -#include <gdk-pixbuf/gdk-pixbuf-core.h> - - -G_BEGIN_DECLS - -/* Scaling */ - -/* Interpolation modes */ -typedef enum { - GDK_INTERP_NEAREST, - GDK_INTERP_TILES, - GDK_INTERP_BILINEAR, - GDK_INTERP_HYPER -} GdkInterpType; - -typedef enum { - GDK_PIXBUF_ROTATE_NONE = 0, - GDK_PIXBUF_ROTATE_COUNTERCLOCKWISE = 90, - GDK_PIXBUF_ROTATE_UPSIDEDOWN = 180, - GDK_PIXBUF_ROTATE_CLOCKWISE = 270 -} GdkPixbufRotation; - -void gdk_pixbuf_scale (const GdkPixbuf *src, - GdkPixbuf *dest, - int dest_x, - int dest_y, - int dest_width, - int dest_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - GdkInterpType interp_type); -void gdk_pixbuf_composite (const GdkPixbuf *src, - GdkPixbuf *dest, - int dest_x, - int dest_y, - int dest_width, - int dest_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - GdkInterpType interp_type, - int overall_alpha); -void gdk_pixbuf_composite_color (const GdkPixbuf *src, - GdkPixbuf *dest, - int dest_x, - int dest_y, - int dest_width, - int dest_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - GdkInterpType interp_type, - int overall_alpha, - int check_x, - int check_y, - int check_size, - guint32 color1, - guint32 color2); - -GdkPixbuf *gdk_pixbuf_scale_simple (const GdkPixbuf *src, - int dest_width, - int dest_height, - GdkInterpType interp_type); - -GdkPixbuf *gdk_pixbuf_composite_color_simple (const GdkPixbuf *src, - int dest_width, - int dest_height, - GdkInterpType interp_type, - int overall_alpha, - int check_size, - guint32 color1, - guint32 color2); - -GdkPixbuf *gdk_pixbuf_rotate_simple (const GdkPixbuf *src, - GdkPixbufRotation angle); -GdkPixbuf *gdk_pixbuf_flip (const GdkPixbuf *src, - gboolean horizontal); - -G_END_DECLS - - -#endif /* GDK_PIXBUF_TRANSFORM_H */ diff --git a/gdk-pixbuf/gdk-pixbuf-util.c b/gdk-pixbuf/gdk-pixbuf-util.c deleted file mode 100644 index 58ee842cc7..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-util.c +++ /dev/null @@ -1,337 +0,0 @@ -/* GdkPixbuf library - Utilities and miscellaneous convenience functions - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Federico Mena-Quintero <federico@gimp.org> - * Cody Russell <bratsche@gnome.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-alias.h" -#include <string.h> - - - -/** - * gdk_pixbuf_add_alpha: - * @pixbuf: A #GdkPixbuf. - * @substitute_color: Whether to set a color to zero opacity. If this - * is %FALSE, then the (@r, @g, @b) arguments will be ignored. - * @r: Red value to substitute. - * @g: Green value to substitute. - * @b: Blue value to substitute. - * - * Takes an existing pixbuf and adds an alpha channel to it. - * If the existing pixbuf already had an alpha channel, the channel - * values are copied from the original; otherwise, the alpha channel - * is initialized to 255 (full opacity). - * - * If @substitute_color is %TRUE, then the color specified by (@r, @g, @b) will be - * assigned zero opacity. That is, if you pass (255, 255, 255) for the - * substitute color, all white pixels will become fully transparent. - * - * Return value: A newly-created pixbuf with a reference count of 1. - **/ -GdkPixbuf * -gdk_pixbuf_add_alpha (const GdkPixbuf *pixbuf, - gboolean substitute_color, guchar r, guchar g, guchar b) -{ - GdkPixbuf *new_pixbuf; - int x, y; - - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), NULL); - g_return_val_if_fail (pixbuf->colorspace == GDK_COLORSPACE_RGB, NULL); - g_return_val_if_fail (pixbuf->n_channels == 3 || pixbuf->n_channels == 4, NULL); - g_return_val_if_fail (pixbuf->bits_per_sample == 8, NULL); - - if (pixbuf->has_alpha) { - new_pixbuf = gdk_pixbuf_copy (pixbuf); - if (!new_pixbuf) - return NULL; - - if (!substitute_color) - return new_pixbuf; - } else { - new_pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, TRUE, 8, pixbuf->width, pixbuf->height); - } - - if (!new_pixbuf) - return NULL; - - for (y = 0; y < pixbuf->height; y++) { - guchar *src, *dest; - guchar tr, tg, tb; - - src = pixbuf->pixels + y * pixbuf->rowstride; - dest = new_pixbuf->pixels + y * new_pixbuf->rowstride; - - if (pixbuf->has_alpha) { - /* Just subst color, we already copied everything else */ - for (x = 0; x < pixbuf->width; x++) { - if (src[0] == r && src[1] == g && src[2] == b) - dest[3] = 0; - src += 4; - dest += 4; - } - } else { - for (x = 0; x < pixbuf->width; x++) { - tr = *dest++ = *src++; - tg = *dest++ = *src++; - tb = *dest++ = *src++; - - if (substitute_color && tr == r && tg == g && tb == b) - *dest++ = 0; - else - *dest++ = 255; - } - } - } - - return new_pixbuf; -} - -/** - * gdk_pixbuf_copy_area: - * @src_pixbuf: Source pixbuf. - * @src_x: Source X coordinate within @src_pixbuf. - * @src_y: Source Y coordinate within @src_pixbuf. - * @width: Width of the area to copy. - * @height: Height of the area to copy. - * @dest_pixbuf: Destination pixbuf. - * @dest_x: X coordinate within @dest_pixbuf. - * @dest_y: Y coordinate within @dest_pixbuf. - * - * Copies a rectangular area from @src_pixbuf to @dest_pixbuf. Conversion of - * pixbuf formats is done automatically. - * - * If the source rectangle overlaps the destination rectangle on the - * same pixbuf, it will be overwritten during the copy operation. - * Therefore, you can not use this function to scroll a pixbuf. - **/ -void -gdk_pixbuf_copy_area (const GdkPixbuf *src_pixbuf, - int src_x, int src_y, - int width, int height, - GdkPixbuf *dest_pixbuf, - int dest_x, int dest_y) -{ - g_return_if_fail (src_pixbuf != NULL); - g_return_if_fail (dest_pixbuf != NULL); - - g_return_if_fail (src_x >= 0 && src_x + width <= src_pixbuf->width); - g_return_if_fail (src_y >= 0 && src_y + height <= src_pixbuf->height); - - g_return_if_fail (dest_x >= 0 && dest_x + width <= dest_pixbuf->width); - g_return_if_fail (dest_y >= 0 && dest_y + height <= dest_pixbuf->height); - - g_return_if_fail (!(gdk_pixbuf_get_has_alpha (src_pixbuf) && !gdk_pixbuf_get_has_alpha (dest_pixbuf))); - - /* This will perform format conversions automatically */ - - gdk_pixbuf_scale (src_pixbuf, - dest_pixbuf, - dest_x, dest_y, - width, height, - (double) (dest_x - src_x), - (double) (dest_y - src_y), - 1.0, 1.0, - GDK_INTERP_NEAREST); -} - - - -/** - * gdk_pixbuf_saturate_and_pixelate: - * @src: source image - * @dest: place to write modified version of @src - * @saturation: saturation factor - * @pixelate: whether to pixelate - * - * Modifies saturation and optionally pixelates @src, placing the result in - * @dest. @src and @dest may be the same pixbuf with no ill effects. If - * @saturation is 1.0 then saturation is not changed. If it's less than 1.0, - * saturation is reduced (the image turns toward grayscale); if greater than - * 1.0, saturation is increased (the image gets more vivid colors). If @pixelate - * is %TRUE, then pixels are faded in a checkerboard pattern to create a - * pixelated image. @src and @dest must have the same image format, size, and - * rowstride. - * - **/ -void -gdk_pixbuf_saturate_and_pixelate(const GdkPixbuf *src, - GdkPixbuf *dest, - gfloat saturation, - gboolean pixelate) -{ - /* NOTE that src and dest MAY be the same pixbuf! */ - - g_return_if_fail (GDK_IS_PIXBUF (src)); - g_return_if_fail (GDK_IS_PIXBUF (dest)); - g_return_if_fail (gdk_pixbuf_get_height (src) == gdk_pixbuf_get_height (dest)); - g_return_if_fail (gdk_pixbuf_get_width (src) == gdk_pixbuf_get_width (dest)); - g_return_if_fail (gdk_pixbuf_get_has_alpha (src) == gdk_pixbuf_get_has_alpha (dest)); - g_return_if_fail (gdk_pixbuf_get_colorspace (src) == gdk_pixbuf_get_colorspace (dest)); - - if (saturation == 1.0 && !pixelate) { - if (dest != src) - gdk_pixbuf_copy_area (src, 0, 0, - gdk_pixbuf_get_width (src), - gdk_pixbuf_get_height (src), - dest, 0, 0); - } else { - int i, j, t; - int width, height, has_alpha, src_rowstride, dest_rowstride, bytes_per_pixel; - guchar *src_line; - guchar *dest_line; - guchar *src_pixel; - guchar *dest_pixel; - guchar intensity; - - has_alpha = gdk_pixbuf_get_has_alpha (src); - bytes_per_pixel = has_alpha ? 4 : 3; - width = gdk_pixbuf_get_width (src); - height = gdk_pixbuf_get_height (src); - src_rowstride = gdk_pixbuf_get_rowstride (src); - dest_rowstride = gdk_pixbuf_get_rowstride (dest); - - src_line = gdk_pixbuf_get_pixels (src); - dest_line = gdk_pixbuf_get_pixels (dest); - -#define DARK_FACTOR 0.7 -#define INTENSITY(r, g, b) ((r) * 0.30 + (g) * 0.59 + (b) * 0.11) -#define CLAMP_UCHAR(v) (t = (v), CLAMP (t, 0, 255)) -#define SATURATE(v) ((1.0 - saturation) * intensity + saturation * (v)) - - for (i = 0 ; i < height ; i++) { - src_pixel = src_line; - src_line += src_rowstride; - dest_pixel = dest_line; - dest_line += dest_rowstride; - - for (j = 0 ; j < width ; j++) { - intensity = INTENSITY (src_pixel[0], src_pixel[1], src_pixel[2]); - if (pixelate && (i + j) % 2 == 0) { - dest_pixel[0] = intensity / 2 + 127; - dest_pixel[1] = intensity / 2 + 127; - dest_pixel[2] = intensity / 2 + 127; - } else if (pixelate) { - dest_pixel[0] = CLAMP_UCHAR ((SATURATE (src_pixel[0])) * DARK_FACTOR); - dest_pixel[1] = CLAMP_UCHAR ((SATURATE (src_pixel[1])) * DARK_FACTOR); - dest_pixel[2] = CLAMP_UCHAR ((SATURATE (src_pixel[2])) * DARK_FACTOR); - } else { - dest_pixel[0] = CLAMP_UCHAR (SATURATE (src_pixel[0])); - dest_pixel[1] = CLAMP_UCHAR (SATURATE (src_pixel[1])); - dest_pixel[2] = CLAMP_UCHAR (SATURATE (src_pixel[2])); - } - - if (has_alpha) - dest_pixel[3] = src_pixel[3]; - - src_pixel += bytes_per_pixel; - dest_pixel += bytes_per_pixel; - } - } - } -} - - -/** - * gdk_pixbuf_apply_embedded_orientation: - * @src: A #GdkPixbuf. - * - * Takes an existing pixbuf and checks for the presence of an - * associated "orientation" option, which may be provided by the - * jpeg loader (which reads the exif orientation tag) or the - * tiff loader (which reads the tiff orientation tag, and - * compensates it for the partial transforms performed by - * libtiff). If an orientation option/tag is present, the - * appropriate transform will be performed so that the pixbuf - * is oriented correctly. - * - * Return value: A newly-created pixbuf, or a reference to the - * input pixbuf (with an increased reference count). - * - * Since: 2.12 - **/ -GdkPixbuf * -gdk_pixbuf_apply_embedded_orientation (GdkPixbuf *src) -{ - const gchar *orientation_string; - int transform = 0; - GdkPixbuf *temp; - GdkPixbuf *dest; - - g_return_val_if_fail (GDK_IS_PIXBUF (src), NULL); - - /* Read the orientation option associated with the pixbuf */ - orientation_string = gdk_pixbuf_get_option (src, "orientation"); - - if (orientation_string) { - /* If an orientation option was found, convert the - orientation string into an integer. */ - transform = (int) g_ascii_strtoll (orientation_string, NULL, 10); - } - - /* Apply the actual transforms, which involve rotations and flips. - The meaning of orientation values 1-8 and the required transforms - are defined by the TIFF and EXIF (for JPEGs) standards. */ - switch (transform) { - case 1: - dest = src; - g_object_ref (dest); - break; - case 2: - dest = gdk_pixbuf_flip (src, TRUE); - break; - case 3: - dest = gdk_pixbuf_rotate_simple (src, GDK_PIXBUF_ROTATE_UPSIDEDOWN); - break; - case 4: - dest = gdk_pixbuf_flip (src, FALSE); - break; - case 5: - temp = gdk_pixbuf_rotate_simple (src, GDK_PIXBUF_ROTATE_CLOCKWISE); - dest = gdk_pixbuf_flip (temp, TRUE); - g_object_unref (temp); - break; - case 6: - dest = gdk_pixbuf_rotate_simple (src, GDK_PIXBUF_ROTATE_CLOCKWISE); - break; - case 7: - temp = gdk_pixbuf_rotate_simple (src, GDK_PIXBUF_ROTATE_CLOCKWISE); - dest = gdk_pixbuf_flip (temp, FALSE); - g_object_unref (temp); - break; - case 8: - dest = gdk_pixbuf_rotate_simple (src, GDK_PIXBUF_ROTATE_COUNTERCLOCKWISE); - break; - default: - /* if no orientation tag was present */ - dest = src; - g_object_ref (dest); - break; - } - - return dest; -} - - -#define __GDK_PIXBUF_UTIL_C__ -#include "gdk-pixbuf-aliasdef.c" - diff --git a/gdk-pixbuf/gdk-pixbuf-xform.c b/gdk-pixbuf/gdk-pixbuf-xform.c deleted file mode 100644 index 1ca70cd604..0000000000 --- a/gdk-pixbuf/gdk-pixbuf-xform.c +++ /dev/null @@ -1,104 +0,0 @@ -/* FIXME FIXME FIXME - * - * This file is not being used. The gdk_pixbuf_scale() here is not useful - * anymore, since we have the new functions in gdk-pixbuf-scale.c. - * - * The rotation function needs to be implemented without libart if it is - * to go inside the GdkPixbuf library. - */ - -GdkPixbuf * -gdk_pixbuf_scale (const GdkPixbuf *pixbuf, gint w, gint h) -{ - guchar *pixels; - gint rowstride; - double affine[6]; - ArtAlphaGamma *alphagamma; - ArtPixBuf *art_pixbuf = NULL; - GdkPixbuf *copy = NULL; - - alphagamma = NULL; - - affine[1] = affine[2] = affine[4] = affine[5] = 0; - - affine[0] = w / (double)(pixbuf->width); - affine[3] = h / (double)(pixbuf->height); - - /* rowstride = w * pixbuf->n_channels; */ - rowstride = w * 3; - - pixels = art_alloc (h * rowstride); - art_rgb_pixbuf_affine (pixels, 0, 0, w, h, rowstride, - pixbuf->art_pixbuf, - affine, ART_FILTER_NEAREST, alphagamma); - - if (pixbuf->art_pixbuf->has_alpha) - /* should be rgba */ - art_pixbuf = art_pixbuf_new_rgb(pixels, w, h, rowstride); - else - art_pixbuf = art_pixbuf_new_rgb(pixels, w, h, rowstride); - - copy = gdk_pixbuf_new (art_pixbuf, NULL); - - if (!copy) - art_free (pixels); - - return copy; -} - -GdkPixbuf * -gdk_pixbuf_rotate (GdkPixbuf *pixbuf, gdouble angle) -{ - art_u8 *pixels; - gint rowstride, w, h; - gdouble rad; - double rot[6], trans[6], affine[6]; - ArtAlphaGamma *alphagamma = NULL; - ArtPixBuf *art_pixbuf = NULL; - - w = pixbuf->art_pixbuf->width; - h = pixbuf->art_pixbuf->height; - - rad = (M_PI * angle / 180.0); - - rot[0] = cos(rad); - rot[1] = sin(rad); - rot[2] = -sin(rad); - rot[3] = cos(rad); - rot[4] = rot[5] = 0; - - trans[0] = trans[3] = 1; - trans[1] = trans[2] = 0; - trans[4] = -(double)w / 2.0; - trans[5] = -(double)h / 2.0; - - art_affine_multiply(rot, trans, rot); - - trans[0] = trans[3] = 1; - trans[1] = trans[2] = 0; - trans[4] = (double)w / 2.0; - trans[5] = (double)h / 2.0; - - art_affine_multiply(affine, rot, trans); -/* - g_print("Affine: %e %e %e %e %e %e\n", affine[0], affine[1], affine[2], - affine[3], affine[4], affine[5]); -*/ - /* rowstride = w * pixbuf->art_pixbuf->n_channels; */ - rowstride = w * 3; - - pixels = art_alloc (h * rowstride); - art_rgb_pixbuf_affine (pixels, 0, 0, w, h, rowstride, - pixbuf->art_pixbuf, - affine, ART_FILTER_NEAREST, alphagamma); - if (pixbuf->art_pixbuf->has_alpha) - /* should be rgba */ - art_pixbuf = art_pixbuf_new_rgb(pixels, w, h, rowstride); - else - art_pixbuf = art_pixbuf_new_rgb(pixels, w, h, rowstride); - - art_pixbuf_free (pixbuf->art_pixbuf); - pixbuf->art_pixbuf = art_pixbuf; - - return pixbuf; -} diff --git a/gdk-pixbuf/gdk-pixbuf.c b/gdk-pixbuf/gdk-pixbuf.c deleted file mode 100644 index 71e0c61e9a..0000000000 --- a/gdk-pixbuf/gdk-pixbuf.c +++ /dev/null @@ -1,732 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Basic memory management - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <math.h> -#include <stdlib.h> -#include <string.h> -#define GDK_PIXBUF_C_COMPILATION -#include "gdk-pixbuf.h" -#include "gdk-pixbuf-private.h" -/* Include the marshallers */ -#include <glib-object.h> -#include "gdk-pixbuf-marshal.c" -#include "gdk-pixbuf-alias.h" - -static void gdk_pixbuf_finalize (GObject *object); -static void gdk_pixbuf_set_property (GObject *object, - guint prop_id, - const GValue *value, - GParamSpec *pspec); -static void gdk_pixbuf_get_property (GObject *object, - guint prop_id, - GValue *value, - GParamSpec *pspec); - - -enum -{ - PROP_0, - PROP_COLORSPACE, - PROP_N_CHANNELS, - PROP_HAS_ALPHA, - PROP_BITS_PER_SAMPLE, - PROP_WIDTH, - PROP_HEIGHT, - PROP_ROWSTRIDE, - PROP_PIXELS -}; - -G_DEFINE_TYPE (GdkPixbuf, gdk_pixbuf, G_TYPE_OBJECT) - -static void -gdk_pixbuf_init (GdkPixbuf *pixbuf) -{ -} - -static void -gdk_pixbuf_class_init (GdkPixbufClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - - object_class->finalize = gdk_pixbuf_finalize; - object_class->set_property = gdk_pixbuf_set_property; - object_class->get_property = gdk_pixbuf_get_property; - -#define PIXBUF_PARAM_FLAGS G_PARAM_READWRITE|G_PARAM_CONSTRUCT_ONLY|\ - G_PARAM_STATIC_NAME|G_PARAM_STATIC_NICK|G_PARAM_STATIC_BLURB - /** - * GdkPixbuf:n-channels: - * - * The number of samples per pixel. - * Currently, only 3 or 4 samples per pixel are supported. - */ - g_object_class_install_property (object_class, - PROP_N_CHANNELS, - g_param_spec_int ("n-channels", - P_("Number of Channels"), - P_("The number of samples per pixel"), - 0, - G_MAXINT, - 3, - PIXBUF_PARAM_FLAGS)); - - g_object_class_install_property (object_class, - PROP_COLORSPACE, - g_param_spec_enum ("colorspace", - P_("Colorspace"), - P_("The colorspace in which the samples are interpreted"), - GDK_TYPE_COLORSPACE, - GDK_COLORSPACE_RGB, - PIXBUF_PARAM_FLAGS)); - - g_object_class_install_property (object_class, - PROP_HAS_ALPHA, - g_param_spec_boolean ("has-alpha", - P_("Has Alpha"), - P_("Whether the pixbuf has an alpha channel"), - FALSE, - PIXBUF_PARAM_FLAGS)); - - /** - * GdkPixbuf:bits-per-sample: - * - * The number of bits per sample. - * Currently only 8 bit per sample are supported. - */ - g_object_class_install_property (object_class, - PROP_BITS_PER_SAMPLE, - g_param_spec_int ("bits-per-sample", - P_("Bits per Sample"), - P_("The number of bits per sample"), - 1, - 16, - 8, - PIXBUF_PARAM_FLAGS)); - - g_object_class_install_property (object_class, - PROP_WIDTH, - g_param_spec_int ("width", - P_("Width"), - P_("The number of columns of the pixbuf"), - 1, - G_MAXINT, - 1, - PIXBUF_PARAM_FLAGS)); - - g_object_class_install_property (object_class, - PROP_HEIGHT, - g_param_spec_int ("height", - P_("Height"), - P_("The number of rows of the pixbuf"), - 1, - G_MAXINT, - 1, - PIXBUF_PARAM_FLAGS)); - - /** - * GdkPixbuf:rowstride: - * - * The number of bytes between the start of a row and - * the start of the next row. This number must (obviously) - * be at least as large as the width of the pixbuf. - */ - g_object_class_install_property (object_class, - PROP_ROWSTRIDE, - g_param_spec_int ("rowstride", - P_("Rowstride"), - P_("The number of bytes between the start of a row and the start of the next row"), - 1, - G_MAXINT, - 1, - PIXBUF_PARAM_FLAGS)); - - g_object_class_install_property (object_class, - PROP_PIXELS, - g_param_spec_pointer ("pixels", - P_("Pixels"), - P_("A pointer to the pixel data of the pixbuf"), - PIXBUF_PARAM_FLAGS)); -} - -static void -gdk_pixbuf_finalize (GObject *object) -{ - GdkPixbuf *pixbuf = GDK_PIXBUF (object); - - if (pixbuf->destroy_fn) - (* pixbuf->destroy_fn) (pixbuf->pixels, pixbuf->destroy_fn_data); - - G_OBJECT_CLASS (gdk_pixbuf_parent_class)->finalize (object); -} - -/* Used as the destroy notification function for gdk_pixbuf_new() */ -static void -free_buffer (guchar *pixels, gpointer data) -{ - g_free (pixels); -} - -/** - * gdk_pixbuf_new: - * @colorspace: Color space for image - * @has_alpha: Whether the image should have transparency information - * @bits_per_sample: Number of bits per color sample - * @width: Width of image in pixels, must be > 0 - * @height: Height of image in pixels, must be > 0 - * - * Creates a new #GdkPixbuf structure and allocates a buffer for it. The - * buffer has an optimal rowstride. Note that the buffer is not cleared; - * you will have to fill it completely yourself. - * - * Return value: A newly-created #GdkPixbuf with a reference count of 1, or - * %NULL if not enough memory could be allocated for the image buffer. - **/ -GdkPixbuf * -gdk_pixbuf_new (GdkColorspace colorspace, - gboolean has_alpha, - int bits_per_sample, - int width, - int height) -{ - guchar *buf; - int channels; - int rowstride; - gsize bytes; - - g_return_val_if_fail (colorspace == GDK_COLORSPACE_RGB, NULL); - g_return_val_if_fail (bits_per_sample == 8, NULL); - g_return_val_if_fail (width > 0, NULL); - g_return_val_if_fail (height > 0, NULL); - - channels = has_alpha ? 4 : 3; - rowstride = width * channels; - if (rowstride / channels != width || rowstride + 3 < 0) /* overflow */ - return NULL; - - /* Always align rows to 32-bit boundaries */ - rowstride = (rowstride + 3) & ~3; - - bytes = height * rowstride; - if (bytes / rowstride != height) /* overflow */ - return NULL; - - buf = g_try_malloc (bytes); - if (!buf) - return NULL; - - return gdk_pixbuf_new_from_data (buf, colorspace, has_alpha, bits_per_sample, - width, height, rowstride, - free_buffer, NULL); -} - -/** - * gdk_pixbuf_copy: - * @pixbuf: A pixbuf. - * - * Creates a new #GdkPixbuf with a copy of the information in the specified - * @pixbuf. - * - * Return value: A newly-created pixbuf with a reference count of 1, or %NULL if - * not enough memory could be allocated. - **/ -GdkPixbuf * -gdk_pixbuf_copy (const GdkPixbuf *pixbuf) -{ - guchar *buf; - int size; - - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), NULL); - - /* Calculate a semi-exact size. Here we copy with full rowstrides; - * maybe we should copy each row individually with the minimum - * rowstride? - */ - - size = ((pixbuf->height - 1) * pixbuf->rowstride + - pixbuf->width * ((pixbuf->n_channels * pixbuf->bits_per_sample + 7) / 8)); - - buf = g_try_malloc (size * sizeof (guchar)); - if (!buf) - return NULL; - - memcpy (buf, pixbuf->pixels, size); - - return gdk_pixbuf_new_from_data (buf, - pixbuf->colorspace, pixbuf->has_alpha, - pixbuf->bits_per_sample, - pixbuf->width, pixbuf->height, - pixbuf->rowstride, - free_buffer, - NULL); -} - -/** - * gdk_pixbuf_new_subpixbuf: - * @src_pixbuf: a #GdkPixbuf - * @src_x: X coord in @src_pixbuf - * @src_y: Y coord in @src_pixbuf - * @width: width of region in @src_pixbuf - * @height: height of region in @src_pixbuf - * - * Creates a new pixbuf which represents a sub-region of - * @src_pixbuf. The new pixbuf shares its pixels with the - * original pixbuf, so writing to one affects both. - * The new pixbuf holds a reference to @src_pixbuf, so - * @src_pixbuf will not be finalized until the new pixbuf - * is finalized. - * - * Return value: a new pixbuf - **/ -GdkPixbuf* -gdk_pixbuf_new_subpixbuf (GdkPixbuf *src_pixbuf, - int src_x, - int src_y, - int width, - int height) -{ - guchar *pixels; - GdkPixbuf *sub; - - g_return_val_if_fail (GDK_IS_PIXBUF (src_pixbuf), NULL); - g_return_val_if_fail (src_x >= 0 && src_x + width <= src_pixbuf->width, NULL); - g_return_val_if_fail (src_y >= 0 && src_y + height <= src_pixbuf->height, NULL); - - pixels = (gdk_pixbuf_get_pixels (src_pixbuf) - + src_y * src_pixbuf->rowstride - + src_x * src_pixbuf->n_channels); - - sub = gdk_pixbuf_new_from_data (pixels, - src_pixbuf->colorspace, - src_pixbuf->has_alpha, - src_pixbuf->bits_per_sample, - width, height, - src_pixbuf->rowstride, - NULL, NULL); - - /* Keep a reference to src_pixbuf */ - g_object_ref (src_pixbuf); - - g_object_set_qdata_full (G_OBJECT (sub), - g_quark_from_static_string ("gdk-pixbuf-subpixbuf-src"), - src_pixbuf, - (GDestroyNotify) g_object_unref); - - return sub; -} - - - -/* Accessors */ - -/** - * gdk_pixbuf_get_colorspace: - * @pixbuf: A pixbuf. - * - * Queries the color space of a pixbuf. - * - * Return value: Color space. - **/ -GdkColorspace -gdk_pixbuf_get_colorspace (const GdkPixbuf *pixbuf) -{ - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), GDK_COLORSPACE_RGB); - - return pixbuf->colorspace; -} - -/** - * gdk_pixbuf_get_n_channels: - * @pixbuf: A pixbuf. - * - * Queries the number of channels of a pixbuf. - * - * Return value: Number of channels. - **/ -int -gdk_pixbuf_get_n_channels (const GdkPixbuf *pixbuf) -{ - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), -1); - - return pixbuf->n_channels; -} - -/** - * gdk_pixbuf_get_has_alpha: - * @pixbuf: A pixbuf. - * - * Queries whether a pixbuf has an alpha channel (opacity information). - * - * Return value: %TRUE if it has an alpha channel, %FALSE otherwise. - **/ -gboolean -gdk_pixbuf_get_has_alpha (const GdkPixbuf *pixbuf) -{ - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), FALSE); - - return pixbuf->has_alpha ? TRUE : FALSE; -} - -/** - * gdk_pixbuf_get_bits_per_sample: - * @pixbuf: A pixbuf. - * - * Queries the number of bits per color sample in a pixbuf. - * - * Return value: Number of bits per color sample. - **/ -int -gdk_pixbuf_get_bits_per_sample (const GdkPixbuf *pixbuf) -{ - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), -1); - - return pixbuf->bits_per_sample; -} - -/** - * gdk_pixbuf_get_pixels: - * @pixbuf: A pixbuf. - * - * Queries a pointer to the pixel data of a pixbuf. - * - * Return value: A pointer to the pixbuf's pixel data. Please see <xref linkend="image-data"/> - * for information about how the pixel data is stored in - * memory. - **/ -guchar * -gdk_pixbuf_get_pixels (const GdkPixbuf *pixbuf) -{ - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), NULL); - - return pixbuf->pixels; -} - -/** - * gdk_pixbuf_get_width: - * @pixbuf: A pixbuf. - * - * Queries the width of a pixbuf. - * - * Return value: Width in pixels. - **/ -int -gdk_pixbuf_get_width (const GdkPixbuf *pixbuf) -{ - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), -1); - - return pixbuf->width; -} - -/** - * gdk_pixbuf_get_height: - * @pixbuf: A pixbuf. - * - * Queries the height of a pixbuf. - * - * Return value: Height in pixels. - **/ -int -gdk_pixbuf_get_height (const GdkPixbuf *pixbuf) -{ - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), -1); - - return pixbuf->height; -} - -/** - * gdk_pixbuf_get_rowstride: - * @pixbuf: A pixbuf. - * - * Queries the rowstride of a pixbuf, which is the number of bytes between the start of a row - * and the start of the next row. - * - * Return value: Distance between row starts. - **/ -int -gdk_pixbuf_get_rowstride (const GdkPixbuf *pixbuf) -{ - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), -1); - - return pixbuf->rowstride; -} - - - -/* General initialization hooks */ -const guint gdk_pixbuf_major_version = GDK_PIXBUF_MAJOR; -const guint gdk_pixbuf_minor_version = GDK_PIXBUF_MINOR; -const guint gdk_pixbuf_micro_version = GDK_PIXBUF_MICRO; - -const char *gdk_pixbuf_version = GDK_PIXBUF_VERSION; - -/* Error quark */ -GQuark -gdk_pixbuf_error_quark (void) -{ - return g_quark_from_static_string ("gdk-pixbuf-error-quark"); -} - -/** - * gdk_pixbuf_fill: - * @pixbuf: a #GdkPixbuf - * @pixel: RGBA pixel to clear to - * (0xffffffff is opaque white, 0x00000000 transparent black) - * - * Clears a pixbuf to the given RGBA value, converting the RGBA value into - * the pixbuf's pixel format. The alpha will be ignored if the pixbuf - * doesn't have an alpha channel. - * - **/ -void -gdk_pixbuf_fill (GdkPixbuf *pixbuf, - guint32 pixel) -{ - guchar *pixels; - guint r, g, b, a; - guchar *p; - guint w, h; - - g_return_if_fail (GDK_IS_PIXBUF (pixbuf)); - - if (pixbuf->width == 0 || pixbuf->height == 0) - return; - - pixels = pixbuf->pixels; - - r = (pixel & 0xff000000) >> 24; - g = (pixel & 0x00ff0000) >> 16; - b = (pixel & 0x0000ff00) >> 8; - a = (pixel & 0x000000ff); - - h = pixbuf->height; - - while (h--) { - w = pixbuf->width; - p = pixels; - - switch (pixbuf->n_channels) { - case 3: - while (w--) { - p[0] = r; - p[1] = g; - p[2] = b; - p += 3; - } - break; - case 4: - while (w--) { - p[0] = r; - p[1] = g; - p[2] = b; - p[3] = a; - p += 4; - } - break; - default: - break; - } - - pixels += pixbuf->rowstride; - } -} - - - -/** - * gdk_pixbuf_get_option: - * @pixbuf: a #GdkPixbuf - * @key: a nul-terminated string. - * - * Looks up @key in the list of options that may have been attached to the - * @pixbuf when it was loaded, or that may have been attached by another - * function using gdk_pixbuf_set_option(). - * - * For instance, the ANI loader provides "Title" and "Artist" options. - * The ICO, XBM, and XPM loaders provide "x_hot" and "y_hot" hot-spot - * options for cursor definitions. The PNG loader provides the tEXt ancillary - * chunk key/value pairs as options. Since 2.12, the TIFF and JPEG loaders - * return an "orientation" option string that corresponds to the embedded - * TIFF/Exif orientation tag (if present). - * - * Return value: the value associated with @key. This is a nul-terminated - * string that should not be freed or %NULL if @key was not found. - **/ -G_CONST_RETURN gchar * -gdk_pixbuf_get_option (GdkPixbuf *pixbuf, - const gchar *key) -{ - gchar **options; - gint i; - - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), NULL); - g_return_val_if_fail (key != NULL, NULL); - - options = g_object_get_qdata (G_OBJECT (pixbuf), - g_quark_from_static_string ("gdk_pixbuf_options")); - if (options) { - for (i = 0; options[2*i]; i++) { - if (strcmp (options[2*i], key) == 0) - return options[2*i+1]; - } - } - - return NULL; -} - -/** - * gdk_pixbuf_set_option: - * @pixbuf: a #GdkPixbuf - * @key: a nul-terminated string. - * @value: a nul-terminated string. - * - * Attaches a key/value pair as an option to a #GdkPixbuf. If %key already - * exists in the list of options attached to @pixbuf, the new value is - * ignored and %FALSE is returned. - * - * Return value: %TRUE on success. - * - * Since: 2.2 - **/ -gboolean -gdk_pixbuf_set_option (GdkPixbuf *pixbuf, - const gchar *key, - const gchar *value) -{ - GQuark quark; - gchar **options; - gint n = 0; - - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), FALSE); - g_return_val_if_fail (key != NULL, FALSE); - g_return_val_if_fail (value != NULL, FALSE); - - quark = g_quark_from_static_string ("gdk_pixbuf_options"); - - options = g_object_get_qdata (G_OBJECT (pixbuf), quark); - - if (options) { - for (n = 0; options[2*n]; n++) { - if (strcmp (options[2*n], key) == 0) - return FALSE; - } - - g_object_steal_qdata (G_OBJECT (pixbuf), quark); - options = g_renew (gchar *, options, 2*(n+1) + 1); - } else { - options = g_new (gchar *, 3); - } - - options[2*n] = g_strdup (key); - options[2*n+1] = g_strdup (value); - options[2*n+2] = NULL; - - g_object_set_qdata_full (G_OBJECT (pixbuf), quark, - options, (GDestroyNotify) g_strfreev); - - return TRUE; -} - -static void -gdk_pixbuf_set_property (GObject *object, - guint prop_id, - const GValue *value, - GParamSpec *pspec) -{ - GdkPixbuf *pixbuf = GDK_PIXBUF (object); - - switch (prop_id) - { - case PROP_COLORSPACE: - pixbuf->colorspace = g_value_get_enum (value); - break; - case PROP_N_CHANNELS: - pixbuf->n_channels = g_value_get_int (value); - break; - case PROP_HAS_ALPHA: - pixbuf->has_alpha = g_value_get_boolean (value); - break; - case PROP_BITS_PER_SAMPLE: - pixbuf->bits_per_sample = g_value_get_int (value); - break; - case PROP_WIDTH: - pixbuf->width = g_value_get_int (value); - break; - case PROP_HEIGHT: - pixbuf->height = g_value_get_int (value); - break; - case PROP_ROWSTRIDE: - pixbuf->rowstride = g_value_get_int (value); - break; - case PROP_PIXELS: - pixbuf->pixels = (guchar *) g_value_get_pointer (value); - break; - default: - G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); - break; - } -} - -static void -gdk_pixbuf_get_property (GObject *object, - guint prop_id, - GValue *value, - GParamSpec *pspec) -{ - GdkPixbuf *pixbuf = GDK_PIXBUF (object); - - switch (prop_id) - { - case PROP_COLORSPACE: - g_value_set_enum (value, gdk_pixbuf_get_colorspace (pixbuf)); - break; - case PROP_N_CHANNELS: - g_value_set_int (value, gdk_pixbuf_get_n_channels (pixbuf)); - break; - case PROP_HAS_ALPHA: - g_value_set_boolean (value, gdk_pixbuf_get_has_alpha (pixbuf)); - break; - case PROP_BITS_PER_SAMPLE: - g_value_set_int (value, gdk_pixbuf_get_bits_per_sample (pixbuf)); - break; - case PROP_WIDTH: - g_value_set_int (value, gdk_pixbuf_get_width (pixbuf)); - break; - case PROP_HEIGHT: - g_value_set_int (value, gdk_pixbuf_get_height (pixbuf)); - break; - case PROP_ROWSTRIDE: - g_value_set_int (value, gdk_pixbuf_get_rowstride (pixbuf)); - break; - case PROP_PIXELS: - g_value_set_pointer (value, gdk_pixbuf_get_pixels (pixbuf)); - break; - default: - G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); - break; - } -} - -#define __GDK_PIXBUF_C__ -#include "gdk-pixbuf-aliasdef.c" diff --git a/gdk-pixbuf/gdk-pixbuf.h b/gdk-pixbuf/gdk-pixbuf.h deleted file mode 100644 index 9a30131fb1..0000000000 --- a/gdk-pixbuf/gdk-pixbuf.h +++ /dev/null @@ -1,45 +0,0 @@ -/* GdkPixbuf library - Main header file - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#ifndef GDK_PIXBUF_H -#define GDK_PIXBUF_H - -#define GDK_PIXBUF_H_INSIDE - -#include <glib.h> -#include <gdk-pixbuf/gdk-pixbuf-features.h> -#include <glib-object.h> - -#include <gdk-pixbuf/gdk-pixbuf-core.h> -#include <gdk-pixbuf/gdk-pixbuf-transform.h> -#include <gdk-pixbuf/gdk-pixbuf-animation.h> -#include <gdk-pixbuf/gdk-pixbuf-simple-anim.h> -#include <gdk-pixbuf/gdk-pixbuf-io.h> -#include <gdk-pixbuf/gdk-pixbuf-loader.h> -#include <gdk-pixbuf/gdk-pixbuf-enum-types.h> - -#undef GDK_PIXBUF_H_INSIDE - -#endif /* GDK_PIXBUF_H */ diff --git a/gdk-pixbuf/gdk-pixbuf.symbols b/gdk-pixbuf/gdk-pixbuf.symbols deleted file mode 100644 index 93885956ea..0000000000 --- a/gdk-pixbuf/gdk-pixbuf.symbols +++ /dev/null @@ -1,202 +0,0 @@ -/* This file lists all exported symbols. It is used to generate - * the gdk_pixbuf.def file used to control exports on Windows and the - * gdk-pixbuf-alias.h/gdk-pixbuf-aliasdef.c files used to avoid PLT - * entries for internal uses of exported functions (see makegdkpixbufalias.pl). - * - * Every symbol must be included in the right - * #ifdef IN_HEADER(sym) #endif and - * #ifdef IN_FILE(sym) #endif sections. - */ -#ifdef ALL_FILES -#define IN_FILE(x) 1 -#define IN_HEADER(x) 1 -#endif -#if IN_HEADER(GDK_PIXBUF_CORE_H) -#if IN_FILE(__GDK_PIXBUF_C__) -gdk_pixbuf_error_quark -gdk_pixbuf_get_type G_GNUC_CONST -gdk_pixbuf_new -gdk_pixbuf_get_bits_per_sample -gdk_pixbuf_get_colorspace -gdk_pixbuf_get_has_alpha -gdk_pixbuf_get_height -gdk_pixbuf_get_n_channels -gdk_pixbuf_get_pixels -gdk_pixbuf_get_rowstride -gdk_pixbuf_get_width -gdk_pixbuf_get_option -gdk_pixbuf_copy -gdk_pixbuf_new_subpixbuf -gdk_pixbuf_fill -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_CORE_H) -#if IN_FILE(__GDK_PIXBUF_DATA_C__) -gdk_pixbuf_new_from_data -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_CORE_H) -#if IN_FILE(__GDK_PIXBUF_IO_C__) -gdk_pixbuf_new_from_file PRIVATE -#ifdef G_OS_WIN32 -gdk_pixbuf_new_from_file_utf8 -#endif -gdk_pixbuf_new_from_file_at_size PRIVATE -#ifdef G_OS_WIN32 -gdk_pixbuf_new_from_file_at_size_utf8 -#endif -gdk_pixbuf_new_from_file_at_scale PRIVATE -#ifdef G_OS_WIN32 -gdk_pixbuf_new_from_file_at_scale_utf8 -#endif -gdk_pixbuf_new_from_xpm_data -gdk_pixbuf_new_from_stream -gdk_pixbuf_new_from_stream_at_scale -gdk_pixbuf_save PRIVATE G_GNUC_NULL_TERMINATED -#ifdef G_OS_WIN32 -gdk_pixbuf_save_utf8 -#endif -gdk_pixbuf_save_to_buffer G_GNUC_NULL_TERMINATED -gdk_pixbuf_save_to_bufferv -gdk_pixbuf_save_to_callback G_GNUC_NULL_TERMINATED -gdk_pixbuf_save_to_callbackv -gdk_pixbuf_savev PRIVATE -#ifdef G_OS_WIN32 -gdk_pixbuf_savev_utf8 -#endif -gdk_pixbuf_save_to_stream -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_CORE_H) -#if IN_FILE(__GDK_PIXDATA_C__) -gdk_pixbuf_new_from_inline -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_CORE_H) -#if IN_FILE(__GDK_PIXBUF_UTIL_C__) -gdk_pixbuf_add_alpha -gdk_pixbuf_copy_area -gdk_pixbuf_saturate_and_pixelate -gdk_pixbuf_apply_embedded_orientation -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_TRANSFORM_H) -#if IN_FILE(__GDK_PIXBUF_SCALE_C__) -gdk_pixbuf_rotate_simple -gdk_pixbuf_scale -gdk_pixbuf_scale_simple -gdk_pixbuf_flip -gdk_pixbuf_composite -gdk_pixbuf_composite_color -gdk_pixbuf_composite_color_simple -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_ANIMATION_H) -#if IN_FILE(__GDK_PIXBUF_ANIMATION_C__) -gdk_pixbuf_animation_get_height -gdk_pixbuf_animation_get_iter -gdk_pixbuf_animation_get_static_image -gdk_pixbuf_animation_get_type G_GNUC_CONST -gdk_pixbuf_animation_get_width -gdk_pixbuf_animation_is_static_image -gdk_pixbuf_animation_iter_advance -gdk_pixbuf_animation_iter_get_delay_time -gdk_pixbuf_animation_iter_get_pixbuf -gdk_pixbuf_animation_iter_get_type G_GNUC_CONST -gdk_pixbuf_animation_iter_on_currently_loading_frame -gdk_pixbuf_animation_new_from_file PRIVATE -#ifdef G_OS_WIN32 -gdk_pixbuf_animation_new_from_file_utf8 -#endif -gdk_pixbuf_non_anim_new -gdk_pixbuf_non_anim_get_type G_GNUC_CONST -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_SIMPLE_ANIM_H) -#if IN_FILE(__GDK_PIXBUF_SIMPLE_ANIM_C__) -gdk_pixbuf_simple_anim_get_type G_GNUC_CONST -gdk_pixbuf_simple_anim_iter_get_type G_GNUC_CONST -gdk_pixbuf_simple_anim_new -gdk_pixbuf_simple_anim_add_frame -gdk_pixbuf_simple_anim_set_loop -gdk_pixbuf_simple_anim_get_loop -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_SCALED_ANIM_H) -#if IN_FILE(__GDK_PIXBUF_SCALED_ANIM_C__) -gdk_pixbuf_scaled_anim_get_type G_GNUC_CONST -gdk_pixbuf_scaled_anim_iter_get_type G_GNUC_CONST -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_IO_H) -#if IN_FILE(__GDK_PIXBUF_IO_C__) -gdk_pixbuf_get_formats -gdk_pixbuf_format_get_description -gdk_pixbuf_format_get_extensions -gdk_pixbuf_format_get_license -gdk_pixbuf_format_get_mime_types -gdk_pixbuf_format_get_name -gdk_pixbuf_format_is_disabled -gdk_pixbuf_format_is_scalable -gdk_pixbuf_format_is_writable -gdk_pixbuf_format_set_disabled -gdk_pixbuf_get_file_info -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_IO_H) -#if IN_FILE(__GDK_PIXBUF_C__) -gdk_pixbuf_set_option -#endif -#endif - -#if IN_HEADER(GDK_PIXBUF_LOADER_H) -#if IN_FILE(__GDK_PIXBUF_LOADER_C__) -gdk_pixbuf_loader_close -gdk_pixbuf_loader_get_animation -gdk_pixbuf_loader_get_format -gdk_pixbuf_loader_get_pixbuf -gdk_pixbuf_loader_get_type G_GNUC_CONST -gdk_pixbuf_loader_new -gdk_pixbuf_loader_new_with_mime_type -gdk_pixbuf_loader_new_with_type -gdk_pixbuf_loader_set_size -gdk_pixbuf_loader_write -#endif -#endif - -#if IN_HEADER(__GDK_PIXBUF_ENUM_TYPES_H__) -#if IN_FILE(__GDK_PIXBUF_ENUM_TYPES_C__) -gdk_colorspace_get_type G_GNUC_CONST -gdk_interp_type_get_type G_GNUC_CONST -gdk_pixbuf_alpha_mode_get_type G_GNUC_CONST -gdk_pixbuf_rotation_get_type G_GNUC_CONST -gdk_pixbuf_error_get_type -#endif -#endif - -#if IN_HEADER(__GDK_PIXDATA_H__) -#if IN_FILE(__GDK_PIXDATA_C__) -gdk_pixbuf_from_pixdata -gdk_pixdata_deserialize -gdk_pixdata_from_pixbuf -gdk_pixdata_serialize -gdk_pixdata_to_csource -#endif -#endif - -#ifdef INCLUDE_VARIABLES -gdk_pixbuf_major_version -gdk_pixbuf_micro_version -gdk_pixbuf_minor_version -gdk_pixbuf_version -#endif diff --git a/gdk-pixbuf/gdk-pixdata.c b/gdk-pixbuf/gdk-pixdata.c deleted file mode 100644 index ed60ab569e..0000000000 --- a/gdk-pixbuf/gdk-pixdata.c +++ /dev/null @@ -1,903 +0,0 @@ -/* GdkPixbuf library - GdkPixdata - functions for inlined pixbuf handling - * Copyright (C) 1999, 2001 Tim Janik - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ -#include "config.h" - -#include "gdk-pixbuf-private.h" -#include "gdk-pixdata.h" -#include "gdk-pixbuf-alias.h" -#include <string.h> - -#define APPEND g_string_append_printf - -/* --- functions --- */ -static guint -pixdata_get_length (const GdkPixdata *pixdata) -{ - guint bpp, length; - - if ((pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGB) - bpp = 3; - else if ((pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGBA) - bpp = 4; - else - return 0; /* invalid format */ - switch (pixdata->pixdata_type & GDK_PIXDATA_ENCODING_MASK) - { - guint8 *rle_buffer; - guint max_length; - case GDK_PIXDATA_ENCODING_RAW: - length = pixdata->rowstride * pixdata->height; - break; - case GDK_PIXDATA_ENCODING_RLE: - /* need an RLE walk to determine size */ - max_length = pixdata->rowstride * pixdata->height; - rle_buffer = pixdata->pixel_data; - length = 0; - while (length < max_length) - { - guint chunk_length = *(rle_buffer++); - - if (chunk_length & 128) - { - chunk_length = chunk_length - 128; - if (!chunk_length) /* RLE data corrupted */ - return 0; - length += chunk_length * bpp; - rle_buffer += bpp; - } - else - { - if (!chunk_length) /* RLE data corrupted */ - return 0; - chunk_length *= bpp; - length += chunk_length; - rle_buffer += chunk_length; - } - } - length = rle_buffer - pixdata->pixel_data; - break; - default: - length = 0; - break; - } - return length; -} - -/** - * gdk_pixdata_serialize: - * @pixdata: a valid #GdkPixdata structure to serialize. - * @stream_length_p: location to store the resulting stream length in. - * - * Serializes a #GdkPixdata structure into a byte stream. - * The byte stream consists of a straightforward writeout of the - * #GdkPixdata fields in network byte order, plus the @pixel_data - * bytes the structure points to. - * - * Return value: A newly-allocated string containing the serialized - * #GdkPixdata structure. - **/ -guint8* /* free result */ -gdk_pixdata_serialize (const GdkPixdata *pixdata, - guint *stream_length_p) -{ - guint8 *stream, *s; - guint32 *istream; - guint length; - - /* check args passing */ - g_return_val_if_fail (pixdata != NULL, NULL); - g_return_val_if_fail (stream_length_p != NULL, NULL); - /* check pixdata contents */ - g_return_val_if_fail (pixdata->magic == GDK_PIXBUF_MAGIC_NUMBER, NULL); - g_return_val_if_fail (pixdata->width > 0, NULL); - g_return_val_if_fail (pixdata->height > 0, NULL); - g_return_val_if_fail (pixdata->rowstride >= pixdata->width, NULL); - g_return_val_if_fail ((pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGB || - (pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGBA, NULL); - g_return_val_if_fail ((pixdata->pixdata_type & GDK_PIXDATA_SAMPLE_WIDTH_MASK) == GDK_PIXDATA_SAMPLE_WIDTH_8, NULL); - g_return_val_if_fail ((pixdata->pixdata_type & GDK_PIXDATA_ENCODING_MASK) == GDK_PIXDATA_ENCODING_RAW || - (pixdata->pixdata_type & GDK_PIXDATA_ENCODING_MASK) == GDK_PIXDATA_ENCODING_RLE, NULL); - g_return_val_if_fail (pixdata->pixel_data != NULL, NULL); - - length = pixdata_get_length (pixdata); - - /* check length field */ - g_return_val_if_fail (length != 0, NULL); - - stream = g_malloc (GDK_PIXDATA_HEADER_LENGTH + length); - istream = (guint32*) stream; - - /* store header */ - *istream++ = g_htonl (GDK_PIXBUF_MAGIC_NUMBER); - *istream++ = g_htonl (GDK_PIXDATA_HEADER_LENGTH + length); - *istream++ = g_htonl (pixdata->pixdata_type); - *istream++ = g_htonl (pixdata->rowstride); - *istream++ = g_htonl (pixdata->width); - *istream++ = g_htonl (pixdata->height); - - /* copy pixel data */ - s = (guint8*) istream; - memcpy (s, pixdata->pixel_data, length); - s += length; - - *stream_length_p = GDK_PIXDATA_HEADER_LENGTH + length; - g_assert (s - stream == *stream_length_p); /* paranoid */ - - return stream; -} - -#define return_header_corrupt(error) { \ - g_set_error_literal (error, GDK_PIXBUF_ERROR, \ - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, _("Image header corrupt")); \ - return FALSE; \ -} -#define return_invalid_format(error) { \ - g_set_error_literal (error, GDK_PIXBUF_ERROR, \ - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, _("Image format unknown")); \ - return FALSE; \ -} -#define return_pixel_corrupt(error) { \ - g_set_error_literal (error, GDK_PIXBUF_ERROR, \ - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, _("Image pixel data corrupt")); \ - return FALSE; \ -} - -static inline const guint8 * -get_uint32 (const guint8 *stream, guint *result) -{ - *result = (stream[0] << 24) + (stream[1] << 16) + (stream[2] << 8) + stream[3]; - return stream + 4; -} - -/** - * gdk_pixdata_deserialize: - * @pixdata: a #GdkPixdata structure to be filled in. - * @stream_length: length of the stream used for deserialization. - * @stream: stream of bytes containing a serialized #GdkPixdata structure. - * @error: #GError location to indicate failures (maybe %NULL to ignore errors). - * - * Deserializes (reconstruct) a #GdkPixdata structure from a byte stream. - * The byte stream consists of a straightforward writeout of the - * #GdkPixdata fields in network byte order, plus the @pixel_data - * bytes the structure points to. - * The @pixdata contents are reconstructed byte by byte and are checked - * for validity. This function may fail with %GDK_PIXBUF_CORRUPT_IMAGE - * or %GDK_PIXBUF_ERROR_UNKNOWN_TYPE. - * - * Return value: Upon successful deserialization %TRUE is returned, - * %FALSE otherwise. - **/ -gboolean -gdk_pixdata_deserialize (GdkPixdata *pixdata, - guint stream_length, - const guint8 *stream, - GError **error) -{ - guint color_type, sample_width, encoding; - - g_return_val_if_fail (pixdata != NULL, FALSE); - if (stream_length < GDK_PIXDATA_HEADER_LENGTH) - return_header_corrupt (error); - g_return_val_if_fail (stream != NULL, FALSE); - - - /* deserialize header */ - stream = get_uint32 (stream, &pixdata->magic); - stream = get_uint32 (stream, (guint32 *)&pixdata->length); - if (pixdata->magic != GDK_PIXBUF_MAGIC_NUMBER || pixdata->length < GDK_PIXDATA_HEADER_LENGTH) - return_header_corrupt (error); - stream = get_uint32 (stream, &pixdata->pixdata_type); - stream = get_uint32 (stream, &pixdata->rowstride); - stream = get_uint32 (stream, &pixdata->width); - stream = get_uint32 (stream, &pixdata->height); - if (pixdata->width < 1 || pixdata->height < 1 || - pixdata->rowstride < pixdata->width) - return_header_corrupt (error); - color_type = pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK; - sample_width = pixdata->pixdata_type & GDK_PIXDATA_SAMPLE_WIDTH_MASK; - encoding = pixdata->pixdata_type & GDK_PIXDATA_ENCODING_MASK; - if ((color_type != GDK_PIXDATA_COLOR_TYPE_RGB && - color_type != GDK_PIXDATA_COLOR_TYPE_RGBA) || - sample_width != GDK_PIXDATA_SAMPLE_WIDTH_8 || - (encoding != GDK_PIXDATA_ENCODING_RAW && - encoding != GDK_PIXDATA_ENCODING_RLE)) - return_invalid_format (error); - - /* deserialize pixel data */ - if (stream_length < pixdata->length - GDK_PIXDATA_HEADER_LENGTH) - return_pixel_corrupt (error); - pixdata->pixel_data = (guint8 *)stream; - - return TRUE; -} - -static gboolean -diff2_rgb (guint8 *ip) -{ - return ip[0] != ip[3] || ip[1] != ip[4] || ip[2] != ip[5]; -} - -static gboolean -diff2_rgba (guint8 *ip) -{ - return ip[0] != ip[4] || ip[1] != ip[5] || ip[2] != ip[6] || ip[3] != ip[7]; -} - -static guint8* /* dest buffer bound */ -rl_encode_rgbx (guint8 *bp, /* dest buffer */ - guint8 *ip, /* image pointer */ - guint8 *limit, /* image upper bound */ - guint n_ch) -{ - gboolean (*diff2_pix) (guint8 *) = n_ch > 3 ? diff2_rgba : diff2_rgb; - guint8 *ilimit = limit - n_ch; - - while (ip < limit) - { - g_assert (ip < ilimit); /* paranoid */ - - if (diff2_pix (ip)) - { - guint8 *s_ip = ip; - guint l = 1; - - ip += n_ch; - while (l < 127 && ip < ilimit && diff2_pix (ip)) - { ip += n_ch; l += 1; } - if (ip == ilimit && l < 127) - { ip += n_ch; l += 1; } - *(bp++) = l; - memcpy (bp, s_ip, l * n_ch); - bp += l * n_ch; - } - else - { - guint l = 2; - - ip += n_ch; - while (l < 127 && ip < ilimit && !diff2_pix (ip)) - { ip += n_ch; l += 1; } - *(bp++) = l | 128; - memcpy (bp, ip, n_ch); - ip += n_ch; - bp += n_ch; - } - if (ip == ilimit) - { - *(bp++) = 1; - memcpy (bp, ip, n_ch); - ip += n_ch; - bp += n_ch; - } - } - - return bp; -} - -/* Used as the destroy notification function for gdk_pixbuf_new() */ -static void -free_buffer (guchar *pixels, gpointer data) -{ - g_free (pixels); -} - -/** - * gdk_pixdata_from_pixbuf: - * @pixdata: a #GdkPixdata to fill. - * @pixbuf: the data to fill @pixdata with. - * @use_rle: whether to use run-length encoding for the pixel data. - * - * Converts a #GdkPixbuf to a #GdkPixdata. If @use_rle is %TRUE, the - * pixel data is run-length encoded into newly-allocated memory and a - * pointer to that memory is returned. - * - * Returns: If @ure_rle is %TRUE, a pointer to the newly-allocated memory - * for the run-length encoded pixel data, otherwise %NULL. - **/ -gpointer -gdk_pixdata_from_pixbuf (GdkPixdata *pixdata, - const GdkPixbuf *pixbuf, - gboolean use_rle) -{ - gpointer free_me = NULL; - guint height, rowstride, encoding, bpp, length; - guint8 *img_buffer; - - g_return_val_if_fail (pixdata != NULL, NULL); - g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), NULL); - g_return_val_if_fail (pixbuf->bits_per_sample == 8, NULL); - g_return_val_if_fail ((pixbuf->n_channels == 3 && !pixbuf->has_alpha) || - (pixbuf->n_channels == 4 && pixbuf->has_alpha), NULL); - g_return_val_if_fail (pixbuf->rowstride >= pixbuf->width, NULL); - - height = pixbuf->height; - rowstride = pixbuf->rowstride; - bpp = pixbuf->has_alpha ? 4 : 3; - encoding = use_rle && ((rowstride / bpp | height) > 1) ? GDK_PIXDATA_ENCODING_RLE : GDK_PIXDATA_ENCODING_RAW; - - if (encoding == GDK_PIXDATA_ENCODING_RLE) - { - guint pad, n_bytes = rowstride * height; - guint8 *img_buffer_end, *data; - GdkPixbuf *buf = NULL; - - if (n_bytes % bpp != 0) - { - rowstride = pixbuf->width * bpp; - n_bytes = rowstride * height; - data = g_malloc (n_bytes); - buf = gdk_pixbuf_new_from_data (data, - GDK_COLORSPACE_RGB, - pixbuf->has_alpha, 8, - pixbuf->width, - pixbuf->height, - rowstride, - free_buffer, NULL); - gdk_pixbuf_copy_area (pixbuf, 0, 0, pixbuf->width, pixbuf->height, - buf, 0, 0); - } - else - buf = (GdkPixbuf *)pixbuf; - pad = rowstride; - pad = MAX (pad, 130 + n_bytes / 127); - data = g_new (guint8, pad + n_bytes); - free_me = data; - img_buffer = data; - img_buffer_end = rl_encode_rgbx (img_buffer, - buf->pixels, buf->pixels + n_bytes, - bpp); - length = img_buffer_end - img_buffer; - if (buf != pixbuf) - g_object_unref (buf); - } - else - { - img_buffer = pixbuf->pixels; - length = rowstride * height; - } - - pixdata->magic = GDK_PIXBUF_MAGIC_NUMBER; - pixdata->length = GDK_PIXDATA_HEADER_LENGTH + length; - pixdata->pixdata_type = pixbuf->has_alpha ? GDK_PIXDATA_COLOR_TYPE_RGBA : GDK_PIXDATA_COLOR_TYPE_RGB; - pixdata->pixdata_type |= GDK_PIXDATA_SAMPLE_WIDTH_8; - pixdata->pixdata_type |= encoding; - pixdata->rowstride = rowstride; - pixdata->width = pixbuf->width; - pixdata->height = height; - pixdata->pixel_data = img_buffer; - - return free_me; -} - -/** - * gdk_pixbuf_from_pixdata: - * @pixdata: a #GdkPixdata to convert into a #GdkPixbuf. - * @copy_pixels: whether to copy raw pixel data; run-length encoded - * pixel data is always copied. - * @error: location to store possible errors. - * - * Converts a #GdkPixdata to a #GdkPixbuf. If @copy_pixels is %TRUE or - * if the pixel data is run-length-encoded, the pixel data is copied into - * newly-allocated memory; otherwise it is reused. - * - * Returns: a new #GdkPixbuf. - **/ -GdkPixbuf* -gdk_pixbuf_from_pixdata (const GdkPixdata *pixdata, - gboolean copy_pixels, - GError **error) -{ - guint encoding, bpp; - guint8 *data = NULL; - - g_return_val_if_fail (pixdata != NULL, NULL); - g_return_val_if_fail (pixdata->width > 0, NULL); - g_return_val_if_fail (pixdata->height > 0, NULL); - g_return_val_if_fail (pixdata->rowstride >= pixdata->width, NULL); - g_return_val_if_fail ((pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGB || - (pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGBA, NULL); - g_return_val_if_fail ((pixdata->pixdata_type & GDK_PIXDATA_SAMPLE_WIDTH_MASK) == GDK_PIXDATA_SAMPLE_WIDTH_8, NULL); - g_return_val_if_fail ((pixdata->pixdata_type & GDK_PIXDATA_ENCODING_MASK) == GDK_PIXDATA_ENCODING_RAW || - (pixdata->pixdata_type & GDK_PIXDATA_ENCODING_MASK) == GDK_PIXDATA_ENCODING_RLE, NULL); - g_return_val_if_fail (pixdata->pixel_data != NULL, NULL); - - bpp = (pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGB ? 3 : 4; - encoding = pixdata->pixdata_type & GDK_PIXDATA_ENCODING_MASK; - if (encoding == GDK_PIXDATA_ENCODING_RLE) - copy_pixels = TRUE; - if (copy_pixels) - { - data = g_try_malloc (pixdata->rowstride * pixdata->height); - if (!data) - { - g_set_error (error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - g_dngettext(GETTEXT_PACKAGE, - "failed to allocate image buffer of %u byte", - "failed to allocate image buffer of %u bytes", - pixdata->rowstride * pixdata->height), - pixdata->rowstride * pixdata->height); - return NULL; - } - } - if (encoding == GDK_PIXDATA_ENCODING_RLE) - { - const guint8 *rle_buffer = pixdata->pixel_data; - guint8 *image_buffer = data; - guint8 *image_limit = data + pixdata->rowstride * pixdata->height; - gboolean check_overrun = FALSE; - - while (image_buffer < image_limit) - { - guint length = *(rle_buffer++); - - if (length & 128) - { - length = length - 128; - check_overrun = image_buffer + length * bpp > image_limit; - if (check_overrun) - length = (image_limit - image_buffer) / bpp; - if (bpp < 4) /* RGB */ - do - { - memcpy (image_buffer, rle_buffer, 3); - image_buffer += 3; - } - while (--length); - else /* RGBA */ - do - { - memcpy (image_buffer, rle_buffer, 4); - image_buffer += 4; - } - while (--length); - rle_buffer += bpp; - } - else - { - length *= bpp; - check_overrun = image_buffer + length > image_limit; - if (check_overrun) - length = image_limit - image_buffer; - memcpy (image_buffer, rle_buffer, length); - image_buffer += length; - rle_buffer += length; - } - } - if (check_overrun) - { - g_free (data); - g_set_error_literal (error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Image pixel data corrupt")); - return NULL; - } - } - else if (copy_pixels) - memcpy (data, pixdata->pixel_data, pixdata->rowstride * pixdata->height); - else - data = pixdata->pixel_data; - - return gdk_pixbuf_new_from_data (data, GDK_COLORSPACE_RGB, - (pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGBA, - 8, pixdata->width, pixdata->height, pixdata->rowstride, - copy_pixels ? (GdkPixbufDestroyNotify) g_free : NULL, data); -} - -typedef struct { - /* config */ - gboolean dump_stream; - gboolean dump_struct; - gboolean dump_macros; - gboolean dump_gtypes; - gboolean dump_rle_decoder; - const gchar *static_prefix; - const gchar *const_prefix; - /* runtime */ - GString *gstring; - guint pos; - gboolean pad; -} CSourceData; - -static inline void -save_uchar (CSourceData *cdata, - guint8 d) -{ - GString *gstring = cdata->gstring; - - if (cdata->pos > 70) - { - if (cdata->dump_struct || cdata->dump_stream) - { - g_string_append (gstring, "\"\n \""); - cdata->pos = 3; - cdata->pad = FALSE; - } - if (cdata->dump_macros) - { - g_string_append (gstring, "\" \\\n \""); - cdata->pos = 3; - cdata->pad = FALSE; - } - } - if (d < 33 || d > 126 || d == '?') - { - APPEND (gstring, "\\%o", d); - cdata->pos += 1 + 1 + (d > 7) + (d > 63); - cdata->pad = d < 64; - return; - } - if (d == '\\') - { - g_string_append (gstring, "\\\\"); - cdata->pos += 2; - } - else if (d == '"') - { - g_string_append (gstring, "\\\""); - cdata->pos += 2; - } - else if (cdata->pad && d >= '0' && d <= '9') - { - g_string_append (gstring, "\"\""); - g_string_append_c (gstring, d); - cdata->pos += 3; - } - else - { - g_string_append_c (gstring, d); - cdata->pos += 1; - } - cdata->pad = FALSE; - return; -} - -static inline void -save_rle_decoder (GString *gstring, - const gchar *macro_name, - const gchar *s_uint, - const gchar *s_uint_8, - guint n_ch) -{ - APPEND (gstring, "#define %s_RUN_LENGTH_DECODE(image_buf, rle_data, size, bpp) do \\\n", - macro_name); - APPEND (gstring, "{ %s __bpp; %s *__ip; const %s *__il, *__rd; \\\n", s_uint, s_uint_8, s_uint_8); - APPEND (gstring, " __bpp = (bpp); __ip = (image_buf); __il = __ip + (size) * __bpp; \\\n"); - - APPEND (gstring, " __rd = (rle_data); if (__bpp > 3) { /* RGBA */ \\\n"); - - APPEND (gstring, " while (__ip < __il) { %s __l = *(__rd++); \\\n", s_uint); - APPEND (gstring, " if (__l & 128) { __l = __l - 128; \\\n"); - APPEND (gstring, " do { memcpy (__ip, __rd, 4); __ip += 4; } while (--__l); __rd += 4; \\\n"); - APPEND (gstring, " } else { __l *= 4; memcpy (__ip, __rd, __l); \\\n"); - APPEND (gstring, " __ip += __l; __rd += __l; } } \\\n"); - - APPEND (gstring, " } else { /* RGB */ \\\n"); - - APPEND (gstring, " while (__ip < __il) { %s __l = *(__rd++); \\\n", s_uint); - APPEND (gstring, " if (__l & 128) { __l = __l - 128; \\\n"); - APPEND (gstring, " do { memcpy (__ip, __rd, 3); __ip += 3; } while (--__l); __rd += 3; \\\n"); - APPEND (gstring, " } else { __l *= 3; memcpy (__ip, __rd, __l); \\\n"); - APPEND (gstring, " __ip += __l; __rd += __l; } } \\\n"); - - APPEND (gstring, " } } while (0)\n"); -} - -/** - * gdk_pixdata_to_csource: - * @pixdata: a #GdkPixdata to convert to C source. - * @name: used for naming generated data structures or macros. - * @dump_type: a #GdkPixdataDumpType determining the kind of C - * source to be generated. - * - * Generates C source code suitable for compiling images directly - * into programs. - * - * GTK+ ships with a program called <command>gdk-pixbuf-csource</command> - * which offers a command line interface to this function. - * - * Returns: a newly-allocated string containing the C source form - * of @pixdata. - **/ -GString* -gdk_pixdata_to_csource (GdkPixdata *pixdata, - const gchar *name, - GdkPixdataDumpType dump_type) -{ - CSourceData cdata = { 0, }; - gchar *s_uint_8; - guint bpp, width, height, rowstride; - gboolean rle_encoded; - gchar *macro_name; - guint8 *img_buffer, *img_buffer_end, *stream = NULL; - guint stream_length; - GString *gstring; - - /* check args passing */ - g_return_val_if_fail (pixdata != NULL, NULL); - g_return_val_if_fail (name != NULL, NULL); - /* check pixdata contents */ - g_return_val_if_fail (pixdata->magic == GDK_PIXBUF_MAGIC_NUMBER, NULL); - g_return_val_if_fail (pixdata->width > 0, NULL); - g_return_val_if_fail (pixdata->height > 0, NULL); - g_return_val_if_fail (pixdata->rowstride >= pixdata->width, NULL); - g_return_val_if_fail ((pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGB || - (pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGBA, NULL); - g_return_val_if_fail ((pixdata->pixdata_type & GDK_PIXDATA_SAMPLE_WIDTH_MASK) == GDK_PIXDATA_SAMPLE_WIDTH_8, NULL); - g_return_val_if_fail ((pixdata->pixdata_type & GDK_PIXDATA_ENCODING_MASK) == GDK_PIXDATA_ENCODING_RAW || - (pixdata->pixdata_type & GDK_PIXDATA_ENCODING_MASK) == GDK_PIXDATA_ENCODING_RLE, NULL); - g_return_val_if_fail (pixdata->pixel_data != NULL, NULL); - - img_buffer = pixdata->pixel_data; - if (pixdata->length < 1) - img_buffer_end = img_buffer + pixdata_get_length (pixdata); - else - img_buffer_end = img_buffer + pixdata->length - GDK_PIXDATA_HEADER_LENGTH; - g_return_val_if_fail (img_buffer < img_buffer_end, NULL); - - bpp = (pixdata->pixdata_type & GDK_PIXDATA_COLOR_TYPE_MASK) == GDK_PIXDATA_COLOR_TYPE_RGB ? 3 : 4; - width = pixdata->width; - height = pixdata->height; - rowstride = pixdata->rowstride; - rle_encoded = (pixdata->pixdata_type & GDK_PIXDATA_ENCODING_RLE) > 0; - macro_name = g_ascii_strup (name, -1); - - cdata.dump_macros = (dump_type & GDK_PIXDATA_DUMP_MACROS) > 0; - cdata.dump_struct = (dump_type & GDK_PIXDATA_DUMP_PIXDATA_STRUCT) > 0; - cdata.dump_stream = !cdata.dump_macros && !cdata.dump_struct; - g_return_val_if_fail (cdata.dump_macros + cdata.dump_struct + cdata.dump_stream == 1, NULL); - - cdata.dump_gtypes = (dump_type & GDK_PIXDATA_DUMP_CTYPES) == 0; - cdata.dump_rle_decoder = (dump_type & GDK_PIXDATA_DUMP_RLE_DECODER) > 0; - cdata.static_prefix = (dump_type & GDK_PIXDATA_DUMP_STATIC) ? "static " : ""; - cdata.const_prefix = (dump_type & GDK_PIXDATA_DUMP_CONST) ? "const " : ""; - gstring = g_string_new (NULL); - cdata.gstring = gstring; - - if (!cdata.dump_macros && cdata.dump_gtypes) - s_uint_8 = "guint8 "; - else if (!cdata.dump_macros) - s_uint_8 = "unsigned char"; - else if (cdata.dump_macros && cdata.dump_gtypes) - s_uint_8 = "guint8"; - else /* cdata.dump_macros && !cdata.dump_gtypes */ - s_uint_8 = "unsigned char"; - - /* initial comment - */ - APPEND (gstring, - "/* GdkPixbuf %s C-Source image dump %s*/\n\n", - bpp > 3 ? "RGBA" : "RGB", - rle_encoded ? "1-byte-run-length-encoded " : ""); - - /* dump RLE decoder for structures - */ - if (cdata.dump_rle_decoder && cdata.dump_struct) - save_rle_decoder (gstring, - macro_name, - cdata.dump_gtypes ? "guint" : "unsigned int", - cdata.dump_gtypes ? "guint8" : "unsigned char", - bpp); - - /* format & size blurbs - */ - if (cdata.dump_macros) - { - APPEND (gstring, "#define %s_ROWSTRIDE (%u)\n", - macro_name, rowstride); - APPEND (gstring, "#define %s_WIDTH (%u)\n", - macro_name, width); - APPEND (gstring, "#define %s_HEIGHT (%u)\n", - macro_name, height); - APPEND (gstring, "#define %s_BYTES_PER_PIXEL (%u) /* 3:RGB, 4:RGBA */\n", - macro_name, bpp); - } - if (cdata.dump_struct) - { - APPEND (gstring, "%s%sGdkPixdata %s = {\n", - cdata.static_prefix, cdata.const_prefix, name); - APPEND (gstring, " 0x%x, /* Pixbuf magic: 'GdkP' */\n", - GDK_PIXBUF_MAGIC_NUMBER); - APPEND (gstring, " %d + %lu, /* header length + pixel_data length */\n", - GDK_PIXDATA_HEADER_LENGTH, - rle_encoded ? (glong)(img_buffer_end - img_buffer) : (glong)rowstride * height); - APPEND (gstring, " 0x%x, /* pixdata_type */\n", - pixdata->pixdata_type); - APPEND (gstring, " %u, /* rowstride */\n", - rowstride); - APPEND (gstring, " %u, /* width */\n", - width); - APPEND (gstring, " %u, /* height */\n", - height); - APPEND (gstring, " /* pixel_data: */\n"); - } - if (cdata.dump_stream) - { - guint pix_length = img_buffer_end - img_buffer; - - stream = gdk_pixdata_serialize (pixdata, &stream_length); - img_buffer = stream; - img_buffer_end = stream + stream_length; - - APPEND (gstring, "#ifdef __SUNPRO_C\n"); - APPEND (gstring, "#pragma align 4 (%s)\n", name); - APPEND (gstring, "#endif\n"); - - APPEND (gstring, "#ifdef __GNUC__\n"); - APPEND (gstring, "%s%s%s %s[] __attribute__ ((__aligned__ (4))) = \n", - cdata.static_prefix, cdata.const_prefix, - cdata.dump_gtypes ? "guint8" : "unsigned char", - name); - APPEND (gstring, "#else\n"); - APPEND (gstring, "%s%s%s %s[] = \n", - cdata.static_prefix, cdata.const_prefix, - cdata.dump_gtypes ? "guint8" : "unsigned char", - name); - APPEND (gstring, "#endif\n"); - - APPEND (gstring, "{ \"\"\n /* Pixbuf magic (0x%x) */\n \"", - GDK_PIXBUF_MAGIC_NUMBER); - cdata.pos = 3; - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - APPEND (gstring, "\"\n /* length: header (%d) + pixel_data (%u) */\n \"", - GDK_PIXDATA_HEADER_LENGTH, - rle_encoded ? pix_length : rowstride * height); - cdata.pos = 3; - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - APPEND (gstring, "\"\n /* pixdata_type (0x%x) */\n \"", - pixdata->pixdata_type); - cdata.pos = 3; - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - APPEND (gstring, "\"\n /* rowstride (%u) */\n \"", - rowstride); - cdata.pos = 3; - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - APPEND (gstring, "\"\n /* width (%u) */\n \"", width); - cdata.pos = 3; - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - APPEND (gstring, "\"\n /* height (%u) */\n \"", height); - cdata.pos = 3; - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - save_uchar (&cdata, *img_buffer++); save_uchar (&cdata, *img_buffer++); - APPEND (gstring, "\"\n /* pixel_data: */\n"); - } - - /* pixel_data intro - */ - if (cdata.dump_macros) - { - APPEND (gstring, "#define %s_%sPIXEL_DATA ((%s*) \\\n", - macro_name, - rle_encoded ? "RLE_" : "", - s_uint_8); - APPEND (gstring, " \""); - cdata.pos = 2; - } - if (cdata.dump_struct) - { - APPEND (gstring, " \""); - cdata.pos = 3; - } - if (cdata.dump_stream) - { - APPEND (gstring, " \""); - cdata.pos = 3; - } - - /* pixel_data - */ - do - save_uchar (&cdata, *img_buffer++); - while (img_buffer < img_buffer_end); - - /* pixel_data trailer - */ - if (cdata.dump_macros) - APPEND (gstring, "\")\n\n"); - if (cdata.dump_struct) - APPEND (gstring, "\",\n};\n\n"); - if (cdata.dump_stream) - APPEND (gstring, "\"};\n\n"); - - /* dump RLE decoder for macros - */ - if (cdata.dump_rle_decoder && cdata.dump_macros) - save_rle_decoder (gstring, - macro_name, - cdata.dump_gtypes ? "guint" : "unsigned int", - cdata.dump_gtypes ? "guint8" : "unsigned char", - bpp); - - /* cleanup - */ - g_free (stream); - g_free (macro_name); - - return gstring; -} - -/** - * gdk_pixbuf_new_from_inline: - * @data_length: Length in bytes of the @data argument or -1 to - * disable length checks - * @data: Byte data containing a serialized #GdkPixdata structure - * @copy_pixels: Whether to copy the pixel data, or use direct pointers - * @data for the resulting pixbuf - * @error: #GError return location, may be %NULL to ignore errors - * - * Create a #GdkPixbuf from a flat representation that is suitable for - * storing as inline data in a program. This is useful if you want to - * ship a program with images, but don't want to depend on any - * external files. - * - * GTK+ ships with a program called <command>gdk-pixbuf-csource</command> - * which allows for conversion of #GdkPixbufs into such a inline representation. - * In almost all cases, you should pass the <option>--raw</option> flag to - * <command>gdk-pixbuf-csource</command>. A sample invocation would be: - * - * <informalexample><programlisting> - * gdk-pixbuf-csource --raw --name=myimage_inline myimage.png - * </programlisting></informalexample> - * - * For the typical case where the inline pixbuf is read-only static data, - * you don't need to copy the pixel data unless you intend to write to - * it, so you can pass %FALSE for @copy_pixels. (If you pass - * <option>--rle</option> to <command>gdk-pixbuf-csource</command>, a copy - * will be made even if @copy_pixels is %FALSE, so using this option is - * generally a bad idea.) - * - * If you create a pixbuf from const inline data compiled into your - * program, it's probably safe to ignore errors and disable length checks, - * since things will always succeed: - * <informalexample><programlisting> - * pixbuf = gdk_pixbuf_new_from_inline (-1, myimage_inline, FALSE, NULL); - * </programlisting></informalexample> - * - * For non-const inline data, you could get out of memory. For untrusted - * inline data located at runtime, you could have corrupt inline data in - * addition. - * - * Return value: A newly-created #GdkPixbuf structure with a reference, - * count of 1, or %NULL if an error occurred. - **/ -GdkPixbuf* -gdk_pixbuf_new_from_inline (gint data_length, - const guint8 *data, - gboolean copy_pixels, - GError **error) -{ - GdkPixdata pixdata; - - if (data_length != -1) - g_return_val_if_fail (data_length > GDK_PIXDATA_HEADER_LENGTH, NULL); - g_return_val_if_fail (data != NULL, NULL); - - if (!gdk_pixdata_deserialize (&pixdata, data_length, data, error)) - return NULL; - - return gdk_pixbuf_from_pixdata (&pixdata, copy_pixels, error); -} - -#define __GDK_PIXDATA_C__ -#include "gdk-pixbuf-aliasdef.c" diff --git a/gdk-pixbuf/gdk-pixdata.h b/gdk-pixbuf/gdk-pixdata.h deleted file mode 100644 index eb85034be5..0000000000 --- a/gdk-pixbuf/gdk-pixdata.h +++ /dev/null @@ -1,170 +0,0 @@ -/* GdkPixbuf library - GdkPixdata - functions for inlined pixbuf handling - * Copyright (C) 1999, 2001 Tim Janik - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ -#ifndef __GDK_PIXDATA_H__ -#define __GDK_PIXDATA_H__ - -#include <gdk-pixbuf/gdk-pixbuf.h> - -G_BEGIN_DECLS - -/** - * GDK_PIXBUF_MAGIC_NUMBER: - * - * Magic number for #GdkPixdata structures. - **/ -#define GDK_PIXBUF_MAGIC_NUMBER (0x47646b50) /* 'GdkP' */ - -/** - * GdkPixdataType: - * @GDK_PIXDATA_COLOR_TYPE_RGB: each pixel has red, green and blue samples. - * @GDK_PIXDATA_COLOR_TYPE_RGBA: each pixel has red, green and blue samples - * and an alpha value. - * @GDK_PIXDATA_COLOR_TYPE_MASK: mask for the colortype flags of the enum. - * @GDK_PIXDATA_SAMPLE_WIDTH_8: each sample has 8 bits. - * @GDK_PIXDATA_SAMPLE_WIDTH_MASK: mask for the sample width flags of the enum. - * @GDK_PIXDATA_ENCODING_RAW: the pixel data is in raw form. - * @GDK_PIXDATA_ENCODING_RLE: the pixel data is run-length encoded. Runs may - * be up to 127 bytes long; their length is stored in a single byte - * preceding the pixel data for the run. If a run is constant, its length - * byte has the high bit set and the pixel data consists of a single pixel - * which must be repeated. - * @GDK_PIXDATA_ENCODING_MASK: mask for the encoding flags of the enum. - * - * An enumeration containing three sets of flags for a #GdkPixdata struct: - * one for the used colorspace, one for the width of the samples and one - * for the encoding of the pixel data. - **/ -typedef enum -{ - /* colorspace + alpha */ - GDK_PIXDATA_COLOR_TYPE_RGB = 0x01, - GDK_PIXDATA_COLOR_TYPE_RGBA = 0x02, - GDK_PIXDATA_COLOR_TYPE_MASK = 0xff, - /* width, support 8bits only currently */ - GDK_PIXDATA_SAMPLE_WIDTH_8 = 0x01 << 16, - GDK_PIXDATA_SAMPLE_WIDTH_MASK = 0x0f << 16, - /* encoding */ - GDK_PIXDATA_ENCODING_RAW = 0x01 << 24, - GDK_PIXDATA_ENCODING_RLE = 0x02 << 24, - GDK_PIXDATA_ENCODING_MASK = 0x0f << 24 -} GdkPixdataType; - -/** - * GdkPixdata: - * @magic: magic number. A valid #GdkPixdata structure must have - * #GDK_PIXBUF_MAGIC_NUMBER here. - * @length: less than 1 to disable length checks, otherwise - * #GDK_PIXDATA_HEADER_LENGTH + length of @pixel_data. - * @pixdata_type: information about colorspace, sample width and - * encoding, in a #GdkPixdataType. - * @rowstride: Distance in bytes between rows. - * @width: Width of the image in pixels. - * @height: Height of the image in pixels. - * @pixel_data: @width x @height pixels, encoded according to @pixdata_type - * and @rowstride. - * - * A #GdkPixdata contains pixbuf information in a form suitable for - * serialization and streaming. - **/ -typedef struct _GdkPixdata GdkPixdata; -struct _GdkPixdata -{ - guint32 magic; /* GDK_PIXBUF_MAGIC_NUMBER */ - gint32 length; /* <1 to disable length checks, otherwise: - * GDK_PIXDATA_HEADER_LENGTH + pixel_data length - */ - guint32 pixdata_type; /* GdkPixdataType */ - guint32 rowstride; - guint32 width; - guint32 height; - guint8 *pixel_data; -}; - -/** - * GDK_PIXDATA_HEADER_LENGTH: - * - * The length of a #GdkPixdata structure without the @pixel_data pointer. - **/ -#define GDK_PIXDATA_HEADER_LENGTH (4 + 4 + 4 + 4 + 4 + 4) - -/* the returned stream is plain htonl of GdkPixdata members + pixel_data */ -guint8* gdk_pixdata_serialize (const GdkPixdata *pixdata, - guint *stream_length_p); -gboolean gdk_pixdata_deserialize (GdkPixdata *pixdata, - guint stream_length, - const guint8 *stream, - GError **error); -gpointer gdk_pixdata_from_pixbuf (GdkPixdata *pixdata, - const GdkPixbuf *pixbuf, - gboolean use_rle); -GdkPixbuf* gdk_pixbuf_from_pixdata (const GdkPixdata *pixdata, - gboolean copy_pixels, - GError **error); -/** - * GdkPixdataDumpType: - * @GDK_PIXDATA_DUMP_PIXDATA_STREAM: Generate pixbuf data stream (a single - * string containing a serialized #GdkPixdata structure in network byte - * order). - * @GDK_PIXDATA_DUMP_PIXDATA_STRUCT: Generate #GdkPixdata structure (needs - * the #GdkPixdata structure definition from gdk-pixdata.h). - * @GDK_PIXDATA_DUMP_MACROS: Generate <function>*_ROWSTRIDE</function>, - * <function>*_WIDTH</function>, <function>*_HEIGHT</function>, - * <function>*_BYTES_PER_PIXEL</function> and - * <function>*_RLE_PIXEL_DATA</function> or <function>*_PIXEL_DATA</function> - * macro definitions for the image. - * @GDK_PIXDATA_DUMP_GTYPES: Generate GLib data types instead of - * standard C data types. - * @GDK_PIXDATA_DUMP_CTYPES: Generate standard C data types instead of - * GLib data types. - * @GDK_PIXDATA_DUMP_STATIC: Generate static symbols. - * @GDK_PIXDATA_DUMP_CONST: Generate const symbols. - * @GDK_PIXDATA_DUMP_RLE_DECODER: Provide a <function>*_RUN_LENGTH_DECODE(image_buf, rle_data, size, bpp)</function> - * macro definition to decode run-length encoded image data. - * - * An enumeration which is used by gdk_pixdata_to_csource() to - * determine the form of C source to be generated. The three values - * @GDK_PIXDATA_DUMP_PIXDATA_STREAM, @GDK_PIXDATA_DUMP_PIXDATA_STRUCT - * and @GDK_PIXDATA_DUMP_MACROS are mutually exclusive, as are - * @GDK_PIXBUF_DUMP_GTYPES and @GDK_PIXBUF_DUMP_CTYPES. The remaining - * elements are optional flags that can be freely added. - **/ -typedef enum -{ - /* type of source to save */ - GDK_PIXDATA_DUMP_PIXDATA_STREAM = 0, - GDK_PIXDATA_DUMP_PIXDATA_STRUCT = 1, - GDK_PIXDATA_DUMP_MACROS = 2, - /* type of variables to use */ - GDK_PIXDATA_DUMP_GTYPES = 0, - GDK_PIXDATA_DUMP_CTYPES = 1 << 8, - GDK_PIXDATA_DUMP_STATIC = 1 << 9, - GDK_PIXDATA_DUMP_CONST = 1 << 10, - /* save RLE decoder macro? */ - GDK_PIXDATA_DUMP_RLE_DECODER = 1 << 16 -} GdkPixdataDumpType; - - -GString* gdk_pixdata_to_csource (GdkPixdata *pixdata, - const gchar *name, - GdkPixdataDumpType dump_type); - - -G_END_DECLS - -#endif /* __GDK_PIXDATA_H__ */ diff --git a/gdk-pixbuf/gdk_pixbuf.rc.in b/gdk-pixbuf/gdk_pixbuf.rc.in deleted file mode 100644 index 090b1da3ea..0000000000 --- a/gdk-pixbuf/gdk_pixbuf.rc.in +++ /dev/null @@ -1,30 +0,0 @@ -#include <winver.h> - -VS_VERSION_INFO VERSIONINFO - FILEVERSION @GTK_MAJOR_VERSION@,@GTK_MINOR_VERSION@,@GTK_MICRO_VERSION@,0 - PRODUCTVERSION @GTK_MAJOR_VERSION@,@GTK_MINOR_VERSION@,@GTK_MICRO_VERSION@,0 - FILEFLAGSMASK 0 - FILEFLAGS 0 - FILEOS VOS__WINDOWS32 - FILETYPE VFT_DLL - FILESUBTYPE VFT2_UNKNOWN - BEGIN - BLOCK "StringFileInfo" - BEGIN - BLOCK "040904B0" - BEGIN - VALUE "CompanyName", "The GTK developer community" - VALUE "FileDescription", "GIMP Toolkit" - VALUE "FileVersion", "@GTK_VERSION@.0" - VALUE "InternalName", "libgdk_pixbuf-@GTK_API_VERSION@-@LT_CURRENT_MINUS_AGE@" - VALUE "LegalCopyright", "Copyright (C) 1999 The Free Software Foundation. Modified by the GTK+ Team and others 1999-2005." - VALUE "OriginalFilename", "libgdk_pixbuf-@GTK_API_VERSION@-@LT_CURRENT_MINUS_AGE@.dll" - VALUE "ProductName", "GTK+" - VALUE "ProductVersion", "@GTK_VERSION@" - END - END - BLOCK "VarFileInfo" - BEGIN - VALUE "Translation", 0x409, 1200 - END - END diff --git a/gdk-pixbuf/gen-color-table.pl b/gdk-pixbuf/gen-color-table.pl deleted file mode 100755 index 8b02fe5836..0000000000 --- a/gdk-pixbuf/gen-color-table.pl +++ /dev/null @@ -1,74 +0,0 @@ -#!/usr/bin/perl -w - -if (@ARGV != 1) { - die "Usage: gen-color-table.pl rgb.txt > xpm-color-table.h\n"; -} - -open IN, $ARGV[0] || die "Cannot open $ARGV[0]: $!\n"; - -@colors = (); -while (defined($_ = <IN>)) { - next if /^!/; - if (!/^\s*([0-9]+)\s+([0-9]+)\s+([0-9]+)\s+(.*\S)\s+$/) { - die "Cannot parse line $_"; - } - - push @colors, [$1, $2, $3, $4]; -} - -@colors = sort { lc($a->[3]) cmp lc($b->[3]) } @colors; - -$offset = 0; - -$date = gmtime; - -print <<EOT; -/* xpm-color-table.h: Generated by gen-color-table.pl from rgb.txt - * - * Date: $date - * - * Do not edit. - */ -static const char color_names[] = -EOT - -for $color (@colors) { - $name = $color->[3]; - - if ($offset != 0) { - print qq(\n); - } - print qq( "$name\\0"); - - $color->[4] = $offset; - $offset += length($name) + 1; -} - -print ";\n\n"; - -print <<EOT; -typedef struct { - guint16 name_offset; - guchar red; - guchar green; - guchar blue; -} XPMColorEntry; - -static const XPMColorEntry xColors[] = { -EOT - -$i = 0; -for $color (@colors) { - $red = $color->[0]; - $green = $color->[1]; - $blue = $color->[2]; - $offset = $color->[4]; - - if ($i != 0) { - print ",\n"; - } - print " { $offset, $red, $green, $blue }"; - $i++; -} - -print "\n};\n"; diff --git a/gdk-pixbuf/io-ani-animation.c b/gdk-pixbuf/io-ani-animation.c deleted file mode 100644 index fc19b68666..0000000000 --- a/gdk-pixbuf/io-ani-animation.c +++ /dev/null @@ -1,347 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - ani support - * - * Copyright (C) 2002 The Free Software Foundation - * - * Author: Matthias Clasen <maclas@gmx.de> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <errno.h> -#include "gdk-pixbuf-io.h" -#include "gdk-pixbuf-private.h" -#include "io-ani-animation.h" - -static void gdk_pixbuf_ani_anim_class_init (GdkPixbufAniAnimClass *klass); -static void gdk_pixbuf_ani_anim_finalize (GObject *object); - -static gboolean gdk_pixbuf_ani_anim_is_static_image (GdkPixbufAnimation *animation); -static GdkPixbuf* gdk_pixbuf_ani_anim_get_static_image (GdkPixbufAnimation *animation); -static void gdk_pixbuf_ani_anim_get_size (GdkPixbufAnimation *anim, - int *width, - int *height); -static GdkPixbufAnimationIter* gdk_pixbuf_ani_anim_get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time); - - - - -static gpointer parent_class; - -GType -gdk_pixbuf_ani_anim_get_type (void) -{ - static GType object_type = 0; - - if (!object_type) { - const GTypeInfo object_info = { - sizeof (GdkPixbufAniAnimClass), - (GBaseInitFunc) NULL, - (GBaseFinalizeFunc) NULL, - (GClassInitFunc) gdk_pixbuf_ani_anim_class_init, - NULL, /* class_finalize */ - NULL, /* class_data */ - sizeof (GdkPixbufAniAnim), - 0, /* n_preallocs */ - (GInstanceInitFunc) NULL, - }; - - object_type = g_type_register_static (GDK_TYPE_PIXBUF_ANIMATION, - g_intern_static_string ("GdkPixbufAniAnim"), - &object_info, 0); - } - - return object_type; -} - -static void -gdk_pixbuf_ani_anim_class_init (GdkPixbufAniAnimClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - GdkPixbufAnimationClass *anim_class = GDK_PIXBUF_ANIMATION_CLASS (klass); - - parent_class = g_type_class_peek_parent (klass); - - object_class->finalize = gdk_pixbuf_ani_anim_finalize; - - anim_class->is_static_image = gdk_pixbuf_ani_anim_is_static_image; - anim_class->get_static_image = gdk_pixbuf_ani_anim_get_static_image; - anim_class->get_size = gdk_pixbuf_ani_anim_get_size; - anim_class->get_iter = gdk_pixbuf_ani_anim_get_iter; -} - -static void -gdk_pixbuf_ani_anim_finalize (GObject *object) -{ - GdkPixbufAniAnim *ani_anim = GDK_PIXBUF_ANI_ANIM (object); - gint i; - - for (i = 0; i < ani_anim->n_pixbufs; i++) { - if (ani_anim->pixbufs[i]) - g_object_unref (ani_anim->pixbufs[i]); - } - g_free (ani_anim->pixbufs); - g_free (ani_anim->sequence); - g_free (ani_anim->delay); - - G_OBJECT_CLASS (parent_class)->finalize (object); -} - -static gboolean -gdk_pixbuf_ani_anim_is_static_image (GdkPixbufAnimation *animation) -{ - GdkPixbufAniAnim *ani_anim; - - ani_anim = GDK_PIXBUF_ANI_ANIM (animation); - - return ani_anim->n_frames == 1; -} - -static GdkPixbuf* -gdk_pixbuf_ani_anim_get_static_image (GdkPixbufAnimation *animation) -{ - GdkPixbufAniAnim *ani_anim; - - ani_anim = GDK_PIXBUF_ANI_ANIM (animation); - - if (ani_anim->pixbufs == NULL) - return NULL; - else - return ani_anim->pixbufs[0]; -} - -static void -gdk_pixbuf_ani_anim_get_size (GdkPixbufAnimation *anim, - int *width, - int *height) -{ - GdkPixbufAniAnim *ani_anim; - - ani_anim = GDK_PIXBUF_ANI_ANIM (anim); - - if (width) - *width = ani_anim->width; - - if (height) - *height = ani_anim->height; -} - - -static void -iter_restart (GdkPixbufAniAnimIter *iter) -{ - iter->current_frame = 0; - iter->position = 0; - iter->elapsed = 0; -} - -static GdkPixbufAnimationIter* -gdk_pixbuf_ani_anim_get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time) -{ - GdkPixbufAniAnimIter *iter; - - iter = g_object_new (GDK_TYPE_PIXBUF_ANI_ANIM_ITER, NULL); - - iter->ani_anim = GDK_PIXBUF_ANI_ANIM (anim); - - g_object_ref (iter->ani_anim); - - iter_restart (iter); - - iter->start_time = *start_time; - iter->current_time = *start_time; - - return GDK_PIXBUF_ANIMATION_ITER (iter); -} - - - -static void gdk_pixbuf_ani_anim_iter_class_init (GdkPixbufAniAnimIterClass *klass); -static void gdk_pixbuf_ani_anim_iter_finalize (GObject *object); - -static int gdk_pixbuf_ani_anim_iter_get_delay_time (GdkPixbufAnimationIter *iter); -static GdkPixbuf* gdk_pixbuf_ani_anim_iter_get_pixbuf (GdkPixbufAnimationIter *iter); -static gboolean gdk_pixbuf_ani_anim_iter_on_currently_loading_frame (GdkPixbufAnimationIter *iter); -static gboolean gdk_pixbuf_ani_anim_iter_advance (GdkPixbufAnimationIter *iter, - const GTimeVal *current_time); - - - -static gpointer iter_parent_class; - -GType -gdk_pixbuf_ani_anim_iter_get_type (void) -{ - static GType object_type = 0; - - if (!object_type) { - const GTypeInfo object_info = { - sizeof (GdkPixbufAniAnimIterClass), - (GBaseInitFunc) NULL, - (GBaseFinalizeFunc) NULL, - (GClassInitFunc) gdk_pixbuf_ani_anim_iter_class_init, - NULL, /* class_finalize */ - NULL, /* class_data */ - sizeof (GdkPixbufAniAnimIter), - 0, /* n_preallocs */ - (GInstanceInitFunc) NULL, - }; - - object_type = g_type_register_static (GDK_TYPE_PIXBUF_ANIMATION_ITER, - g_intern_static_string ("GdkPixbufAniAnimIter"), - &object_info, 0); - } - - return object_type; -} - -static void -gdk_pixbuf_ani_anim_iter_class_init (GdkPixbufAniAnimIterClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - GdkPixbufAnimationIterClass *anim_iter_class = - GDK_PIXBUF_ANIMATION_ITER_CLASS (klass); - - iter_parent_class = g_type_class_peek_parent (klass); - - object_class->finalize = gdk_pixbuf_ani_anim_iter_finalize; - - anim_iter_class->get_delay_time = gdk_pixbuf_ani_anim_iter_get_delay_time; - anim_iter_class->get_pixbuf = gdk_pixbuf_ani_anim_iter_get_pixbuf; - anim_iter_class->on_currently_loading_frame = gdk_pixbuf_ani_anim_iter_on_currently_loading_frame; - anim_iter_class->advance = gdk_pixbuf_ani_anim_iter_advance; -} - -static void -gdk_pixbuf_ani_anim_iter_finalize (GObject *object) -{ - GdkPixbufAniAnimIter *iter = GDK_PIXBUF_ANI_ANIM_ITER (object); - - g_object_unref (iter->ani_anim); - - G_OBJECT_CLASS (iter_parent_class)->finalize (object); -} - -static gboolean -gdk_pixbuf_ani_anim_iter_advance (GdkPixbufAnimationIter *anim_iter, - const GTimeVal *current_time) -{ - GdkPixbufAniAnimIter *iter; - gint elapsed; - gint tmp; - gint old; - - iter = GDK_PIXBUF_ANI_ANIM_ITER (anim_iter); - - iter->current_time = *current_time; - - /* We use milliseconds for all times */ - elapsed = - (((iter->current_time.tv_sec - iter->start_time.tv_sec) * G_USEC_PER_SEC + - iter->current_time.tv_usec - iter->start_time.tv_usec)) / 1000; - - if (elapsed < 0) { - /* Try to compensate; probably the system clock - * was set backwards - */ - iter->start_time = iter->current_time; - elapsed = 0; - } - - g_assert (iter->ani_anim->total_time > 0); - - /* See how many times we've already played the full animation, - * and subtract time for that. - */ - elapsed = elapsed % iter->ani_anim->total_time; - - iter->position = elapsed; - - /* Now move to the proper frame */ - - iter->elapsed = 0; - for (tmp = 0; tmp < iter->ani_anim->n_frames; tmp++) { - if (iter->position >= iter->elapsed && - iter->position < (iter->elapsed + iter->ani_anim->delay[tmp])) - break; - iter->elapsed += iter->ani_anim->delay[tmp]; - } - - old = iter->current_frame; - - iter->current_frame = tmp; - - return iter->current_frame != old; -} - -int -gdk_pixbuf_ani_anim_iter_get_delay_time (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufAniAnimIter *iter; - - iter = GDK_PIXBUF_ANI_ANIM_ITER (anim_iter); - - return iter->ani_anim->delay[iter->current_frame] - (iter->position - iter->elapsed); -} - -GdkPixbuf* -gdk_pixbuf_ani_anim_iter_get_pixbuf (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufAniAnimIter *iter; - gint frame; - - iter = GDK_PIXBUF_ANI_ANIM_ITER (anim_iter); - - frame = iter->ani_anim->sequence[iter->current_frame]; - - /* this is necessary if the animation is displayed while loading */ - while (frame > 0 && !iter->ani_anim->pixbufs[frame]) - frame--; - - return iter->ani_anim->pixbufs[frame]; -} - -static gboolean -gdk_pixbuf_ani_anim_iter_on_currently_loading_frame (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufAniAnimIter *iter; - gint frame; - - iter = GDK_PIXBUF_ANI_ANIM_ITER (anim_iter); - - if (iter->current_frame >= iter->ani_anim->n_frames - 1) - return TRUE; - - frame = iter->ani_anim->sequence[iter->current_frame + 1]; - - if (!iter->ani_anim->pixbufs[frame]) - return TRUE; - - return FALSE; -} - - - - - - - - - - diff --git a/gdk-pixbuf/io-ani-animation.h b/gdk-pixbuf/io-ani-animation.h deleted file mode 100644 index 88629abf16..0000000000 --- a/gdk-pixbuf/io-ani-animation.h +++ /dev/null @@ -1,113 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - ANI loader declarations - * - * Copyright (C) 2002 The Free Software Foundation - * - * Author: Matthias Clasen <maclas@gmx.de> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#ifndef GDK_PIXBUF_ANI_ANIMATION_H -#define GDK_PIXBUF_ANI_ANIMATION_H - -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-animation.h" - -typedef struct _GdkPixbufAniAnim GdkPixbufAniAnim; -typedef struct _GdkPixbufAniAnimClass GdkPixbufAniAnimClass; - -#define GDK_TYPE_PIXBUF_ANI_ANIM (gdk_pixbuf_ani_anim_get_type ()) -#define GDK_PIXBUF_ANI_ANIM(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_ANI_ANIM, GdkPixbufAniAnim)) -#define GDK_IS_PIXBUF_ANI_ANIM(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_ANI_ANIM)) - -#define GDK_PIXBUF_ANI_ANIM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_ANI_ANIM, GdkPixbufAniAnimClass)) -#define GDK_IS_PIXBUF_ANI_ANIM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_ANI_ANIM)) -#define GDK_PIXBUF_ANI_ANIM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_ANI_ANIM, GdkPixbufAniAnimClass)) - -/* Private part of the GdkPixbufAniAnim structure */ -struct _GdkPixbufAniAnim { - GdkPixbufAnimation parent_instance; - - /* Total length of animation */ - int total_time; - - /* Number of frames */ - int n_frames; - - /* Number of pixbufs */ - int n_pixbufs; - - GdkPixbuf **pixbufs; - - /* Maps frame number to pixbuf */ - int *sequence; - - /* The duration of each frame, in milliseconds */ - int *delay; - - /* bounding box size */ - int width, height; -}; - -struct _GdkPixbufAniAnimClass { - GdkPixbufAnimationClass parent_class; - -}; - -GType gdk_pixbuf_ani_anim_get_type (void) G_GNUC_CONST; - - - -typedef struct _GdkPixbufAniAnimIter GdkPixbufAniAnimIter; -typedef struct _GdkPixbufAniAnimIterClass GdkPixbufAniAnimIterClass; - - -#define GDK_TYPE_PIXBUF_ANI_ANIM_ITER (gdk_pixbuf_ani_anim_iter_get_type ()) -#define GDK_PIXBUF_ANI_ANIM_ITER(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_ANI_ANIM_ITER, GdkPixbufAniAnimIter)) -#define GDK_IS_PIXBUF_ANI_ANIM_ITER(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_ANI_ANIM_ITER)) - -#define GDK_PIXBUF_ANI_ANIM_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_ANI_ANIM_ITER, GdkPixbufAniAnimIterClass)) -#define GDK_IS_PIXBUF_ANI_ANIM_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_ANI_ANIM_ITER)) -#define GDK_PIXBUF_ANI_ANIM_ITER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_ANI_ANIM_ITER, GdkPixbufAniAnimIterClass)) - -struct _GdkPixbufAniAnimIter { - GdkPixbufAnimationIter parent_instance; - - GdkPixbufAniAnim *ani_anim; - - GTimeVal start_time; - GTimeVal current_time; - - /* Time in milliseconds into this run of the animation */ - gint position; - - /* Index of the current frame */ - gint current_frame; - - /* Time in milliseconds from the start of the animation till the - begin of the current frame */ - gint elapsed; -}; - -struct _GdkPixbufAniAnimIterClass { - GdkPixbufAnimationIterClass parent_class; - -}; - -GType gdk_pixbuf_ani_anim_iter_get_type (void) G_GNUC_CONST; - -#endif diff --git a/gdk-pixbuf/io-ani.c b/gdk-pixbuf/io-ani.c deleted file mode 100644 index 0f42868523..0000000000 --- a/gdk-pixbuf/io-ani.c +++ /dev/null @@ -1,720 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* GdkPixbuf library - ANI image loader - * - * Copyright (C) 2002 The Free Software Foundation - * - * Authors: Matthias Clasen <maclas@gmx.de> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#undef DEBUG_ANI - -#include "config.h" -#include <stdlib.h> -#include <string.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" -#include "io-ani-animation.h" - -static int -lsb_32 (guchar *src) -{ - return src[0] | (src[1] << 8) | (src[2] << 16) | (src[3] << 24); -} - -#define MAKE_TAG(a,b,c,d) ( (guint32)d << 24 | \ - (guint32)c << 16 | \ - (guint32)b << 8 | \ - (guint32)a ) - -#define TAG_RIFF MAKE_TAG('R','I','F','F') -#define TAG_ACON MAKE_TAG('A','C','O','N') -#define TAG_LIST MAKE_TAG('L','I','S','T') -#define TAG_INAM MAKE_TAG('I','N','A','M') -#define TAG_IART MAKE_TAG('I','A','R','T') -#define TAG_anih MAKE_TAG('a','n','i','h') -#define TAG_seq MAKE_TAG('s','e','q',' ') -#define TAG_rate MAKE_TAG('r','a','t','e') -#define TAG_icon MAKE_TAG('i','c','o','n') - -typedef struct _AniLoaderContext -{ - guint32 cp; - - guchar *buffer; - guchar *byte; - guint n_bytes; - guint buffer_size; - - GdkPixbufModulePreparedFunc prepared_func; - GdkPixbufModuleUpdatedFunc updated_func; - gpointer user_data; - - guint32 data_size; - - guint32 HeaderSize; - guint32 NumFrames; - guint32 NumSteps; - guint32 Width; - guint32 Height; - guint32 BitCount; - guint32 NumPlanes; - guint32 DisplayRate; - guint32 Flags; - - guint32 chunk_id; - guint32 chunk_size; - - gchar *title; - gchar *author; - - GdkPixbufAniAnim *animation; - GdkPixbufLoader *loader; - - int pos; -} AniLoaderContext; - - -#define BYTES_LEFT(context) \ - ((context)->n_bytes - ((context)->byte - (context)->buffer)) - -static void -read_int8 (AniLoaderContext *context, - guchar *data, - int count) -{ - int total = MIN (count, BYTES_LEFT (context)); - memcpy (data, context->byte, total); - context->byte += total; - context->cp += total; -} - - -static guint32 -read_int32 (AniLoaderContext *context) -{ - guint32 result; - - read_int8 (context, (guchar*) &result, 4); - return lsb_32 ((guchar *) &result); -} - -static void -context_free (AniLoaderContext *context) -{ - if (!context) - return; - - if (context->loader) - { - gdk_pixbuf_loader_close (context->loader, NULL); - g_object_unref (context->loader); - } - if (context->animation) - g_object_unref (context->animation); - g_free (context->buffer); - g_free (context->title); - g_free (context->author); - - g_free (context); -} - -static void -prepared_callback (GdkPixbufLoader *loader, - gpointer data) -{ - AniLoaderContext *context = (AniLoaderContext*)data; - -#ifdef DEBUG_ANI - g_print ("%d pixbuf prepared\n", context->pos); -#endif - - GdkPixbuf *pixbuf = gdk_pixbuf_loader_get_pixbuf (loader); - if (!pixbuf) - return; - - if (gdk_pixbuf_get_width (pixbuf) > context->animation->width) - context->animation->width = gdk_pixbuf_get_width (pixbuf); - - if (gdk_pixbuf_get_height (pixbuf) > context->animation->height) - context->animation->height = gdk_pixbuf_get_height (pixbuf); - - if (context->title != NULL) - gdk_pixbuf_set_option (pixbuf, "Title", context->title); - - if (context->author != NULL) - gdk_pixbuf_set_option (pixbuf, "Author", context->author); - - g_object_ref (pixbuf); - context->animation->pixbufs[context->pos] = pixbuf; - - if (context->pos == 0) - { - if (context->prepared_func) - (* context->prepared_func) (pixbuf, - GDK_PIXBUF_ANIMATION (context->animation), - context->user_data); - } - else { - /* FIXME - this is necessary for nice display of loading - animations because GtkImage ignores - gdk_pixbuf_animation_iter_on_currently_loading_frame() - and always exposes the full frame */ - GdkPixbuf *last = context->animation->pixbufs[context->pos - 1]; - gint width = MIN (gdk_pixbuf_get_width (last), gdk_pixbuf_get_width (pixbuf)); - gint height = MIN (gdk_pixbuf_get_height (last), gdk_pixbuf_get_height (pixbuf)); - gdk_pixbuf_copy_area (last, 0, 0, width, height, pixbuf, 0, 0); - } - - context->pos++; -} - -static void -updated_callback (GdkPixbufLoader* loader, - gint x, gint y, gint width, gint height, - gpointer data) -{ - AniLoaderContext *context = (AniLoaderContext*)data; - - GdkPixbuf *pixbuf = gdk_pixbuf_loader_get_pixbuf (loader); - - if (context->updated_func) - (* context->updated_func) (pixbuf, - x, y, width, height, - context->user_data); -} - -static gboolean -ani_load_chunk (AniLoaderContext *context, GError **error) -{ - int i; - - if (context->chunk_id == 0x0) { - if (BYTES_LEFT (context) < 8) - return FALSE; - context->chunk_id = read_int32 (context); - context->chunk_size = read_int32 (context); - /* Pad it up to word length */ - if (context->chunk_size % 2) - context->chunk_size += (2 - (context->chunk_size % 2)); - - } - - while (context->chunk_id == TAG_LIST) - { - if (BYTES_LEFT (context) < 12) - return FALSE; - - read_int32 (context); - context->chunk_id = read_int32 (context); - context->chunk_size = read_int32 (context); - /* Pad it up to word length */ - if (context->chunk_size % 2) - context->chunk_size += (2 - (context->chunk_size % 2)); - - } - - if (context->chunk_id == TAG_icon) - { - GError *loader_error = NULL; - guchar *data; - guint32 towrite; - - if (context->loader == NULL) - { - if (context->pos >= context->NumFrames) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Unexpected icon chunk in animation")); - return FALSE; - } - -#ifdef DEBUG_ANI - g_print ("opening loader\n"); -#endif - context->loader = gdk_pixbuf_loader_new_with_type ("ico", &loader_error); - if (loader_error) - { - g_propagate_error (error, loader_error); - return FALSE; - } - g_signal_connect (context->loader, "area_prepared", - G_CALLBACK (prepared_callback), context); - g_signal_connect (context->loader, "area_updated", - G_CALLBACK (updated_callback), context); - } - - towrite = MIN (context->chunk_size, BYTES_LEFT (context)); - data = context->byte; - context->byte += towrite; - context->cp += towrite; -#ifdef DEBUG_ANI - g_print ("miss %d, get %d, leftover %d\n", context->chunk_size, towrite, BYTES_LEFT (context)); -#endif - context->chunk_size -= towrite; - if (!gdk_pixbuf_loader_write (context->loader, data, towrite, &loader_error)) - { - g_propagate_error (error, loader_error); - gdk_pixbuf_loader_close (context->loader, NULL); - g_object_unref (context->loader); - context->loader = NULL; - return FALSE; - } - if (context->chunk_size == 0) - { -#ifdef DEBUG_ANI - g_print ("closing loader\n"); -#endif - if (!gdk_pixbuf_loader_close (context->loader, &loader_error)) - { - g_propagate_error (error, loader_error); - g_object_unref (context->loader); - context->loader = NULL; - return FALSE; - } - g_object_unref (context->loader); - context->loader = NULL; - context->chunk_id = 0x0; - } - return BYTES_LEFT (context) > 0; - } - - if (BYTES_LEFT (context) < context->chunk_size) - return FALSE; - - if (context->chunk_id == TAG_anih) - { - context->HeaderSize = read_int32 (context); - context->NumFrames = read_int32 (context); - context->NumSteps = read_int32 (context); - context->Width = read_int32 (context); - context->Height = read_int32 (context); - context->BitCount = read_int32 (context); - context->NumPlanes = read_int32 (context); - context->DisplayRate = read_int32 (context); - context->Flags = read_int32 (context); - -#ifdef DEBUG_ANI - g_print ("HeaderSize \t%" G_GUINT32_FORMAT - "\nNumFrames \t%" G_GUINT32_FORMAT - "\nNumSteps \t%" G_GUINT32_FORMAT - "\nWidth \t%" G_GUINT32_FORMAT - "\nHeight \t%" G_GUINT32_FORMAT - "\nBitCount \t%" G_GUINT32_FORMAT - "\nNumPlanes \t%" G_GUINT32_FORMAT - "\nDisplayRate \t%" G_GUINT32_FORMAT - "\nSequenceFlag \t%d" - "\nIconFlag \t%d" - "\n", - context->HeaderSize, context->NumFrames, - context->NumSteps, context->Width, - context->Height, context->BitCount, - context->NumPlanes, context->DisplayRate, - (context->Flags & 0x2) != 0, - (context->Flags & 0x1) != 0); -#endif - if (!(context->Flags & 0x2)) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Unsupported animation type")); - return FALSE; - } - if (context->NumFrames == 0 || - context->NumFrames >= 1024 || - context->NumSteps == 0 || - context->NumSteps >= 1024) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in animation")); - return FALSE; - } - - context->animation = g_object_new (GDK_TYPE_PIXBUF_ANI_ANIM, NULL); - if (!context->animation) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load animation")); - return FALSE; - } - - context->animation->n_pixbufs = context->NumFrames; - context->animation->n_frames = context->NumSteps; - - context->animation->total_time = context->NumSteps * (context->DisplayRate * 1000 / 60); - context->animation->width = 0; - context->animation->height = 0; - - context->animation->pixbufs = g_try_new0 (GdkPixbuf*, context->NumFrames); - context->animation->delay = g_try_new (gint, context->NumSteps); - context->animation->sequence = g_try_new (gint, context->NumSteps); - - if (!context->animation->pixbufs || - !context->animation->delay || - !context->animation->sequence) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load animation")); - return FALSE; - } - - for (i = 0; i < context->NumSteps; i++) - { - /* default values if the corresponding chunks are absent */ - context->animation->delay[i] = context->DisplayRate * 1000 / 60; - context->animation->sequence[i] = MIN (i, context->NumFrames - 1); - } - } - else if (context->chunk_id == TAG_rate) - { - if (context->chunk_size != 4 * context->NumSteps) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Malformed chunk in animation")); - return FALSE; - } - if (!context->animation) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in animation")); - return FALSE; - } - - context->animation->total_time = 0; - for (i = 0; i < context->NumSteps; i++) - { - context->animation->delay[i] = read_int32 (context) * 1000 / 60; - context->animation->total_time += context->animation->delay[i]; - } - } - else if (context->chunk_id == TAG_seq) - { - if (context->chunk_size != 4 * context->NumSteps) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Malformed chunk in animation")); - return FALSE; - } - if (!context->animation) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in animation")); - return FALSE; - } - for (i = 0; i < context->NumSteps; i++) - { - context->animation->sequence[i] = read_int32 (context); - if (context->animation->sequence[i] >= context->NumFrames) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Malformed chunk in animation")); - return FALSE; - } - } - } - else if (context->chunk_id == TAG_INAM) - { - if (!context->animation) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in animation")); - return FALSE; - } - context->title = g_try_malloc (context->chunk_size + 1); - if (!context->title) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load animation")); - return FALSE; - } - context->title[context->chunk_size] = 0; - read_int8 (context, (guchar *)context->title, context->chunk_size); -#ifdef DEBUG_ANI - g_print ("INAM %s\n", context->title); -#endif - for (i = 0; i < context->pos; i++) - gdk_pixbuf_set_option (context->animation->pixbufs[i], "Title", context->title); - } - else if (context->chunk_id == TAG_IART) - { - if (!context->animation) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in animation")); - return FALSE; - } - context->author = g_try_malloc (context->chunk_size + 1); - if (!context->author) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load animation")); - return FALSE; - } - context->author[context->chunk_size] = 0; - read_int8 (context, (guchar *)context->author, context->chunk_size); -#ifdef DEBUG_ANI - g_print ("IART %s\n", context->author); -#endif - for (i = 0; i < context->pos; i++) - gdk_pixbuf_set_option (context->animation->pixbufs[i], "Author", context->author); - } - -#ifdef DEBUG_ANI - { - gint32 dummy = lsb_32 ((guchar *)&context->chunk_id); - - g_print ("Loaded chunk with ID '%c%c%c%c' and length %" G_GUINT32_FORMAT "\n", - ((char*)&dummy)[0], ((char*)&dummy)[1], - ((char*)&dummy)[2], ((char*)&dummy)[3], - context->chunk_size); - } -#endif - - context->chunk_id = 0x0; - return TRUE; -} - -static gboolean -gdk_pixbuf__ani_image_load_increment (gpointer data, - const guchar *buf, guint size, - GError **error) -{ - AniLoaderContext *context = (AniLoaderContext *)data; - - if (context->n_bytes + size >= context->buffer_size) { - int drop = context->byte - context->buffer; - memmove (context->buffer, context->byte, context->n_bytes - drop); - context->n_bytes -= drop; - context->byte = context->buffer; - if (context->n_bytes + size >= context->buffer_size) { - guchar *tmp; - context->buffer_size = MAX (context->n_bytes + size, context->buffer_size + 4096); -#ifdef DEBUG_ANI - g_print ("growing buffer to %" G_GUINT32_FORMAT "\n", context->buffer_size); -#endif - tmp = g_try_realloc (context->buffer, context->buffer_size); - if (!tmp) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load animation")); - return FALSE; - } - context->byte = context->buffer = tmp; - } - } - memcpy (context->buffer + context->n_bytes, buf, size); - context->n_bytes += size; - - if (context->data_size == 0) - { - guint32 riff_id, chunk_id; - - if (BYTES_LEFT (context) < 12) - return TRUE; - - riff_id = read_int32 (context); - context->data_size = read_int32 (context); - chunk_id = read_int32 (context); - - if (riff_id != TAG_RIFF || - context->data_size == 0 || - chunk_id != TAG_ACON) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in animation")); - return FALSE; - } - } - - if (context->cp < context->data_size + 8) - { - GError *chunk_error = NULL; - - while (ani_load_chunk (context, &chunk_error)) ; - if (chunk_error) - { - g_propagate_error (error, chunk_error); - return FALSE; - } - } - - return TRUE; -} - -static gpointer -gdk_pixbuf__ani_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error) -{ - AniLoaderContext *context; - - context = g_new0 (AniLoaderContext, 1); - - context->prepared_func = prepared_func; - context->updated_func = updated_func; - context->user_data = user_data; - - context->pos = 0; - - context->buffer_size = 4096; - context->buffer = g_try_malloc (context->buffer_size); - if (!context->buffer) - { - context_free (context); - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load animation")); - return NULL; - } - - context->byte = context->buffer; - context->n_bytes = 0; - - return (gpointer) context; -} - -static gboolean -gdk_pixbuf__ani_image_stop_load (gpointer data, - GError **error) -{ - AniLoaderContext *context = (AniLoaderContext *) data; - - g_return_val_if_fail (context != NULL, TRUE); - context_free (context); - - return TRUE; -} - -static void -prepared_notify (GdkPixbuf *pixbuf, - GdkPixbufAnimation *anim, - gpointer user_data) -{ - if (anim != NULL) - g_object_ref (anim); - *((GdkPixbufAnimation **)user_data) = anim; -} - -static GdkPixbufAnimation * -gdk_pixbuf__ani_image_load_animation (FILE *f, GError **error) -{ - guchar buffer[4096]; - size_t length; - GdkPixbufAnimation *anim = NULL; - gpointer context; - - context = gdk_pixbuf__ani_image_begin_load (NULL, prepared_notify, - NULL, &anim, error); - - if (!context) - return NULL; - - while (!feof (f) && !ferror (f)) { - length = fread (buffer, 1, sizeof (buffer), f); - if (length > 0) - if (!gdk_pixbuf__ani_image_load_increment (context, buffer, length, error)) { - gdk_pixbuf__ani_image_stop_load (context, NULL); - if (anim != NULL) - g_object_unref (anim); - return NULL; - } - } - - if (!gdk_pixbuf__ani_image_stop_load (context, error)) { - if (anim != NULL) - g_object_unref (anim); - return NULL; - } - - return anim; -} - -#ifndef INCLUDE_ani -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__ani_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->load_animation = gdk_pixbuf__ani_image_load_animation; - module->begin_load = gdk_pixbuf__ani_image_begin_load; - module->stop_load = gdk_pixbuf__ani_image_stop_load; - module->load_increment = gdk_pixbuf__ani_image_load_increment; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "RIFF ACON", " xxxx ", 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "application/x-navi-animation", - NULL - }; - static gchar * extensions[] = { - "ani", - NULL - }; - - info->name = "ani"; - info->signature = signature; - info->description = N_("The ANI image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} - - - - diff --git a/gdk-pixbuf/io-bmp.c b/gdk-pixbuf/io-bmp.c deleted file mode 100644 index e654d1f7d5..0000000000 --- a/gdk-pixbuf/io-bmp.c +++ /dev/null @@ -1,1429 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* GdkPixbuf library - Windows Bitmap image loader - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Arjan van de Ven <arjan@fenrus.demon.nl> - * Federico Mena-Quintero <federico@gimp.org> - * - * Based on io-ras.c - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <stdio.h> -#ifdef HAVE_UNISTD_H -#include <unistd.h> -#endif -#include <string.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - -#define DUMPBIH 0 - - - -#if 0 -/* If these structures were unpacked, they would define the two headers of the - * BMP file. After them comes the palette, and then the image data. - * - * We do not use these structures; we just keep them here for reference. - */ -struct BitmapFileHeader { - guint16 magic; - guint32 file_size; - guint32 reserved; - guint32 data_offset; -}; - -struct BitmapInfoHeader { - guint32 header_size; - guint32 width; - guint32 height; - guint16 planes; - guint16 bpp; - guint32 compression; - guint32 data_size; - guint32 x_ppm; - guint32 y_ppm; - guint32 n_colors; - guint32 n_important_colors; -}; -#endif - -/* Compression values */ - -#define BI_RGB 0 -#define BI_RLE8 1 -#define BI_RLE4 2 -#define BI_BITFIELDS 3 - -/* State machine */ -typedef enum { - READ_STATE_HEADERS, /* Reading the bitmap file header and bitmap info header */ - READ_STATE_PALETTE, /* Reading the palette */ - READ_STATE_BITMASKS, /* Reading the bitmasks for BI_BITFIELDS */ - READ_STATE_DATA, /* Reading the actual image data */ - READ_STATE_ERROR, /* An error occurred; further data will be ignored */ - READ_STATE_DONE /* Done reading the image; further data will be ignored */ -} ReadState; - -/* - -DumpBIH printf's the values in a BitmapInfoHeader to the screen, for -debugging purposes. - -*/ -#if DUMPBIH -static void DumpBIH(unsigned char *BIH) -{ - printf("biSize = %i \n", - (int) (BIH[3] << 24) + (BIH[2] << 16) + (BIH[1] << 8) + - (BIH[0])); - printf("biWidth = %i \n", - (int) (BIH[7] << 24) + (BIH[6] << 16) + (BIH[5] << 8) + - (BIH[4])); - printf("biHeight = %i \n", - (int) (BIH[11] << 24) + (BIH[10] << 16) + (BIH[9] << 8) + - (BIH[8])); - printf("biPlanes = %i \n", (int) (BIH[13] << 8) + (BIH[12])); - printf("biBitCount = %i \n", (int) (BIH[15] << 8) + (BIH[14])); - printf("biCompress = %i \n", - (int) (BIH[19] << 24) + (BIH[18] << 16) + (BIH[17] << 8) + - (BIH[16])); - printf("biSizeImage = %i \n", - (int) (BIH[23] << 24) + (BIH[22] << 16) + (BIH[21] << 8) + - (BIH[20])); - printf("biXPels = %i \n", - (int) (BIH[27] << 24) + (BIH[26] << 16) + (BIH[25] << 8) + - (BIH[24])); - printf("biYPels = %i \n", - (int) (BIH[31] << 24) + (BIH[30] << 16) + (BIH[29] << 8) + - (BIH[28])); - printf("biClrUsed = %i \n", - (int) (BIH[35] << 24) + (BIH[34] << 16) + (BIH[33] << 8) + - (BIH[32])); - printf("biClrImprtnt= %i \n", - (int) (BIH[39] << 24) + (BIH[38] << 16) + (BIH[37] << 8) + - (BIH[36])); -} -#endif -/* struct headerpair contains the decoded width/height/depth info for - the current bitmap */ - -struct headerpair { - guint32 size; - gint32 width; - gint32 height; - guint depth; - guint Negative; /* Negative = 1 -> top down BMP, - Negative = 0 -> bottom up BMP */ - guint n_colors; -}; - -/* Data needed for the "state" during decompression */ -struct bmp_compression_state { - gint phase; - gint run; - gint count; - gint x, y; - guchar *p; -}; - -/* Progressive loading */ - -struct bmp_progressive_state { - GdkPixbufModuleSizeFunc size_func; - GdkPixbufModulePreparedFunc prepared_func; - GdkPixbufModuleUpdatedFunc updated_func; - gpointer user_data; - - ReadState read_state; - - guint LineWidth; - guint Lines; /* # of finished lines */ - - guchar *buff; - guint BufferSize; - guint BufferPadding; - guint BufferDone; - - guchar (*Colormap)[3]; - - gint Type; /* - 32 = RGB + alpha - 24 = RGB - 16 = RGB - 4 = 4 bpp colormapped - 8 = 8 bpp colormapped - 1 = 1 bit bitonal - */ - guint Compressed; - struct bmp_compression_state compr; - - - struct headerpair Header; /* Decoded (BE->CPU) header */ - - /* Bit masks, shift amounts, and significant bits for BI_BITFIELDS coding */ - int r_mask, r_shift, r_bits; - int g_mask, g_shift, g_bits; - int b_mask, b_shift, b_bits; - int a_mask, a_shift, a_bits; - - GdkPixbuf *pixbuf; /* Our "target" */ -}; - -static gpointer -gdk_pixbuf__bmp_image_begin_load(GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error); - -static gboolean gdk_pixbuf__bmp_image_stop_load(gpointer data, GError **error); -static gboolean gdk_pixbuf__bmp_image_load_increment(gpointer data, - const guchar * buf, - guint size, - GError **error); - - -/* Picks up a 32-bit little-endian integer starting at the specified location. - * Does it by hand instead of dereferencing a simple (gint *) cast due to - * alignment constraints many platforms. - */ -static int -lsb_32 (guchar *src) -{ - return src[0] | (src[1] << 8) | (src[2] << 16) | (src[3] << 24); -} - -/* Same as above, but for 16-bit little-endian integers. */ -static short -lsb_16 (guchar *src) -{ - return src[0] | (src[1] << 8); -} - -static gboolean grow_buffer (struct bmp_progressive_state *State, - GError **error) -{ - guchar *tmp; - - if (State->BufferSize == 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("BMP image has bogus header data")); - State->read_state = READ_STATE_ERROR; - return FALSE; - } - - tmp = g_try_realloc (State->buff, State->BufferSize); - - if (!tmp) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load bitmap image")); - State->read_state = READ_STATE_ERROR; - return FALSE; - } - - State->buff = tmp; - return TRUE; -} - -static gboolean -decode_bitmasks (guchar *buf, - struct bmp_progressive_state *State, - GError **error); - -static gboolean DecodeHeader(unsigned char *BFH, unsigned char *BIH, - struct bmp_progressive_state *State, - GError **error) -{ - gint clrUsed; - - /* First check for the two first bytes content. A sane - BMP file must start with bytes 0x42 0x4D. */ - if (*BFH != 0x42 || *(BFH + 1) != 0x4D) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("BMP image has bogus header data")); - State->read_state = READ_STATE_ERROR; - return FALSE; - } - - /* FIXME this is totally unrobust against bogus image data. */ - if (State->BufferSize < lsb_32 (&BIH[0]) + 14) { - State->BufferSize = lsb_32 (&BIH[0]) + 14; - if (!grow_buffer (State, error)) - return FALSE; - return TRUE; - } - -#if DUMPBIH - DumpBIH(BIH); -#endif - - State->Header.size = lsb_32 (&BIH[0]); - if (State->Header.size == 124) { - /* BMP v5 */ - State->Header.width = lsb_32 (&BIH[4]); - State->Header.height = lsb_32 (&BIH[8]); - State->Header.depth = lsb_16 (&BIH[14]); - State->Compressed = lsb_32 (&BIH[16]); - } else if (State->Header.size == 108) { - /* BMP v4 */ - State->Header.width = lsb_32 (&BIH[4]); - State->Header.height = lsb_32 (&BIH[8]); - State->Header.depth = lsb_16 (&BIH[14]); - State->Compressed = lsb_32 (&BIH[16]); - } else if (State->Header.size == 64) { - /* BMP OS/2 v2 */ - State->Header.width = lsb_32 (&BIH[4]); - State->Header.height = lsb_32 (&BIH[8]); - State->Header.depth = lsb_16 (&BIH[14]); - State->Compressed = lsb_32 (&BIH[16]); - } else if (State->Header.size == 40) { - /* BMP v3 */ - State->Header.width = lsb_32 (&BIH[4]); - State->Header.height = lsb_32 (&BIH[8]); - State->Header.depth = lsb_16 (&BIH[14]); - State->Compressed = lsb_32 (&BIH[16]); - } else if (State->Header.size == 12) { - /* BMP OS/2 */ - State->Header.width = lsb_16 (&BIH[4]); - State->Header.height = lsb_16 (&BIH[6]); - State->Header.depth = lsb_16 (&BIH[10]); - State->Compressed = BI_RGB; - } else { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("BMP image has unsupported header size")); - State->read_state = READ_STATE_ERROR; - return FALSE; - } - - if (State->Header.size == 12) - clrUsed = 1 << State->Header.depth; - else - clrUsed = (int) (BIH[35] << 24) + (BIH[34] << 16) + (BIH[33] << 8) + (BIH[32]); - - if (clrUsed != 0) - State->Header.n_colors = clrUsed; - else - State->Header.n_colors = (1 << State->Header.depth); - - if (State->Header.n_colors > (1 << State->Header.depth)) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("BMP image has bogus header data")); - State->read_state = READ_STATE_ERROR; - return FALSE; - } - - State->Type = State->Header.depth; /* This may be less trivial someday */ - - /* Negative heights indicates bottom-down pixelorder */ - if (State->Header.height < 0) { - State->Header.height = -State->Header.height; - State->Header.Negative = 1; - } - - if (State->Header.Negative && - (State->Compressed != BI_RGB && State->Compressed != BI_BITFIELDS)) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Topdown BMP images cannot be compressed")); - State->read_state = READ_STATE_ERROR; - return FALSE; - } - - if (State->Header.width <= 0 || State->Header.height == 0 || - (State->Compressed == BI_RLE4 && State->Type != 4) || - (State->Compressed == BI_RLE8 && State->Type != 8) || - (State->Compressed == BI_BITFIELDS && !(State->Type == 16 || State->Type == 32)) || - (State->Compressed > BI_BITFIELDS)) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("BMP image has bogus header data")); - State->read_state = READ_STATE_ERROR; - return FALSE; - } - - if (State->Type == 32) - State->LineWidth = State->Header.width * 4; - else if (State->Type == 24) - State->LineWidth = State->Header.width * 3; - else if (State->Type == 16) - State->LineWidth = State->Header.width * 2; - else if (State->Type == 8) - State->LineWidth = State->Header.width * 1; - else if (State->Type == 4) - State->LineWidth = (State->Header.width + 1) / 2; - else if (State->Type == 1) { - State->LineWidth = State->Header.width / 8; - if ((State->Header.width & 7) != 0) - State->LineWidth++; - } else { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("BMP image has bogus header data")); - State->read_state = READ_STATE_ERROR; - return FALSE; - } - - /* Pad to a 32 bit boundary */ - if (((State->LineWidth % 4) > 0) - && (State->Compressed == BI_RGB || State->Compressed == BI_BITFIELDS)) - State->LineWidth = (State->LineWidth / 4) * 4 + 4; - - if (State->pixbuf == NULL) { - if (State->size_func) { - gint width = State->Header.width; - gint height = State->Header.height; - - (*State->size_func) (&width, &height, State->user_data); - if (width == 0 || height == 0) { - State->read_state = READ_STATE_DONE; - State->BufferSize = 0; - return TRUE; - } - } - - if (State->Type == 32 || - State->Compressed == BI_RLE4 || - State->Compressed == BI_RLE8) - State->pixbuf = - gdk_pixbuf_new(GDK_COLORSPACE_RGB, TRUE, 8, - (gint) State->Header.width, - (gint) State->Header.height); - else - State->pixbuf = - gdk_pixbuf_new(GDK_COLORSPACE_RGB, FALSE, 8, - (gint) State->Header.width, - (gint) State->Header.height); - - if (State->pixbuf == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load bitmap image")); - State->read_state = READ_STATE_ERROR; - return FALSE; - } - - if (State->prepared_func != NULL) - /* Notify the client that we are ready to go */ - (*State->prepared_func) (State->pixbuf, NULL, State->user_data); - - /* make all pixels initially transparent */ - if (State->Compressed == BI_RLE4 || State->Compressed == BI_RLE8) { - memset (State->pixbuf->pixels, 0, State->pixbuf->rowstride * State->Header.height); - State->compr.p = State->pixbuf->pixels - + State->pixbuf->rowstride * (State->Header.height- 1); - } - } - - State->BufferDone = 0; - if (State->Type <= 8) { - gint samples; - - State->read_state = READ_STATE_PALETTE; - - /* Allocate enough to hold the palette */ - samples = (State->Header.size == 12 ? 3 : 4); - State->BufferSize = State->Header.n_colors * samples; - - /* Skip over everything between the palette and the data. - This protects us against a malicious BFH[10] value. - */ - State->BufferPadding = (lsb_32 (&BFH[10]) - 14 - State->Header.size) - State->BufferSize; - - } else if (State->Compressed == BI_RGB) { - if (State->BufferSize < lsb_32 (&BFH[10])) - { - /* skip over padding between headers and image data */ - State->read_state = READ_STATE_HEADERS; - State->BufferDone = State->BufferSize; - State->BufferSize = lsb_32 (&BFH[10]); - } - else - { - State->read_state = READ_STATE_DATA; - State->BufferSize = State->LineWidth; - } - } else if (State->Compressed == BI_BITFIELDS) { - if (State->Header.size == 108 || State->Header.size == 124) - { - /* v4 and v5 have the bitmasks in the header */ - if (!decode_bitmasks (&BIH[40], State, error)) { - State->read_state = READ_STATE_ERROR; - return FALSE; - } - } - else - { - State->read_state = READ_STATE_BITMASKS; - State->BufferSize = 12; - } - } else { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("BMP image has bogus header data")); - State->read_state = READ_STATE_ERROR; - return FALSE; - } - - if (!grow_buffer (State, error)) - return FALSE; - - return TRUE; -} - -static gboolean DecodeColormap (guchar *buff, - struct bmp_progressive_state *State, - GError **error) -{ - gint i; - gint samples; - - g_assert (State->read_state == READ_STATE_PALETTE); - - samples = (State->Header.size == 12 ? 3 : 4); - if (State->BufferSize < State->Header.n_colors * samples) { - State->BufferSize = State->Header.n_colors * samples; - if (!grow_buffer (State, error)) - return FALSE; - return TRUE; - } - - State->Colormap = g_malloc0 ((1 << State->Header.depth) * sizeof (*State->Colormap)); - for (i = 0; i < State->Header.n_colors; i++) - - { - State->Colormap[i][0] = buff[i * samples]; - State->Colormap[i][1] = buff[i * samples + 1]; - State->Colormap[i][2] = buff[i * samples + 2]; -#ifdef DUMPCMAP - g_print ("color %d %x %x %x\n", i, - State->Colormap[i][0], - State->Colormap[i][1], - State->Colormap[i][2]); -#endif - } - - State->read_state = READ_STATE_DATA; - - State->BufferDone = 0; - if (!(State->Compressed == BI_RGB || State->Compressed == BI_BITFIELDS)) - State->BufferSize = 2; - else - State->BufferSize = State->LineWidth; - - if (!grow_buffer (State, error)) - return FALSE; - - return TRUE; -} - -/* Finds the lowest set bit and the number of set bits */ -static void -find_bits (int n, int *lowest, int *n_set) -{ - int i; - - *n_set = 0; - - for (i = 31; i >= 0; i--) - if (n & (1 << i)) { - *lowest = i; - (*n_set)++; - } -} - -/* Decodes the bitmasks for BI_BITFIELDS coding */ -static gboolean -decode_bitmasks (guchar *buf, - struct bmp_progressive_state *State, - GError **error) -{ - State->a_mask = State->a_shift = State->a_bits = 0; - State->r_mask = buf[0] | (buf[1] << 8) | (buf[2] << 16) | (buf[3] << 24); - buf += 4; - - State->g_mask = buf[0] | (buf[1] << 8) | (buf[2] << 16) | (buf[3] << 24); - buf += 4; - - State->b_mask = buf[0] | (buf[1] << 8) | (buf[2] << 16) | (buf[3] << 24); - - find_bits (State->r_mask, &State->r_shift, &State->r_bits); - find_bits (State->g_mask, &State->g_shift, &State->g_bits); - find_bits (State->b_mask, &State->b_shift, &State->b_bits); - - /* v4 and v5 have an alpha mask */ - if (State->Header.size == 108 || State->Header.size == 124) { - buf += 4; - State->a_mask = buf[0] | (buf[1] << 8) | (buf[2] << 16) | (buf[3] << 24); - find_bits (State->a_mask, &State->a_shift, &State->a_bits); - } - - if (State->r_bits == 0 || State->g_bits == 0 || State->b_bits == 0) { - if (State->Type == 16) { - State->r_mask = 0x7c00; - State->r_shift = 10; - State->g_mask = 0x03e0; - State->g_shift = 5; - State->b_mask = 0x001f; - State->b_shift = 0; - - State->r_bits = State->g_bits = State->b_bits = 5; - } - else { - State->r_mask = 0x00ff0000; - State->r_shift = 16; - State->g_mask = 0x0000ff00; - State->g_shift = 8; - State->b_mask = 0x000000ff; - State->b_shift = 0; - State->a_mask = 0xff000000; - State->a_shift = 24; - - State->r_bits = State->g_bits = State->b_bits = State->a_bits = 8; - } - } - - if (State->r_bits > 8) { - State->r_shift += State->r_bits - 8; - State->r_bits = 8; - } - if (State->g_bits > 8) { - State->g_shift += State->g_bits - 8; - State->g_bits = 8; - } - if (State->b_bits > 8) { - State->b_shift += State->b_bits - 8; - State->b_bits = 8; - } - if (State->a_bits > 8) { - State->a_shift += State->a_bits - 8; - State->a_bits = 8; - } - - State->read_state = READ_STATE_DATA; - State->BufferDone = 0; - State->BufferSize = State->LineWidth; - if (!grow_buffer (State, error)) - return FALSE; - - return TRUE; -} - -/* - * func - called when we have pixmap created (but no image data) - * user_data - passed as arg 1 to func - * return context (opaque to user) - */ - -static gpointer -gdk_pixbuf__bmp_image_begin_load(GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error) -{ - struct bmp_progressive_state *context; - - context = g_new0(struct bmp_progressive_state, 1); - context->size_func = size_func; - context->prepared_func = prepared_func; - context->updated_func = updated_func; - context->user_data = user_data; - - context->read_state = READ_STATE_HEADERS; - - context->BufferSize = 26; - context->BufferPadding = 0; - context->buff = g_malloc(26); - context->BufferDone = 0; - /* 14 for the BitmapFileHeader, 12 for the BitmapImageHeader */ - - context->Colormap = NULL; - - context->Lines = 0; - - context->Type = 0; - - memset(&context->Header, 0, sizeof(struct headerpair)); - memset(&context->compr, 0, sizeof(struct bmp_compression_state)); - - - context->pixbuf = NULL; - - return (gpointer) context; -} - -/* - * context - returned from image_begin_load - * - * free context, unref gdk_pixbuf - */ -static gboolean gdk_pixbuf__bmp_image_stop_load(gpointer data, GError **error) -{ - gboolean retval = TRUE; - - struct bmp_progressive_state *context = - (struct bmp_progressive_state *) data; - - /* FIXME this thing needs to report errors if - * we have unused image data - */ - - g_return_val_if_fail(context != NULL, TRUE); - - g_free(context->Colormap); - - if (context->pixbuf) - g_object_unref(context->pixbuf); - - if (context->read_state == READ_STATE_HEADERS) { - if (error && *error == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Premature end-of-file encountered")); - } - retval = FALSE; - } - - g_free(context->buff); - g_free(context); - - return retval; -} - - -/* -The OneLineXX functions are called when 1 line worth of data is present. -OneLine24 is the 24 bpp-version. -*/ -static void OneLine32(struct bmp_progressive_state *context) -{ - int i; - guchar *pixels; - guchar *src; - - if (!context->Header.Negative) - pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * (context->Header.height - context->Lines - 1)); - else - pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * context->Lines); - - src = context->buff; - - if (context->Compressed == BI_BITFIELDS) { - int r_lshift, r_rshift; - int g_lshift, g_rshift; - int b_lshift, b_rshift; - int a_lshift, a_rshift; - - r_lshift = 8 - context->r_bits; - g_lshift = 8 - context->g_bits; - b_lshift = 8 - context->b_bits; - a_lshift = 8 - context->a_bits; - - r_rshift = context->r_bits - r_lshift; - g_rshift = context->g_bits - g_lshift; - b_rshift = context->b_bits - b_lshift; - a_rshift = context->a_bits - a_lshift; - - for (i = 0; i < context->Header.width; i++) { - unsigned int v, r, g, b, a; - - v = src[0] | (src[1] << 8) | (src[2] << 16) | (src[3] << 24); - - r = (v & context->r_mask) >> context->r_shift; - g = (v & context->g_mask) >> context->g_shift; - b = (v & context->b_mask) >> context->b_shift; - a = (v & context->a_mask) >> context->a_shift; - - *pixels++ = (r << r_lshift) | (r >> r_rshift); - *pixels++ = (g << g_lshift) | (g >> g_rshift); - *pixels++ = (b << b_lshift) | (b >> b_rshift); - if (context->a_bits) - *pixels++ = (a << a_lshift) | (a >> a_rshift); - else - *pixels++ = 0xff; - - src += 4; - } - } else - for (i = 0; i < context->Header.width; i++) { - *pixels++ = src[2]; - *pixels++ = src[1]; - *pixels++ = src[0]; - *pixels++ = 0xff; - - src += 4; - } -} - -static void OneLine24(struct bmp_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - if (context->Header.Negative == 0) - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (context->Header.height - context->Lines - 1)); - else - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - context->Lines); - while (X < context->Header.width) { - Pixels[X * 3 + 0] = context->buff[X * 3 + 2]; - Pixels[X * 3 + 1] = context->buff[X * 3 + 1]; - Pixels[X * 3 + 2] = context->buff[X * 3 + 0]; - X++; - } - -} - -static void OneLine16(struct bmp_progressive_state *context) -{ - int i; - guchar *pixels; - guchar *src; - - if (!context->Header.Negative) - pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * (context->Header.height - context->Lines - 1)); - else - pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * context->Lines); - - src = context->buff; - - if (context->Compressed == BI_BITFIELDS) { - int r_lshift, r_rshift; - int g_lshift, g_rshift; - int b_lshift, b_rshift; - - r_lshift = 8 - context->r_bits; - g_lshift = 8 - context->g_bits; - b_lshift = 8 - context->b_bits; - - r_rshift = context->r_bits - r_lshift; - g_rshift = context->g_bits - g_lshift; - b_rshift = context->b_bits - b_lshift; - - for (i = 0; i < context->Header.width; i++) { - int v, r, g, b; - - v = (int) src[0] | ((int) src[1] << 8); - - r = (v & context->r_mask) >> context->r_shift; - g = (v & context->g_mask) >> context->g_shift; - b = (v & context->b_mask) >> context->b_shift; - - *pixels++ = (r << r_lshift) | (r >> r_rshift); - *pixels++ = (g << g_lshift) | (g >> g_rshift); - *pixels++ = (b << b_lshift) | (b >> b_rshift); - - src += 2; - } - } else - for (i = 0; i < context->Header.width; i++) { - int v, r, g, b; - - v = src[0] | (src[1] << 8); - - r = (v >> 10) & 0x1f; - g = (v >> 5) & 0x1f; - b = v & 0x1f; - - *pixels++ = (r << 3) | (r >> 2); - *pixels++ = (g << 3) | (g >> 2); - *pixels++ = (b << 3) | (b >> 2); - - src += 2; - } -} - -static void OneLine8(struct bmp_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - if (context->Header.Negative == 0) - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (context->Header.height - context->Lines - 1)); - else - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - context->Lines); - while (X < context->Header.width) { - Pixels[X * 3 + 0] = - context->Colormap[context->buff[X]][2]; - Pixels[X * 3 + 1] = - context->Colormap[context->buff[X]][1]; - Pixels[X * 3 + 2] = - context->Colormap[context->buff[X]][0]; - X++; - } -} - -static void OneLine4(struct bmp_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - if (context->Header.Negative == 0) - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (context->Header.height - context->Lines - 1)); - else - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - context->Lines); - - while (X < context->Header.width) { - guchar Pix; - - Pix = context->buff[X / 2]; - - Pixels[X * 3 + 0] = - context->Colormap[Pix >> 4][2]; - Pixels[X * 3 + 1] = - context->Colormap[Pix >> 4][1]; - Pixels[X * 3 + 2] = - context->Colormap[Pix >> 4][0]; - X++; - if (X < context->Header.width) { - /* Handle the other 4 bit pixel only when there is one */ - Pixels[X * 3 + 0] = - context->Colormap[Pix & 15][2]; - Pixels[X * 3 + 1] = - context->Colormap[Pix & 15][1]; - Pixels[X * 3 + 2] = - context->Colormap[Pix & 15][0]; - X++; - } - } - -} - -static void OneLine1(struct bmp_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - if (context->Header.Negative == 0) - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (context->Header.height - context->Lines - 1)); - else - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - context->Lines); - while (X < context->Header.width) { - gint Bit; - - Bit = (context->buff[X / 8]) >> (7 - (X & 7)); - Bit = Bit & 1; - Pixels[X * 3 + 0] = context->Colormap[Bit][2]; - Pixels[X * 3 + 1] = context->Colormap[Bit][1]; - Pixels[X * 3 + 2] = context->Colormap[Bit][0]; - X++; - } -} - - -static void OneLine(struct bmp_progressive_state *context) -{ - context->BufferDone = 0; - if (context->Lines >= context->Header.height) - return; - - if (context->Type == 32) - OneLine32(context); - else if (context->Type == 24) - OneLine24(context); - else if (context->Type == 16) - OneLine16(context); - else if (context->Type == 8) - OneLine8(context); - else if (context->Type == 4) - OneLine4(context); - else if (context->Type == 1) - OneLine1(context); - else - g_assert_not_reached (); - - context->Lines++; - - if (context->updated_func != NULL) { - (*context->updated_func) (context->pixbuf, - 0, - (context->Header.Negative ? - (context->Lines - 1) : - (context->Header.height - context->Lines)), - context->Header.width, - 1, - context->user_data); - - } -} - -#define NEUTRAL 0 -#define ENCODED 1 -#define ESCAPE 2 -#define DELTA_X 3 -#define DELTA_Y 4 -#define ABSOLUTE 5 -#define SKIP 6 - -#define END_OF_LINE 0 -#define END_OF_BITMAP 1 -#define DELTA 2 - -static gboolean -DoCompressed(struct bmp_progressive_state *context, GError **error) -{ - gint i, j; - gint y; - guchar c; - gint idx; - - /* context->compr.y might be past the last line because we are - * on padding past the end of a valid data, or we might have hit - * out-of-bounds data. Either way we just eat-and-ignore the - * rest of the file. Doing the check only here and not when - * we change y below is fine since BufferSize is always 2 here - * and the BMP file format always starts new data on 16-bit - * boundaries. - */ - if (context->compr.y >= context->Header.height) { - context->BufferDone = 0; - return TRUE; - } - - y = context->compr.y; - - for (i = 0; i < context->BufferSize; i++) { - c = context->buff[i]; - switch (context->compr.phase) { - case NEUTRAL: - if (c) { - context->compr.run = c; - context->compr.phase = ENCODED; - } - else - context->compr.phase = ESCAPE; - break; - case ENCODED: - for (j = 0; j < context->compr.run; j++) { - if (context->Compressed == BI_RLE8) - idx = c; - else if (j & 1) - idx = c & 0x0f; - else - idx = (c >> 4) & 0x0f; - if (context->compr.x < context->Header.width) { - *context->compr.p++ = context->Colormap[idx][2]; - *context->compr.p++ = context->Colormap[idx][1]; - *context->compr.p++ = context->Colormap[idx][0]; - *context->compr.p++ = 0xff; - context->compr.x++; - } - } - context->compr.phase = NEUTRAL; - break; - case ESCAPE: - switch (c) { - case END_OF_LINE: - context->compr.x = 0; - context->compr.y++; - context->compr.p = context->pixbuf->pixels - + (context->pixbuf->rowstride * (context->Header.height - context->compr.y - 1)) - + (4 * context->compr.x); - context->compr.phase = NEUTRAL; - break; - case END_OF_BITMAP: - context->compr.x = 0; - context->compr.y = context->Header.height; - context->compr.phase = NEUTRAL; - break; - case DELTA: - context->compr.phase = DELTA_X; - break; - default: - context->compr.run = c; - context->compr.count = 0; - context->compr.phase = ABSOLUTE; - break; - } - break; - case DELTA_X: - context->compr.x += c; - context->compr.phase = DELTA_Y; - break; - case DELTA_Y: - context->compr.y += c; - context->compr.p = context->pixbuf->pixels - + (context->pixbuf->rowstride * (context->Header.height - context->compr.y - 1)) - + (4 * context->compr.x); - context->compr.phase = NEUTRAL; - break; - case ABSOLUTE: - if (context->Compressed == BI_RLE8) { - idx = c; - if (context->compr.x < context->Header.width) { - *context->compr.p++ = context->Colormap[idx][2]; - *context->compr.p++ = context->Colormap[idx][1]; - *context->compr.p++ = context->Colormap[idx][0]; - *context->compr.p++ = 0xff; - context->compr.x++; - } - context->compr.count++; - - if (context->compr.count == context->compr.run) { - if (context->compr.run & 1) - context->compr.phase = SKIP; - else - context->compr.phase = NEUTRAL; - } - } - else { - for (j = 0; j < 2; j++) { - if (context->compr.count & 1) - idx = c & 0x0f; - else - idx = (c >> 4) & 0x0f; - if (context->compr.x < context->Header.width) { - *context->compr.p++ = context->Colormap[idx][2]; - *context->compr.p++ = context->Colormap[idx][1]; - *context->compr.p++ = context->Colormap[idx][0]; - *context->compr.p++ = 0xff; - context->compr.x++; - } - context->compr.count++; - - if (context->compr.count == context->compr.run) { - if ((context->compr.run & 3) == 1 - || (context->compr.run & 3) == 2) - context->compr.phase = SKIP; - else - context->compr.phase = NEUTRAL; - break; - } - } - } - break; - case SKIP: - context->compr.phase = NEUTRAL; - break; - } - } - if (context->updated_func != NULL) { - if (context->compr.y > y) - { - gint new_y = MIN (context->compr.y, context->Header.height); - (*context->updated_func) (context->pixbuf, - 0, - context->Header.height - new_y, - context->Header.width, - new_y - y, - context->user_data); - } - - } - - context->BufferDone = 0; - return TRUE; -} - -/* - * context - from image_begin_load - * buf - new image data - * size - length of new image data - * - * append image data onto incrementally built output image - */ -static gboolean -gdk_pixbuf__bmp_image_load_increment(gpointer data, - const guchar * buf, - guint size, - GError **error) -{ - struct bmp_progressive_state *context = - (struct bmp_progressive_state *) data; - - gint BytesToCopy; - gint BytesToRemove; - - if (context->read_state == READ_STATE_DONE) - return TRUE; - else if (context->read_state == READ_STATE_ERROR) - return FALSE; - - while (size > 0) { - if (context->BufferDone < context->BufferSize) { /* We still - have headerbytes to do */ - BytesToCopy = - context->BufferSize - context->BufferDone; - if (BytesToCopy > size) - BytesToCopy = size; - - memmove(context->buff + context->BufferDone, - buf, BytesToCopy); - - size -= BytesToCopy; - buf += BytesToCopy; - context->BufferDone += BytesToCopy; - - if (context->BufferDone != context->BufferSize) - break; - } - - /* context->buff is full. Now we discard all "padding" */ - if (context->BufferPadding != 0) { - BytesToRemove = context->BufferPadding - size; - if (BytesToRemove > size) { - BytesToRemove = size; - } - size -= BytesToRemove; - context->BufferPadding -= BytesToRemove; - - if (context->BufferPadding != 0) - break; - } - - switch (context->read_state) { - case READ_STATE_HEADERS: - if (!DecodeHeader (context->buff, - context->buff + 14, context, - error)) - return FALSE; - - break; - - case READ_STATE_PALETTE: - if (!DecodeColormap (context->buff, context, error)) - return FALSE; - break; - - case READ_STATE_BITMASKS: - if (!decode_bitmasks (context->buff, context, error)) - return FALSE; - break; - - case READ_STATE_DATA: - if (context->Compressed == BI_RGB || context->Compressed == BI_BITFIELDS) - OneLine (context); - else if (!DoCompressed (context, error)) - return FALSE; - - break; - case READ_STATE_DONE: - return TRUE; - break; - - default: - g_assert_not_reached (); - } - } - - return TRUE; -} - -/* for our convenience when filling file header */ -#define put16(buf,data) { guint16 x; \ - x = GUINT16_TO_LE (data); \ - memcpy(buf, &x, 2); \ - buf += 2; } -#define put32(buf,data) { guint32 x; \ - x = GUINT32_TO_LE (data); \ - memcpy(buf, &x, 4); \ - buf += 4; } - -static gboolean -gdk_pixbuf__bmp_image_save_to_callback (GdkPixbufSaveFunc save_func, - gpointer user_data, - GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error) -{ - guint width, height, channel, size, stride, src_stride, x, y; - guchar BFH_BIH[54], *pixels, *buf, *src, *dst, *dst_line; - gboolean ret; - - width = gdk_pixbuf_get_width (pixbuf); - height = gdk_pixbuf_get_height (pixbuf); - channel = gdk_pixbuf_get_n_channels (pixbuf); - pixels = gdk_pixbuf_get_pixels (pixbuf); - src_stride = gdk_pixbuf_get_rowstride (pixbuf); - stride = (width * 3 + 3) & ~3; - size = stride * height; - - /* filling BFH */ - dst = BFH_BIH; - *dst++ = 'B'; /* bfType */ - *dst++ = 'M'; - put32 (dst, size + 14 + 40); /* bfSize */ - put32 (dst, 0); /* bfReserved1 + bfReserved2 */ - put32 (dst, 14 + 40); /* bfOffBits */ - - /* filling BIH */ - put32 (dst, 40); /* biSize */ - put32 (dst, width); /* biWidth */ - put32 (dst, height); /* biHeight */ - put16 (dst, 1); /* biPlanes */ - put16 (dst, 24); /* biBitCount */ - put32 (dst, BI_RGB); /* biCompression */ - put32 (dst, size); /* biSizeImage */ - put32 (dst, 0); /* biXPelsPerMeter */ - put32 (dst, 0); /* biYPelsPerMeter */ - put32 (dst, 0); /* biClrUsed */ - put32 (dst, 0); /* biClrImportant */ - - if (!save_func ((gchar *)BFH_BIH, 14 + 40, error, user_data)) - return FALSE; - - dst_line = buf = g_try_malloc (size); - if (!buf) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Couldn't allocate memory for saving BMP file")); - return FALSE; - } - - /* saving as a bottom-up bmp */ - pixels += (height - 1) * src_stride; - for (y = 0; y < height; ++y, pixels -= src_stride, dst_line += stride) { - dst = dst_line; - src = pixels; - for (x = 0; x < width; ++x, dst += 3, src += channel) { - dst[0] = src[2]; - dst[1] = src[1]; - dst[2] = src[0]; - } - } - ret = save_func ((gchar *)buf, size, error, user_data); - g_free (buf); - - return ret; -} - -static gboolean -save_to_file_cb (const gchar *buf, - gsize count, - GError **error, - gpointer data) -{ - gint bytes; - - while (count > 0) { - bytes = fwrite (buf, sizeof (gchar), count, (FILE *) data); - if (bytes <= 0) - break; - count -= bytes; - buf += bytes; - } - - if (count) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Couldn't write to BMP file")); - return FALSE; - } - - return TRUE; -} - -static gboolean -gdk_pixbuf__bmp_image_save (FILE *f, - GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error) -{ - return gdk_pixbuf__bmp_image_save_to_callback (save_to_file_cb, - f, pixbuf, keys, - values, error); -} - -#ifndef INCLUDE_bmp -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__bmp_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->begin_load = gdk_pixbuf__bmp_image_begin_load; - module->stop_load = gdk_pixbuf__bmp_image_stop_load; - module->load_increment = gdk_pixbuf__bmp_image_load_increment; - module->save = gdk_pixbuf__bmp_image_save; - module->save_to_callback = gdk_pixbuf__bmp_image_save_to_callback; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "BM", NULL, 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/bmp", - "image/x-bmp", - "image/x-MS-bmp", - NULL - }; - static gchar * extensions[] = { - "bmp", - NULL - }; - - info->name = "bmp"; - info->signature = signature; - info->description = N_("The BMP image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_WRITABLE | GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} - diff --git a/gdk-pixbuf/io-gdip-animation.c b/gdk-pixbuf/io-gdip-animation.c deleted file mode 100644 index 7281b6d115..0000000000 --- a/gdk-pixbuf/io-gdip-animation.c +++ /dev/null @@ -1,383 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/* GdkPixbuf library - animated gdip support - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Jonathan Blandford <jrb@redhat.com> - * Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include <errno.h> -#include "io-gdip-native.h" -#include "io-gdip-animation.h" - -static void gdk_pixbuf_gdip_anim_class_init (GdkPixbufGdipAnimClass *klass); -static void gdk_pixbuf_gdip_anim_finalize (GObject *object); - -static gboolean gdk_pixbuf_gdip_anim_is_static_image (GdkPixbufAnimation *animation); -static GdkPixbuf* gdk_pixbuf_gdip_anim_get_static_image (GdkPixbufAnimation *animation); - -static void gdk_pixbuf_gdip_anim_get_size (GdkPixbufAnimation *anim, - int *width, - int *height); -static GdkPixbufAnimationIter* gdk_pixbuf_gdip_anim_get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time); - -static gpointer parent_class; - -GType -gdk_pixbuf_gdip_anim_get_type (void) -{ - static GType object_type = 0; - - if (!object_type) { - const GTypeInfo object_info = { - sizeof (GdkPixbufGdipAnimClass), - (GBaseInitFunc) NULL, - (GBaseFinalizeFunc) NULL, - (GClassInitFunc) gdk_pixbuf_gdip_anim_class_init, - NULL, /* class_finalize */ - NULL, /* class_data */ - sizeof (GdkPixbufGdipAnim), - 0, /* n_preallocs */ - (GInstanceInitFunc) NULL, - }; - - object_type = g_type_from_name ("GdkPixbufGdipAnim"); - if (object_type == 0) { - object_type = g_type_register_static (GDK_TYPE_PIXBUF_ANIMATION, - g_intern_static_string ("GdkPixbufGdipAnim"), - &object_info, 0); - } - } - - return object_type; -} - -static void -gdk_pixbuf_gdip_anim_class_init (GdkPixbufGdipAnimClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - GdkPixbufAnimationClass *anim_class = GDK_PIXBUF_ANIMATION_CLASS (klass); - - parent_class = g_type_class_peek_parent (klass); - - object_class->finalize = gdk_pixbuf_gdip_anim_finalize; - - anim_class->is_static_image = gdk_pixbuf_gdip_anim_is_static_image; - anim_class->get_static_image = gdk_pixbuf_gdip_anim_get_static_image; - anim_class->get_size = gdk_pixbuf_gdip_anim_get_size; - anim_class->get_iter = gdk_pixbuf_gdip_anim_get_iter; -} - -static void -gdk_pixbuf_gdip_anim_finalize (GObject *object) -{ - GdkPixbufGdipAnim *gdip_anim = GDK_PIXBUF_GDIP_ANIM (object); - - GList *l; - GdkPixbufFrame *frame; - - for (l = gdip_anim->frames; l; l = l->next) { - frame = l->data; - g_object_unref (frame->pixbuf); - g_free (frame); - } - - g_list_free (gdip_anim->frames); - - G_OBJECT_CLASS (parent_class)->finalize (object); -} - -static gboolean -gdk_pixbuf_gdip_anim_is_static_image (GdkPixbufAnimation *animation) -{ - GdkPixbufGdipAnim *gdip_anim; - - gdip_anim = GDK_PIXBUF_GDIP_ANIM (animation); - - return (gdip_anim->frames != NULL && - gdip_anim->frames->next == NULL); -} - -static GdkPixbuf* -gdk_pixbuf_gdip_anim_get_static_image (GdkPixbufAnimation *animation) -{ - GdkPixbufGdipAnim *gdip_anim; - - gdip_anim = GDK_PIXBUF_GDIP_ANIM (animation); - - if (gdip_anim->frames == NULL) - return NULL; - else - return GDK_PIXBUF (((GdkPixbufFrame*)gdip_anim->frames->data)->pixbuf); -} - -static void -gdk_pixbuf_gdip_anim_get_size (GdkPixbufAnimation *anim, - int *width, - int *height) -{ - GdkPixbufGdipAnim *gdip_anim; - - gdip_anim = GDK_PIXBUF_GDIP_ANIM (anim); - - if (width) - *width = gdip_anim->width; - - if (height) - *height = gdip_anim->height; -} - - -static void -iter_clear (GdkPixbufGdipAnimIter *iter) -{ - iter->current_frame = NULL; -} - -static void -iter_restart (GdkPixbufGdipAnimIter *iter) -{ - iter_clear (iter); - - iter->current_frame = iter->gdip_anim->frames; -} - -static GdkPixbufAnimationIter* -gdk_pixbuf_gdip_anim_get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time) -{ - GdkPixbufGdipAnimIter *iter; - - iter = g_object_new (GDK_TYPE_PIXBUF_GDIP_ANIM_ITER, NULL); - - iter->gdip_anim = GDK_PIXBUF_GDIP_ANIM (anim); - - g_object_ref (iter->gdip_anim); - - iter_restart (iter); - - iter->start_time = *start_time; - iter->current_time = *start_time; - iter->first_loop_slowness = 0; - - return GDK_PIXBUF_ANIMATION_ITER (iter); -} - -static void gdk_pixbuf_gdip_anim_iter_class_init (GdkPixbufGdipAnimIterClass *klass); -static void gdk_pixbuf_gdip_anim_iter_finalize (GObject *object); - -static int gdk_pixbuf_gdip_anim_iter_get_delay_time (GdkPixbufAnimationIter *iter); -static GdkPixbuf* gdk_pixbuf_gdip_anim_iter_get_pixbuf (GdkPixbufAnimationIter *iter); -static gboolean gdk_pixbuf_gdip_anim_iter_on_currently_loading_frame (GdkPixbufAnimationIter *iter); -static gboolean gdk_pixbuf_gdip_anim_iter_advance (GdkPixbufAnimationIter *iter, - const GTimeVal *current_time); - -static gpointer iter_parent_class; - -GType -gdk_pixbuf_gdip_anim_iter_get_type (void) -{ - static GType object_type = 0; - - if (!object_type) { - const GTypeInfo object_info = { - sizeof (GdkPixbufGdipAnimIterClass), - (GBaseInitFunc) NULL, - (GBaseFinalizeFunc) NULL, - (GClassInitFunc) gdk_pixbuf_gdip_anim_iter_class_init, - NULL, /* class_finalize */ - NULL, /* class_data */ - sizeof (GdkPixbufGdipAnimIter), - 0, /* n_preallocs */ - (GInstanceInitFunc) NULL, - }; - - object_type = g_type_from_name ("GdkPixbufGdipAnimIter"); - if (object_type == 0) { - object_type = g_type_register_static (GDK_TYPE_PIXBUF_ANIMATION_ITER, - g_intern_static_string ("GdkPixbufGdipAnimIter"), - &object_info, 0); - } - } - - return object_type; -} - -static void -gdk_pixbuf_gdip_anim_iter_class_init (GdkPixbufGdipAnimIterClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - GdkPixbufAnimationIterClass *anim_iter_class = - GDK_PIXBUF_ANIMATION_ITER_CLASS (klass); - - iter_parent_class = g_type_class_peek_parent (klass); - - object_class->finalize = gdk_pixbuf_gdip_anim_iter_finalize; - - anim_iter_class->get_delay_time = gdk_pixbuf_gdip_anim_iter_get_delay_time; - anim_iter_class->get_pixbuf = gdk_pixbuf_gdip_anim_iter_get_pixbuf; - anim_iter_class->on_currently_loading_frame = gdk_pixbuf_gdip_anim_iter_on_currently_loading_frame; - anim_iter_class->advance = gdk_pixbuf_gdip_anim_iter_advance; -} - -static void -gdk_pixbuf_gdip_anim_iter_finalize (GObject *object) -{ - GdkPixbufGdipAnimIter *iter = GDK_PIXBUF_GDIP_ANIM_ITER (object); - - iter_clear (iter); - - g_object_unref (iter->gdip_anim); - - G_OBJECT_CLASS (iter_parent_class)->finalize (object); -} - -static gboolean -gdk_pixbuf_gdip_anim_iter_advance (GdkPixbufAnimationIter *anim_iter, - const GTimeVal *current_time) -{ - GdkPixbufGdipAnimIter *iter; - gint elapsed; - gint loop; - GList *tmp; - GList *old; - - iter = GDK_PIXBUF_GDIP_ANIM_ITER (anim_iter); - - iter->current_time = *current_time; - - /* We use milliseconds for all times */ - elapsed = - (((iter->current_time.tv_sec - iter->start_time.tv_sec) * G_USEC_PER_SEC + - iter->current_time.tv_usec - iter->start_time.tv_usec)) / 1000; - - if (elapsed < 0) { - /* Try to compensate; probably the system clock - * was set backwards - */ - iter->start_time = iter->current_time; - elapsed = 0; - } - - g_assert (iter->gdip_anim->total_time > 0); - - /* See how many times we've already played the full animation, - * and subtract time for that. - */ - - if (iter->gdip_anim->loading) - loop = 0; - else { - /* If current_frame is NULL at this point, we have loaded the - * animation from a source which fell behind the speed of the - * display. We remember how much slower the first loop was due - * to this and correct the position calculation in order to not - * jump in the middle of the second loop. - */ - if (iter->current_frame == NULL) - iter->first_loop_slowness = MAX(0, elapsed - iter->gdip_anim->total_time); - - loop = (elapsed - iter->first_loop_slowness) / iter->gdip_anim->total_time; - elapsed = (elapsed - iter->first_loop_slowness) % iter->gdip_anim->total_time; - } - - iter->position = elapsed; - - /* Now move to the proper frame */ - if (iter->gdip_anim->loop == 0 || loop < iter->gdip_anim->loop) - tmp = iter->gdip_anim->frames; - else - tmp = NULL; - while (tmp != NULL) { - GdkPixbufFrame *frame = tmp->data; - - if (iter->position >= frame->elapsed && - iter->position < (frame->elapsed + frame->delay_time)) - break; - - tmp = tmp->next; - } - - old = iter->current_frame; - - iter->current_frame = tmp; - - return iter->current_frame != old; -} - -int -gdk_pixbuf_gdip_anim_iter_get_delay_time (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufFrame *frame; - GdkPixbufGdipAnimIter *iter; - - iter = GDK_PIXBUF_GDIP_ANIM_ITER (anim_iter); - - if (iter->current_frame) { - frame = iter->current_frame->data; - -#if 0 - g_print ("frame start: %d pos: %d frame len: %d frame remaining: %d\n", - frame->elapsed, - iter->position, - frame->delay_time, - frame->delay_time - (iter->position - frame->elapsed)); -#endif - - return frame->delay_time - (iter->position - frame->elapsed); - } else - return -1; /* show last frame forever */ -} - -GdkPixbuf* -gdk_pixbuf_gdip_anim_iter_get_pixbuf (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufGdipAnimIter *iter; - GdkPixbufFrame *frame; - - iter = GDK_PIXBUF_GDIP_ANIM_ITER (anim_iter); - - frame = iter->current_frame ? iter->current_frame->data : g_list_last (iter->gdip_anim->frames)->data; - -#if 0 - if (FALSE && frame) - g_print ("current frame %d dispose mode %d %d x %d\n", - g_list_index (iter->gdip_anim->frames, - frame), - frame->action, - gdk_pixbuf_get_width (frame->pixbuf), - gdk_pixbuf_get_height (frame->pixbuf)); -#endif - - if (frame == NULL) - return NULL; - - return frame->pixbuf; -} - -static gboolean -gdk_pixbuf_gdip_anim_iter_on_currently_loading_frame (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufGdipAnimIter *iter; - - iter = GDK_PIXBUF_GDIP_ANIM_ITER (anim_iter); - - return iter->current_frame == NULL || iter->current_frame->next == NULL; -} diff --git a/gdk-pixbuf/io-gdip-animation.h b/gdk-pixbuf/io-gdip-animation.h deleted file mode 100644 index 01e827876d..0000000000 --- a/gdk-pixbuf/io-gdip-animation.h +++ /dev/null @@ -1,117 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - GDIP loader declarations - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#ifndef GDK_PIXBUF_GDIP_H -#define GDK_PIXBUF_GDIP_H - -#include <gdk-pixbuf/gdk-pixbuf-animation.h> - -typedef struct _GdkPixbufGdipAnim GdkPixbufGdipAnim; -typedef struct _GdkPixbufGdipAnimClass GdkPixbufGdipAnimClass; -typedef struct _GdkPixbufFrame GdkPixbufFrame; - -#define GDK_TYPE_PIXBUF_GDIP_ANIM (gdk_pixbuf_gdip_anim_get_type ()) -#define GDK_PIXBUF_GDIP_ANIM(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_GDIP_ANIM, GdkPixbufGdipAnim)) -#define GDK_IS_PIXBUF_GDIP_ANIM(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_GDIP_ANIM)) - -#define GDK_PIXBUF_GDIP_ANIM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_GDIP_ANIM, GdkPixbufGdipAnimClass)) -#define GDK_IS_PIXBUF_GDIP_ANIM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_GDIP_ANIM)) -#define GDK_PIXBUF_GDIP_ANIM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_GDIP_ANIM, GdkPixbufGdipAnimClass)) - -/* Private part of the GdkPixbufGdipAnim structure */ -struct _GdkPixbufGdipAnim { - GdkPixbufAnimation parent_instance; - - /* Number of frames */ - int n_frames; - - /* Total length of animation */ - int total_time; - - /* List of GdkPixbufFrame structures */ - GList *frames; - - /* bounding box size */ - int width, height; - - int loop; - gboolean loading; -}; - -struct _GdkPixbufGdipAnimClass { - GdkPixbufAnimationClass parent_class; - -}; - -GType gdk_pixbuf_gdip_anim_get_type (void) G_GNUC_CONST; - -typedef struct _GdkPixbufGdipAnimIter GdkPixbufGdipAnimIter; -typedef struct _GdkPixbufGdipAnimIterClass GdkPixbufGdipAnimIterClass; - - -#define GDK_TYPE_PIXBUF_GDIP_ANIM_ITER (gdk_pixbuf_gdip_anim_iter_get_type ()) -#define GDK_PIXBUF_GDIP_ANIM_ITER(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_GDIP_ANIM_ITER, GdkPixbufGdipAnimIter)) -#define GDK_IS_PIXBUF_GDIP_ANIM_ITER(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_GDIP_ANIM_ITER)) - -#define GDK_PIXBUF_GDIP_ANIM_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_GDIP_ANIM_ITER, GdkPixbufGdipAnimIterClass)) -#define GDK_IS_PIXBUF_GDIP_ANIM_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_GDIP_ANIM_ITER)) -#define GDK_PIXBUF_GDIP_ANIM_ITER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_GDIP_ANIM_ITER, GdkPixbufGdipAnimIterClass)) - -struct _GdkPixbufGdipAnimIter { - GdkPixbufAnimationIter parent_instance; - - GdkPixbufGdipAnim *gdip_anim; - - GTimeVal start_time; - GTimeVal current_time; - - /* Time in milliseconds into this run of the animation */ - gint position; - - GList *current_frame; - - gint first_loop_slowness; -}; - -struct _GdkPixbufGdipAnimIterClass { - GdkPixbufAnimationIterClass parent_class; - -}; - -GType gdk_pixbuf_gdip_anim_iter_get_type (void) G_GNUC_CONST; - -struct _GdkPixbufFrame { - /* The pixbuf with this frame's image data */ - GdkPixbuf *pixbuf; - - /* Frame duration in ms */ - int delay_time; - - /* Sum of preceding delay times */ - int elapsed; -}; - -#endif diff --git a/gdk-pixbuf/io-gdip-bmp.c b/gdk-pixbuf/io-gdip-bmp.c deleted file mode 100644 index 40f6a5f536..0000000000 --- a/gdk-pixbuf/io-gdip-bmp.c +++ /dev/null @@ -1,87 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader
- *
- * Copyright (C) 2008 Dominic Lachowicz
- * Copyright (C) 2008 Alberto Ruiz
- *
- * Authors: Dominic Lachowicz <domlachowicz@gmail.com>
- * Alberto Ruiz <aruiz@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-#include "io-gdip-utils.h"
-
-static gboolean
-gdk_pixbuf__gdip_image_save_BMP_to_callback (GdkPixbufSaveFunc save_func,
- gpointer user_data,
- GdkPixbuf *pixbuf,
- gchar **keys,
- gchar **values,
- GError **error)
-{
- return gdip_save_pixbuf (pixbuf, L"image/bmp", NULL, save_func, user_data, error);
-}
-
-static gboolean
-gdk_pixbuf__gdip_image_save_BMP (FILE *f,
- GdkPixbuf *pixbuf,
- gchar **keys,
- gchar **values,
- GError **error)
-{
- return gdk_pixbuf__gdip_image_save_BMP_to_callback (gdip_save_to_file_callback, f, pixbuf, keys, values, error);
-}
-
-#ifndef INCLUDE_gdiplus
-#define MODULE_ENTRY(function) G_MODULE_EXPORT void function
-#else
-#define MODULE_ENTRY(function) void _gdk_pixbuf__gdip_bmp_ ## function
-#endif
-
-MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module)
-{
- gdip_fill_vtable (module);
-
- module->save_to_callback = gdk_pixbuf__gdip_image_save_BMP_to_callback;
- module->save = gdk_pixbuf__gdip_image_save_BMP; /* for gtk < 2.14, you need to implement both. otherwise gdk-pixbuf-queryloaders fails */
-}
-
-MODULE_ENTRY (fill_info) (GdkPixbufFormat *info)
-{
- static GdkPixbufModulePattern signature[] = {
- { "BM", NULL, 100 }, /* BMP */
- { NULL, NULL, 0 }
- };
-
- static gchar *mime_types[] = {
- "image/bmp",
- "image/x-bmp",
- "image/x-MS-bmp",
- NULL
- };
-
- static gchar *extensions[] = {
- "bmp",
- NULL
- };
-
- info->name = "bmp";
- info->signature = signature;
- info->description = _("The BMP image format");
- info->mime_types = mime_types;
- info->extensions = extensions;
- info->flags = GDK_PIXBUF_FORMAT_WRITABLE | GDK_PIXBUF_FORMAT_THREADSAFE;
- info->license = "LGPL";
-}
diff --git a/gdk-pixbuf/io-gdip-emf.c b/gdk-pixbuf/io-gdip-emf.c deleted file mode 100644 index 07ee0b0200..0000000000 --- a/gdk-pixbuf/io-gdip-emf.c +++ /dev/null @@ -1,64 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader - * - * Copyright (C) 2008 Dominic Lachowicz - * Copyright (C) 2008 Alberto Ruiz - * - * Authors: Dominic Lachowicz <domlachowicz@gmail.com> - * Alberto Ruiz <aruiz@gnome.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "io-gdip-utils.h" - -#ifndef INCLUDE_gdiplus -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__gdip_emf_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - gdip_fill_vector_vtable (module); -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "\x01\x00\x00\x00", NULL, 100 }, /* EMF */ - { NULL, NULL, 0 } - }; - - static gchar *mime_types[] = { - "application/emf", - "application/x-emf", - "image/x-emf", - "image/x-mgx-emf", - NULL - }; - - static gchar *extensions[] = { - "emf", - NULL - }; - - info->name = "emf"; - info->signature = signature; - info->description = _("The EMF image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-gdip-gif.c b/gdk-pixbuf/io-gdip-gif.c deleted file mode 100644 index f991a9d3de..0000000000 --- a/gdk-pixbuf/io-gdip-gif.c +++ /dev/null @@ -1,85 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader
- *
- * Copyright (C) 2008 Dominic Lachowicz
- * Copyright (C) 2008 Alberto Ruiz
- *
- * Authors: Dominic Lachowicz <domlachowicz@gmail.com>
- * Alberto Ruiz <aruiz@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-#include "io-gdip-utils.h"
-
-static gboolean
-gdk_pixbuf__gdip_image_save_GIF_to_callback (GdkPixbufSaveFunc save_func,
- gpointer user_data,
- GdkPixbuf *pixbuf,
- gchar **keys,
- gchar **values,
- GError **error)
-{
- return gdip_save_pixbuf (pixbuf, L"image/gif", NULL, save_func, user_data, error);
-}
-
-static gboolean
-gdk_pixbuf__gdip_image_save_GIF (FILE *f,
- GdkPixbuf *pixbuf,
- gchar **keys,
- gchar **values,
- GError **error)
-{
- return gdk_pixbuf__gdip_image_save_GIF_to_callback (gdip_save_to_file_callback, f, pixbuf, keys, values, error);
-}
-
-#ifndef INCLUDE_gdiplus
-#define MODULE_ENTRY(function) G_MODULE_EXPORT void function
-#else
-#define MODULE_ENTRY(function) void _gdk_pixbuf__gdip_gif_ ## function
-#endif
-
-MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module)
-{
- gdip_fill_vtable (module);
-
- module->save_to_callback = gdk_pixbuf__gdip_image_save_GIF_to_callback;
- module->save = gdk_pixbuf__gdip_image_save_GIF; /* for gtk < 2.14, you need to implement both. otherwise gdk-pixbuf-queryloaders fails */
-}
-
-MODULE_ENTRY (fill_info) (GdkPixbufFormat *info)
-{
- static GdkPixbufModulePattern signature[] = {
- { "GIF8", NULL, 100 }, /* GIF */
- { NULL, NULL, 0 }
- };
-
- static gchar *mime_types[] = {
- "image/gif",
- NULL
- };
-
- static gchar *extensions[] = {
- "gif",
- NULL
- };
-
- info->name = "gif";
- info->signature = signature;
- info->description = _("The GIF image format");
- info->mime_types = mime_types;
- info->extensions = extensions;
- info->flags = GDK_PIXBUF_FORMAT_WRITABLE | GDK_PIXBUF_FORMAT_THREADSAFE;
- info->license = "LGPL";
-}
diff --git a/gdk-pixbuf/io-gdip-ico.c b/gdk-pixbuf/io-gdip-ico.c deleted file mode 100644 index 8538b58111..0000000000 --- a/gdk-pixbuf/io-gdip-ico.c +++ /dev/null @@ -1,64 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader - * - * Copyright (C) 2008 Dominic Lachowicz - * Copyright (C) 2008 Alberto Ruiz - * - * Authors: Dominic Lachowicz <domlachowicz@gmail.com> - * Alberto Ruiz <aruiz@gnome.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "io-gdip-utils.h" - -#ifndef INCLUDE_gdiplus -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__gdip_ico_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - gdip_fill_vtable (module); -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { " \x1 ", "zz znz", 100 }, /* ICO */ - { " \x2 ", "zz znz", 100 }, /* ICO */ - { NULL, NULL, 0 } - }; - - static gchar *mime_types[] = { - "image/x-icon", - "image/x-ico", - NULL - }; - - static gchar *extensions[] = { - "ico", - "cur", - NULL - }; - - info->name = "ico"; - info->signature = signature; - info->description = _("The ICO image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-gdip-jpeg.c b/gdk-pixbuf/io-gdip-jpeg.c deleted file mode 100644 index 8bd3058606..0000000000 --- a/gdk-pixbuf/io-gdip-jpeg.c +++ /dev/null @@ -1,141 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader
- *
- * Copyright (C) 2008 Dominic Lachowicz
- * Copyright (C) 2008 Alberto Ruiz
- *
- * Authors: Dominic Lachowicz <domlachowicz@gmail.com>
- * Alberto Ruiz <aruiz@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-#define INITGUID
-#include "io-gdip-utils.h"
-
-DEFINE_GUID(EncoderQuality, 0x1d5be4b5,0xfa4a,0x452d,0x9c,0xdd,0x5d,0xb3,0x51,0x05,0xe7,0xeb);
-
-static gboolean
-gdk_pixbuf__gdip_image_save_JPEG_to_callback (GdkPixbufSaveFunc save_func,
- gpointer user_data,
- GdkPixbuf *pixbuf,
- gchar **keys,
- gchar **values,
- GError **error)
-{
- EncoderParameters encoder_params;
- LONG quality = 75; /* default; must be between 0 and 100 */
-
- if (keys && *keys) {
- gchar **kiter = keys;
- gchar **viter = values;
-
- while (*kiter) {
- if (strcmp (*kiter, "quality") == 0) {
- char *endptr = NULL;
- quality = strtol (*viter, &endptr, 10);
-
- if (endptr == *viter) {
- g_set_error (error,
- GDK_PIXBUF_ERROR,
- GDK_PIXBUF_ERROR_BAD_OPTION,
- _("JPEG quality must be a value between 0 and 100; value '%s' could not be parsed."),
- *viter);
-
- return FALSE;
- }
-
- if (quality < 0 ||
- quality > 100) {
- /* This is a user-visible error;
- * lets people skip the range-checking
- * in their app.
- */
- g_set_error (error,
- GDK_PIXBUF_ERROR,
- GDK_PIXBUF_ERROR_BAD_OPTION,
- _("JPEG quality must be a value between 0 and 100; value '%d' is not allowed."),
- (int)quality);
-
- return FALSE;
- }
- } else {
- g_warning ("Unrecognized parameter (%s) passed to JPEG saver.", *kiter);
- }
-
- ++kiter;
- ++viter;
- }
- }
-
- encoder_params.Count = 1;
- encoder_params.Parameter[0].Guid = EncoderQuality;
- encoder_params.Parameter[0].Type = EncoderParameterValueTypeLong;
- encoder_params.Parameter[0].NumberOfValues = 1;
- encoder_params.Parameter[0].Value = &quality;
-
- return gdip_save_pixbuf (pixbuf, L"image/jpeg", &encoder_params, save_func, user_data, error);
-}
-
-static gboolean
-gdk_pixbuf__gdip_image_save_JPEG (FILE *f,
- GdkPixbuf *pixbuf,
- gchar **keys,
- gchar **values,
- GError **error)
-{
- return gdk_pixbuf__gdip_image_save_JPEG_to_callback (gdip_save_to_file_callback, f, pixbuf, keys, values, error);
-}
-
-#ifndef INCLUDE_gdiplus
-#define MODULE_ENTRY(function) G_MODULE_EXPORT void function
-#else
-#define MODULE_ENTRY(function) void _gdk_pixbuf__gdip_jpeg_ ## function
-#endif
-
-MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module)
-{
- gdip_fill_vtable (module);
-
- module->save_to_callback = gdk_pixbuf__gdip_image_save_JPEG_to_callback;
- module->save = gdk_pixbuf__gdip_image_save_JPEG; /* for gtk < 2.14, you need to implement both. otherwise gdk-pixbuf-queryloaders fails */
-}
-
-MODULE_ENTRY (fill_info) (GdkPixbufFormat *info)
-{
- static GdkPixbufModulePattern signature[] = {
- { "\xff\xd8", NULL, 100 }, /* JPEG */
- { NULL, NULL, 0 }
- };
-
- static gchar *mime_types[] = {
- "image/jpeg",
- NULL
- };
-
- static gchar *extensions[] = {
- "jpeg",
- "jpe",
- "jpg",
- NULL
- };
-
- info->name = "jpeg";
- info->signature = signature;
- info->description = _("The JPEG image format");
- info->mime_types = mime_types;
- info->extensions = extensions;
- info->flags = GDK_PIXBUF_FORMAT_WRITABLE | GDK_PIXBUF_FORMAT_THREADSAFE;
- info->license = "LGPL";
-}
diff --git a/gdk-pixbuf/io-gdip-native.h b/gdk-pixbuf/io-gdip-native.h deleted file mode 100644 index 24ea824f46..0000000000 --- a/gdk-pixbuf/io-gdip-native.h +++ /dev/null @@ -1,264 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader - * - * Copyright (C) 2007 Google (Evan Stade) - * Copyright (C) 2008 Alberto Ruiz <aruiz@gnome.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2.1 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA - */ - -#ifndef _HAVE_IO_GDIP_NATIVE_H -#define _HAVE_IO_GDIP_NATIVE_H - -#include <windows.h> - -#include <glib.h> - -/* //////////// Native API ///////////// */ - -#define WINGDIPAPI __stdcall - -typedef gulong ARGB; -typedef gint PixelFormat; - -typedef enum { - EncoderParameterValueTypeByte = 1, - EncoderParameterValueTypeASCII = 2, - EncoderParameterValueTypeShort = 3, - EncoderParameterValueTypeLong = 4, - EncoderParameterValueTypeRational = 5, - EncoderParameterValueTypeLongRange = 6, - EncoderParameterValueTypeUndefined = 7, - EncoderParameterValueTypeRationalRange = 8, - EncoderParameterValueTypePointer = 9 -} EncoderParameterValueType; - -#define PixelFormatIndexed 0x00010000 -#define PixelFormatGDI 0x00020000 -#define PixelFormatAlpha 0x00040000 -#define PixelFormatPAlpha 0x00080000 -#define PixelFormatExtended 0x00100000 -#define PixelFormatCanonical 0x00200000 - -#define PixelFormatUndefined 0 -#define PixelFormatDontCare 0 - -#define PixelFormat1bppIndexed (1 | ( 1 << 8) | PixelFormatIndexed | PixelFormatGDI) -#define PixelFormat4bppIndexed (2 | ( 4 << 8) | PixelFormatIndexed | PixelFormatGDI) -#define PixelFormat8bppIndexed (3 | ( 8 << 8) | PixelFormatIndexed | PixelFormatGDI) -#define PixelFormat16bppGrayScale (4 | (16 << 8) | PixelFormatExtended) -#define PixelFormat16bppRGB555 (5 | (16 << 8) | PixelFormatGDI) -#define PixelFormat16bppRGB565 (6 | (16 << 8) | PixelFormatGDI) -#define PixelFormat16bppARGB1555 (7 | (16 << 8) | PixelFormatAlpha | PixelFormatGDI) -#define PixelFormat24bppRGB (8 | (24 << 8) | PixelFormatGDI) -#define PixelFormat32bppRGB (9 | (32 << 8) | PixelFormatGDI) -#define PixelFormat32bppARGB (10 | (32 << 8) | PixelFormatAlpha | PixelFormatGDI | PixelFormatCanonical) -#define PixelFormat32bppPARGB (11 | (32 << 8) | PixelFormatAlpha | PixelFormatPAlpha | PixelFormatGDI) -#define PixelFormat48bppRGB (12 | (48 << 8) | PixelFormatExtended) -#define PixelFormat64bppARGB (13 | (64 << 8) | PixelFormatAlpha | PixelFormatCanonical | PixelFormatExtended) -#define PixelFormat64bppPARGB (14 | (64 << 8) | PixelFormatAlpha | PixelFormatPAlpha | PixelFormatExtended) -#define PixelFormatMax 15 - -enum _Status -{ - Ok = 0, - GenericError = 1, - InvalidParameter = 2, - OutOfMemory = 3, - ObjectBusy = 4, - InsufficientBuffer = 5, - NotImplemented = 6, - Win32Error = 7, - WrongState = 8, - Aborted = 9, - FileNotFound = 10, - ValueOverflow = 11, - AccessDenied = 12, - UnknownImageFormat = 13, - FontFamilyNotFound = 14, - FontStyleNotFound = 15, - NotTrueTypeFont = 16, - UnsupportedGdiplusVersion = 17, - GdiplusNotInitialized = 18, - PropertyNotFound = 19, - PropertyNotSupported = 20, - ProfileNotFound = 21 -}; -typedef enum _Status Status; -typedef enum _Status GpStatus; - -typedef enum { - ImageFlagsNone = 0, - ImageFlagsScalable = 0x0001, - ImageFlagsHasAlpha = 0x0002, - ImageFlagsHasTranslucent = 0x0004, - ImageFlagsPartiallyScalable = 0x0008, - ImageFlagsColorSpaceRGB = 0x0010, - ImageFlagsColorSpaceCMYK = 0x0020, - ImageFlagsColorSpaceGRAY = 0x0040, - ImageFlagsColorSpaceYCBCR = 0x0080, - ImageFlagsColorSpaceYCCK = 0x0100, - ImageFlagsHasRealDPI = 0x1000, - ImageFlagsHasRealPixelSize = 0x2000, - ImageFlagsReadOnly = 0x00010000, - ImageFlagsCaching = 0x00020000 -} ImageFlags; - -enum _ImageLockMode -{ - ImageLockModeRead = 1, - ImageLockModeWrite = 2, - ImageLockModeUserInputBuf = 4 -}; -typedef enum _ImageLockMode ImageLockMode; - -enum _ImageType -{ - ImageTypeUnknown, - ImageTypeBitmap, - ImageTypeMetafile -}; -typedef enum _ImageType ImageType; - -typedef struct _GpImage GpImage; -typedef struct _GpBitmap GpBitmap; -typedef struct _GpGraphics GpGraphics; - -struct _GdiplusStartupInput -{ - UINT32 GdiplusVersion; - gpointer DebugEventCallback; - BOOL SuppressBackgroundThread; - BOOL SuppressExternalCodecs; -}; -typedef struct _GdiplusStartupInput GdiplusStartupInput; - -struct _PropItem -{ - ULONG id; - ULONG length; - WORD type; - VOID *value; -}; -typedef struct _PropItem PropertyItem; - -struct _EncoderParameter -{ - GUID Guid; - ULONG NumberOfValues; - ULONG Type; - VOID* Value; -}; -typedef struct _EncoderParameter EncoderParameter; - -struct _EncoderParameters -{ - UINT Count; /* Number of parameters in this structure */ - EncoderParameter Parameter[1]; /* Parameter values */ -}; -typedef struct _EncoderParameters EncoderParameters; - -struct _ImageCodecInfo -{ - CLSID Clsid; - GUID FormatID; - const WCHAR* CodecName; - const WCHAR* DllName; - const WCHAR* FormatDescription; - const WCHAR* FilenameExtension; - const WCHAR* MimeType; - DWORD Flags; - DWORD Version; - DWORD SigCount; - DWORD SigSize; - const BYTE* SigPattern; - const BYTE* SigMask; -}; -typedef struct _ImageCodecInfo ImageCodecInfo; - -struct _BitmapData -{ - UINT Width; - UINT Height; - INT Stride; - PixelFormat PixelFormat; - VOID* Scan0; - UINT_PTR Reserved; -}; -typedef struct _BitmapData BitmapData; - -struct _GpRect -{ - INT X; - INT Y; - INT Width; - INT Height; -}; -typedef struct _GpRect GpRect; - -#ifndef IStream_Release -#define IStream_Release(This) (This)->lpVtbl->Release(This) -#endif - -#ifndef IStream_Seek -#define IStream_Seek(This,dlibMove,dwOrigin,plibNewPosition) (This)->lpVtbl->Seek(This,dlibMove,dwOrigin,plibNewPosition) -#endif - -#ifndef IStream_Read -#define IStream_Read(This,pv,cb,pcbRead) (This)->lpVtbl->Read(This,pv,cb,pcbRead) -#endif - -#ifndef IStream_SetSize -#define IStream_SetSize(This,size) (This)->lpVtbl->SetSize(This,size) -#endif - -typedef GpStatus (WINGDIPAPI* GdiplusStartupFunc) (gpointer, const gpointer, gpointer); -typedef GpStatus (WINGDIPAPI* GdipCreateBitmapFromStreamFunc) (gpointer, GpBitmap**); -typedef GpStatus (WINGDIPAPI* GdipBitmapGetPixelFunc) (GpBitmap*, gint x, gint y, ARGB*); -typedef GpStatus (WINGDIPAPI* GdipGetImageWidthFunc) (GpImage*, guint*); -typedef GpStatus (WINGDIPAPI* GdipGetImageHeightFunc) (GpImage*, guint*); -typedef GpStatus (WINGDIPAPI* GdipDisposeImageFunc) (GpImage*); -typedef GpStatus (WINGDIPAPI* GdipGetImageFlagsFunc) (GpImage *, guint*); -typedef GpStatus (WINGDIPAPI* GdipImageGetFrameCountFunc) (GpImage *image, const GUID* dimensionID, UINT* count); -typedef GpStatus (WINGDIPAPI* GdipImageSelectActiveFrameFunc) (GpImage *image, const GUID* dimensionID, UINT frameIndex); -typedef GpStatus (WINGDIPAPI* GdipGetPropertyItemSizeFunc) (GpImage *image, int propId, guint* size); -typedef GpStatus (WINGDIPAPI* GdipGetPropertyItemFunc) (GpImage *image, int propId, guint propSize, PropertyItem* buffer); -typedef GpStatus (WINGDIPAPI* GdipGetPropertyCountFunc) (GpImage *image, guint* numOfProperty); -typedef GpStatus (WINGDIPAPI* GdipGetPropertyIdListFunc) (GpImage *image, guint numOfProperty, PROPID* list); -typedef GpStatus (WINGDIPAPI* GdipCreateBitmapFromScan0Func) (INT width, INT height, INT stride, PixelFormat format, BYTE* scan0, - GpBitmap** bitmap); -typedef GpStatus (WINGDIPAPI* GdipSaveImageToStreamFunc) (GpImage *image, IStream* stream, const CLSID* clsidEncoder, - const EncoderParameters* encoderParams); - -typedef GpStatus (WINGDIPAPI* GdipGetImageEncodersFunc) (UINT numEncoders, UINT size, ImageCodecInfo *encoders); -typedef GpStatus (WINGDIPAPI* GdipGetImageEncodersSizeFunc) (UINT *numEncoders, UINT *size); -typedef GpStatus (WINGDIPAPI* GdipBitmapSetPixelFunc) (GpBitmap* bitmap, INT x, INT y, ARGB color); - -typedef GpStatus (WINGDIPAPI* GdipDrawImageIFunc) (GpGraphics *graphics, GpImage *image, INT x, INT y); -typedef GpStatus (WINGDIPAPI* GdipGetImageGraphicsContextFunc) (GpImage *image, GpGraphics **graphics); -typedef GpStatus (WINGDIPAPI* GdipFlushFunc) (GpGraphics *graphics, INT intention); -typedef GpStatus (WINGDIPAPI* GdipGraphicsClearFunc) (GpGraphics *graphics, ARGB color); -typedef GpStatus (WINGDIPAPI* GdipBitmapSetResolutionFunc) (GpBitmap* bitmap, float xdpi, float ydpi); -typedef GpStatus (WINGDIPAPI* GdipGetImageHorizontalResolutionFunc) (GpImage *image, float *resolution); -typedef GpStatus (WINGDIPAPI* GdipGetImageVerticalResolutionFunc) (GpImage *image, float *resolution); -typedef GpStatus (WINGDIPAPI* GdipLoadImageFromStreamFunc) (IStream* stream, GpImage **image); -typedef GpStatus (WINGDIPAPI* GdipDeleteGraphicsFunc) (GpGraphics *graphics); - -typedef GpStatus (WINGDIPAPI* GdipBitmapLockBitsFunc) (GpBitmap* bitmap, const GpRect* rect, UINT flags, PixelFormat format, BitmapData* lockedBitmapData); -typedef GpStatus (WINGDIPAPI* GdipBitmapUnlockBitsFunc) (GpBitmap* bitmap, BitmapData* lockedBitmapData); -typedef GpStatus (WINGDIPAPI* GdipGetImagePixelFormatFunc) (GpImage *image, PixelFormat *format); -typedef GpStatus (WINGDIPAPI* GdipCloneBitmapAreaIFunc) (INT x, INT y, INT width, INT height, PixelFormat format, GpBitmap *srcBitmap, GpBitmap **dstBitmap); - -#endif diff --git a/gdk-pixbuf/io-gdip-png.c b/gdk-pixbuf/io-gdip-png.c deleted file mode 100644 index 8b094bfca4..0000000000 --- a/gdk-pixbuf/io-gdip-png.c +++ /dev/null @@ -1,138 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader
- *
- * Copyright (C) 2008 Dominic Lachowicz
- * Copyright (C) 2008 Alberto Ruiz
- *
- * Authors: Dominic Lachowicz <domlachowicz@gmail.com>
- * Alberto Ruiz <aruiz@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-#define INITGUID
-#include "io-gdip-utils.h"
-
-DEFINE_GUID(EncoderCompression, 0xe09d739d,0xccd4,0x44ee,0x8e,0xba,0x3f,0xbf,0x8b,0xe4,0xfc,0x58);
-
-static gboolean
-gdk_pixbuf__gdip_image_save_PNG_to_callback (GdkPixbufSaveFunc save_func,
- gpointer user_data,
- GdkPixbuf *pixbuf,
- gchar **keys,
- gchar **values,
- GError **error)
-{
- EncoderParameters encoder_params;
- LONG compression = 5;
-
- if (keys && *keys) {
- gchar **kiter = keys;
- gchar **viter = values;
-
- while (*kiter) {
- if (strncmp (*kiter, "tEXt::", 6) == 0) {
- /* TODO: support exif data and the like */
- }
- else if (strcmp (*kiter, "compression") == 0) {
- char *endptr = NULL;
- compression = strtol (*viter, &endptr, 10);
-
- if (endptr == *viter) {
- g_set_error (error,
- GDK_PIXBUF_ERROR,
- GDK_PIXBUF_ERROR_BAD_OPTION,
- _("PNG compression level must be a value between 0 and 9; value '%s' could not be parsed."),
- *viter);
- return FALSE;
- }
- if (compression < 0 || compression > 9) {
- /* This is a user-visible error;
- * lets people skip the range-checking
- * in their app.
- */
- g_set_error (error,
- GDK_PIXBUF_ERROR,
- GDK_PIXBUF_ERROR_BAD_OPTION,
- _("PNG compression level must be a value between 0 and 9; value '%d' is not allowed."),
- (int)compression);
- return FALSE;
- }
- } else {
- g_warning ("Unrecognized parameter (%s) passed to PNG saver.", *kiter);
- }
-
- ++kiter;
- ++viter;
- }
- }
-
- encoder_params.Count = 1;
- encoder_params.Parameter[0].Guid = EncoderCompression;
- encoder_params.Parameter[0].Type = EncoderParameterValueTypeLong;
- encoder_params.Parameter[0].NumberOfValues = 1;
- encoder_params.Parameter[0].Value = &compression;
-
- return gdip_save_pixbuf (pixbuf, L"image/png", &encoder_params, save_func, user_data, error);
-}
-
-static gboolean
-gdk_pixbuf__gdip_image_save_PNG (FILE *f,
- GdkPixbuf *pixbuf,
- gchar **keys,
- gchar **values,
- GError **error)
-{
- return gdk_pixbuf__gdip_image_save_PNG_to_callback (gdip_save_to_file_callback, f, pixbuf, keys, values, error);
-}
-
-#ifndef INCLUDE_gdip_png
-#define MODULE_ENTRY(function) G_MODULE_EXPORT void function
-#else
-#define MODULE_ENTRY(function) void _gdk_pixbuf__gdip_png_ ## function
-#endif
-
-MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module)
-{
- gdip_fill_vtable (module);
-
- module->save_to_callback = gdk_pixbuf__gdip_image_save_PNG_to_callback;
- module->save = gdk_pixbuf__gdip_image_save_PNG; /* for gtk < 2.14, you need to implement both. otherwise gdk-pixbuf-queryloaders fails */
-}
-
-MODULE_ENTRY (fill_info) (GdkPixbufFormat *info)
-{
- static GdkPixbufModulePattern signature[] = {
- { "\x89PNG\r\n\x1a\x0a", NULL, 100 }, /* PNG */
- { NULL, NULL, 0 }
- };
-
- static gchar *mime_types[] = {
- "image/png",
- NULL
- };
-
- static gchar *extensions[] = {
- "png",
- NULL
- };
-
- info->name = "png";
- info->signature = signature;
- info->description = _("The PNG image format");
- info->mime_types = mime_types;
- info->extensions = extensions;
- info->flags = GDK_PIXBUF_FORMAT_WRITABLE | GDK_PIXBUF_FORMAT_THREADSAFE;
- info->license = "LGPL";
-}
diff --git a/gdk-pixbuf/io-gdip-propertytags.h b/gdk-pixbuf/io-gdip-propertytags.h deleted file mode 100644 index 95243bfe1a..0000000000 --- a/gdk-pixbuf/io-gdip-propertytags.h +++ /dev/null @@ -1,228 +0,0 @@ -#ifndef HAVE_IO_GDIP_PROPERTIES_H -#define HAVE_IO_GDIP_PROPERTIES_H - -#define PropertyTagTypeByte 1 -#define PropertyTagTypeASCII 2 -#define PropertyTagTypeShort 3 -#define PropertyTagTypeLong 4 -#define PropertyTagTypeRational 5 -#define PropertyTagTypeUndefined 7 -#define PropertyTagTypeSLONG 9 -#define PropertyTagTypeSRational 10 - -#define PropertyTagExifIFD 0x8769 -#define PropertyTagGpsIFD 0x8825 -#define PropertyTagNewSubfileType 0x00FE -#define PropertyTagSubfileType 0x00FF -#define PropertyTagImageWidth 0x0100 -#define PropertyTagImageHeight 0x0101 -#define PropertyTagBitsPerSample 0x0102 -#define PropertyTagCompression 0x0103 -#define PropertyTagPhotometricInterp 0x0106 -#define PropertyTagThreshHolding 0x0107 -#define PropertyTagCellWidth 0x0108 -#define PropertyTagCellHeight 0x0109 -#define PropertyTagFillOrder 0x010A -#define PropertyTagDocumentName 0x010D -#define PropertyTagImageDescription 0x010E -#define PropertyTagEquipMake 0x010F -#define PropertyTagEquipModel 0x0110 -#define PropertyTagStripOffsets 0x0111 -#define PropertyTagOrientation 0x0112 -#define PropertyTagSamplesPerPixel 0x0115 -#define PropertyTagRowsPerStrip 0x0116 -#define PropertyTagStripBytesCount 0x0117 -#define PropertyTagMinSampleValue 0x0118 -#define PropertyTagMaxSampleValue 0x0119 -#define PropertyTagXResolution 0x011A -#define PropertyTagYResolution 0x011B -#define PropertyTagPlanarConfig 0x011C -#define PropertyTagPageName 0x011D -#define PropertyTagXPosition 0x011E -#define PropertyTagYPosition 0x011F -#define PropertyTagFreeOffset 0x0120 -#define PropertyTagFreeByteCounts 0x0121 -#define PropertyTagGrayResponseUnit 0x0122 -#define PropertyTagGrayResponseCurve 0x0123 -#define PropertyTagT4Option 0x0124 -#define PropertyTagT6Option 0x0125 -#define PropertyTagResolutionUnit 0x0128 -#define PropertyTagPageNumber 0x0129 -#define PropertyTagTransferFuncition 0x012D -#define PropertyTagSoftwareUsed 0x0131 -#define PropertyTagDateTime 0x0132 -#define PropertyTagArtist 0x013B -#define PropertyTagHostComputer 0x013C -#define PropertyTagPredictor 0x013D -#define PropertyTagWhitePoint 0x013E -#define PropertyTagPrimaryChromaticities 0x013F -#define PropertyTagColorMap 0x0140 -#define PropertyTagHalftoneHints 0x0141 -#define PropertyTagTileWidth 0x0142 -#define PropertyTagTileLength 0x0143 -#define PropertyTagTileOffset 0x0144 -#define PropertyTagTileByteCounts 0x0145 -#define PropertyTagInkSet 0x014C -#define PropertyTagInkNames 0x014D -#define PropertyTagNumberOfInks 0x014E -#define PropertyTagDotRange 0x0150 -#define PropertyTagTargetPrinter 0x0151 -#define PropertyTagExtraSamples 0x0152 -#define PropertyTagSampleFormat 0x0153 -#define PropertyTagSMinSampleValue 0x0154 -#define PropertyTagSMaxSampleValue 0x0155 -#define PropertyTagTransferRange 0x0156 -#define PropertyTagJPEGProc 0x0200 -#define PropertyTagJPEGInterFormat 0x0201 -#define PropertyTagJPEGInterLength 0x0202 -#define PropertyTagJPEGRestartInterval 0x0203 -#define PropertyTagJPEGLosslessPredictors 0x0205 -#define PropertyTagJPEGPointTransforms 0x0206 -#define PropertyTagJPEGQTables 0x0207 -#define PropertyTagJPEGDCTables 0x0208 -#define PropertyTagJPEGACTables 0x0209 -#define PropertyTagYCbCrCoefficients 0x0211 -#define PropertyTagYCbCrSubsampling 0x0212 -#define PropertyTagYCbCrPositioning 0x0213 -#define PropertyTagREFBlackWhite 0x0214 -#define PropertyTagICCProfile 0x8773 -#define PropertyTagGamma 0x0301 -#define PropertyTagICCProfileDescriptor 0x0302 -#define PropertyTagSRGBRenderingIntent 0x0303 -#define PropertyTagImageTitle 0x0320 -#define PropertyTagCopyright 0x8298 -#define PropertyTagResolutionXUnit 0x5001 -#define PropertyTagResolutionYUnit 0x5002 -#define PropertyTagResolutionXLengthUnit 0x5003 -#define PropertyTagResolutionYLengthUnit 0x5004 -#define PropertyTagPrintFlags 0x5005 -#define PropertyTagPrintFlagsVersion 0x5006 -#define PropertyTagPrintFlagsCrop 0x5007 -#define PropertyTagPrintFlagsBleedWidth 0x5008 -#define PropertyTagPrintFlagsBleedWidthScale 0x5009 -#define PropertyTagHalftoneLPI 0x500A -#define PropertyTagHalftoneLPIUnit 0x500B -#define PropertyTagHalftoneDegree 0x500C -#define PropertyTagHalftoneShape 0x500D -#define PropertyTagHalftoneMisc 0x500E -#define PropertyTagHalftoneScreen 0x500F -#define PropertyTagJPEGQuality 0x5010 -#define PropertyTagGridSize 0x5011 -#define PropertyTagThumbnailFormat 0x5012 -#define PropertyTagThumbnailWidth 0x5013 -#define PropertyTagThumbnailHeight 0x5014 -#define PropertyTagThumbnailColorDepth 0x5015 -#define PropertyTagThumbnailPlanes 0x5016 -#define PropertyTagThumbnailRawBytes 0x5017 -#define PropertyTagThumbnailSize 0x5018 -#define PropertyTagThumbnailCompressedSize 0x5019 -#define PropertyTagColorTransferFunction 0x501A -#define PropertyTagThumbnailData 0x501B -#define PropertyTagThumbnailImageWidth 0x5020 -#define PropertyTagThumbnailImageHeight 0x5021 -#define PropertyTagThumbnailBitsPerSample 0x5022 -#define PropertyTagThumbnailCompression 0x5023 -#define PropertyTagThumbnailPhotometricInterp 0x5024 -#define PropertyTagThumbnailImageDescription 0x5025 -#define PropertyTagThumbnailEquipMake 0x5026 -#define PropertyTagThumbnailEquipModel 0x5027 -#define PropertyTagThumbnailStripOffsets 0x5028 -#define PropertyTagThumbnailOrientation 0x5029 -#define PropertyTagThumbnailSamplesPerPixel 0x502A -#define PropertyTagThumbnailRowsPerStrip 0x502B -#define PropertyTagThumbnailStripBytesCount 0x502C -#define PropertyTagThumbnailResolutionX 0x502D -#define PropertyTagThumbnailResolutionY 0x502E -#define PropertyTagThumbnailPlanarConfig 0x502F -#define PropertyTagThumbnailResolutionUnit 0x5030 -#define PropertyTagThumbnailTransferFunction 0x5031 -#define PropertyTagThumbnailSoftwareUsed 0x5032 -#define PropertyTagThumbnailDateTime 0x5033 -#define PropertyTagThumbnailArtist 0x5034 -#define PropertyTagThumbnailWhitePoint 0x5035 -#define PropertyTagThumbnailPrimaryChromaticities 0x5036 -#define PropertyTagThumbnailYCbCrCoefficients 0x5037 -#define PropertyTagThumbnailYCbCrSubsampling 0x5038 -#define PropertyTagThumbnailYCbCrPositioning 0x5039 -#define PropertyTagThumbnailRefBlackWhite 0x503A -#define PropertyTagThumbnailCopyRight 0x503B -#define PropertyTagLuminanceTable 0x5090 -#define PropertyTagChrominanceTable 0x5091 -#define PropertyTagFrameDelay 0x5100 -#define PropertyTagLoopCount 0x5101 -#define PropertyTagPixelUnit 0x5110 -#define PropertyTagPixelPerUnitX 0x5111 -#define PropertyTagPixelPerUnitY 0x5112 -#define PropertyTagPaletteHistogram 0x5113 -#define PropertyTagExifExposureTime 0x829A -#define PropertyTagExifFNumber 0x829D -#define PropertyTagExifExposureProg 0x8822 -#define PropertyTagExifSpectralSense 0x8824 -#define PropertyTagExifISOSpeed 0x8827 -#define PropertyTagExifOECF 0x8828 -#define PropertyTagExifVer 0x9000 -#define PropertyTagExifDTOrig 0x9003 -#define PropertyTagExifDTDigitized 0x9004 -#define PropertyTagExifCompConfig 0x9101 -#define PropertyTagExifCompBPP 0x9102 -#define PropertyTagExifShutterSpeed 0x9201 -#define PropertyTagExifAperture 0x9202 -#define PropertyTagExifBrightness 0x9203 -#define PropertyTagExifExposureBias 0x9204 -#define PropertyTagExifMaxAperture 0x9205 -#define PropertyTagExifSubjectDist 0x9206 -#define PropertyTagExifMeteringMode 0x9207 -#define PropertyTagExifLightSource 0x9208 -#define PropertyTagExifFlash 0x9209 -#define PropertyTagExifFocalLength 0x920A -#define PropertyTagExifMakerNote 0x927C -#define PropertyTagExifUserComment 0x9286 -#define PropertyTagExifDTSubsec 0x9290 -#define PropertyTagExifDTOrigSS 0x9291 -#define PropertyTagExifDTDigSS 0x9292 -#define PropertyTagExifFPXVer 0xA000 -#define PropertyTagExifColorSpace 0xA001 -#define PropertyTagExifPixXDim 0xA002 -#define PropertyTagExifPixYDim 0xA003 -#define PropertyTagExifRelatedWav 0xA004 -#define PropertyTagExifInterop 0xA005 -#define PropertyTagExifFlashEnergy 0xA20B -#define PropertyTagExifSpatialFR 0xA20C -#define PropertyTagExifFocalXRes 0xA20E -#define PropertyTagExifFocalYRes 0xA20F -#define PropertyTagExifFocalResUnit 0xA210 -#define PropertyTagExifSubjectLoc 0xA214 -#define PropertyTagExifExposureIndex 0xA215 -#define PropertyTagExifSensingMethod 0xA217 -#define PropertyTagExifFileSource 0xA300 -#define PropertyTagExifSceneType 0xA301 -#define PropertyTagExifCfaPattern 0xA302 -#define PropertyTagGpsVer 0x0000 -#define PropertyTagGpsLatitudeRef 0x0001 -#define PropertyTagGpsLatitude 0x0002 -#define PropertyTagGpsLongitudeRef 0x0003 -#define PropertyTagGpsLongitude 0x0004 -#define PropertyTagGpsAltitudeRef 0x0005 -#define PropertyTagGpsAltitude 0x0006 -#define PropertyTagGpsGpsTime 0x0007 -#define PropertyTagGpsGpsSatellites 0x0008 -#define PropertyTagGpsGpsStatus 0x0009 -#define PropertyTagGpsGpsMeasureMode 0x00A -#define PropertyTagGpsGpsDop 0x000B -#define PropertyTagGpsSpeedRef 0x000C -#define PropertyTagGpsSpeed 0x000D -#define PropertyTagGpsTrackRef 0x000E -#define PropertyTagGpsTrack 0x000F -#define PropertyTagGpsImgDirRef 0x0010 -#define PropertyTagGpsImgDir 0x0011 -#define PropertyTagGpsMapDatum 0x0012 -#define PropertyTagGpsDestLatRef 0x0013 -#define PropertyTagGpsDestLat 0x0014 -#define PropertyTagGpsDestLongRef 0x0015 -#define PropertyTagGpsDestLong 0x0016 -#define PropertyTagGpsDestBearRef 0x0017 -#define PropertyTagGpsDestBear 0x0018 -#define PropertyTagGpsDestDistRef 0x0019 -#define PropertyTagGpsDestDist 0x001A - -#endif diff --git a/gdk-pixbuf/io-gdip-tiff.c b/gdk-pixbuf/io-gdip-tiff.c deleted file mode 100644 index 7e0a1898ea..0000000000 --- a/gdk-pixbuf/io-gdip-tiff.c +++ /dev/null @@ -1,87 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader
- *
- * Copyright (C) 2008 Dominic Lachowicz
- * Copyright (C) 2008 Alberto Ruiz
- *
- * Authors: Dominic Lachowicz <domlachowicz@gmail.com>
- * Alberto Ruiz <aruiz@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-#include "io-gdip-utils.h"
-
-static gboolean
-gdk_pixbuf__gdip_image_save_TIFF_to_callback (GdkPixbufSaveFunc save_func,
- gpointer user_data,
- GdkPixbuf *pixbuf,
- gchar **keys,
- gchar **values,
- GError **error)
-{
- return gdip_save_pixbuf (pixbuf, L"image/tiff", NULL, save_func, user_data, error);
-}
-
-static gboolean
-gdk_pixbuf__gdip_image_save_TIFF (FILE *f,
- GdkPixbuf *pixbuf,
- gchar **keys,
- gchar **values,
- GError **error)
-{
- return gdk_pixbuf__gdip_image_save_TIFF_to_callback (gdip_save_to_file_callback, f, pixbuf, keys, values, error);
-}
-
-#ifndef INCLUDE_gdiplus
-#define MODULE_ENTRY(function) G_MODULE_EXPORT void function
-#else
-#define MODULE_ENTRY(function) void _gdk_pixbuf__gdip_tiff_ ## function
-#endif
-
-MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module)
-{
- gdip_fill_vtable (module);
-
- module->save_to_callback = gdk_pixbuf__gdip_image_save_TIFF_to_callback;
- module->save = gdk_pixbuf__gdip_image_save_TIFF; /* for gtk < 2.14, you need to implement both. otherwise gdk-pixbuf-queryloaders fails */
-}
-
-MODULE_ENTRY (fill_info) (GdkPixbufFormat *info)
-{
- static GdkPixbufModulePattern signature[] = {
- { "MM \x2a", " z ", 100 }, /* TIFF */
- { "II\x2a ", " z", 100 }, /* TIFF */
- { NULL, NULL, 0 }
- };
-
- static gchar *mime_types[] = {
- "image/tiff",
- NULL
- };
-
- static gchar *extensions[] = {
- "tiff",
- "tif",
- NULL
- };
-
- info->name = "tiff";
- info->signature = signature;
- info->description = "The TIFF image format";
- info->mime_types = mime_types;
- info->extensions = extensions;
- info->flags = GDK_PIXBUF_FORMAT_WRITABLE | GDK_PIXBUF_FORMAT_THREADSAFE;
- info->license = "LGPL";
-}
diff --git a/gdk-pixbuf/io-gdip-utils.c b/gdk-pixbuf/io-gdip-utils.c deleted file mode 100644 index b8fa72bea1..0000000000 --- a/gdk-pixbuf/io-gdip-utils.c +++ /dev/null @@ -1,1022 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader - * - * Copyright (C) 2008 Dominic Lachowicz - * Copyright (C) 2008 Alberto Ruiz - * - * Authors: Dominic Lachowicz <domlachowicz@gmail.com> - * Alberto Ruiz <aruiz@gnome.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#define INITGUID -#include <ole2.h> - -#include "io-gdip-utils.h" -#include "io-gdip-native.h" -#include "io-gdip-propertytags.h" -#include "io-gdip-animation.h" - -#define LOAD_BUFFER_SIZE 65536 - -struct _GdipContext { - GdkPixbufModuleUpdatedFunc updated_func; - GdkPixbufModulePreparedFunc prepared_func; - GdkPixbufModuleSizeFunc size_func; - - gpointer user_data; - GByteArray *buffer; - IStream *stream; - HGLOBAL hg; -}; -typedef struct _GdipContext GdipContext; - -static GdiplusStartupFunc GdiplusStartup; -static GdipCreateBitmapFromStreamFunc GdipCreateBitmapFromStream; -static GdipBitmapGetPixelFunc GdipBitmapGetPixel; -static GdipGetImageHeightFunc GdipGetImageHeight; -static GdipDisposeImageFunc GdipDisposeImage; -static GdipGetImageFlagsFunc GdipGetImageFlags; -static GdipGetImageWidthFunc GdipGetImageWidth; -static GdipImageGetFrameCountFunc GdipImageGetFrameCount; -static GdipImageSelectActiveFrameFunc GdipImageSelectActiveFrame; -static GdipGetPropertyItemSizeFunc GdipGetPropertyItemSize; -static GdipGetPropertyItemFunc GdipGetPropertyItem; -static GdipGetPropertyCountFunc GdipGetPropertyCount; -static GdipGetPropertyIdListFunc GdipGetPropertyIdList; -static GdipCreateBitmapFromScan0Func GdipCreateBitmapFromScan0; -static GdipSaveImageToStreamFunc GdipSaveImageToStream; -static GdipBitmapSetPixelFunc GdipBitmapSetPixel; -static GdipDrawImageIFunc GdipDrawImageI; -static GdipGetImageGraphicsContextFunc GdipGetImageGraphicsContext; -static GdipFlushFunc GdipFlush; -static GdipGraphicsClearFunc GdipGraphicsClear; -static GdipBitmapSetResolutionFunc GdipBitmapSetResolution; -static GdipGetImageHorizontalResolutionFunc GdipGetImageHorizontalResolution; -static GdipGetImageVerticalResolutionFunc GdipGetImageVerticalResolution; -static GdipLoadImageFromStreamFunc GdipLoadImageFromStream; -static GdipDeleteGraphicsFunc GdipDeleteGraphics; -static GdipGetImageEncodersFunc GdipGetImageEncoders; -static GdipGetImageEncodersSizeFunc GdipGetImageEncodersSize; -static GdipBitmapLockBitsFunc GdipBitmapLockBits; -static GdipBitmapUnlockBitsFunc GdipBitmapUnlockBits; -static GdipGetImagePixelFormatFunc GdipGetImagePixelFormat; -static GdipCloneBitmapAreaIFunc GdipCloneBitmapAreaI; - -DEFINE_GUID(FrameDimensionTime, 0x6aedbd6d,0x3fb5,0x418a,0x83,0xa6,0x7f,0x45,0x22,0x9d,0xc8,0x72); -DEFINE_GUID(FrameDimensionPage, 0x7462dc86,0x6180,0x4c7e,0x8e,0x3f,0xee,0x73,0x33,0xa7,0xa4,0x83); - -static void -gdip_set_error_from_hresult (GError **error, gint code, HRESULT hr, const char *format) -{ - gchar *msg; - - msg = g_win32_error_message (hr); - - if (msg) { - g_set_error (error, GDK_PIXBUF_ERROR, code, format, msg); - g_free (msg); - } -} - -static void -gdip_set_error_from_gpstatus (GError **error, gint code, GpStatus status) -{ - const char *msg; - - switch (status) - { -#define CASE(x) case x: msg = #x; break - CASE (GenericError); - CASE (InvalidParameter); - CASE (OutOfMemory); - CASE (ObjectBusy); - CASE (InsufficientBuffer); - CASE (NotImplemented); - CASE (Win32Error); - CASE (WrongState); - CASE (Aborted); - CASE (FileNotFound); - CASE (ValueOverflow); - CASE (AccessDenied); - CASE (UnknownImageFormat); - CASE (FontFamilyNotFound); - CASE (FontStyleNotFound); - CASE (NotTrueTypeFont); - CASE (UnsupportedGdiplusVersion); - CASE (GdiplusNotInitialized); - CASE (PropertyNotFound); - CASE (PropertyNotSupported); - CASE (ProfileNotFound); - default: - msg = "Unknown error"; - } - g_set_error_literal (error, GDK_PIXBUF_ERROR, code, msg); -} - -static gboolean -gdip_init (void) -{ - GdiplusStartupInput input; - ULONG_PTR gdiplusToken = 0; - static HINSTANCE gdipluslib = NULL; - - if (!gdipluslib) - gdipluslib = LoadLibrary ("gdiplus.dll"); - else - return TRUE; /* gdip_init() is idempotent */ - - if (!gdipluslib) - return FALSE; - -#define LOOKUP(func) \ - G_STMT_START { \ - func = (func##Func) GetProcAddress (gdipluslib, #func); \ - if (!func) {\ - g_warning ("Couldn't find GDI+ function %s\n", #func); \ - return FALSE; \ - } \ - } G_STMT_END - - LOOKUP (GdiplusStartup); - LOOKUP (GdipCreateBitmapFromStream); - LOOKUP (GdipBitmapGetPixel); - LOOKUP (GdipGetImageHeight); - LOOKUP (GdipDisposeImage); - LOOKUP (GdipGetImageFlags); - LOOKUP (GdipGetImageWidth); - LOOKUP (GdipImageGetFrameCount); - LOOKUP (GdipImageSelectActiveFrame); - LOOKUP (GdipGetPropertyItemSize); - LOOKUP (GdipGetPropertyItem); - LOOKUP (GdipGetPropertyCount); - LOOKUP (GdipGetPropertyIdList); - LOOKUP (GdipCreateBitmapFromScan0); - LOOKUP (GdipSaveImageToStream); - LOOKUP (GdipBitmapSetPixel); - LOOKUP (GdipDrawImageI); - LOOKUP (GdipGetImageGraphicsContext); - LOOKUP (GdipFlush); - LOOKUP (GdipGraphicsClear); - LOOKUP (GdipBitmapSetResolution); - LOOKUP (GdipGetImageHorizontalResolution); - LOOKUP (GdipGetImageVerticalResolution); - LOOKUP (GdipLoadImageFromStream); - LOOKUP (GdipDeleteGraphics); - LOOKUP (GdipGetImageEncoders); - LOOKUP (GdipGetImageEncodersSize); - LOOKUP (GdipBitmapLockBits); - LOOKUP (GdipBitmapUnlockBits); - LOOKUP (GdipGetImagePixelFormat); - LOOKUP (GdipCloneBitmapAreaI); - -#undef LOOKUP - - input.GdiplusVersion = 1; - input.DebugEventCallback = NULL; - input.SuppressBackgroundThread = input.SuppressExternalCodecs = FALSE; - - return (GdiplusStartup (&gdiplusToken, &input, NULL) == 0 ? TRUE : FALSE); -} - -static gboolean -GetEncoderClsid (const WCHAR *format, CLSID *pClsid) -{ - UINT num, size; - int j; - ImageCodecInfo *pImageCodecInfo; - - if (Ok != GdipGetImageEncodersSize (&num, &size)) - return FALSE; - - pImageCodecInfo = (ImageCodecInfo *) g_malloc (size); - - if (Ok != GdipGetImageEncoders (num, size, pImageCodecInfo)) { - g_free (pImageCodecInfo); - return FALSE; - } - - for (j = 0; j < num; j++) { - if (wcscmp (pImageCodecInfo[j].MimeType, format) == 0) { - *pClsid = pImageCodecInfo[j].Clsid; - g_free (pImageCodecInfo); - return TRUE; - } - } - - g_free (pImageCodecInfo); - - return FALSE; -} - -static HGLOBAL -gdip_buffer_to_hglobal (const gchar *buffer, size_t size, GError **error) -{ - HGLOBAL hg = NULL; - - hg = GlobalAlloc (GPTR, size); - - if (!hg) { - gdip_set_error_from_hresult (error, GDK_PIXBUF_ERROR_FAILED, GetLastError (), _("Could not allocate memory: %s")); - return NULL; - } - - CopyMemory (hg, buffer, size); - - return hg; -} - -static gboolean -gdip_save_bitmap_to_callback (GpBitmap *bitmap, - const CLSID *format, - const EncoderParameters *encoder_params, - GdkPixbufSaveFunc save_func, - gpointer user_data, - GError **error) -{ - HRESULT hr; - IStream *streamOut = NULL; - gboolean success = FALSE; - guint64 zero = 0; - GpStatus status; - - hr = CreateStreamOnHGlobal (NULL, TRUE, &streamOut); - if (!SUCCEEDED (hr)) { - gdip_set_error_from_hresult (error, GDK_PIXBUF_ERROR_FAILED, hr, _("Could not create stream: %s")); - return FALSE; - } - - status = GdipSaveImageToStream ((GpImage *)bitmap, streamOut, format, encoder_params); - if (Ok != status) { - gdip_set_error_from_gpstatus (error, GDK_PIXBUF_ERROR_FAILED, status); - IStream_Release (streamOut); - return FALSE; - } - - /* seek back to the beginning of the stream */ - hr = IStream_Seek (streamOut, *(LARGE_INTEGER *)&zero, STREAM_SEEK_SET, NULL); - if (!SUCCEEDED (hr)) { - gdip_set_error_from_hresult (error, GDK_PIXBUF_ERROR_FAILED, hr, _("Could not seek stream: %s")); - IStream_Release (streamOut); - return FALSE; - } - - for (;;) { - char buffer[LOAD_BUFFER_SIZE]; - ULONG nread; - - hr = IStream_Read (streamOut, buffer, sizeof(buffer), &nread); - if (!SUCCEEDED (hr)) - { - gdip_set_error_from_hresult (error, GDK_PIXBUF_ERROR_FAILED, hr, _("Could not read from stream: %s")); - break; - } - else if (0 == nread) { - success = TRUE; /* EOF */ - break; - } - else if (!(*save_func) (buffer, nread, error, user_data)) - break; - } - - IStream_Release (streamOut); - - return success; -} - -static GpBitmap * -gdip_pixbuf_to_bitmap (GdkPixbuf *pixbuf) -{ - GpBitmap *bitmap = NULL; - - int width, height, stride, n_channels; - guint8 *pixels; - - width = gdk_pixbuf_get_width (pixbuf); - height = gdk_pixbuf_get_height (pixbuf); - stride = gdk_pixbuf_get_rowstride (pixbuf); - n_channels = gdk_pixbuf_get_n_channels (pixbuf); - pixels = gdk_pixbuf_get_pixels (pixbuf); - - if (n_channels == 3 || n_channels == 4) { - /* rgbX. need to convert to argb. pass a null data to get an empty bitmap */ - GdipCreateBitmapFromScan0 (width, height, 0, PixelFormat32bppARGB, NULL, &bitmap); - - if (bitmap) { - int x, y; - - for (y = 0; y < height; y++) { - for (x = 0; x < width; x++) { - ARGB p; - guint8 alpha; - guchar *base = pixels + (y * stride + (x * n_channels)); - - if (n_channels == 4) - alpha = base[3]; - else - alpha = 0xff; - - if (alpha == 0) - p = 0; - else { - guint8 red = base[0]; - guint8 green = base[1]; - guint8 blue = base[2]; - - p = (alpha << 24) | (red << 16) | (green << 8) | (blue << 0); - } - - GdipBitmapSetPixel (bitmap, x, y, p); - } - } - } - } - else { - g_warning ("Unsupported number of channels: %d\n", n_channels); - } - - return bitmap; -} - -static GpBitmap * -gdip_buffer_to_bitmap (GdipContext *context, GError **error) -{ - HRESULT hr; - HGLOBAL hg = NULL; - GpBitmap *bitmap = NULL; - IStream *stream = NULL; - GpStatus status; - guint64 size64 = context->buffer->len; - - hg = gdip_buffer_to_hglobal (context->buffer->data, context->buffer->len, error); - - if (!hg) - return NULL; - - hr = CreateStreamOnHGlobal (hg, FALSE, (LPSTREAM *)&stream); - - if (!SUCCEEDED (hr)) { - gdip_set_error_from_hresult (error, GDK_PIXBUF_ERROR_FAILED, hr, _("Could not create stream: %s")); - GlobalFree (hg); - return NULL; - } - - IStream_SetSize (stream, *(ULARGE_INTEGER *)&size64); - - status = GdipCreateBitmapFromStream (stream, &bitmap); - - if (Ok != status) { - gdip_set_error_from_gpstatus (error, GDK_PIXBUF_ERROR_FAILED, status); - IStream_Release (stream); - GlobalFree (hg); - return NULL; - } - - context->stream = stream; - context->hg = hg; - - return bitmap; -} - -static GpImage * -gdip_buffer_to_image (GdipContext *context, GError **error) -{ - HRESULT hr; - HGLOBAL hg = NULL; - GpImage *image = NULL; - IStream *stream = NULL; - GpStatus status; - guint64 size64 = context->buffer->len; - - hg = gdip_buffer_to_hglobal (context->buffer->data, context->buffer->len, error); - - if (!hg) - return NULL; - - hr = CreateStreamOnHGlobal (hg, FALSE, (LPSTREAM *)&stream); - - if (!SUCCEEDED (hr)) { - gdip_set_error_from_hresult (error, GDK_PIXBUF_ERROR_FAILED, hr, _("Could not create stream: %s")); - GlobalFree (hg); - return NULL; - } - - IStream_SetSize (stream, *(ULARGE_INTEGER *)&size64); - status = GdipLoadImageFromStream (stream, &image); - - if (Ok != status) { - gdip_set_error_from_gpstatus (error, GDK_PIXBUF_ERROR_FAILED, status); - IStream_Release (stream); - GlobalFree (hg); - return NULL; - } - - context->stream = stream; - context->hg = hg; - - return image; -} - -static void -gdip_bitmap_get_size (GpBitmap *bitmap, guint *width, guint *height) -{ - if (bitmap == NULL || width == NULL || height == NULL) - return; - - *width = *height = 0; - - GdipGetImageWidth ((GpImage *) bitmap, width); - GdipGetImageHeight ((GpImage *) bitmap, height); -} - -static void -gdip_bitmap_get_has_alpha (GpBitmap *bitmap, gboolean *has_alpha) -{ - guint flags = 0; - - if (bitmap == NULL || has_alpha == NULL) - return; - - GdipGetImageFlags ((GpImage *) bitmap, &flags); - *has_alpha = (flags & ImageFlagsHasAlpha); -} - -static gboolean -gdip_bitmap_get_n_frames (GpBitmap *bitmap, guint *n_frames, gboolean timeDimension) -{ - if (bitmap == NULL || n_frames == NULL) - return FALSE; - - *n_frames = 1; - - return (Ok == GdipImageGetFrameCount ((GpImage *) bitmap, (timeDimension ? &FrameDimensionTime : &FrameDimensionPage), n_frames)); -} - -static gboolean -gdip_bitmap_select_frame (GpBitmap *bitmap, guint frame, gboolean timeDimension) -{ - if (bitmap == NULL) - return FALSE; - - return (Ok == GdipImageSelectActiveFrame ((GpImage *)bitmap, (timeDimension ? &FrameDimensionTime : &FrameDimensionPage), frame)); -} - -static gboolean -gdip_bitmap_get_property_as_string (GpBitmap *bitmap, guint propertyId, gchar **str) -{ - guint item_size; - gboolean success = FALSE; - - if (bitmap == NULL || str == NULL) - return FALSE; - - *str = 0; - - if (Ok == GdipGetPropertyItemSize ((GpImage *)bitmap, propertyId, &item_size)) { - PropertyItem *item; - - item = (PropertyItem *)g_try_malloc (item_size); - if (Ok == GdipGetPropertyItem ((GpImage *)bitmap, propertyId, item_size, item)) { - GString *gstr; - int i; - - gstr = g_string_new (NULL); - - success = TRUE; - switch (item->type) { - case PropertyTagTypeByte: - for (i = 0; i < item->length / sizeof(guint8); i++) { - guint8 *bytes = (guint8 *)item->value; - - if (gstr->len != 0) - g_string_append_c(gstr, ','); - g_string_append_printf (gstr, "%u", (guint32)bytes[i]); - } - break; - - case PropertyTagTypeASCII: - g_string_append_len (gstr, (const char *)item->value, item->length); - break; - - case PropertyTagTypeShort: - for (i = 0; i < item->length / sizeof(guint16); i++) { - guint16 *shorts = (guint16 *)item->value; - - if (gstr->len != 0) - g_string_append_c (gstr, ','); - g_string_append_printf (gstr, "%u", (guint32)shorts[i]); - } - break; - - case PropertyTagTypeLong: - for (i = 0; i < item->length / sizeof(guint32); i++) { - guint32 *longs = (guint32 *)item->value; - - if (gstr->len != 0) - g_string_append_c (gstr, ','); - g_string_append_printf (gstr, "%u", longs[i]); - } - break; - - case PropertyTagTypeSLONG: - for (i = 0; i < item->length / sizeof(guint32); i++) { - gint32 *longs = (gint32 *)item->value; - - if (gstr->len != 0) - g_string_append_c (gstr, ','); - g_string_append_printf (gstr, "%d", longs[i]); - } - break; - - default: - success = FALSE; - break; - } - - if (gstr->len > 0) - *str = g_string_free (gstr, FALSE); - else - g_string_free (gstr, TRUE); - } - - g_free (item); - } - - return success; -} - -static gboolean -gdip_bitmap_get_frame_delay (GpBitmap *bitmap, guint *delay) -{ - guint item_size; - gboolean success = FALSE; - - if (bitmap == NULL || delay == NULL) - return FALSE; - - *delay = 0; - - if (Ok == GdipGetPropertyItemSize ((GpImage *)bitmap, PropertyTagFrameDelay, &item_size)) { - PropertyItem *item; - - item = (PropertyItem *)g_try_malloc (item_size); - if (Ok == GdipGetPropertyItem ((GpImage *)bitmap, PropertyTagFrameDelay, item_size, item)) { - /* PropertyTagFrameDelay. Time delay, in hundredths of a second, between two frames in an animated GIF image. */ - *delay = *((long *)item->value); - success = TRUE; - } - - g_free (item); - } - - return success; -} - -static gboolean -gdip_bitmap_get_n_loops (GpBitmap *bitmap, guint *loops) -{ - guint item_size; - gboolean success = FALSE; - - if (bitmap == NULL || loops == NULL) - return FALSE; - - *loops = 1; - - /* PropertyTagLoopCount. 0 == infinitely */ - if (Ok == GdipGetPropertyItemSize ((GpImage *)bitmap, PropertyTagLoopCount, &item_size)) { - PropertyItem *item; - - item = (PropertyItem *)g_try_malloc (item_size); - if (Ok == GdipGetPropertyItem ((GpImage *)bitmap, PropertyTagLoopCount, item_size, item)) { - *loops = *((short *)item->value); - success = TRUE; - } - - g_free (item); - } - - return success; -} - -static void -destroy_gdipcontext (GdipContext *context) -{ - if (context != NULL) { - if (context->stream != NULL) { - IStream_Release(context->stream); - GlobalFree (context->hg); - } - g_byte_array_free (context->buffer, TRUE); - g_free (context); - } -} - -static void -emit_updated (GdipContext *context, GdkPixbuf *pixbuf) -{ - if (context->updated_func) - (*context->updated_func) (pixbuf, - 0, 0, - gdk_pixbuf_get_width (pixbuf), - gdk_pixbuf_get_height (pixbuf), - context->user_data); -} - -static void -emit_prepared (GdipContext *context, GdkPixbuf *pixbuf, GdkPixbufAnimation *anim) -{ - if (context->prepared_func) - (*context->prepared_func) (pixbuf, anim, context->user_data); -} - -static gpointer -gdk_pixbuf__gdip_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error) -{ - GdipContext *context = g_new0 (GdipContext, 1); - - context->size_func = size_func; - context->prepared_func = prepared_func; - context->updated_func = updated_func; - context->user_data = user_data; - context->buffer = g_byte_array_new (); - - return context; -} - -static gboolean -gdk_pixbuf__gdip_image_load_increment (gpointer data, - const guchar *buf, guint size, - GError **error) -{ - GdipContext *context = (GdipContext *)data; - GByteArray *image_buffer = context->buffer; - - g_byte_array_append (image_buffer, (guint8 *)buf, size); - - return TRUE; -} - -static GdkPixbuf * -gdip_bitmap_to_pixbuf (GpBitmap *bitmap, GError **error) -{ - GdkPixbuf *pixbuf = NULL; - guchar *cursor = NULL; - gint rowstride; - gboolean has_alpha = FALSE; - gint n_channels = 0; - gchar *option; - - guint width = 0, height = 0, x, y; - - gdip_bitmap_get_size (bitmap, &width, &height); - gdip_bitmap_get_has_alpha (bitmap, &has_alpha); - - pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, has_alpha, 8, width, height); - - if (!pixbuf) { - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, _("Couldn't load bitmap")); - return NULL; - } - - rowstride = gdk_pixbuf_get_rowstride (pixbuf); - cursor = gdk_pixbuf_get_pixels (pixbuf); - n_channels = gdk_pixbuf_get_n_channels (pixbuf); - - for (y = 0; y < height; y++) { - for (x = 0; x < width; x++) { - ARGB pixel; - GpStatus status; - guchar *b = cursor + (y * rowstride + (x * n_channels)); - - if (Ok != (status = GdipBitmapGetPixel (bitmap, x, y, &pixel))) { - gdip_set_error_from_gpstatus (error, GDK_PIXBUF_ERROR_FAILED, status); - g_object_unref (pixbuf); - return NULL; - } - - b[0] = (pixel & 0xff0000) >> 16; - b[1] = (pixel & 0x00ff00) >> 8; - b[2] = (pixel & 0x0000ff) >> 0; - - if (has_alpha) - b[3] = (pixel & 0xff000000) >> 24; - } - } - - if (gdip_bitmap_get_property_as_string (bitmap, PropertyTagOrientation, &option)) { - gdk_pixbuf_set_option (pixbuf, "orientation", option); - g_free (option); - } - - if (gdip_bitmap_get_property_as_string (bitmap, PropertyTagArtist, &option)) { - gdk_pixbuf_set_option (pixbuf, "Author", option); - g_free (option); - } - - if (gdip_bitmap_get_property_as_string (bitmap, PropertyTagImageTitle, &option)) { - gdk_pixbuf_set_option (pixbuf, "Title", option); - g_free (option); - } - - return pixbuf; -} - -static gboolean -stop_load (GpBitmap *bitmap, GdipContext *context, GError **error) -{ - guint n_frames = 1, i; - GdkPixbufGdipAnim *animation = NULL; - - gdip_bitmap_get_n_frames (bitmap, &n_frames, TRUE); - - for (i = 0; i < n_frames; i++) { - GdkPixbuf *pixbuf = NULL; - GdkPixbufFrame *frame; - guint frame_delay = 0; - - gdip_bitmap_select_frame (bitmap, i, TRUE); - - pixbuf = gdip_bitmap_to_pixbuf (bitmap, error); - - if (!pixbuf) { - if (animation != NULL) - g_object_unref (G_OBJECT (animation)); - - GdipDisposeImage ((GpImage *)bitmap); - destroy_gdipcontext (context); - return FALSE; - } - - if (animation == NULL) { - guint n_loops = 1; - - animation = g_object_new (GDK_TYPE_PIXBUF_GDIP_ANIM, NULL); - gdip_bitmap_get_n_loops (bitmap, &n_loops); - animation->loop = n_loops; - } - - frame = g_new (GdkPixbufFrame, 1); - frame->pixbuf = pixbuf; - - gdip_bitmap_get_frame_delay (bitmap, &frame_delay); - - animation->n_frames++; - animation->frames = g_list_append (animation->frames, frame); - - animation->width = gdk_pixbuf_get_width (pixbuf); - animation->height = gdk_pixbuf_get_height (pixbuf); - - /* GIF delay is in hundredths, we want thousandths */ - frame->delay_time = frame_delay * 10; - frame->elapsed = animation->total_time; - - /* Some GIFs apparently have delay time of 0, - * that crashes everything so set it to "fast". - * Also, timeouts less than 20 or so just lock up - * the app or make the animation choppy, so fix them. - */ - if (frame->delay_time < 20) - frame->delay_time = 20; /* 20 = "fast" */ - - animation->total_time += frame->delay_time; - - if (i == 0) - emit_prepared (context, pixbuf, GDK_PIXBUF_ANIMATION (animation)); - - emit_updated (context, pixbuf); - } - - if (animation != NULL) - g_object_unref (G_OBJECT (animation)); - - GdipDisposeImage ((GpImage *)bitmap); - destroy_gdipcontext (context); - - return TRUE; -} - -static gboolean -gdk_pixbuf__gdip_image_stop_load (gpointer data, GError **error) -{ - GdipContext *context = (GdipContext *)data; - GpBitmap *bitmap = NULL; - - bitmap = gdip_buffer_to_bitmap (context, error); - - if (!bitmap) { - destroy_gdipcontext (context); - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_CORRUPT_IMAGE, _("Couldn't load bitmap")); - return FALSE; - } - - return stop_load (bitmap, context, error); -} - -static gboolean -gdk_pixbuf__gdip_image_stop_vector_load (gpointer data, GError **error) -{ - GdipContext *context = (GdipContext *)data; - - GpImage *metafile; - GpGraphics *graphics; - GpBitmap *bitmap; - GpStatus status; - float metafile_xres, metafile_yres; - guint width, height; - - metafile = gdip_buffer_to_image (context, error); - if (!metafile) { - destroy_gdipcontext (context); - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_CORRUPT_IMAGE, _("Couldn't load metafile")); - return FALSE; - } - - GdipGetImageWidth (metafile, &width); - GdipGetImageHeight (metafile, &height); - - status = GdipCreateBitmapFromScan0 (width, height, 0, PixelFormat32bppARGB, NULL, &bitmap); - if (Ok != status) { - gdip_set_error_from_gpstatus (error, GDK_PIXBUF_ERROR_FAILED, status); - GdipDisposeImage (metafile); - - return FALSE; - } - - GdipGetImageHorizontalResolution (metafile, &metafile_xres); - GdipGetImageVerticalResolution (metafile, &metafile_yres); - GdipBitmapSetResolution (bitmap, metafile_xres, metafile_yres); - - status = GdipGetImageGraphicsContext ((GpImage *)bitmap, &graphics); - if (Ok != status) { - gdip_set_error_from_gpstatus (error, GDK_PIXBUF_ERROR_FAILED, status); - GdipDisposeImage ((GpImage *)bitmap); - GdipDisposeImage (metafile); - - return FALSE; - } - - /* gotta clear the bitmap */ - GdipGraphicsClear (graphics, 0xffffffff); - - status = GdipDrawImageI (graphics, metafile, 0, 0); - if (Ok != status) { - gdip_set_error_from_gpstatus (error, GDK_PIXBUF_ERROR_FAILED, status); - GdipDeleteGraphics (graphics); - GdipDisposeImage ((GpImage *)bitmap); - GdipDisposeImage (metafile); - - return FALSE; - } - - GdipFlush (graphics, 1); - - GdipDeleteGraphics (graphics); - GdipDisposeImage (metafile); - - return stop_load (bitmap, context, error); -} - -static void -gdip_animation_prepare (GdkPixbuf *pixbuf, - GdkPixbufAnimation *animation, - gpointer user_data) -{ - GdkPixbufAnimation **anim; - - anim = (GdkPixbufAnimation **)user_data; - - /* save a reference to the animation */ - g_object_ref (animation); - *anim = animation; -} - -static GdkPixbufAnimation * -gdk_pixbuf__gdip_image_load_animation (FILE *file, - GError **error) -{ - GdkPixbufAnimation *animation = NULL; - - gpointer context; - char buffer[LOAD_BUFFER_SIZE]; - size_t length; - - context = gdk_pixbuf__gdip_image_begin_load (NULL, gdip_animation_prepare, NULL, &animation, error); - - while (!feof (file) && !ferror (file)) { - length = fread (buffer, 1, sizeof (buffer), file); - if (length > 0) { - if (!gdk_pixbuf__gdip_image_load_increment (context, buffer, length, error)) { - gdk_pixbuf__gdip_image_stop_load (context, NULL); - - if (animation) - g_object_unref (animation); - - return NULL; - } - } - } - - if (!gdk_pixbuf__gdip_image_stop_load(context, error)) { - if (animation) - g_object_unref (animation); - - return NULL; - } - - return animation; -} - -gboolean -gdip_save_to_file_callback (const gchar *buf, - gsize count, - GError **error, - gpointer data) -{ - FILE *filehandle = data; - gsize n; - - n = fwrite (buf, 1, count, filehandle); - if (n != count) { - gint save_errno = errno; - g_set_error (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Error writing to image file: %s"), - g_strerror (save_errno)); - return FALSE; - } - - return TRUE; -} - -void -gdip_fill_vtable (GdkPixbufModule *module) -{ - if (gdip_init ()) { - module->begin_load = gdk_pixbuf__gdip_image_begin_load; - module->stop_load = gdk_pixbuf__gdip_image_stop_load; - module->load_increment = gdk_pixbuf__gdip_image_load_increment; - - /* this is the only way to get gtk_image_new_from_file() to load animations. it regrettably - does not use the GdkPixbufLoader interface. */ - module->load_animation = gdk_pixbuf__gdip_image_load_animation; - } -} - -void -gdip_fill_vector_vtable (GdkPixbufModule *module) -{ - if (gdip_init ()) { - module->begin_load = gdk_pixbuf__gdip_image_begin_load; - module->stop_load = gdk_pixbuf__gdip_image_stop_vector_load; - module->load_increment = gdk_pixbuf__gdip_image_load_increment; - } -} - -gboolean -gdip_save_pixbuf (GdkPixbuf *pixbuf, - const WCHAR *format, - const EncoderParameters *encoder_params, - GdkPixbufSaveFunc save_func, - gpointer user_data, - GError **error) -{ - GpBitmap *image; - CLSID clsid; - gboolean success; - - if (!GetEncoderClsid (format, &clsid)) { - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_FAILED, _("Unsupported image format for GDI+")); - return FALSE; - } - - image = gdip_pixbuf_to_bitmap (pixbuf); - - if (image == NULL) { - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_FAILED, _("Couldn't save")); - return FALSE; - } - - success = gdip_save_bitmap_to_callback (image, &clsid, encoder_params, save_func, user_data, error); - - GdipDisposeImage ((GpImage *)image); - - return success; -} diff --git a/gdk-pixbuf/io-gdip-utils.h b/gdk-pixbuf/io-gdip-utils.h deleted file mode 100644 index 14681c1e26..0000000000 --- a/gdk-pixbuf/io-gdip-utils.h +++ /dev/null @@ -1,52 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader - * - * Copyright (C) 2008 Dominic Lachowicz - * Copyright (C) 2008 Alberto Ruiz - * - * Authors: Dominic Lachowicz <domlachowicz@gmail.com> - * Alberto Ruiz <aruiz@gnome.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#ifndef _HAVE_IO_GDIP_UTILS_H -#define _HAVE_IO_GDIP_UTILS_H - -#include "gdk-pixbuf.h" -#include "gdk-pixbuf-i18n.h" - -#include "io-gdip-native.h" - -gboolean -gdip_save_to_file_callback (const gchar *buf, - gsize count, - GError **error, - gpointer data); - -void -gdip_fill_vtable (GdkPixbufModule *module); - -void -gdip_fill_vector_vtable (GdkPixbufModule *module); - -gboolean -gdip_save_pixbuf (GdkPixbuf *pixbuf, - const WCHAR *format, - const EncoderParameters *encoder_params, - GdkPixbufSaveFunc save_func, - gpointer user_data, - GError **error); - -#endif diff --git a/gdk-pixbuf/io-gdip-wmf.c b/gdk-pixbuf/io-gdip-wmf.c deleted file mode 100644 index 3c89d4a3d7..0000000000 --- a/gdk-pixbuf/io-gdip-wmf.c +++ /dev/null @@ -1,63 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/* GdkPixbuf library - Win32 GDI+ Pixbuf Loader - * - * Copyright (C) 2008 Dominic Lachowicz - * Copyright (C) 2008 Alberto Ruiz - * - * Authors: Dominic Lachowicz <domlachowicz@gmail.com> - * Alberto Ruiz <aruiz@gnome.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "io-gdip-utils.h" - -#ifndef INCLUDE_gdiplus -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__gdip_wmf_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - gdip_fill_vector_vtable (module); -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "\xd7\xcd\xc6\x9a", NULL, 100 }, /* WMF */ - { "\x01\x00\x09\x00", NULL, 100 }, /* WMF */ - { NULL, NULL, 0 } - }; - - static gchar *mime_types[] = { - "image/x-wmf", - NULL - }; - - static gchar *extensions[] = { - "wmf", - "apm", - NULL - }; - - info->name = "wmf"; - info->signature = signature; - info->description = _("The WMF image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-gif-animation.c b/gdk-pixbuf/io-gif-animation.c deleted file mode 100644 index 391e928503..0000000000 --- a/gdk-pixbuf/io-gif-animation.c +++ /dev/null @@ -1,602 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - animated gif support - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Jonathan Blandford <jrb@redhat.com> - * Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <errno.h> -#include "gdk-pixbuf-private.h" -#include "io-gif-animation.h" - -static void gdk_pixbuf_gif_anim_class_init (GdkPixbufGifAnimClass *klass); -static void gdk_pixbuf_gif_anim_finalize (GObject *object); - -static gboolean gdk_pixbuf_gif_anim_is_static_image (GdkPixbufAnimation *animation); -static GdkPixbuf* gdk_pixbuf_gif_anim_get_static_image (GdkPixbufAnimation *animation); - -static void gdk_pixbuf_gif_anim_get_size (GdkPixbufAnimation *anim, - int *width, - int *height); -static GdkPixbufAnimationIter* gdk_pixbuf_gif_anim_get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time); - - - - -static gpointer parent_class; - -GType -gdk_pixbuf_gif_anim_get_type (void) -{ - static GType object_type = 0; - - if (!object_type) { - const GTypeInfo object_info = { - sizeof (GdkPixbufGifAnimClass), - (GBaseInitFunc) NULL, - (GBaseFinalizeFunc) NULL, - (GClassInitFunc) gdk_pixbuf_gif_anim_class_init, - NULL, /* class_finalize */ - NULL, /* class_data */ - sizeof (GdkPixbufGifAnim), - 0, /* n_preallocs */ - (GInstanceInitFunc) NULL, - }; - - object_type = g_type_register_static (GDK_TYPE_PIXBUF_ANIMATION, - g_intern_static_string ("GdkPixbufGifAnim"), - &object_info, 0); - } - - return object_type; -} - -static void -gdk_pixbuf_gif_anim_class_init (GdkPixbufGifAnimClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - GdkPixbufAnimationClass *anim_class = GDK_PIXBUF_ANIMATION_CLASS (klass); - - parent_class = g_type_class_peek_parent (klass); - - object_class->finalize = gdk_pixbuf_gif_anim_finalize; - - anim_class->is_static_image = gdk_pixbuf_gif_anim_is_static_image; - anim_class->get_static_image = gdk_pixbuf_gif_anim_get_static_image; - anim_class->get_size = gdk_pixbuf_gif_anim_get_size; - anim_class->get_iter = gdk_pixbuf_gif_anim_get_iter; -} - -static void -gdk_pixbuf_gif_anim_finalize (GObject *object) -{ - GdkPixbufGifAnim *gif_anim = GDK_PIXBUF_GIF_ANIM (object); - - GList *l; - GdkPixbufFrame *frame; - - for (l = gif_anim->frames; l; l = l->next) { - frame = l->data; - g_object_unref (frame->pixbuf); - if (frame->composited) - g_object_unref (frame->composited); - if (frame->revert) - g_object_unref (frame->revert); - g_free (frame); - } - - g_list_free (gif_anim->frames); - - G_OBJECT_CLASS (parent_class)->finalize (object); -} - -static gboolean -gdk_pixbuf_gif_anim_is_static_image (GdkPixbufAnimation *animation) -{ - GdkPixbufGifAnim *gif_anim; - - gif_anim = GDK_PIXBUF_GIF_ANIM (animation); - - return (gif_anim->frames != NULL && - gif_anim->frames->next == NULL); -} - -static GdkPixbuf* -gdk_pixbuf_gif_anim_get_static_image (GdkPixbufAnimation *animation) -{ - GdkPixbufGifAnim *gif_anim; - - gif_anim = GDK_PIXBUF_GIF_ANIM (animation); - - if (gif_anim->frames == NULL) - return NULL; - else - return GDK_PIXBUF (((GdkPixbufFrame*)gif_anim->frames->data)->pixbuf); -} - -static void -gdk_pixbuf_gif_anim_get_size (GdkPixbufAnimation *anim, - int *width, - int *height) -{ - GdkPixbufGifAnim *gif_anim; - - gif_anim = GDK_PIXBUF_GIF_ANIM (anim); - - if (width) - *width = gif_anim->width; - - if (height) - *height = gif_anim->height; -} - - -static void -iter_clear (GdkPixbufGifAnimIter *iter) -{ - iter->current_frame = NULL; -} - -static void -iter_restart (GdkPixbufGifAnimIter *iter) -{ - iter_clear (iter); - - iter->current_frame = iter->gif_anim->frames; -} - -static GdkPixbufAnimationIter* -gdk_pixbuf_gif_anim_get_iter (GdkPixbufAnimation *anim, - const GTimeVal *start_time) -{ - GdkPixbufGifAnimIter *iter; - - iter = g_object_new (GDK_TYPE_PIXBUF_GIF_ANIM_ITER, NULL); - - iter->gif_anim = GDK_PIXBUF_GIF_ANIM (anim); - - g_object_ref (iter->gif_anim); - - iter_restart (iter); - - iter->start_time = *start_time; - iter->current_time = *start_time; - iter->first_loop_slowness = 0; - - return GDK_PIXBUF_ANIMATION_ITER (iter); -} - - - -static void gdk_pixbuf_gif_anim_iter_class_init (GdkPixbufGifAnimIterClass *klass); -static void gdk_pixbuf_gif_anim_iter_finalize (GObject *object); - -static int gdk_pixbuf_gif_anim_iter_get_delay_time (GdkPixbufAnimationIter *iter); -static GdkPixbuf* gdk_pixbuf_gif_anim_iter_get_pixbuf (GdkPixbufAnimationIter *iter); -static gboolean gdk_pixbuf_gif_anim_iter_on_currently_loading_frame (GdkPixbufAnimationIter *iter); -static gboolean gdk_pixbuf_gif_anim_iter_advance (GdkPixbufAnimationIter *iter, - const GTimeVal *current_time); - - - -static gpointer iter_parent_class; - -GType -gdk_pixbuf_gif_anim_iter_get_type (void) -{ - static GType object_type = 0; - - if (!object_type) { - const GTypeInfo object_info = { - sizeof (GdkPixbufGifAnimIterClass), - (GBaseInitFunc) NULL, - (GBaseFinalizeFunc) NULL, - (GClassInitFunc) gdk_pixbuf_gif_anim_iter_class_init, - NULL, /* class_finalize */ - NULL, /* class_data */ - sizeof (GdkPixbufGifAnimIter), - 0, /* n_preallocs */ - (GInstanceInitFunc) NULL, - }; - - object_type = g_type_register_static (GDK_TYPE_PIXBUF_ANIMATION_ITER, - g_intern_static_string ("GdkPixbufGifAnimIter"), - &object_info, 0); - } - - return object_type; -} - -static void -gdk_pixbuf_gif_anim_iter_class_init (GdkPixbufGifAnimIterClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - GdkPixbufAnimationIterClass *anim_iter_class = - GDK_PIXBUF_ANIMATION_ITER_CLASS (klass); - - iter_parent_class = g_type_class_peek_parent (klass); - - object_class->finalize = gdk_pixbuf_gif_anim_iter_finalize; - - anim_iter_class->get_delay_time = gdk_pixbuf_gif_anim_iter_get_delay_time; - anim_iter_class->get_pixbuf = gdk_pixbuf_gif_anim_iter_get_pixbuf; - anim_iter_class->on_currently_loading_frame = gdk_pixbuf_gif_anim_iter_on_currently_loading_frame; - anim_iter_class->advance = gdk_pixbuf_gif_anim_iter_advance; -} - -static void -gdk_pixbuf_gif_anim_iter_finalize (GObject *object) -{ - GdkPixbufGifAnimIter *iter = GDK_PIXBUF_GIF_ANIM_ITER (object); - - iter_clear (iter); - - g_object_unref (iter->gif_anim); - - G_OBJECT_CLASS (iter_parent_class)->finalize (object); -} - -static gboolean -gdk_pixbuf_gif_anim_iter_advance (GdkPixbufAnimationIter *anim_iter, - const GTimeVal *current_time) -{ - GdkPixbufGifAnimIter *iter; - gint elapsed; - gint loop; - GList *tmp; - GList *old; - - iter = GDK_PIXBUF_GIF_ANIM_ITER (anim_iter); - - iter->current_time = *current_time; - - /* We use milliseconds for all times */ - elapsed = - (((iter->current_time.tv_sec - iter->start_time.tv_sec) * G_USEC_PER_SEC + - iter->current_time.tv_usec - iter->start_time.tv_usec)) / 1000; - - if (elapsed < 0) { - /* Try to compensate; probably the system clock - * was set backwards - */ - iter->start_time = iter->current_time; - elapsed = 0; - } - - g_assert (iter->gif_anim->total_time > 0); - - /* See how many times we've already played the full animation, - * and subtract time for that. - */ - - if (iter->gif_anim->loading) - loop = 0; - else { - /* If current_frame is NULL at this point, we have loaded the - * animation from a source which fell behind the speed of the - * display. We remember how much slower the first loop was due - * to this and correct the position calculation in order to not - * jump in the middle of the second loop. - */ - if (iter->current_frame == NULL) - iter->first_loop_slowness = MAX(0, elapsed - iter->gif_anim->total_time); - - loop = (elapsed - iter->first_loop_slowness) / iter->gif_anim->total_time; - elapsed = (elapsed - iter->first_loop_slowness) % iter->gif_anim->total_time; - } - - iter->position = elapsed; - - /* Now move to the proper frame */ - if (iter->gif_anim->loop == 0 || loop < iter->gif_anim->loop) - tmp = iter->gif_anim->frames; - else - tmp = NULL; - while (tmp != NULL) { - GdkPixbufFrame *frame = tmp->data; - - if (iter->position >= frame->elapsed && - iter->position < (frame->elapsed + frame->delay_time)) - break; - - tmp = tmp->next; - } - - old = iter->current_frame; - - iter->current_frame = tmp; - - return iter->current_frame != old; -} - -int -gdk_pixbuf_gif_anim_iter_get_delay_time (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufFrame *frame; - GdkPixbufGifAnimIter *iter; - - iter = GDK_PIXBUF_GIF_ANIM_ITER (anim_iter); - - if (iter->current_frame) { - frame = iter->current_frame->data; - -#if 0 - g_print ("frame start: %d pos: %d frame len: %d frame remaining: %d\n", - frame->elapsed, - iter->position, - frame->delay_time, - frame->delay_time - (iter->position - frame->elapsed)); -#endif - - return frame->delay_time - (iter->position - frame->elapsed); - } else - return -1; /* show last frame forever */ -} - -void -gdk_pixbuf_gif_anim_frame_composite (GdkPixbufGifAnim *gif_anim, - GdkPixbufFrame *frame) -{ - GList *link; - GList *tmp; - - link = g_list_find (gif_anim->frames, frame); - - if (frame->need_recomposite || frame->composited == NULL) { - /* For now, to composite we start with the last - * composited frame and composite everything up to - * here. - */ - - /* Rewind to last composited frame. */ - tmp = link; - while (tmp != NULL) { - GdkPixbufFrame *f = tmp->data; - - if (f->need_recomposite) { - if (f->composited) { - g_object_unref (f->composited); - f->composited = NULL; - } - } - - if (f->composited != NULL) - break; - - tmp = tmp->prev; - } - - /* Go forward, compositing all frames up to the current frame */ - if (tmp == NULL) - tmp = gif_anim->frames; - - while (tmp != NULL) { - GdkPixbufFrame *f = tmp->data; - gint clipped_width, clipped_height; - - if (f->pixbuf == NULL) - return; - - clipped_width = MIN (gif_anim->width - f->x_offset, gdk_pixbuf_get_width (f->pixbuf)); - clipped_height = MIN (gif_anim->height - f->y_offset, gdk_pixbuf_get_height (f->pixbuf)); - - if (f->need_recomposite) { - if (f->composited) { - g_object_unref (f->composited); - f->composited = NULL; - } - } - - if (f->composited != NULL) - goto next; - - if (tmp->prev == NULL) { - /* First frame may be smaller than the whole image; - * if so, we make the area outside it full alpha if the - * image has alpha, and background color otherwise. - * GIF spec doesn't actually say what to do about this. - */ - f->composited = gdk_pixbuf_new (GDK_COLORSPACE_RGB, - TRUE, - 8, gif_anim->width, gif_anim->height); - - if (f->composited == NULL) - return; - - /* alpha gets dumped if f->composited has no alpha */ - - gdk_pixbuf_fill (f->composited, - (gif_anim->bg_red << 24) | - (gif_anim->bg_green << 16) | - (gif_anim->bg_blue << 8)); - - if (clipped_width > 0 && clipped_height > 0) - gdk_pixbuf_composite (f->pixbuf, - f->composited, - f->x_offset, - f->y_offset, - clipped_width, - clipped_height, - f->x_offset, f->y_offset, - 1.0, 1.0, - GDK_INTERP_BILINEAR, - 255); - - if (f->action == GDK_PIXBUF_FRAME_REVERT) - g_warning ("First frame of GIF has bad dispose mode, GIF loader should not have loaded this image"); - - f->need_recomposite = FALSE; - } else { - GdkPixbufFrame *prev_frame; - gint prev_clipped_width; - gint prev_clipped_height; - - prev_frame = tmp->prev->data; - - prev_clipped_width = MIN (gif_anim->width - prev_frame->x_offset, gdk_pixbuf_get_width (prev_frame->pixbuf)); - prev_clipped_height = MIN (gif_anim->height - prev_frame->y_offset, gdk_pixbuf_get_height (prev_frame->pixbuf)); - - /* Init f->composited with what we should have after the previous - * frame - */ - - if (prev_frame->action == GDK_PIXBUF_FRAME_RETAIN) { - f->composited = gdk_pixbuf_copy (prev_frame->composited); - - if (f->composited == NULL) - return; - - } else if (prev_frame->action == GDK_PIXBUF_FRAME_DISPOSE) { - f->composited = gdk_pixbuf_copy (prev_frame->composited); - - if (f->composited == NULL) - return; - - if (prev_clipped_width > 0 && prev_clipped_height > 0) { - /* Clear area of previous frame to background */ - GdkPixbuf *area; - - area = gdk_pixbuf_new_subpixbuf (f->composited, - prev_frame->x_offset, - prev_frame->y_offset, - prev_clipped_width, - prev_clipped_height); - - if (area == NULL) - return; - - gdk_pixbuf_fill (area, - (gif_anim->bg_red << 24) | - (gif_anim->bg_green << 16) | - (gif_anim->bg_blue << 8)); - - g_object_unref (area); - } - } else if (prev_frame->action == GDK_PIXBUF_FRAME_REVERT) { - f->composited = gdk_pixbuf_copy (prev_frame->composited); - - if (f->composited == NULL) - return; - - if (prev_frame->revert != NULL && - prev_clipped_width > 0 && prev_clipped_height > 0) { - /* Copy in the revert frame */ - gdk_pixbuf_copy_area (prev_frame->revert, - 0, 0, - gdk_pixbuf_get_width (prev_frame->revert), - gdk_pixbuf_get_height (prev_frame->revert), - f->composited, - prev_frame->x_offset, - prev_frame->y_offset); - } - } else { - g_warning ("Unknown revert action for GIF frame"); - } - - if (f->revert == NULL && - f->action == GDK_PIXBUF_FRAME_REVERT) { - if (clipped_width > 0 && clipped_height > 0) { - /* We need to save the contents before compositing */ - GdkPixbuf *area; - - area = gdk_pixbuf_new_subpixbuf (f->composited, - f->x_offset, - f->y_offset, - clipped_width, - clipped_height); - - if (area == NULL) - return; - - f->revert = gdk_pixbuf_copy (area); - - g_object_unref (area); - - if (f->revert == NULL) - return; - } - } - - if (clipped_width > 0 && clipped_height > 0 && - f->pixbuf != NULL && f->composited != NULL) { - /* Put current frame onto f->composited */ - gdk_pixbuf_composite (f->pixbuf, - f->composited, - f->x_offset, - f->y_offset, - clipped_width, - clipped_height, - f->x_offset, f->y_offset, - 1.0, 1.0, - GDK_INTERP_NEAREST, - 255); - } - - f->need_recomposite = FALSE; - } - - next: - if (tmp == link) - break; - - tmp = tmp->next; - } - } -} - -GdkPixbuf* -gdk_pixbuf_gif_anim_iter_get_pixbuf (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufGifAnimIter *iter; - GdkPixbufFrame *frame; - - iter = GDK_PIXBUF_GIF_ANIM_ITER (anim_iter); - - frame = iter->current_frame ? iter->current_frame->data : g_list_last (iter->gif_anim->frames)->data; - -#if 0 - if (FALSE && frame) - g_print ("current frame %d dispose mode %d %d x %d\n", - g_list_index (iter->gif_anim->frames, - frame), - frame->action, - gdk_pixbuf_get_width (frame->pixbuf), - gdk_pixbuf_get_height (frame->pixbuf)); -#endif - - if (frame == NULL) - return NULL; - - gdk_pixbuf_gif_anim_frame_composite (iter->gif_anim, frame); - - return frame->composited; -} - -static gboolean -gdk_pixbuf_gif_anim_iter_on_currently_loading_frame (GdkPixbufAnimationIter *anim_iter) -{ - GdkPixbufGifAnimIter *iter; - - iter = GDK_PIXBUF_GIF_ANIM_ITER (anim_iter); - - return iter->current_frame == NULL || iter->current_frame->next == NULL; -} diff --git a/gdk-pixbuf/io-gif-animation.h b/gdk-pixbuf/io-gif-animation.h deleted file mode 100644 index 3e8e52287b..0000000000 --- a/gdk-pixbuf/io-gif-animation.h +++ /dev/null @@ -1,175 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - GIF loader declarations - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Miguel de Icaza <miguel@gnu.org> - * Federico Mena-Quintero <federico@gimp.org> - * Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#ifndef GDK_PIXBUF_GIF_H -#define GDK_PIXBUF_GIF_H - -#include "gdk-pixbuf-animation.h" - -typedef enum { - /* Keep this frame and composite next frame over it */ - /* (GIF disposal method 1) */ - GDK_PIXBUF_FRAME_RETAIN, - /* Revert to background color before compositing next frame */ - /* (GIF disposal method 2) */ - GDK_PIXBUF_FRAME_DISPOSE, - /* Revert to previously-displayed composite image after - * displaying this frame - */ - /* (GIF disposal method 3) */ - GDK_PIXBUF_FRAME_REVERT -} GdkPixbufFrameAction; - - - -typedef struct _GdkPixbufGifAnim GdkPixbufGifAnim; -typedef struct _GdkPixbufGifAnimClass GdkPixbufGifAnimClass; -typedef struct _GdkPixbufFrame GdkPixbufFrame; - -#define GDK_TYPE_PIXBUF_GIF_ANIM (gdk_pixbuf_gif_anim_get_type ()) -#define GDK_PIXBUF_GIF_ANIM(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_GIF_ANIM, GdkPixbufGifAnim)) -#define GDK_IS_PIXBUF_GIF_ANIM(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_GIF_ANIM)) - -#define GDK_PIXBUF_GIF_ANIM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_GIF_ANIM, GdkPixbufGifAnimClass)) -#define GDK_IS_PIXBUF_GIF_ANIM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_GIF_ANIM)) -#define GDK_PIXBUF_GIF_ANIM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_GIF_ANIM, GdkPixbufGifAnimClass)) - -/* Private part of the GdkPixbufGifAnim structure */ -struct _GdkPixbufGifAnim { - GdkPixbufAnimation parent_instance; - - /* Number of frames */ - int n_frames; - - /* Total length of animation */ - int total_time; - - /* List of GdkPixbufFrame structures */ - GList *frames; - - /* bounding box size */ - int width, height; - - guchar bg_red; - guchar bg_green; - guchar bg_blue; - - int loop; - gboolean loading; -}; - -struct _GdkPixbufGifAnimClass { - GdkPixbufAnimationClass parent_class; - -}; - -GType gdk_pixbuf_gif_anim_get_type (void) G_GNUC_CONST; - - - -typedef struct _GdkPixbufGifAnimIter GdkPixbufGifAnimIter; -typedef struct _GdkPixbufGifAnimIterClass GdkPixbufGifAnimIterClass; - - -#define GDK_TYPE_PIXBUF_GIF_ANIM_ITER (gdk_pixbuf_gif_anim_iter_get_type ()) -#define GDK_PIXBUF_GIF_ANIM_ITER(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_GIF_ANIM_ITER, GdkPixbufGifAnimIter)) -#define GDK_IS_PIXBUF_GIF_ANIM_ITER(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_GIF_ANIM_ITER)) - -#define GDK_PIXBUF_GIF_ANIM_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_GIF_ANIM_ITER, GdkPixbufGifAnimIterClass)) -#define GDK_IS_PIXBUF_GIF_ANIM_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_GIF_ANIM_ITER)) -#define GDK_PIXBUF_GIF_ANIM_ITER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_GIF_ANIM_ITER, GdkPixbufGifAnimIterClass)) - -struct _GdkPixbufGifAnimIter { - GdkPixbufAnimationIter parent_instance; - - GdkPixbufGifAnim *gif_anim; - - GTimeVal start_time; - GTimeVal current_time; - - /* Time in milliseconds into this run of the animation */ - gint position; - - GList *current_frame; - - gint first_loop_slowness; -}; - -struct _GdkPixbufGifAnimIterClass { - GdkPixbufAnimationIterClass parent_class; - -}; - -GType gdk_pixbuf_gif_anim_iter_get_type (void) G_GNUC_CONST; - - - -struct _GdkPixbufFrame { - /* The pixbuf with this frame's image data */ - GdkPixbuf *pixbuf; - - /* Offsets for overlaying onto the GIF graphic area */ - int x_offset; - int y_offset; - - /* Frame duration in ms */ - int delay_time; - - /* Sum of preceding delay times */ - int elapsed; - - /* Overlay mode */ - GdkPixbufFrameAction action; - - /* TRUE if the pixbuf has been modified since - * the last frame composite operation - */ - gboolean need_recomposite; - - /* TRUE if the background for this frame is transparent */ - gboolean bg_transparent; - - /* The below reflects the "use hell of a lot of RAM" - * philosophy of coding - */ - - /* Cached composite image (the image you actually display - * for this frame) - */ - GdkPixbuf *composited; - - /* Cached revert image (the contents of the area - * covered by the frame prior to compositing; - * same size as pixbuf, not as the composite image; only - * used for FRAME_REVERT frames) - */ - GdkPixbuf *revert; -}; - -void gdk_pixbuf_gif_anim_frame_composite (GdkPixbufGifAnim *gif_anim, - GdkPixbufFrame *frame); - -#endif diff --git a/gdk-pixbuf/io-gif.c b/gdk-pixbuf/io-gif.c deleted file mode 100644 index d414d78201..0000000000 --- a/gdk-pixbuf/io-gif.c +++ /dev/null @@ -1,1698 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - GIF image loader - * - * Copyright (C) 1999 Mark Crichton - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Jonathan Blandford <jrb@redhat.com> - * Adapted from the gimp gif filter written by Adam Moss <adam@gimp.org> - * Gimp work based on earlier work. - * Permission to relicense under the LGPL obtained. - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -/* This loader is very hairy code. - * - * The main loop was not designed for incremental loading, so when it was hacked - * in it got a bit messy. Basicly, every function is written to expect a failed - * read_gif, and lets you call it again assuming that the bytes are there. - * - * Return vals. - * Unless otherwise specified, these are the return vals for most functions: - * - * 0 -> success - * -1 -> more bytes needed. - * -2 -> failure; abort the load - * -3 -> control needs to be passed back to the main loop - * \_ (most of the time returning 0 will get this, but not always) - * - * >1 -> for functions that get a guchar, the char will be returned. - * - * -jrb (11/03/1999) - */ - -/* - * If you have any images that crash this code, please, please let me know and - * send them to me. - * <jrb@redhat.com> - */ - - - -#include "config.h" -#include <stdio.h> -#include <string.h> -#include <errno.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" -#include "io-gif-animation.h" - - - -#undef DUMP_IMAGE_DETAILS -#undef IO_GIFDEBUG - -#define MAXCOLORMAPSIZE 256 -#define MAX_LZW_BITS 12 - -#define INTERLACE 0x40 -#define LOCALCOLORMAP 0x80 -#define BitSet(byte, bit) (((byte) & (bit)) == (bit)) -#define LM_to_uint(a,b) (((b)<<8)|(a)) - - - -typedef unsigned char CMap[3][MAXCOLORMAPSIZE]; - -/* Possible states we can be in. */ -enum { - GIF_START, - GIF_GET_COLORMAP, - GIF_GET_NEXT_STEP, - GIF_GET_FRAME_INFO, - GIF_GET_EXTENSION, - GIF_GET_COLORMAP2, - GIF_PREPARE_LZW, - GIF_LZW_FILL_BUFFER, - GIF_LZW_CLEAR_CODE, - GIF_GET_LZW, - GIF_DONE -}; - - -typedef struct _Gif89 Gif89; -struct _Gif89 -{ - int transparent; - int delay_time; - int input_flag; - int disposal; -}; - -typedef struct _GifContext GifContext; -struct _GifContext -{ - int state; /* really only relevant for progressive loading */ - unsigned int width; - unsigned int height; - - gboolean has_global_cmap; - - CMap global_color_map; - gint global_colormap_size; - unsigned int global_bit_pixel; - unsigned int global_color_resolution; - unsigned int background_index; - gboolean stop_after_first_frame; - - gboolean frame_cmap_active; - CMap frame_color_map; - gint frame_colormap_size; - unsigned int frame_bit_pixel; - - unsigned int aspect_ratio; - GdkPixbufGifAnim *animation; - GdkPixbufFrame *frame; - Gif89 gif89; - - /* stuff per frame. */ - int frame_len; - int frame_height; - int frame_interlace; - int x_offset; - int y_offset; - - /* Static read only */ - FILE *file; - - /* progressive read, only. */ - GdkPixbufModulePreparedFunc prepare_func; - GdkPixbufModuleUpdatedFunc update_func; - gpointer user_data; - guchar *buf; - guint ptr; - guint size; - guint amount_needed; - - /* extension context */ - guchar extension_label; - guchar extension_flag; - gboolean in_loop_extension; - - /* get block context */ - guchar block_count; - guchar block_buf[280]; - gint block_ptr; - - int old_state; /* used by lzw_fill buffer */ - /* get_code context */ - int code_curbit; - int code_lastbit; - int code_done; - int code_last_byte; - int lzw_code_pending; - - /* lzw context */ - gint lzw_fresh; - gint lzw_code_size; - guchar lzw_set_code_size; - gint lzw_max_code; - gint lzw_max_code_size; - gint lzw_firstcode; - gint lzw_oldcode; - gint lzw_clear_code; - gint lzw_end_code; - gint *lzw_sp; - - gint lzw_table[2][(1 << MAX_LZW_BITS)]; - gint lzw_stack[(1 << (MAX_LZW_BITS)) * 2 + 1]; - - /* painting context */ - gint draw_xpos; - gint draw_ypos; - gint draw_pass; - - /* error pointer */ - GError **error; -}; - -static int GetDataBlock (GifContext *, unsigned char *); - - - -#ifdef IO_GIFDEBUG -static int count = 0; -#endif - -/* Returns TRUE if read is OK, - * FALSE if more memory is needed. */ -static gboolean -gif_read (GifContext *context, guchar *buffer, size_t len) -{ - gboolean retval; -#ifdef IO_GIFDEBUG - gint i; -#endif - if (context->file) { -#ifdef IO_GIFDEBUG - count += len; - g_print ("Fsize :%d\tcount :%d\t", len, count); -#endif - retval = (fread(buffer, len, 1, context->file) != 0); - - if (!retval && ferror (context->file)) { - gint save_errno = errno; - g_set_error (context->error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Failure reading GIF: %s"), - g_strerror (save_errno)); - } - -#ifdef IO_GIFDEBUG - if (len < 100) { - for (i = 0; i < len; i++) - g_print ("%d ", buffer[i]); - } - g_print ("\n"); -#endif - - return retval; - } else { -#ifdef IO_GIFDEBUG -/* g_print ("\tlooking for %d bytes. size == %d, ptr == %d\n", len, context->size, context->ptr); */ -#endif - if ((context->size - context->ptr) >= len) { -#ifdef IO_GIFDEBUG - count += len; -#endif - memcpy (buffer, context->buf + context->ptr, len); - context->ptr += len; - context->amount_needed = 0; -#ifdef IO_GIFDEBUG - g_print ("Psize :%d\tcount :%d\t", len, count); - if (len < 100) { - for (i = 0; i < len; i++) - g_print ("%d ", buffer[i]); - } - g_print ("\n"); -#endif - return TRUE; - } - context->amount_needed = len - (context->size - context->ptr); - } - return FALSE; -} - -/* Changes the stage to be GIF_GET_COLORMAP */ -static void -gif_set_get_colormap (GifContext *context) -{ - context->global_colormap_size = 0; - context->state = GIF_GET_COLORMAP; -} - -static void -gif_set_get_colormap2 (GifContext *context) -{ - context->frame_colormap_size = 0; - context->state = GIF_GET_COLORMAP2; -} - -static gint -gif_get_colormap (GifContext *context) -{ - unsigned char rgb[3]; - - while (context->global_colormap_size < context->global_bit_pixel) { - if (!gif_read (context, rgb, sizeof (rgb))) { - return -1; - } - - context->global_color_map[0][context->global_colormap_size] = rgb[0]; - context->global_color_map[1][context->global_colormap_size] = rgb[1]; - context->global_color_map[2][context->global_colormap_size] = rgb[2]; - - if (context->global_colormap_size == context->background_index) { - context->animation->bg_red = rgb[0]; - context->animation->bg_green = rgb[1]; - context->animation->bg_blue = rgb[2]; - } - - context->global_colormap_size ++; - } - - return 0; -} - - -static gint -gif_get_colormap2 (GifContext *context) -{ - unsigned char rgb[3]; - - while (context->frame_colormap_size < context->frame_bit_pixel) { - if (!gif_read (context, rgb, sizeof (rgb))) { - return -1; - } - - context->frame_color_map[0][context->frame_colormap_size] = rgb[0]; - context->frame_color_map[1][context->frame_colormap_size] = rgb[1]; - context->frame_color_map[2][context->frame_colormap_size] = rgb[2]; - - context->frame_colormap_size ++; - } - - return 0; -} - -/* - * in order for this function to work, we need to perform some black magic. - * We want to return -1 to let the calling function know, as before, that it needs - * more bytes. If we return 0, we were able to successfully read all block->count bytes. - * Problem is, we don't want to reread block_count every time, so we check to see if - * context->block_count is 0 before we read in the function. - * - * As a result, context->block_count MUST be 0 the first time the get_data_block is called - * within a context, and cannot be 0 the second time it's called. - */ - -static int -get_data_block (GifContext *context, - unsigned char *buf, - gint *empty_block) -{ - - if (context->block_count == 0) { - if (!gif_read (context, &context->block_count, 1)) { - return -1; - } - } - - if (context->block_count == 0) - if (empty_block) { - *empty_block = TRUE; - return 0; - } - - if (!gif_read (context, buf, context->block_count)) { - return -1; - } - - return 0; -} - -static void -gif_set_get_extension (GifContext *context) -{ - context->state = GIF_GET_EXTENSION; - context->extension_flag = TRUE; - context->extension_label = 0; - context->block_count = 0; - context->block_ptr = 0; -} - -static int -gif_get_extension (GifContext *context) -{ - gint retval; - gint empty_block = FALSE; - - if (context->extension_flag) { - if (context->extension_label == 0) { - /* I guess bad things can happen if we have an extension of 0 )-: */ - /* I should look into this sometime */ - if (!gif_read (context, & context->extension_label , 1)) { - return -1; - } - } - - switch (context->extension_label) { - case 0xf9: /* Graphic Control Extension */ - retval = get_data_block (context, (unsigned char *) context->block_buf, NULL); - if (retval != 0) - return retval; - - if (context->frame == NULL) { - /* I only want to set the transparency if I haven't - * created the frame yet. - */ - context->gif89.disposal = (context->block_buf[0] >> 2) & 0x7; - context->gif89.input_flag = (context->block_buf[0] >> 1) & 0x1; - context->gif89.delay_time = LM_to_uint (context->block_buf[1], context->block_buf[2]); - - if ((context->block_buf[0] & 0x1) != 0) { - context->gif89.transparent = context->block_buf[3]; - } else { - context->gif89.transparent = -1; - } - } - - /* Now we've successfully loaded this one, we continue on our way */ - context->block_count = 0; - context->extension_flag = FALSE; - break; - case 0xff: /* application extension */ - if (!context->in_loop_extension) { - retval = get_data_block (context, (unsigned char *) context->block_buf, NULL); - if (retval != 0) - return retval; - if (!strncmp ((gchar *)context->block_buf, "NETSCAPE2.0", 11) || - !strncmp ((gchar *)context->block_buf, "ANIMEXTS1.0", 11)) { - context->in_loop_extension = TRUE; - } - context->block_count = 0; - } - if (context->in_loop_extension) { - do { - retval = get_data_block (context, (unsigned char *) context->block_buf, &empty_block); - if (retval != 0) - return retval; - if (context->block_buf[0] == 0x01) { - context->animation->loop = context->block_buf[1] + (context->block_buf[2] << 8); - if (context->animation->loop != 0) - context->animation->loop++; - } - context->block_count = 0; - } - while (!empty_block); - context->in_loop_extension = FALSE; - context->extension_flag = FALSE; - return 0; - } - break; - default: - /* Unhandled extension */ - break; - } - } - /* read all blocks, until I get an empty block, in case there was an extension I didn't know about. */ - do { - retval = get_data_block (context, (unsigned char *) context->block_buf, &empty_block); - if (retval != 0) - return retval; - context->block_count = 0; - } while (!empty_block); - - return 0; -} - -static int ZeroDataBlock = FALSE; - -static int -GetDataBlock (GifContext *context, - unsigned char *buf) -{ -/* unsigned char count; */ - - if (!gif_read (context, &context->block_count, 1)) { - /*g_message (_("GIF: error in getting DataBlock size\n"));*/ - return -1; - } - - ZeroDataBlock = context->block_count == 0; - - if ((context->block_count != 0) && (!gif_read (context, buf, context->block_count))) { - /*g_message (_("GIF: error in reading DataBlock\n"));*/ - return -1; - } - - return context->block_count; -} - - -static void -gif_set_lzw_fill_buffer (GifContext *context) -{ - context->block_count = 0; - context->old_state = context->state; - context->state = GIF_LZW_FILL_BUFFER; -} - -static int -gif_lzw_fill_buffer (GifContext *context) -{ - gint retval; - - if (context->code_done) { - if (context->code_curbit >= context->code_lastbit) { - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("GIF file was missing some data (perhaps it was truncated somehow?)")); - - return -2; - } - /* Is this supposed to be an error or what? */ - /* g_message ("trying to read more data after we've done stuff\n"); */ - g_set_error (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Internal error in the GIF loader (%s)"), - G_STRLOC); - - return -2; - } - - context->block_buf[0] = context->block_buf[context->code_last_byte - 2]; - context->block_buf[1] = context->block_buf[context->code_last_byte - 1]; - - retval = get_data_block (context, &context->block_buf[2], NULL); - - if (retval == -1) - return -1; - - if (context->block_count == 0) - context->code_done = TRUE; - - context->code_last_byte = 2 + context->block_count; - context->code_curbit = (context->code_curbit - context->code_lastbit) + 16; - context->code_lastbit = (2 + context->block_count) * 8; - - context->state = context->old_state; - return 0; -} - -static int -get_code (GifContext *context, - int code_size) -{ - int i, j, ret; - - if ((context->code_curbit + code_size) >= context->code_lastbit){ - gif_set_lzw_fill_buffer (context); - return -3; - } - - ret = 0; - for (i = context->code_curbit, j = 0; j < code_size; ++i, ++j) - ret |= ((context->block_buf[i / 8] & (1 << (i % 8))) != 0) << j; - - context->code_curbit += code_size; - - return ret; -} - - -static void -set_gif_lzw_clear_code (GifContext *context) -{ - context->state = GIF_LZW_CLEAR_CODE; - context->lzw_code_pending = -1; -} - -static int -gif_lzw_clear_code (GifContext *context) -{ - gint code; - - code = get_code (context, context->lzw_code_size); - if (code == -3) - return -0; - - context->lzw_firstcode = context->lzw_oldcode = code; - context->lzw_code_pending = code; - context->state = GIF_GET_LZW; - return 0; -} - -#define CHECK_LZW_SP() G_STMT_START { \ - if ((guchar *)context->lzw_sp >= \ - (guchar *)context->lzw_stack + sizeof (context->lzw_stack)) { \ - g_set_error_literal (context->error, \ - GDK_PIXBUF_ERROR, \ - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, \ - _("Stack overflow")); \ - return -2; \ - } \ -} G_STMT_END - -static int -lzw_read_byte (GifContext *context) -{ - int code, incode; - gint retval; - gint my_retval; - register int i; - - if (context->lzw_code_pending != -1) { - retval = context->lzw_code_pending; - context->lzw_code_pending = -1; - return retval; - } - - if (context->lzw_fresh) { - context->lzw_fresh = FALSE; - do { - retval = get_code (context, context->lzw_code_size); - if (retval < 0) { - return retval; - } - - context->lzw_firstcode = context->lzw_oldcode = retval; - } while (context->lzw_firstcode == context->lzw_clear_code); - return context->lzw_firstcode; - } - - if (context->lzw_sp > context->lzw_stack) { - my_retval = *--(context->lzw_sp); - return my_retval; - } - - while ((code = get_code (context, context->lzw_code_size)) >= 0) { - if (code == context->lzw_clear_code) { - for (i = 0; i < context->lzw_clear_code; ++i) { - context->lzw_table[0][i] = 0; - context->lzw_table[1][i] = i; - } - for (; i < (1 << MAX_LZW_BITS); ++i) - context->lzw_table[0][i] = context->lzw_table[1][i] = 0; - context->lzw_code_size = context->lzw_set_code_size + 1; - context->lzw_max_code_size = 2 * context->lzw_clear_code; - context->lzw_max_code = context->lzw_clear_code + 2; - context->lzw_sp = context->lzw_stack; - - set_gif_lzw_clear_code (context); - return -3; - } else if (code == context->lzw_end_code) { - int count; - unsigned char buf[260]; - - /* FIXME - we should handle this case */ - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("GIF image loader cannot understand this image.")); - return -2; - - if (ZeroDataBlock) { - return -2; - } - - while ((count = GetDataBlock (context, buf)) > 0) - ; - - if (count != 0) { - /*g_print (_("GIF: missing EOD in data stream (common occurence)"));*/ - return -2; - } - } - - incode = code; - - if (code >= context->lzw_max_code) { - CHECK_LZW_SP (); - *(context->lzw_sp)++ = context->lzw_firstcode; - code = context->lzw_oldcode; - } - - while (code >= context->lzw_clear_code) { - if (code >= (1 << MAX_LZW_BITS)) { - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Bad code encountered")); - return -2; - } - CHECK_LZW_SP (); - *(context->lzw_sp)++ = context->lzw_table[1][code]; - - if (code == context->lzw_table[0][code]) { - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Circular table entry in GIF file")); - return -2; - } - code = context->lzw_table[0][code]; - } - - CHECK_LZW_SP (); - *(context->lzw_sp)++ = context->lzw_firstcode = context->lzw_table[1][code]; - - if ((code = context->lzw_max_code) < (1 << MAX_LZW_BITS)) { - context->lzw_table[0][code] = context->lzw_oldcode; - context->lzw_table[1][code] = context->lzw_firstcode; - ++context->lzw_max_code; - if ((context->lzw_max_code >= context->lzw_max_code_size) && - (context->lzw_max_code_size < (1 << MAX_LZW_BITS))) { - context->lzw_max_code_size *= 2; - ++context->lzw_code_size; - } - } - - context->lzw_oldcode = incode; - - if (context->lzw_sp > context->lzw_stack) { - my_retval = *--(context->lzw_sp); - return my_retval; - } - } - return code; -} - -static void -gif_set_get_lzw (GifContext *context) -{ - context->state = GIF_GET_LZW; - context->draw_xpos = 0; - context->draw_ypos = 0; - context->draw_pass = 0; -} - -static void -gif_fill_in_pixels (GifContext *context, guchar *dest, gint offset, guchar v) -{ - guchar *pixel = NULL; - guchar (*cmap)[MAXCOLORMAPSIZE]; - - if (context->frame_cmap_active) - cmap = context->frame_color_map; - else - cmap = context->global_color_map; - - if (context->gif89.transparent != -1) { - pixel = dest + (context->draw_ypos + offset) * gdk_pixbuf_get_rowstride (context->frame->pixbuf) + context->draw_xpos * 4; - *pixel = cmap [0][(guchar) v]; - *(pixel+1) = cmap [1][(guchar) v]; - *(pixel+2) = cmap [2][(guchar) v]; - *(pixel+3) = (guchar) ((v == context->gif89.transparent) ? 0 : 255); - } else { - pixel = dest + (context->draw_ypos + offset) * gdk_pixbuf_get_rowstride (context->frame->pixbuf) + context->draw_xpos * 3; - *pixel = cmap [0][(guchar) v]; - *(pixel+1) = cmap [1][(guchar) v]; - *(pixel+2) = cmap [2][(guchar) v]; - } -} - - -/* only called if progressive and interlaced */ -static void -gif_fill_in_lines (GifContext *context, guchar *dest, guchar v) -{ - switch (context->draw_pass) { - case 0: - if (context->draw_ypos > 4) { - gif_fill_in_pixels (context, dest, -4, v); - gif_fill_in_pixels (context, dest, -3, v); - } - if (context->draw_ypos < (context->frame_height - 4)) { - gif_fill_in_pixels (context, dest, 3, v); - gif_fill_in_pixels (context, dest, 4, v); - } - /* we don't need a break here. We draw the outer pixels first, then the - * inner ones, then the innermost ones. case 0 needs to draw all 3 bands. - * case 1, just the last two, and case 2 just draws the last one*/ - case 1: - if (context->draw_ypos > 2) - gif_fill_in_pixels (context, dest, -2, v); - if (context->draw_ypos < (context->frame_height - 2)) - gif_fill_in_pixels (context, dest, 2, v); - /* no break as above. */ - case 2: - if (context->draw_ypos > 1) - gif_fill_in_pixels (context, dest, -1, v); - if (context->draw_ypos < (context->frame_height - 1)) - gif_fill_in_pixels (context, dest, 1, v); - case 3: - default: - break; - } -} - -/* Clips a rectancle to the base dimensions. Returns TRUE if the clipped rectangle is non-empty. */ -static gboolean -clip_frame (GifContext *context, - gint *x, - gint *y, - gint *width, - gint *height) -{ - gint orig_x, orig_y; - - orig_x = *x; - orig_y = *y; - *x = MAX (0, *x); - *y = MAX (0, *y); - *width = MIN (context->width, orig_x + *width) - *x; - *height = MIN (context->height, orig_y + *height) - *y; - - if (*width > 0 && *height > 0) - return TRUE; - - /* The frame is completely off-bounds */ - - *x = 0; - *y = 0; - *width = 0; - *height = 0; - - return FALSE; -} - -/* Call update_func on the given rectangle, unless it is completely off-bounds */ -static void -maybe_update (GifContext *context, - gint x, - gint y, - gint width, - gint height) -{ - if (clip_frame (context, &x, &y, &width, &height)) - (*context->update_func) (context->frame->pixbuf, - x, y, width, height, - context->user_data); -} - -static int -gif_get_lzw (GifContext *context) -{ - guchar *dest, *temp; - gint lower_bound, upper_bound; /* bounds for emitting the area_updated signal */ - gboolean bound_flag; - gint first_pass; /* bounds for emitting the area_updated signal */ - gint v; - - if (context->frame == NULL) { - context->frame = g_new (GdkPixbufFrame, 1); - - context->frame->composited = NULL; - context->frame->revert = NULL; - - if (context->frame_len == 0 || context->frame_height == 0) { - /* An empty frame, we just output a single transparent - * pixel at (0, 0). - */ - context->x_offset = 0; - context->y_offset = 0; - context->frame_len = 1; - context->frame_height = 1; - context->frame->pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, TRUE, 8, 1, 1); - if (context->frame->pixbuf) { - guchar *pixels; - - pixels = gdk_pixbuf_get_pixels (context->frame->pixbuf); - pixels[0] = 0; - pixels[1] = 0; - pixels[2] = 0; - pixels[3] = 0; - } - } else - context->frame->pixbuf = - gdk_pixbuf_new (GDK_COLORSPACE_RGB, - TRUE, - 8, - context->frame_len, - context->frame_height); - if (!context->frame->pixbuf) { - g_free (context->frame); - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load GIF file")); - return -2; - } - - context->frame->x_offset = context->x_offset; - context->frame->y_offset = context->y_offset; - context->frame->need_recomposite = TRUE; - - /* GIF delay is in hundredths, we want thousandths */ - context->frame->delay_time = context->gif89.delay_time * 10; - - /* GIFs with delay time 0 are mostly broken, but they - * just want a default, "not that fast" delay. - */ - if (context->frame->delay_time == 0) - context->frame->delay_time = 100; - - /* No GIFs gets to play faster than 50 fps. They just - * lock up poor gtk. - */ - if (context->frame->delay_time < 20) - context->frame->delay_time = 20; /* 20 = "fast" */ - - context->frame->elapsed = context->animation->total_time; - context->animation->total_time += context->frame->delay_time; - - switch (context->gif89.disposal) { - case 0: - case 1: - context->frame->action = GDK_PIXBUF_FRAME_RETAIN; - break; - case 2: - context->frame->action = GDK_PIXBUF_FRAME_DISPOSE; - break; - case 3: - context->frame->action = GDK_PIXBUF_FRAME_REVERT; - break; - default: - context->frame->action = GDK_PIXBUF_FRAME_RETAIN; - break; - } - - context->frame->bg_transparent = (context->gif89.transparent == context->background_index); - - context->animation->n_frames ++; - context->animation->frames = g_list_append (context->animation->frames, context->frame); - - /* Only call prepare_func for the first frame */ - if (context->animation->frames->next == NULL) { - if (context->animation->width == 0 ) - context->animation->width = gdk_pixbuf_get_width(context->frame->pixbuf); - if (context->animation->height == 0) - context->animation->height = gdk_pixbuf_get_height (context->frame->pixbuf); - - if (context->prepare_func) - (* context->prepare_func) (context->frame->pixbuf, - GDK_PIXBUF_ANIMATION (context->animation), - context->user_data); - } else { - /* Otherwise init frame with last frame */ - GList *link; - GdkPixbufFrame *prev_frame; - gint x, y, w, h; - - link = g_list_find (context->animation->frames, context->frame); - - prev_frame = link->prev->data; - - gdk_pixbuf_gif_anim_frame_composite (context->animation, prev_frame); - - /* Composite failed */ - if (prev_frame->composited == NULL) { - GdkPixbufFrame *frame = NULL; - link = g_list_first (context->animation->frames); - while (link != NULL) { - frame = (GdkPixbufFrame *)link->data; - if (frame != NULL) { - if (frame->pixbuf != NULL) - g_object_unref (frame->pixbuf); - if (frame->composited != NULL) - g_object_unref (frame->composited); - if (frame->revert != NULL) - g_object_unref (frame->revert); - g_free (frame); - } - link = link->next; - } - - g_list_free (context->animation->frames); - context->animation->frames = NULL; - - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to composite a frame in GIF file")); - return -2; - } - - x = context->frame->x_offset; - y = context->frame->y_offset; - w = gdk_pixbuf_get_width (context->frame->pixbuf); - h = gdk_pixbuf_get_height (context->frame->pixbuf); - if (clip_frame (context, &x, &y, &w, &h)) - gdk_pixbuf_copy_area (prev_frame->composited, - x, y, w, h, - context->frame->pixbuf, - 0, 0); - } - } - - dest = gdk_pixbuf_get_pixels (context->frame->pixbuf); - - bound_flag = FALSE; - lower_bound = upper_bound = context->draw_ypos; - first_pass = context->draw_pass; - - while (TRUE) { - guchar (*cmap)[MAXCOLORMAPSIZE]; - - if (context->frame_cmap_active) - cmap = context->frame_color_map; - else - cmap = context->global_color_map; - - v = lzw_read_byte (context); - if (v < 0) { - goto finished_data; - } - bound_flag = TRUE; - - g_assert (gdk_pixbuf_get_has_alpha (context->frame->pixbuf)); - - temp = dest + context->draw_ypos * gdk_pixbuf_get_rowstride (context->frame->pixbuf) + context->draw_xpos * 4; - *temp = cmap [0][(guchar) v]; - *(temp+1) = cmap [1][(guchar) v]; - *(temp+2) = cmap [2][(guchar) v]; - *(temp+3) = (guchar) ((v == context->gif89.transparent) ? 0 : 255); - - if (context->prepare_func && context->frame_interlace) - gif_fill_in_lines (context, dest, v); - - context->draw_xpos++; - - if (context->draw_xpos == context->frame_len) { - context->draw_xpos = 0; - if (context->frame_interlace) { - switch (context->draw_pass) { - case 0: - case 1: - context->draw_ypos += 8; - break; - case 2: - context->draw_ypos += 4; - break; - case 3: - context->draw_ypos += 2; - break; - } - - if (context->draw_ypos >= context->frame_height) { - context->draw_pass++; - switch (context->draw_pass) { - case 1: - context->draw_ypos = 4; - break; - case 2: - context->draw_ypos = 2; - break; - case 3: - context->draw_ypos = 1; - break; - default: - goto done; - } - } - } else { - context->draw_ypos++; - } - if (context->draw_pass != first_pass) { - if (context->draw_ypos > lower_bound) { - lower_bound = 0; - upper_bound = context->frame_height; - } else { - - } - } else - upper_bound = context->draw_ypos; - } - if (context->draw_ypos >= context->frame_height) - break; - } - - done: - - context->state = GIF_GET_NEXT_STEP; - - v = 0; - - finished_data: - - if (bound_flag) - context->frame->need_recomposite = TRUE; - - if (bound_flag && context->update_func) { - if (lower_bound <= upper_bound && first_pass == context->draw_pass) { - maybe_update (context, - context->frame->x_offset, - context->frame->y_offset + lower_bound, - gdk_pixbuf_get_width (context->frame->pixbuf), - upper_bound - lower_bound); - } else { - if (lower_bound <= upper_bound) { - maybe_update (context, - context->frame->x_offset, - context->frame->y_offset, - gdk_pixbuf_get_width (context->frame->pixbuf), - gdk_pixbuf_get_height (context->frame->pixbuf)); - } else { - maybe_update (context, - context->frame->x_offset, - context->frame->y_offset, - gdk_pixbuf_get_width (context->frame->pixbuf), - upper_bound); - maybe_update (context, - context->frame->x_offset, - context->frame->y_offset + lower_bound, - gdk_pixbuf_get_width (context->frame->pixbuf), - gdk_pixbuf_get_height (context->frame->pixbuf) - lower_bound); - } - } - } - - if (context->state == GIF_GET_NEXT_STEP) { - /* Will be freed with context->animation, we are just - * marking that we're done with it (no current frame) - */ - context->frame = NULL; - context->frame_cmap_active = FALSE; - - if (context->stop_after_first_frame) - context->state = GIF_DONE; - } - - return v; -} - -static void -gif_set_prepare_lzw (GifContext *context) -{ - context->state = GIF_PREPARE_LZW; - context->lzw_code_pending = -1; -} -static int -gif_prepare_lzw (GifContext *context) -{ - gint i; - - if (!gif_read (context, &(context->lzw_set_code_size), 1)) { - /*g_message (_("GIF: EOF / read error on image data\n"));*/ - return -1; - } - - if (context->lzw_set_code_size > MAX_LZW_BITS) { - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("GIF image is corrupt (incorrect LZW compression)")); - return -2; - } - - context->lzw_code_size = context->lzw_set_code_size + 1; - context->lzw_clear_code = 1 << context->lzw_set_code_size; - context->lzw_end_code = context->lzw_clear_code + 1; - context->lzw_max_code_size = 2 * context->lzw_clear_code; - context->lzw_max_code = context->lzw_clear_code + 2; - context->lzw_fresh = TRUE; - context->code_curbit = 0; - context->code_lastbit = 0; - context->code_last_byte = 0; - context->code_done = FALSE; - - g_assert (context->lzw_clear_code <= - G_N_ELEMENTS (context->lzw_table[0])); - - for (i = 0; i < context->lzw_clear_code; ++i) { - context->lzw_table[0][i] = 0; - context->lzw_table[1][i] = i; - } - for (; i < (1 << MAX_LZW_BITS); ++i) - context->lzw_table[0][i] = context->lzw_table[1][0] = 0; - - context->lzw_sp = context->lzw_stack; - gif_set_get_lzw (context); - - return 0; -} - -/* needs 13 bytes to proceed. */ -static gint -gif_init (GifContext *context) -{ - unsigned char buf[16]; - char version[4]; - - if (!gif_read (context, buf, 6)) { - /* Unable to read magic number, - * gif_read() should have set error - */ - return -1; - } - - if (strncmp ((char *) buf, "GIF", 3) != 0) { - /* Not a GIF file */ - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("File does not appear to be a GIF file")); - return -2; - } - - strncpy (version, (char *) buf + 3, 3); - version[3] = '\0'; - - if ((strcmp (version, "87a") != 0) && (strcmp (version, "89a") != 0)) { - /* bad version number, not '87a' or '89a' */ - g_set_error (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Version %s of the GIF file format is not supported"), - version); - return -2; - } - - /* read the screen descriptor */ - if (!gif_read (context, buf, 7)) { - /* Failed to read screen descriptor, error set */ - return -1; - } - - context->width = LM_to_uint (buf[0], buf[1]); - context->height = LM_to_uint (buf[2], buf[3]); - /* The 4th byte is - * high bit: whether to use the background index - * next 3: color resolution - * next: whether colormap is sorted by priority of allocation - * last 3: size of colormap - */ - context->global_bit_pixel = 2 << (buf[4] & 0x07); - context->global_color_resolution = (((buf[4] & 0x70) >> 3) + 1); - context->has_global_cmap = (buf[4] & 0x80) != 0; - context->background_index = buf[5]; - context->aspect_ratio = buf[6]; - - /* Use background of transparent black as default, though if - * one isn't set explicitly no one should ever use it. - */ - context->animation->bg_red = 0; - context->animation->bg_green = 0; - context->animation->bg_blue = 0; - - context->animation->width = context->width; - context->animation->height = context->height; - - if (context->has_global_cmap) { - gif_set_get_colormap (context); - } else { - context->state = GIF_GET_NEXT_STEP; - } - -#ifdef DUMP_IMAGE_DETAILS - g_print (">Image width: %d height: %d global_cmap: %d background: %d\n", - context->width, context->height, context->has_global_cmap, context->background_index); -#endif - - return 0; -} - -static void -gif_set_get_frame_info (GifContext *context) -{ - context->state = GIF_GET_FRAME_INFO; -} - -static gint -gif_get_frame_info (GifContext *context) -{ - unsigned char buf[9]; - - if (!gif_read (context, buf, 9)) { - return -1; - } - - /* Okay, we got all the info we need. Lets record it */ - context->frame_len = LM_to_uint (buf[4], buf[5]); - context->frame_height = LM_to_uint (buf[6], buf[7]); - context->x_offset = LM_to_uint (buf[0], buf[1]); - context->y_offset = LM_to_uint (buf[2], buf[3]); - - if (context->animation->frames == NULL && - context->gif89.disposal == 3) { - /* First frame can't have "revert to previous" as its - * dispose mode. Silently use "retain" instead. - */ - context->gif89.disposal = 0; - } - - context->frame_interlace = BitSet (buf[8], INTERLACE); - -#ifdef DUMP_IMAGE_DETAILS - g_print (">width: %d height: %d xoffset: %d yoffset: %d disposal: %d delay: %d transparent: %d interlace: %d\n", - context->frame_len, context->frame_height, context->x_offset, context->y_offset, - context->gif89.disposal, context->gif89.delay_time, context->gif89.transparent, context->frame_interlace); -#endif - - if (BitSet (buf[8], LOCALCOLORMAP)) { - -#ifdef DUMP_IMAGE_DETAILS - g_print (">has local colormap\n"); -#endif - - /* Does this frame have it's own colormap. */ - /* really only relevant when looking at the first frame - * of an animated gif. */ - /* if it does, we need to re-read in the colormap, - * the gray_scale, and the bit_pixel */ - context->frame_cmap_active = TRUE; - context->frame_bit_pixel = 1 << ((buf[8] & 0x07) + 1); - gif_set_get_colormap2 (context); - return 0; - } - - if (!context->has_global_cmap) { - context->state = GIF_DONE; - - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("GIF image has no global colormap, and a frame inside it has no local colormap.")); - - return -2; - } - - gif_set_prepare_lzw (context); - return 0; - -} - -static gint -gif_get_next_step (GifContext *context) -{ - unsigned char c; - while (TRUE) { - if (!gif_read (context, &c, 1)) { - return -1; - } - if (c == ';') { - /* GIF terminator */ - /* hmm. Not 100% sure what to do about this. Should - * i try to return a blank image instead? */ - context->state = GIF_DONE; - return 0; - } - - if (c == '!') { - /* Check the extension */ - gif_set_get_extension (context); - return 0; - } - - /* look for frame */ - if (c != ',') { - /* Not a valid start character */ - continue; - } - /* load the frame */ - gif_set_get_frame_info (context); - return 0; - } -} - - -#define LOG(x) /* g_print ("%s: %s\n", G_STRLOC, x); */ - -static gint -gif_main_loop (GifContext *context) -{ - gint retval = 0; - - do { - switch (context->state) { - case GIF_START: - LOG("start\n"); - retval = gif_init (context); - break; - - case GIF_GET_COLORMAP: - LOG("get_colormap\n"); - retval = gif_get_colormap (context); - if (retval == 0) - context->state = GIF_GET_NEXT_STEP; - break; - - case GIF_GET_NEXT_STEP: - LOG("next_step\n"); - retval = gif_get_next_step (context); - break; - - case GIF_GET_FRAME_INFO: - LOG("frame_info\n"); - retval = gif_get_frame_info (context); - break; - - case GIF_GET_EXTENSION: - LOG("get_extension\n"); - retval = gif_get_extension (context); - if (retval == 0) - context->state = GIF_GET_NEXT_STEP; - break; - - case GIF_GET_COLORMAP2: - LOG("get_colormap2\n"); - retval = gif_get_colormap2 (context); - if (retval == 0) - gif_set_prepare_lzw (context); - break; - - case GIF_PREPARE_LZW: - LOG("prepare_lzw\n"); - retval = gif_prepare_lzw (context); - break; - - case GIF_LZW_FILL_BUFFER: - LOG("fill_buffer\n"); - retval = gif_lzw_fill_buffer (context); - break; - - case GIF_LZW_CLEAR_CODE: - LOG("clear_code\n"); - retval = gif_lzw_clear_code (context); - break; - - case GIF_GET_LZW: - LOG("get_lzw\n"); - retval = gif_get_lzw (context); - break; - - case GIF_DONE: - LOG("done\n"); - default: - retval = 0; - goto done; - }; - } while ((retval == 0) || (retval == -3)); - done: - return retval; -} - -static GifContext * -new_context (void) -{ - GifContext *context; - - context = g_try_malloc (sizeof (GifContext)); - if (context == NULL) - return NULL; - - memset (context, 0, sizeof (GifContext)); - - context->animation = g_object_new (GDK_TYPE_PIXBUF_GIF_ANIM, NULL); - context->frame = NULL; - context->file = NULL; - context->state = GIF_START; - context->prepare_func = NULL; - context->update_func = NULL; - context->user_data = NULL; - context->buf = NULL; - context->amount_needed = 0; - context->gif89.transparent = -1; - context->gif89.delay_time = -1; - context->gif89.input_flag = -1; - context->gif89.disposal = -1; - context->animation->loop = 1; - context->in_loop_extension = FALSE; - context->stop_after_first_frame = FALSE; - - return context; -} -/* Shared library entry point */ -static GdkPixbuf * -gdk_pixbuf__gif_image_load (FILE *file, GError **error) -{ - GifContext *context; - GdkPixbuf *pixbuf; - - g_return_val_if_fail (file != NULL, NULL); - - context = new_context (); - - if (context == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load GIF file")); - return NULL; - } - - context->file = file; - context->error = error; - context->stop_after_first_frame = TRUE; - - if (gif_main_loop (context) == -1 || context->animation->frames == NULL) { - if (context->error && *(context->error) == NULL) - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("GIF file was missing some data (perhaps it was truncated somehow?)")); - } - - pixbuf = gdk_pixbuf_animation_get_static_image (GDK_PIXBUF_ANIMATION (context->animation)); - - if (pixbuf) - g_object_ref (pixbuf); - - g_object_unref (context->animation); - - g_free (context->buf); - g_free (context); - - return pixbuf; -} - -static gpointer -gdk_pixbuf__gif_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepare_func, - GdkPixbufModuleUpdatedFunc update_func, - gpointer user_data, - GError **error) -{ - GifContext *context; - -#ifdef IO_GIFDEBUG - count = 0; -#endif - context = new_context (); - - if (context == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load GIF file")); - return NULL; - } - - context->error = error; - context->prepare_func = prepare_func; - context->update_func = update_func; - context->user_data = user_data; - - return (gpointer) context; -} - -static gboolean -gdk_pixbuf__gif_image_stop_load (gpointer data, GError **error) -{ - GifContext *context = (GifContext *) data; - gboolean retval = TRUE; - - if (context->state != GIF_DONE || context->animation->frames == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("GIF image was truncated or incomplete.")); - - retval = FALSE; - } - - g_object_unref (context->animation); - - g_free (context->buf); - g_free (context); - - return retval; -} - -static gboolean -gdk_pixbuf__gif_image_load_increment (gpointer data, - const guchar *buf, guint size, - GError **error) -{ - gint retval; - GifContext *context = (GifContext *) data; - - context->error = error; - - if (context->amount_needed == 0) { - /* we aren't looking for some bytes. */ - /* we can use buf now, but we don't want to keep it around at all. - * it will be gone by the end of the call. */ - context->buf = (guchar*) buf; /* very dubious const cast */ - context->ptr = 0; - context->size = size; - } else { - /* we need some bytes */ - if (size < context->amount_needed) { - context->amount_needed -= size; - /* copy it over and return */ - memcpy (context->buf + context->size, buf, size); - context->size += size; - return TRUE; - } else if (size == context->amount_needed) { - memcpy (context->buf + context->size, buf, size); - context->size += size; - } else { - context->buf = g_realloc (context->buf, context->size + size); - memcpy (context->buf + context->size, buf, size); - context->size += size; - } - } - - retval = gif_main_loop (context); - - if (retval == -2) { - if (context->buf == buf) - context->buf = NULL; - return FALSE; - } - if (retval == -1) { - /* we didn't have enough memory */ - /* prepare for the next image_load_increment */ - if (context->buf == buf) { - g_assert (context->size == size); - context->buf = g_new (guchar, context->amount_needed + (context->size - context->ptr)); - memcpy (context->buf, buf + context->ptr, context->size - context->ptr); - } else { - /* copy the left overs to the begining of the buffer */ - /* and realloc the memory */ - memmove (context->buf, context->buf + context->ptr, context->size - context->ptr); - context->buf = g_realloc (context->buf, context->amount_needed + (context->size - context->ptr)); - } - context->size = context->size - context->ptr; - context->ptr = 0; - } else { - /* we are prolly all done */ - if (context->buf == buf) - context->buf = NULL; - } - return TRUE; -} - -static GdkPixbufAnimation * -gdk_pixbuf__gif_image_load_animation (FILE *file, - GError **error) -{ - GifContext *context; - GdkPixbufAnimation *animation; - - g_return_val_if_fail (file != NULL, NULL); - - context = new_context (); - - if (context == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load GIF file")); - return NULL; - } - - context->error = error; - context->file = file; - - if (gif_main_loop (context) == -1 || context->animation->frames == NULL) { - if (context->error && *(context->error) == NULL) - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("GIF file was missing some data (perhaps it was truncated somehow?)")); - - g_object_unref (context->animation); - context->animation = NULL; - } - - if (context->animation) - animation = GDK_PIXBUF_ANIMATION (context->animation); - else - animation = NULL; - - if (context->error && *(context->error)) - g_print ("%s\n", (*(context->error))->message); - - g_free (context->buf); - g_free (context); - return animation; -} - -#ifndef INCLUDE_gif -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__gif_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->load = gdk_pixbuf__gif_image_load; - module->begin_load = gdk_pixbuf__gif_image_begin_load; - module->stop_load = gdk_pixbuf__gif_image_stop_load; - module->load_increment = gdk_pixbuf__gif_image_load_increment; - module->load_animation = gdk_pixbuf__gif_image_load_animation; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "GIF8", NULL, 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/gif", - NULL - }; - static gchar * extensions[] = { - "gif", - NULL - }; - - info->name = "gif"; - info->signature = signature; - info->description = N_("The GIF image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-icns.c b/gdk-pixbuf/io-icns.c deleted file mode 100644 index eee7dcc849..0000000000 --- a/gdk-pixbuf/io-icns.c +++ /dev/null @@ -1,404 +0,0 @@ -/* Mac OS X .icns icons loader - * - * Copyright (c) 2007 Lyonel Vincent <lyonel@ezix.org> - * Copyright (c) 2007 Bastien Nocera <hadess@hadess.net> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#ifndef _WIN32 -#define _GNU_SOURCE -#endif -#include <stdlib.h> -#include <string.h> -#include <errno.h> - -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - -G_MODULE_EXPORT void fill_vtable (GdkPixbufModule * module); -G_MODULE_EXPORT void fill_info (GdkPixbufFormat * info); - -#define IN /**/ -#define OUT /**/ -#define INOUT /**/ - -struct IcnsBlockHeader -{ - char id[4]; - guint32 size; /* caution: bigendian */ -}; -typedef struct IcnsBlockHeader IcnsBlockHeader; - -/* - * load raw icon data from 'icns' resource - * - * returns TRUE when successful - */ -static gboolean -load_resources (unsigned size, IN gpointer data, gsize datalen, - OUT guchar ** picture, OUT gsize * plen, - OUT guchar ** mask, OUT gsize * mlen) -{ - IcnsBlockHeader *header = NULL; - const char *bytes = NULL; - const char *current = NULL; - guint32 blocklen = 0; - guint32 icnslen = 0; - gboolean needs_mask = TRUE; - - if (datalen < 2 * sizeof (guint32)) - return FALSE; - if (!data) - return FALSE; - - *picture = *mask = NULL; - *plen = *mlen = 0; - - bytes = data; - header = (IcnsBlockHeader *) data; - if (memcmp (header->id, "icns", 4) != 0) - return FALSE; - - icnslen = GUINT32_FROM_BE (header->size); - if ((icnslen > datalen) || (icnslen < 2 * sizeof (guint32))) - return FALSE; - - current = bytes + sizeof (IcnsBlockHeader); - while ((current - bytes < icnslen) && (icnslen - (current - bytes) >= sizeof (IcnsBlockHeader))) - { - header = (IcnsBlockHeader *) current; - blocklen = GUINT32_FROM_BE (header->size); - - /* Check that blocklen isn't garbage */ - if (blocklen > icnslen - (current - bytes)) - return FALSE; - - switch (size) - { - case 256: - case 512: - if (memcmp (header->id, "ic08", 4) == 0 /* 256x256 icon */ - || memcmp (header->id, "ic09", 4) == 0) /* 512x512 icon */ - { - *picture = (gpointer) (current + sizeof (IcnsBlockHeader)); - *plen = blocklen - sizeof (IcnsBlockHeader); - } - needs_mask = FALSE; - break; - case 128: - if (memcmp (header->id, "it32", 4) == 0) /* 128x128 icon */ - { - *picture = (gpointer) (current + sizeof (IcnsBlockHeader)); - *plen = blocklen - sizeof (IcnsBlockHeader); - if (memcmp (*picture, "\0\0\0\0", 4) == 0) - { - *picture += 4; - *plen -= 4; - } - } - if (memcmp (header->id, "t8mk", 4) == 0) /* 128x128 mask */ - { - *mask = (gpointer) (current + sizeof (IcnsBlockHeader)); - *mlen = blocklen - sizeof (IcnsBlockHeader); - } - break; - case 48: - if (memcmp (header->id, "ih32", 4) == 0) /* 48x48 icon */ - { - *picture = (gpointer) (current + sizeof (IcnsBlockHeader)); - *plen = blocklen - sizeof (IcnsBlockHeader); - } - if (memcmp (header->id, "h8mk", 4) == 0) /* 48x48 mask */ - { - *mask = (gpointer) (current + sizeof (IcnsBlockHeader)); - *mlen = blocklen - sizeof (IcnsBlockHeader); - } - break; - case 32: - if (memcmp (header->id, "il32", 4) == 0) /* 32x32 icon */ - { - *picture = (gpointer) (current + sizeof (IcnsBlockHeader)); - *plen = blocklen - sizeof (IcnsBlockHeader); - } - if (memcmp (header->id, "l8mk", 4) == 0) /* 32x32 mask */ - { - *mask = (gpointer) (current + sizeof (IcnsBlockHeader)); - *mlen = blocklen - sizeof (IcnsBlockHeader); - } - break; - case 16: - if (memcmp (header->id, "is32", 4) == 0) /* 16x16 icon */ - { - *picture = (gpointer) (current + sizeof (IcnsBlockHeader)); - *plen = blocklen - sizeof (IcnsBlockHeader); - } - if (memcmp (header->id, "s8mk", 4) == 0) /* 16x16 mask */ - { - *mask = (gpointer) (current + sizeof (IcnsBlockHeader)); - *mlen = blocklen - sizeof (IcnsBlockHeader); - } - break; - default: - return FALSE; - } - - current += blocklen; - } - - if (!*picture) - return FALSE; - if (needs_mask && !*mask) - return FALSE; - return TRUE; -} - -/* - * uncompress RLE-encoded bytes into RGBA scratch zone: - * if firstbyte >= 0x80, it indicates the number of identical bytes + 125 - * (repeated value is stored next: 1 byte) - * otherwise, it indicates the number of non-repeating bytes - 1 - * (non-repeating values are stored next: n bytes) - */ -static gboolean -uncompress (unsigned size, INOUT guchar ** source, OUT guchar * target, INOUT gsize * _remaining) -{ - guchar *data = *source; - gsize remaining; - gsize i = 0; - - /* The first time we're called, set remaining */ - if (*_remaining == 0) { - remaining = size * size; - } else { - remaining = *_remaining; - } - - while (remaining > 0) - { - guint8 count = 0; - - if (data[0] & 0x80) /* repeating byte */ - { - count = data[0] - 125; - - if (count > remaining) - return FALSE; - - for (i = 0; i < count; i++) - { - *target = data[1]; - target += 4; - } - - data += 2; - } - else /* non-repeating bytes */ - { - count = data[0] + 1; - - if (count > remaining) - return FALSE; - - for (i = 0; i < count; i++) - { - *target = data[i + 1]; - target += 4; - } - data += count + 1; - } - - remaining -= count; - } - - *source = data; - *_remaining = remaining; - return TRUE; -} - -static GdkPixbuf * -load_icon (unsigned size, IN gpointer data, gsize datalen) -{ - guchar *icon = NULL; - guchar *mask = NULL; - gsize isize = 0, msize = 0, i; - guchar *image = NULL; - - if (!load_resources (size, data, datalen, &icon, &isize, &mask, &msize)) - return NULL; - - /* 256x256 icons don't use RLE or uncompressed data, - * They're usually JPEG 2000 images */ - if (size == 256) - { - GdkPixbufLoader *loader; - GdkPixbuf *pixbuf; - - loader = gdk_pixbuf_loader_new (); - if (!gdk_pixbuf_loader_write (loader, icon, isize, NULL) - || !gdk_pixbuf_loader_close (loader, NULL)) - { - g_object_unref (loader); - return NULL; - } - - pixbuf = gdk_pixbuf_loader_get_pixbuf (loader); - g_object_ref (pixbuf); - g_object_unref (loader); - - return pixbuf; - } - - g_assert (mask); - - if (msize != size * size) /* wrong mask size */ - return NULL; - - image = (guchar *) g_try_malloc0 (size * size * 4); /* 4 bytes/pixel = RGBA */ - - if (!image) - return NULL; - - if (isize == size * size * 4) /* icon data is uncompressed */ - for (i = 0; i < size * size; i++) /* 4 bytes/pixel = ARGB (A: ignored) */ - { - image[i * 4] = icon[4 * i + 1]; /* R */ - image[i * 4 + 1] = icon[4 * i + 2]; /* G */ - image[i * 4 + 2] = icon[4 * i + 3]; /* B */ - } - else - { - guchar *data = icon; - gsize remaining = 0; - - /* R */ - if (!uncompress (size, &data, image, &remaining)) - goto bail; - /* G */ - if (!uncompress (size, &data, image + 1, &remaining)) - goto bail; - /* B */ - if (!uncompress (size, &data, image + 2, &remaining)) - goto bail; - } - - for (i = 0; i < size * size; i++) /* copy mask to alpha channel */ - image[i * 4 + 3] = mask[i]; - - return gdk_pixbuf_new_from_data ((guchar *) image, GDK_COLORSPACE_RGB, /* RGB image */ - TRUE, /* with alpha channel */ - 8, /* 8 bits per sample */ - size, /* width */ - size, /* height */ - size * 4, /* no gap between rows */ - (GdkPixbufDestroyNotify)g_free, /* free() function */ - NULL); /* param to free() function */ - -bail: - g_free (image); - return NULL; -} - -static int sizes[] = { - 256, /* late-Tiger icons */ - 128, /* Standard OS X */ - 48, /* Not very common */ - 32, /* Standard Mac OS Classic (8 & 9) */ - 24, /* OS X toolbars */ - 16 /* used in Mac OS Classic and dialog boxes */ -}; - -static GdkPixbuf * -icns_image_load (FILE *f, GError ** error) -{ - GByteArray *data; - GdkPixbuf *pixbuf = NULL; - guint i; - - data = g_byte_array_new (); - while (!feof (f)) - { - gint save_errno; - guchar buf[4096]; - gsize bytes; - - bytes = fread (buf, 1, sizeof (buf), f); - save_errno = errno; - data = g_byte_array_append (data, buf, bytes); - - if (ferror (f)) - { - g_set_error (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Error reading ICNS image: %s"), - g_strerror (save_errno)); - - g_byte_array_free (data, TRUE); - - return NULL; - } - } - - for (i = 0; i < G_N_ELEMENTS(sizes) && !pixbuf; i++) - pixbuf = load_icon (sizes[i], data->data, data->len); - - g_byte_array_free (data, TRUE); - - if (!pixbuf) - g_set_error_literal (error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Could not decode ICNS file")); - - return pixbuf; -} - -#ifndef INCLUDE_icns -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__icns_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule * module) -{ - module->load = icns_image_load; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat * info) -{ - static GdkPixbufModulePattern signature[] = { - {"icns", NULL, 100}, /* file begins with 'icns' */ - {NULL, NULL, 0} - }; - static gchar *mime_types[] = { - "image/x-icns", - NULL - }; - static gchar *extensions[] = { - "icns", - NULL - }; - - info->name = "icns"; - info->signature = signature; - info->description = N_("The ICNS image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "GPL"; - info->disabled = FALSE; -} - diff --git a/gdk-pixbuf/io-ico.c b/gdk-pixbuf/io-ico.c deleted file mode 100644 index e7fedb9295..0000000000 --- a/gdk-pixbuf/io-ico.c +++ /dev/null @@ -1,1254 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* GdkPixbuf library - Windows Icon/Cursor image loader - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Arjan van de Ven <arjan@fenrus.demon.nl> - * Federico Mena-Quintero <federico@gimp.org> - * - * Based on io-bmp.c - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#undef DUMPBIH -/* - -Icons are just like BMP's, except for the header. - -Known bugs: - * bi-tonal files aren't tested - -*/ - -#include "config.h" -#include <stdio.h> -#include <stdlib.h> -#ifdef HAVE_UNISTD_H -#include <unistd.h> -#endif -#include <string.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" -#include <errno.h> - - - -/* - -These structures are actually dummies. These are according to -the "Windows API reference guide volume II" as written by -Borland International, but GCC fiddles with the alignment of -the internal members. - -*/ - -struct BitmapFileHeader { - gushort bfType; - guint bfSize; - guint reserverd; - guint bfOffbits; -}; - -struct BitmapInfoHeader { - guint biSize; - guint biWidth; - guint biHeight; - gushort biPlanes; - gushort biBitCount; - guint biCompression; - guint biSizeImage; - guint biXPelsPerMeter; - guint biYPelsPerMeter; - guint biClrUsed; - guint biClrImportant; -}; - -#ifdef DUMPBIH -/* - -DumpBIH printf's the values in a BitmapInfoHeader to the screen, for -debugging purposes. - -*/ -static void DumpBIH(unsigned char *BIH) -{ - printf("biSize = %i \n", - (int)(BIH[3] << 24) + (BIH[2] << 16) + (BIH[1] << 8) + (BIH[0])); - printf("biWidth = %i \n", - (int)(BIH[7] << 24) + (BIH[6] << 16) + (BIH[5] << 8) + (BIH[4])); - printf("biHeight = %i \n", - (int)(BIH[11] << 24) + (BIH[10] << 16) + (BIH[9] << 8) + - (BIH[8])); - printf("biPlanes = %i \n", (int)(BIH[13] << 8) + (BIH[12])); - printf("biBitCount = %i \n", (int)(BIH[15] << 8) + (BIH[14])); - printf("biCompress = %i \n", - (int)(BIH[19] << 24) + (BIH[18] << 16) + (BIH[17] << 8) + - (BIH[16])); - printf("biSizeImage = %i \n", - (int)(BIH[23] << 24) + (BIH[22] << 16) + (BIH[21] << 8) + - (BIH[20])); - printf("biXPels = %i \n", - (int)(BIH[27] << 24) + (BIH[26] << 16) + (BIH[25] << 8) + - (BIH[24])); - printf("biYPels = %i \n", - (int)(BIH[31] << 24) + (BIH[30] << 16) + (BIH[29] << 8) + - (BIH[28])); - printf("biClrUsed = %i \n", - (int)(BIH[35] << 24) + (BIH[34] << 16) + (BIH[33] << 8) + - (BIH[32])); - printf("biClrImprtnt= %i \n", - (int)(BIH[39] << 24) + (BIH[38] << 16) + (BIH[37] << 8) + - (BIH[36])); -} -#endif - -/* Progressive loading */ -struct headerpair { - gint width; - gint height; - guint depth; - guint Negative; /* Negative = 1 -> top down BMP, - Negative = 0 -> bottom up BMP */ -}; - -struct ico_progressive_state { - GdkPixbufModuleSizeFunc size_func; - GdkPixbufModulePreparedFunc prepared_func; - GdkPixbufModuleUpdatedFunc updated_func; - gpointer user_data; - - gint HeaderSize; /* The size of the header-part (incl colormap) */ - guchar *HeaderBuf; /* The buffer for the header (incl colormap) */ - gint BytesInHeaderBuf; /* The size of the allocated HeaderBuf */ - gint HeaderDone; /* The nr of bytes actually in HeaderBuf */ - - gint LineWidth; /* The width of a line in bytes */ - guchar *LineBuf; /* Buffer for 1 line */ - gint LineDone; /* # of bytes in LineBuf */ - gint Lines; /* # of finished lines */ - - gint Type; /* - 32 = RGBA - 24 = RGB - 16 = 555 RGB - 8 = 8 bit colormapped - 4 = 4 bpp colormapped - 1 = 1 bit bitonal - */ - gboolean cursor; - gint x_hot; - gint y_hot; - - struct headerpair Header; /* Decoded (BE->CPU) header */ - - gint DIBoffset; - gint ImageScore; - - - GdkPixbuf *pixbuf; /* Our "target" */ -}; - -static gpointer -gdk_pixbuf__ico_image_begin_load(GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error); -static gboolean gdk_pixbuf__ico_image_stop_load(gpointer data, GError **error); -static gboolean gdk_pixbuf__ico_image_load_increment(gpointer data, - const guchar * buf, guint size, - GError **error); - -static void -context_free (struct ico_progressive_state *context) -{ - g_free (context->LineBuf); - context->LineBuf = NULL; - g_free (context->HeaderBuf); - - if (context->pixbuf) - g_object_unref (context->pixbuf); - - g_free (context); -} - -static void DecodeHeader(guchar *Data, gint Bytes, - struct ico_progressive_state *State, - GError **error) -{ -/* For ICO's we have to be very clever. There are multiple images possible - in an .ICO. As a simple heuristic, we select the image which occupies the - largest number of bytes. - */ - - gint IconCount = 0; /* The number of icon-versions in the file */ - guchar *BIH; /* The DIB for the used icon */ - guchar *Ptr; - gint I; - guint16 imgtype; /* 1 = icon, 2 = cursor */ - - /* Step 1: The ICO header */ - - /* First word should be 0 according to specs */ - if (((Data[1] << 8) + Data[0]) != 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in icon")); - return; - - } - - imgtype = (Data[3] << 8) + Data[2]; - - State->cursor = (imgtype == 2) ? TRUE : FALSE; - - /* If it is not a cursor make sure it is actually an icon */ - if (!State->cursor && imgtype != 1) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in icon")); - return; - } - - - IconCount = (Data[5] << 8) + (Data[4]); - - State->HeaderSize = 6 + IconCount*16; - - if (State->HeaderSize>State->BytesInHeaderBuf) { - guchar *tmp=g_try_realloc(State->HeaderBuf,State->HeaderSize); - if (!tmp) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load icon")); - return; - } - State->HeaderBuf = tmp; - State->BytesInHeaderBuf = State->HeaderSize; - } - if (Bytes < State->HeaderSize) - return; - - /* We now have all the "short-specs" of the versions - So we iterate through them and select the best one */ - - State->ImageScore = 0; - State->DIBoffset = 0; - Ptr = Data + 6; - for (I=0;I<IconCount;I++) { - int ThisScore; - - ThisScore = (Ptr[11] << 24) + (Ptr[10] << 16) + (Ptr[9] << 8) + (Ptr[8]); - - if (ThisScore>=State->ImageScore) { - State->ImageScore = ThisScore; - State->x_hot = (Ptr[5] << 8) + Ptr[4]; - State->y_hot = (Ptr[7] << 8) + Ptr[6]; - State->DIBoffset = (Ptr[15]<<24)+(Ptr[14]<<16)+ - (Ptr[13]<<8) + (Ptr[12]); - - } - - - Ptr += 16; - } - - if (State->DIBoffset < 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in icon")); - return; - } - - /* We now have a winner, pointed to in State->DIBoffset, - so we know how many bytes are in the "header" part. */ - - State->HeaderSize = State->DIBoffset + 40; /* 40 = sizeof(InfoHeader) */ - - if (State->HeaderSize < 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in icon")); - return; - } - - if (State->HeaderSize>State->BytesInHeaderBuf) { - guchar *tmp=g_try_realloc(State->HeaderBuf,State->HeaderSize); - if (!tmp) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load icon")); - return; - } - State->HeaderBuf = tmp; - State->BytesInHeaderBuf = State->HeaderSize; - } - if (Bytes<State->HeaderSize) - return; - - BIH = Data+State->DIBoffset; - -#ifdef DUMPBIH - DumpBIH(BIH); -#endif - /* Add the palette to the headersize */ - - State->Header.width = - (int)(BIH[7] << 24) + (BIH[6] << 16) + (BIH[5] << 8) + (BIH[4]); - if (State->Header.width == 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Icon has zero width")); - return; - } - State->Header.height = - (int)((BIH[11] << 24) + (BIH[10] << 16) + (BIH[9] << 8) + (BIH[8]))/2; - /* /2 because the BIH height includes the transparency mask */ - if (State->Header.height == 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Icon has zero height")); - return; - } - State->Header.depth = (BIH[15] << 8) + (BIH[14]); - - State->Type = State->Header.depth; - if (State->Lines>=State->Header.height) - State->Type = 1; /* The transparency mask is 1 bpp */ - - /* Determine the palette size. If the header indicates 0, it - is actually the maximum for the bpp. You have to love the - guys who made the spec. */ - I = (int)(BIH[35] << 24) + (BIH[34] << 16) + (BIH[33] << 8) + (BIH[32]); - I = I*4; - if ((I==0)&&(State->Type==1)) - I = 2*4; - if ((I==0)&&(State->Type==4)) - I = 16*4; - if ((I==0)&&(State->Type==8)) - I = 256*4; - - State->HeaderSize+=I; - - if (State->HeaderSize < 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid header in icon")); - return; - } - - if (State->HeaderSize>State->BytesInHeaderBuf) { - guchar *tmp=g_try_realloc(State->HeaderBuf,State->HeaderSize); - if (!tmp) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load icon")); - return; - } - State->HeaderBuf = tmp; - State->BytesInHeaderBuf = State->HeaderSize; - } - if (Bytes < State->HeaderSize) - return; - - if ((BIH[16] != 0) || (BIH[17] != 0) || (BIH[18] != 0) - || (BIH[19] != 0)) { - /* FIXME: is this the correct message? */ - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Compressed icons are not supported")); - return; - } - - /* Negative heights mean top-down pixel-order */ - if (State->Header.height < 0) { - State->Header.height = -State->Header.height; - State->Header.Negative = 1; - } - if (State->Header.width < 0) { - State->Header.width = -State->Header.width; - } - g_assert (State->Header.width > 0); - g_assert (State->Header.height > 0); - - if (State->Type == 32) - State->LineWidth = State->Header.width * 4; - else if (State->Type == 24) - State->LineWidth = State->Header.width * 3; - else if (State->Type == 16) - State->LineWidth = State->Header.width * 2; - else if (State->Type == 8) - State->LineWidth = State->Header.width * 1; - else if (State->Type == 4) - State->LineWidth = (State->Header.width+1)/2; - else if (State->Type == 1) { - State->LineWidth = State->Header.width / 8; - if ((State->Header.width & 7) != 0) - State->LineWidth++; - } else { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Unsupported icon type")); - return; - } - - /* Pad to a 32 bit boundary */ - if (((State->LineWidth % 4) > 0)) - State->LineWidth = (State->LineWidth / 4) * 4 + 4; - - - if (State->LineBuf == NULL) { - State->LineBuf = g_try_malloc(State->LineWidth); - if (!State->LineBuf) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load icon")); - return; - } - } - - g_assert(State->LineBuf != NULL); - - - if (State->pixbuf == NULL) { -#if 1 - if (State->size_func) { - gint width = State->Header.width; - gint height = State->Header.height; - - (*State->size_func) (&width, &height, State->user_data); - if (width == 0 || height == 0) { - State->LineWidth = 0; - return; - } - } -#endif - - State->pixbuf = - gdk_pixbuf_new(GDK_COLORSPACE_RGB, TRUE, 8, - State->Header.width, - State->Header.height); - if (!State->pixbuf) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load icon")); - return; - } - if (State->cursor) { - gchar hot[10]; - g_snprintf (hot, 10, "%d", State->x_hot); - gdk_pixbuf_set_option (State->pixbuf, "x_hot", hot); - g_snprintf (hot, 10, "%d", State->y_hot); - gdk_pixbuf_set_option (State->pixbuf, "y_hot", hot); - } - - if (State->prepared_func != NULL) - /* Notify the client that we are ready to go */ - (*State->prepared_func) (State->pixbuf, - NULL, - State->user_data); - - } - -} - -/* - * func - called when we have pixmap created (but no image data) - * user_data - passed as arg 1 to func - * return context (opaque to user) - */ - -static gpointer -gdk_pixbuf__ico_image_begin_load(GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error) -{ - struct ico_progressive_state *context; - - context = g_new0(struct ico_progressive_state, 1); - context->size_func = size_func; - context->prepared_func = prepared_func; - context->updated_func = updated_func; - context->user_data = user_data; - - context->HeaderSize = 54; - context->HeaderBuf = g_try_malloc(14 + 40 + 4*256 + 512); - if (!context->HeaderBuf) { - g_free (context); - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load ICO file")); - return NULL; - } - /* 4*256 for the colormap */ - context->BytesInHeaderBuf = 14 + 40 + 4*256 + 512 ; - context->HeaderDone = 0; - - context->LineWidth = 0; - context->LineBuf = NULL; - context->LineDone = 0; - context->Lines = 0; - - context->Type = 0; - - memset(&context->Header, 0, sizeof(struct headerpair)); - - - context->pixbuf = NULL; - - - return (gpointer) context; -} - -/* - * context - returned from image_begin_load - * - * free context, unref gdk_pixbuf - */ -static gboolean -gdk_pixbuf__ico_image_stop_load(gpointer data, - GError **error) -{ - struct ico_progressive_state *context = - (struct ico_progressive_state *) data; - - /* FIXME this thing needs to report errors if - * we have unused image data - */ - - g_return_val_if_fail(context != NULL, TRUE); - - context_free (context); - return TRUE; -} - -static void -OneLine32 (struct ico_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - if (context->Header.Negative == 0) - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (context->Header.height - context->Lines - 1)); - else - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - context->Lines); - while (X < context->Header.width) { - Pixels[X * 4 + 0] = context->LineBuf[X * 4 + 2]; - Pixels[X * 4 + 1] = context->LineBuf[X * 4 + 1]; - Pixels[X * 4 + 2] = context->LineBuf[X * 4 + 0]; - Pixels[X * 4 + 3] = context->LineBuf[X * 4 + 3]; - X++; - } -} - -static void OneLine24(struct ico_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - if (context->Header.Negative == 0) - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (context->Header.height - context->Lines - 1)); - else - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - context->Lines); - while (X < context->Header.width) { - Pixels[X * 4 + 0] = context->LineBuf[X * 3 + 2]; - Pixels[X * 4 + 1] = context->LineBuf[X * 3 + 1]; - Pixels[X * 4 + 2] = context->LineBuf[X * 3 + 0]; - X++; - } - -} - -static void -OneLine16 (struct ico_progressive_state *context) -{ - int i; - guchar *pixels; - guchar *src; - - if (context->Header.Negative == 0) - pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * (context->Header.height - context->Lines - 1)); - else - pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * context->Lines); - - src = context->LineBuf; - - for (i = 0; i < context->Header.width; i++) { - int v, r, g, b; - - v = (int) src[0] | ((int) src[1] << 8); - src += 2; - - /* Extract 5-bit RGB values */ - - r = (v >> 10) & 0x1f; - g = (v >> 5) & 0x1f; - b = v & 0x1f; - - /* Fill the rightmost bits to form 8-bit values */ - - *pixels++ = (r << 3) | (r >> 2); - *pixels++ = (g << 3) | (g >> 2); - *pixels++ = (b << 3) | (b >> 2); - pixels++; /* skip alpha channel */ - } -} - - -static void OneLine8(struct ico_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - if (context->Header.Negative == 0) - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (context->Header.height - context->Lines - 1)); - else - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - context->Lines); - while (X < context->Header.width) { - /* The joys of having a BGR byteorder */ - Pixels[X * 4 + 0] = - context->HeaderBuf[4 * context->LineBuf[X] + 42+context->DIBoffset]; - Pixels[X * 4 + 1] = - context->HeaderBuf[4 * context->LineBuf[X] + 41+context->DIBoffset]; - Pixels[X * 4 + 2] = - context->HeaderBuf[4 * context->LineBuf[X] + 40+context->DIBoffset]; - X++; - } -} -static void OneLine4(struct ico_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - if (context->Header.Negative == 0) - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (context->Header.height - context->Lines - 1)); - else - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - context->Lines); - - while (X < context->Header.width) { - guchar Pix; - - Pix = context->LineBuf[X/2]; - - Pixels[X * 4 + 0] = - context->HeaderBuf[4 * (Pix>>4) + 42+context->DIBoffset]; - Pixels[X * 4 + 1] = - context->HeaderBuf[4 * (Pix>>4) + 41+context->DIBoffset]; - Pixels[X * 4 + 2] = - context->HeaderBuf[4 * (Pix>>4) + 40+context->DIBoffset]; - X++; - if (X<context->Header.width) { - /* Handle the other 4 bit pixel only when there is one */ - Pixels[X * 4 + 0] = - context->HeaderBuf[4 * (Pix&15) + 42+context->DIBoffset]; - Pixels[X * 4 + 1] = - context->HeaderBuf[4 * (Pix&15) + 41+context->DIBoffset]; - Pixels[X * 4 + 2] = - context->HeaderBuf[4 * (Pix&15) + 40+context->DIBoffset]; - X++; - } - } - -} - -static void OneLine1(struct ico_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - if (context->Header.Negative == 0) - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (context->Header.height - context->Lines - 1)); - else - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - context->Lines); - while (X < context->Header.width) { - int Bit; - - Bit = (context->LineBuf[X / 8]) >> (7 - (X & 7)); - Bit = Bit & 1; - /* The joys of having a BGR byteorder */ - Pixels[X * 4 + 0] = Bit*255; - Pixels[X * 4 + 1] = Bit*255; - Pixels[X * 4 + 2] = Bit*255; - X++; - } -} - -static void OneLineTransp(struct ico_progressive_state *context) -{ - gint X; - guchar *Pixels; - - /* Ignore the XOR mask for XP style 32-bpp icons with alpha */ - if (context->Header.depth == 32) - return; - - X = 0; - if (context->Header.Negative == 0) - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (2*context->Header.height - context->Lines - 1)); - else - Pixels = (context->pixbuf->pixels + - context->pixbuf->rowstride * - (context->Lines-context->Header.height)); - while (X < context->Header.width) { - int Bit; - - Bit = (context->LineBuf[X / 8]) >> (7 - (X & 7)); - Bit = Bit & 1; - /* The joys of having a BGR byteorder */ - Pixels[X * 4 + 3] = 255-Bit*255; -#if 0 - if (Bit){ - Pixels[X*4+0] = 255; - Pixels[X*4+1] = 255; - } else { - Pixels[X*4+0] = 0; - Pixels[X*4+1] = 0; - } -#endif - X++; - } -} - - -static void OneLine(struct ico_progressive_state *context) -{ - context->LineDone = 0; - - if (context->Lines >= context->Header.height*2) { - return; - } - - if (context->Lines <context->Header.height) { - if (context->Type == 32) - OneLine32 (context); - else if (context->Type == 24) - OneLine24(context); - else if (context->Type == 16) - OneLine16 (context); - else if (context->Type == 8) - OneLine8(context); - else if (context->Type == 4) - OneLine4(context); - else if (context->Type == 1) - OneLine1(context); - else - g_assert_not_reached (); - } else - OneLineTransp(context); - - context->Lines++; - if (context->Lines>=context->Header.height) { - context->Type = 1; - context->LineWidth = context->Header.width / 8; - if ((context->Header.width & 7) != 0) - context->LineWidth++; - /* Pad to a 32 bit boundary */ - if (((context->LineWidth % 4) > 0)) - context->LineWidth = (context->LineWidth / 4) * 4 + 4; - - } - - - if (context->updated_func != NULL) { - (*context->updated_func) (context->pixbuf, - 0, - context->Lines % context->Header.height, - context->Header.width, - 1, - context->user_data); - - } -} - -/* - * context - from image_begin_load - * buf - new image data - * size - length of new image data - * - * append image data onto inrecrementally built output image - */ -static gboolean -gdk_pixbuf__ico_image_load_increment(gpointer data, - const guchar * buf, - guint size, - GError **error) -{ - struct ico_progressive_state *context = - (struct ico_progressive_state *) data; - - gint BytesToCopy; - - while (size > 0) { - g_assert(context->LineDone >= 0); - if (context->HeaderDone < context->HeaderSize) { /* We still - have headerbytes to do */ - BytesToCopy = - context->HeaderSize - context->HeaderDone; - if (BytesToCopy > size) - BytesToCopy = size; - - memmove(context->HeaderBuf + context->HeaderDone, - buf, BytesToCopy); - - size -= BytesToCopy; - buf += BytesToCopy; - context->HeaderDone += BytesToCopy; - } - else { - BytesToCopy = - context->LineWidth - context->LineDone; - if (BytesToCopy > size) - BytesToCopy = size; - - if (BytesToCopy > 0) { - memmove(context->LineBuf + - context->LineDone, buf, - BytesToCopy); - - size -= BytesToCopy; - buf += BytesToCopy; - context->LineDone += BytesToCopy; - } - if ((context->LineDone >= context->LineWidth) && - (context->LineWidth > 0)) - OneLine(context); - - - } - - if (context->HeaderDone >= 6 && context->pixbuf == NULL) { - GError *decode_err = NULL; - DecodeHeader(context->HeaderBuf, - context->HeaderDone, context, &decode_err); - if (context->LineBuf != NULL && context->LineWidth == 0) - return TRUE; - - if (decode_err) { - g_propagate_error (error, decode_err); - return FALSE; - } - } - } - - return TRUE; -} - -/* saving ICOs */ - -static gint -write8 (FILE *f, - guint8 *data, - gint count) -{ - gint bytes; - gint written; - - written = 0; - while (count > 0) - { - bytes = fwrite ((char*) data, sizeof (char), count, f); - if (bytes <= 0) - break; - count -= bytes; - data += bytes; - written += bytes; - } - - return written; -} - -static gint -write16 (FILE *f, - guint16 *data, - gint count) -{ - gint i; - - for (i = 0; i < count; i++) - data[i] = GUINT16_TO_LE (data[i]); - - return write8 (f, (guint8*) data, count * 2); -} - -static gint -write32 (FILE *f, - guint32 *data, - gint count) -{ - gint i; - - for (i = 0; i < count; i++) - data[i] = GUINT32_TO_LE (data[i]); - - return write8 (f, (guint8*) data, count * 4); -} - -typedef struct _IconEntry IconEntry; -struct _IconEntry { - gint width; - gint height; - gint depth; - gint hot_x; - gint hot_y; - - guint8 n_colors; - guint32 *colors; - guint xor_rowstride; - guint8 *xor; - guint and_rowstride; - guint8 *and; -}; - -static gboolean -fill_entry (IconEntry *icon, - GdkPixbuf *pixbuf, - gint hot_x, - gint hot_y, - GError **error) - { - guchar *p, *pixels, *and, *xor; - gint n_channels, v, x, y; - - if (icon->width > 255 || icon->height > 255) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("Image too large to be saved as ICO")); - return FALSE; - } - - if (hot_x > -1 && hot_y > -1) { - icon->hot_x = hot_x; - icon->hot_y = hot_y; - if (icon->hot_x >= icon->width || icon->hot_y >= icon->height) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("Cursor hotspot outside image")); - return FALSE; - } - } - else { - icon->hot_x = -1; - icon->hot_y = -1; - } - - switch (icon->depth) { - case 32: - icon->xor_rowstride = icon->width * 4; - break; - case 24: - icon->xor_rowstride = icon->width * 3; - break; - case 16: - icon->xor_rowstride = icon->width * 2; - break; - default: - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("Unsupported depth for ICO file: %d"), icon->depth); - return FALSE; - } - - if ((icon->xor_rowstride % 4) != 0) - icon->xor_rowstride = 4 * ((icon->xor_rowstride / 4) + 1); - icon->xor = g_new0 (guchar, icon->xor_rowstride * icon->height); - - icon->and_rowstride = (icon->width + 7) / 8; - if ((icon->and_rowstride % 4) != 0) - icon->and_rowstride = 4 * ((icon->and_rowstride / 4) + 1); - icon->and = g_new0 (guchar, icon->and_rowstride * icon->height); - - pixels = gdk_pixbuf_get_pixels (pixbuf); - n_channels = gdk_pixbuf_get_n_channels (pixbuf); - for (y = 0; y < icon->height; y++) { - p = pixels + gdk_pixbuf_get_rowstride (pixbuf) * (icon->height - 1 - y); - and = icon->and + icon->and_rowstride * y; - xor = icon->xor + icon->xor_rowstride * y; - for (x = 0; x < icon->width; x++) { - switch (icon->depth) { - case 32: - xor[0] = p[2]; - xor[1] = p[1]; - xor[2] = p[0]; - xor[3] = 0xff; - if (n_channels == 4) { - xor[3] = p[3]; - if (p[3] < 0x80) - *and |= 1 << (7 - x % 8); - } - xor += 4; - break; - case 24: - xor[0] = p[2]; - xor[1] = p[1]; - xor[2] = p[0]; - if (n_channels == 4 && p[3] < 0x80) - *and |= 1 << (7 - x % 8); - xor += 3; - break; - case 16: - v = ((p[0] >> 3) << 10) | ((p[1] >> 3) << 5) | (p[2] >> 3); - xor[0] = v & 0xff; - xor[1] = v >> 8; - if (n_channels == 4 && p[3] < 0x80) - *and |= 1 << (7 - x % 8); - xor += 2; - break; - } - - p += n_channels; - if (x % 8 == 7) - and++; - } - } - - return TRUE; -} - -static void -free_entry (IconEntry *icon) -{ - g_free (icon->colors); - g_free (icon->and); - g_free (icon->xor); - g_free (icon); -} - -static void -write_icon (FILE *f, GSList *entries) -{ - IconEntry *icon; - GSList *entry; - guint8 bytes[4]; - guint16 words[4]; - guint32 dwords[6]; - gint type; - gint n_entries; - gint offset; - gint size; - - if (((IconEntry *)entries->data)->hot_x > -1) - type = 2; - else - type = 1; - n_entries = g_slist_length (entries); - - /* header */ - words[0] = 0; - words[1] = type; - words[2] = n_entries; - write16 (f, words, 3); - - offset = 6 + 16 * n_entries; - - for (entry = entries; entry; entry = entry->next) { - icon = (IconEntry *)entry->data; - size = 40 + icon->height * (icon->and_rowstride + icon->xor_rowstride); - - /* directory entry */ - bytes[0] = icon->width; - bytes[1] = icon->height; - bytes[2] = icon->n_colors; - bytes[3] = 0; - write8 (f, bytes, 4); - if (type == 1) { - words[0] = 1; - words[1] = icon->depth; - } - else { - words[0] = icon->hot_x; - words[1] = icon->hot_y; - } - write16 (f, words, 2); - dwords[0] = size; - dwords[1] = offset; - write32 (f, dwords, 2); - - offset += size; - } - - for (entry = entries; entry; entry = entry->next) { - icon = (IconEntry *)entry->data; - - /* bitmap header */ - dwords[0] = 40; - dwords[1] = icon->width; - dwords[2] = icon->height * 2; - write32 (f, dwords, 3); - words[0] = 1; - words[1] = icon->depth; - write16 (f, words, 2); - dwords[0] = 0; - dwords[1] = 0; - dwords[2] = 0; - dwords[3] = 0; - dwords[4] = 0; - dwords[5] = 0; - write32 (f, dwords, 6); - - /* image data */ - write8 (f, icon->xor, icon->xor_rowstride * icon->height); - write8 (f, icon->and, icon->and_rowstride * icon->height); - } -} - -static gboolean -gdk_pixbuf__ico_image_save (FILE *f, - GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error) -{ - gint hot_x, hot_y; - IconEntry *icon; - GSList *entries = NULL; - - /* support only single-image ICOs for now */ - icon = g_new0 (IconEntry, 1); - icon->width = gdk_pixbuf_get_width (pixbuf); - icon->height = gdk_pixbuf_get_height (pixbuf); - icon->depth = gdk_pixbuf_get_has_alpha (pixbuf) ? 32 : 24; - hot_x = -1; - hot_y = -1; - - /* parse options */ - if (keys && *keys) { - gchar **kiter; - gchar **viter; - - for (kiter = keys, viter = values; *kiter && *viter; kiter++, viter++) { - char *endptr; - if (strcmp (*kiter, "depth") == 0) { - sscanf (*viter, "%d", &icon->depth); - } - else if (strcmp (*kiter, "x_hot") == 0) { - hot_x = strtol (*viter, &endptr, 10); - } - else if (strcmp (*kiter, "y_hot") == 0) { - hot_y = strtol (*viter, &endptr, 10); - } - - } - } - - if (!fill_entry (icon, pixbuf, hot_x, hot_y, error)) { - free_entry (icon); - return FALSE; - } - - entries = g_slist_append (entries, icon); - write_icon (f, entries); - - g_slist_foreach (entries, (GFunc)free_entry, NULL); - g_slist_free (entries); - - return TRUE; -} - -#ifndef INCLUDE_ico -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__ico_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->begin_load = gdk_pixbuf__ico_image_begin_load; - module->stop_load = gdk_pixbuf__ico_image_stop_load; - module->load_increment = gdk_pixbuf__ico_image_load_increment; - module->save = gdk_pixbuf__ico_image_save; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { " \x1 ", "zz znz", 100 }, - { " \x2 ", "zz znz", 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/x-icon", - "image/x-ico", - "image/x-win-bitmap", - NULL - }; - static gchar * extensions[] = { - "ico", - "cur", - NULL - }; - - info->name = "ico"; - info->signature = signature; - info->description = N_("The ICO image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_WRITABLE | GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} - - - - diff --git a/gdk-pixbuf/io-jasper.c b/gdk-pixbuf/io-jasper.c deleted file mode 100644 index e60a7c82e9..0000000000 --- a/gdk-pixbuf/io-jasper.c +++ /dev/null @@ -1,313 +0,0 @@ -/* JPEG 2000 loader - * - * Copyright (c) 2007 Bastien Nocera <hadess@hadess.net> - * Inspired by work by Ben Karel <web+moz@eschew.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include <stdlib.h> -#include <string.h> -#include <errno.h> - -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - -#include <jasper/jasper.h> - -G_MODULE_EXPORT void fill_vtable (GdkPixbufModule * module); -G_MODULE_EXPORT void fill_info (GdkPixbufFormat * info); - -struct jasper_context { - GdkPixbuf *pixbuf; - - GdkPixbufModuleSizeFunc size_func; - GdkPixbufModuleUpdatedFunc updated_func; - GdkPixbufModulePreparedFunc prepared_func; - gpointer user_data; - - jas_stream_t *stream; - - int width, height; -}; - -static void -free_jasper_context (struct jasper_context *context) -{ - if (!context) - return; - - if (context->stream) { - jas_stream_close (context->stream); - context->stream = NULL; - } - - g_free (context); -} - -static gpointer -jasper_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, GError **error) -{ - struct jasper_context *context; - jas_stream_t *stream; - - jas_init (); - - stream = jas_stream_memopen (NULL, -1); - if (!stream) { - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Couldn't allocate memory for stream")); - return NULL; - } - - context = g_new0 (struct jasper_context, 1); - if (!context) - return NULL; - - context->size_func = size_func; - context->updated_func = updated_func; - context->prepared_func = prepared_func; - context->user_data = user_data; - context->width = context->height = -1; - - context->stream = stream; - - return context; -} - -static gboolean -jasper_image_try_load (struct jasper_context *context, GError **error) -{ - jas_image_t *raw_image, *image; - int num_components, colourspace_family; - int i, rowstride, shift; - guchar *pixels; - - raw_image = jas_image_decode (context->stream, -1, 0); - if (!raw_image) { - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Couldn't decode image")); - return FALSE; - } - - if (context->width == -1 && context->height == -1) { - int width, height; - - context->width = width = jas_image_cmptwidth (raw_image, 0); - context->height = height = jas_image_cmptheight (raw_image, 0); - - if (context->size_func) { - (*context->size_func) (&width, &height, context->user_data); - - if (width == 0 || height == 0) { - jas_image_destroy(raw_image); - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Transformed JPEG2000 has zero width or height")); - return FALSE; - } - } - } - - /* We only know how to handle grayscale and RGB images */ - num_components = jas_image_numcmpts (raw_image); - colourspace_family = jas_clrspc_fam (jas_image_clrspc (raw_image)); - - if ((num_components != 3 && num_components != 4 && num_components != 1) || - (colourspace_family != JAS_CLRSPC_FAM_RGB && colourspace_family != JAS_CLRSPC_FAM_GRAY)) { - jas_image_destroy (raw_image); - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("Image type currently not supported")); - return FALSE; - } - - /* Apply the colour profile to the image, creating a new one */ - if (jas_image_clrspc (raw_image) != JAS_CLRSPC_SRGB) { - jas_cmprof_t *profile; - - profile = jas_cmprof_createfromclrspc (JAS_CLRSPC_SRGB); - if (!profile) { - jas_image_destroy (raw_image); - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Couldn't allocate memory for color profile")); - return FALSE; - } - - image = jas_image_chclrspc (raw_image, profile, JAS_CMXFORM_INTENT_PER); - if (!image) { - jas_image_destroy (raw_image); - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Couldn't allocate memory for color profile")); - return FALSE; - } - } else { - image = raw_image; - } - - if (!context->pixbuf) { - int bits_per_sample; - - /* Unfortunately, gdk-pixbuf doesn't support 16 bpp images - * bits_per_sample = jas_image_cmptprec (image, 0); - if (bits_per_sample < 8) - bits_per_sample = 8; - else if (bits_per_sample > 8) - bits_per_sample = 16; - */ - bits_per_sample = 8; - - context->pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, - FALSE, bits_per_sample, - context->width, context->height); - if (context->pixbuf == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to open JPEG 2000 file")); - return FALSE; - } - if (context->prepared_func) - context->prepared_func (context->pixbuf, NULL, context->user_data); - } - - /* We calculate how much we should shift the pixel - * data by to make it fit into our pixbuf */ - shift = MAX (jas_image_cmptprec (image, 0) - gdk_pixbuf_get_bits_per_sample (context->pixbuf), 0); - - /* Loop over the 3 colourspaces */ - rowstride = gdk_pixbuf_get_rowstride (context->pixbuf); - pixels = gdk_pixbuf_get_pixels (context->pixbuf); - - for (i = 0; i < num_components; i++) { - jas_matrix_t *matrix; - int j; - - matrix = jas_matrix_create (context->height, context->width); - - /* in libjasper, R is 0, G is 1, etc. we're lucky :) - * but we need to handle the "opacity" channel ourselves */ - if (i != 4) { - jas_image_readcmpt (image, i, 0, 0, context->width, context->height, matrix); - } else { - jas_image_readcmpt (image, JAS_IMAGE_CT_OPACITY, 0, 0, context->width, context->height, matrix); - } - - for (j = 0; j < context->height; j++) { - int k; - - for (k = 0; k < context->width; k++) { - if (num_components == 3 || num_components == 4) { - pixels[j * rowstride + k * 3 + i] = jas_matrix_get (matrix, j, k) >> shift; - } else { - pixels[j * rowstride + k * 3] = - pixels[j * rowstride + k * 3 + 1] = - pixels[j * rowstride + k * 3 + 2] = jas_matrix_get (matrix, j, k) >> shift; - } - } - /* Update once per line for the last component, otherwise - * we might contain garbage */ - if (context->updated_func && (i == num_components - 1) && k != 0) { - context->updated_func (context->pixbuf, 0, j, k, 1, context->user_data); - } - } - - jas_matrix_destroy (matrix); - } - - if (image != raw_image) - jas_image_destroy (image); - jas_image_destroy (raw_image); - - return TRUE; -} - -static gboolean -jasper_image_stop_load (gpointer data, GError **error) -{ - struct jasper_context *context = (struct jasper_context *) data; - gboolean ret; - - jas_stream_rewind (context->stream); - ret = jasper_image_try_load (context, error); - - free_jasper_context (context); - - return ret; -} - -static gboolean -jasper_image_load_increment (gpointer data, const guchar *buf, guint size, GError **error) -{ - struct jasper_context *context = (struct jasper_context *) data; - - if (jas_stream_write (context->stream, buf, size) < 0) { - g_set_error_literal (error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Couldn't allocate memory to buffer image data")); - return FALSE; - } - - return TRUE; -} - -#ifndef INCLUDE_jasper -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__jasper_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule * module) -{ - module->begin_load = jasper_image_begin_load; - module->stop_load = jasper_image_stop_load; - module->load_increment = jasper_image_load_increment; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat * info) -{ - static GdkPixbufModulePattern signature[] = { - { " jP", "!!!! ", 100 }, /* file begins with 'jP' at offset 4 */ - { "\xff\x4f\xff\x51\x00", NULL, 100 }, /* file starts with FF 4F FF 51 00 */ - { NULL, NULL, 0 } - }; - static gchar *mime_types[] = { - "image/jp2", - "image/jpeg2000", - "image/jpx", - NULL - }; - static gchar *extensions[] = { - "jp2", - "jpc", - "jpx", - "j2k", - "jpf", - NULL - }; - - info->name = "jpeg2000"; - info->signature = signature; - info->description = N_("The JPEG 2000 image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; - info->disabled = FALSE; -} - diff --git a/gdk-pixbuf/io-jpeg.c b/gdk-pixbuf/io-jpeg.c deleted file mode 100644 index cc1db97e6d..0000000000 --- a/gdk-pixbuf/io-jpeg.c +++ /dev/null @@ -1,1315 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* GdkPixbuf library - JPEG image loader - * - * Copyright (C) 1999 Michael Zucchi - * Copyright (C) 1999 The Free Software Foundation - * - * Progressive loading code Copyright (C) 1999 Red Hat, Inc. - * - * Authors: Michael Zucchi <zucchi@zedzone.mmc.com.au> - * Federico Mena-Quintero <federico@gimp.org> - * Michael Fulbright <drmike@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - - -#include "config.h" -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <setjmp.h> -#include <jpeglib.h> -#include <jerror.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - -#ifndef HAVE_SIGSETJMP -#define sigjmp_buf jmp_buf -#define sigsetjmp(jb, x) setjmp(jb) -#define siglongjmp longjmp -#endif - - -/* we are a "source manager" as far as libjpeg is concerned */ -#define JPEG_PROG_BUF_SIZE 65536 - -typedef struct { - struct jpeg_source_mgr pub; /* public fields */ - - JOCTET buffer[JPEG_PROG_BUF_SIZE]; /* start of buffer */ - long skip_next; /* number of bytes to skip next read */ - -} my_source_mgr; - -typedef my_source_mgr * my_src_ptr; - -/* error handler data */ -struct error_handler_data { - struct jpeg_error_mgr pub; - sigjmp_buf setjmp_buffer; - GError **error; -}; - -/* progressive loader context */ -typedef struct { - GdkPixbufModuleSizeFunc size_func; - GdkPixbufModuleUpdatedFunc updated_func; - GdkPixbufModulePreparedFunc prepared_func; - gpointer user_data; - - GdkPixbuf *pixbuf; - guchar *dptr; /* current position in pixbuf */ - - gboolean did_prescan; /* are we in image data yet? */ - gboolean got_header; /* have we loaded jpeg header? */ - gboolean src_initialized;/* TRUE when jpeg lib initialized */ - gboolean in_output; /* did we get suspended in an output pass? */ - struct jpeg_decompress_struct cinfo; - struct error_handler_data jerr; -} JpegProgContext; - -static GdkPixbuf *gdk_pixbuf__jpeg_image_load (FILE *f, GError **error); -static gpointer gdk_pixbuf__jpeg_image_begin_load (GdkPixbufModuleSizeFunc func0, - GdkPixbufModulePreparedFunc func1, - GdkPixbufModuleUpdatedFunc func2, - gpointer user_data, - GError **error); -static gboolean gdk_pixbuf__jpeg_image_stop_load (gpointer context, GError **error); -static gboolean gdk_pixbuf__jpeg_image_load_increment(gpointer context, - const guchar *buf, guint size, - GError **error); - - -static void -fatal_error_handler (j_common_ptr cinfo) -{ - struct error_handler_data *errmgr; - char buffer[JMSG_LENGTH_MAX]; - - errmgr = (struct error_handler_data *) cinfo->err; - - /* Create the message */ - (* cinfo->err->format_message) (cinfo, buffer); - - /* broken check for *error == NULL for robustness against - * crappy JPEG library - */ - if (errmgr->error && *errmgr->error == NULL) { - g_set_error (errmgr->error, - GDK_PIXBUF_ERROR, - cinfo->err->msg_code == JERR_OUT_OF_MEMORY - ? GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY - : GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Error interpreting JPEG image file (%s)"), - buffer); - } - - siglongjmp (errmgr->setjmp_buffer, 1); - - g_assert_not_reached (); -} - -static void -output_message_handler (j_common_ptr cinfo) -{ - /* This method keeps libjpeg from dumping crap to stderr */ - - /* do nothing */ -} - -/* explode gray image data from jpeg library into rgb components in pixbuf */ -static void -explode_gray_into_buf (struct jpeg_decompress_struct *cinfo, - guchar **lines) -{ - gint i, j; - guint w; - - g_return_if_fail (cinfo != NULL); - g_return_if_fail (cinfo->output_components == 1); - g_return_if_fail (cinfo->out_color_space == JCS_GRAYSCALE); - - /* Expand grey->colour. Expand from the end of the - * memory down, so we can use the same buffer. - */ - w = cinfo->output_width; - for (i = cinfo->rec_outbuf_height - 1; i >= 0; i--) { - guchar *from, *to; - - from = lines[i] + w - 1; - to = lines[i] + (w - 1) * 3; - for (j = w - 1; j >= 0; j--) { - to[0] = from[0]; - to[1] = from[0]; - to[2] = from[0]; - to -= 3; - from--; - } - } -} - - -static void -convert_cmyk_to_rgb (struct jpeg_decompress_struct *cinfo, - guchar **lines) -{ - gint i, j; - - g_return_if_fail (cinfo != NULL); - g_return_if_fail (cinfo->output_components == 4); - g_return_if_fail (cinfo->out_color_space == JCS_CMYK); - - for (i = cinfo->rec_outbuf_height - 1; i >= 0; i--) { - guchar *p; - - p = lines[i]; - for (j = 0; j < cinfo->output_width; j++) { - int c, m, y, k; - c = p[0]; - m = p[1]; - y = p[2]; - k = p[3]; - if (cinfo->saw_Adobe_marker) { - p[0] = k*c / 255; - p[1] = k*m / 255; - p[2] = k*y / 255; - } - else { - p[0] = (255 - k)*(255 - c) / 255; - p[1] = (255 - k)*(255 - m) / 255; - p[2] = (255 - k)*(255 - y) / 255; - } - p[3] = 255; - p += 4; - } - } -} - -typedef struct { - struct jpeg_source_mgr pub; /* public fields */ - - FILE * infile; /* source stream */ - JOCTET * buffer; /* start of buffer */ - boolean start_of_file; /* have we gotten any data yet? */ -} stdio_source_mgr; - -typedef stdio_source_mgr * stdio_src_ptr; - -static void -stdio_init_source (j_decompress_ptr cinfo) -{ - stdio_src_ptr src = (stdio_src_ptr)cinfo->src; - src->start_of_file = FALSE; -} - -static boolean -stdio_fill_input_buffer (j_decompress_ptr cinfo) -{ - stdio_src_ptr src = (stdio_src_ptr) cinfo->src; - size_t nbytes; - - nbytes = fread (src->buffer, 1, JPEG_PROG_BUF_SIZE, src->infile); - - if (nbytes <= 0) { -#if 0 - if (src->start_of_file) /* Treat empty input file as fatal error */ - ERREXIT(cinfo, JERR_INPUT_EMPTY); - WARNMS(cinfo, JWRN_JPEG_EOF); -#endif - /* Insert a fake EOI marker */ - src->buffer[0] = (JOCTET) 0xFF; - src->buffer[1] = (JOCTET) JPEG_EOI; - nbytes = 2; - } - - src->pub.next_input_byte = src->buffer; - src->pub.bytes_in_buffer = nbytes; - src->start_of_file = FALSE; - - return TRUE; -} - -static void -stdio_skip_input_data (j_decompress_ptr cinfo, long num_bytes) -{ - stdio_src_ptr src = (stdio_src_ptr) cinfo->src; - - if (num_bytes > 0) { - while (num_bytes > (long) src->pub.bytes_in_buffer) { - num_bytes -= (long) src->pub.bytes_in_buffer; - (void)stdio_fill_input_buffer(cinfo); - } - src->pub.next_input_byte += (size_t) num_bytes; - src->pub.bytes_in_buffer -= (size_t) num_bytes; - } -} - -static void -stdio_term_source (j_decompress_ptr cinfo) -{ -} - -static gchar * -colorspace_name (const J_COLOR_SPACE jpeg_color_space) -{ - switch (jpeg_color_space) { - case JCS_UNKNOWN: return "UNKNOWN"; - case JCS_GRAYSCALE: return "GRAYSCALE"; - case JCS_RGB: return "RGB"; - case JCS_YCbCr: return "YCbCr"; - case JCS_CMYK: return "CMYK"; - case JCS_YCCK: return "YCCK"; - default: return "invalid"; - } -} - - -const char leth[] = {0x49, 0x49, 0x2a, 0x00}; // Little endian TIFF header -const char beth[] = {0x4d, 0x4d, 0x00, 0x2a}; // Big endian TIFF header -const char types[] = {0x00, 0x01, 0x01, 0x02, 0x04, 0x08, 0x00, - 0x08, 0x00, 0x04, 0x08}; // size in bytes for EXIF types - -#define DE_ENDIAN16(val) endian == G_BIG_ENDIAN ? GUINT16_FROM_BE(val) : GUINT16_FROM_LE(val) -#define DE_ENDIAN32(val) endian == G_BIG_ENDIAN ? GUINT32_FROM_BE(val) : GUINT32_FROM_LE(val) - -#define ENDIAN16_IT(val) endian == G_BIG_ENDIAN ? GUINT16_TO_BE(val) : GUINT16_TO_LE(val) -#define ENDIAN32_IT(val) endian == G_BIG_ENDIAN ? GUINT32_TO_BE(val) : GUINT32_TO_LE(val) - -#define EXIF_JPEG_MARKER JPEG_APP0+1 -#define EXIF_IDENT_STRING "Exif\000\000" - -static unsigned short de_get16(void *ptr, guint endian) -{ - unsigned short val; - - memcpy(&val, ptr, sizeof(val)); - val = DE_ENDIAN16(val); - - return val; -} - -static unsigned int de_get32(void *ptr, guint endian) -{ - unsigned int val; - - memcpy(&val, ptr, sizeof(val)); - val = DE_ENDIAN32(val); - - return val; -} - -static gint -get_orientation (j_decompress_ptr cinfo) -{ - /* This function looks through the meta data in the libjpeg decompress structure to - determine if an EXIF Orientation tag is present and if so return its value (1-8). - If no EXIF Orientation tag is found 0 (zero) is returned. */ - - guint i; /* index into working buffer */ - guint orient_tag_id; /* endianed version of orientation tag ID */ - guint ret; /* Return value */ - guint offset; /* de-endianed offset in various situations */ - guint tags; /* number of tags in current ifd */ - guint type; /* de-endianed type of tag used as index into types[] */ - guint count; /* de-endianed count of elements in a tag */ - guint tiff = 0; /* offset to active tiff header */ - guint endian = 0; /* detected endian of data */ - - jpeg_saved_marker_ptr exif_marker; /* Location of the Exif APP1 marker */ - jpeg_saved_marker_ptr cmarker; /* Location to check for Exif APP1 marker */ - - /* check for Exif marker (also called the APP1 marker) */ - exif_marker = NULL; - cmarker = cinfo->marker_list; - while (cmarker) { - if (cmarker->marker == EXIF_JPEG_MARKER) { - /* The Exif APP1 marker should contain a unique - identification string ("Exif\0\0"). Check for it. */ - if (!memcmp (cmarker->data, EXIF_IDENT_STRING, 6)) { - exif_marker = cmarker; - } - } - cmarker = cmarker->next; - } - - /* Did we find the Exif APP1 marker? */ - if (exif_marker == NULL) - return 0; - - /* Do we have enough data? */ - if (exif_marker->data_length < 32) - return 0; - - /* Check for TIFF header and catch endianess */ - i = 0; - - /* Just skip data until TIFF header - it should be within 16 bytes from marker start. - Normal structure relative to APP1 marker - - 0x0000: APP1 marker entry = 2 bytes - 0x0002: APP1 length entry = 2 bytes - 0x0004: Exif Identifier entry = 6 bytes - 0x000A: Start of TIFF header (Byte order entry) - 4 bytes - - This is what we look for, to determine endianess. - 0x000E: 0th IFD offset pointer - 4 bytes - - exif_marker->data points to the first data after the APP1 marker - and length entries, which is the exif identification string. - The TIFF header should thus normally be found at i=6, below, - and the pointer to IFD0 will be at 6+4 = 10. - */ - - while (i < 16) { - - /* Little endian TIFF header */ - if (memcmp (&exif_marker->data[i], leth, 4) == 0){ - endian = G_LITTLE_ENDIAN; - } - - /* Big endian TIFF header */ - else if (memcmp (&exif_marker->data[i], beth, 4) == 0){ - endian = G_BIG_ENDIAN; - } - - /* Keep looking through buffer */ - else { - i++; - continue; - } - /* We have found either big or little endian TIFF header */ - tiff = i; - break; - } - - /* So did we find a TIFF header or did we just hit end of buffer? */ - if (tiff == 0) - return 0; - - /* Endian the orientation tag ID, to locate it more easily */ - orient_tag_id = ENDIAN16_IT(0x112); - - /* Read out the offset pointer to IFD0 */ - offset = de_get32(&exif_marker->data[i] + 4, endian); - i = i + offset; - - /* Check that we still are within the buffer and can read the tag count */ - if ((i + 2) > exif_marker->data_length) - return 0; - - /* Find out how many tags we have in IFD0. As per the TIFF spec, the first - two bytes of the IFD contain a count of the number of tags. */ - tags = de_get16(&exif_marker->data[i], endian); - i = i + 2; - - /* Check that we still have enough data for all tags to check. The tags - are listed in consecutive 12-byte blocks. The tag ID, type, size, and - a pointer to the actual value, are packed into these 12 byte entries. */ - if ((i + tags * 12) > exif_marker->data_length) - return 0; - - /* Check through IFD0 for tags of interest */ - while (tags--){ - type = de_get16(&exif_marker->data[i + 2], endian); - count = de_get32(&exif_marker->data[i + 4], endian); - - /* Is this the orientation tag? */ - if (memcmp (&exif_marker->data[i], (char *) &orient_tag_id, 2) == 0){ - - /* Check that type and count fields are OK. The orientation field - will consist of a single (count=1) 2-byte integer (type=3). */ - if (type != 3 || count != 1) return 0; - - /* Return the orientation value. Within the 12-byte block, the - pointer to the actual data is at offset 8. */ - ret = de_get16(&exif_marker->data[i + 8], endian); - return ret <= 8 ? ret : 0; - } - /* move the pointer to the next 12-byte tag field. */ - i = i + 12; - } - - return 0; /* No EXIF Orientation tag found */ -} - - -/* Shared library entry point */ -static GdkPixbuf * -gdk_pixbuf__jpeg_image_load (FILE *f, GError **error) -{ - gint i; - int is_otag; - char otag_str[5]; - GdkPixbuf * volatile pixbuf = NULL; - guchar *dptr; - guchar *lines[4]; /* Used to expand rows, via rec_outbuf_height, - * from the header file: - * " Usually rec_outbuf_height will be 1 or 2, - * at most 4." - */ - guchar **lptr; - struct jpeg_decompress_struct cinfo; - struct error_handler_data jerr; - stdio_src_ptr src; - - /* setup error handler */ - cinfo.err = jpeg_std_error (&jerr.pub); - jerr.pub.error_exit = fatal_error_handler; - jerr.pub.output_message = output_message_handler; - jerr.error = error; - - if (sigsetjmp (jerr.setjmp_buffer, 1)) { - /* Whoops there was a jpeg error */ - if (pixbuf) - g_object_unref (pixbuf); - - jpeg_destroy_decompress (&cinfo); - - /* error should have been set by fatal_error_handler () */ - return NULL; - } - - /* load header, setup */ - jpeg_create_decompress (&cinfo); - - cinfo.src = (struct jpeg_source_mgr *) - (*cinfo.mem->alloc_small) ((j_common_ptr) &cinfo, JPOOL_PERMANENT, - sizeof (stdio_source_mgr)); - src = (stdio_src_ptr) cinfo.src; - src->buffer = (JOCTET *) - (*cinfo.mem->alloc_small) ((j_common_ptr) &cinfo, JPOOL_PERMANENT, - JPEG_PROG_BUF_SIZE * sizeof (JOCTET)); - - src->pub.init_source = stdio_init_source; - src->pub.fill_input_buffer = stdio_fill_input_buffer; - src->pub.skip_input_data = stdio_skip_input_data; - src->pub.resync_to_restart = jpeg_resync_to_restart; /* use default method */ - src->pub.term_source = stdio_term_source; - src->infile = f; - src->pub.bytes_in_buffer = 0; /* forces fill_input_buffer on first read */ - src->pub.next_input_byte = NULL; /* until buffer loaded */ - - jpeg_save_markers (&cinfo, EXIF_JPEG_MARKER, 0xffff); - jpeg_read_header (&cinfo, TRUE); - - /* check for orientation tag */ - is_otag = get_orientation (&cinfo); - - jpeg_start_decompress (&cinfo); - cinfo.do_fancy_upsampling = FALSE; - cinfo.do_block_smoothing = FALSE; - - pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, - cinfo.out_color_components == 4 ? TRUE : FALSE, - 8, cinfo.output_width, cinfo.output_height); - - if (!pixbuf) { - jpeg_destroy_decompress (&cinfo); - - /* broken check for *error == NULL for robustness against - * crappy JPEG library - */ - if (error && *error == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to load image, try exiting some applications to free memory")); - } - - return NULL; - } - - /* if orientation tag was found set an option to remember its value */ - if (is_otag) { - g_snprintf (otag_str, sizeof (otag_str), "%d", is_otag); - gdk_pixbuf_set_option (pixbuf, "orientation", otag_str); - } - - - dptr = pixbuf->pixels; - - /* decompress all the lines, a few at a time */ - while (cinfo.output_scanline < cinfo.output_height) { - lptr = lines; - for (i = 0; i < cinfo.rec_outbuf_height; i++) { - *lptr++ = dptr; - dptr += pixbuf->rowstride; - } - - jpeg_read_scanlines (&cinfo, lines, cinfo.rec_outbuf_height); - - switch (cinfo.out_color_space) { - case JCS_GRAYSCALE: - explode_gray_into_buf (&cinfo, lines); - break; - case JCS_RGB: - /* do nothing */ - break; - case JCS_CMYK: - convert_cmyk_to_rgb (&cinfo, lines); - break; - default: - g_object_unref (pixbuf); - if (error && *error == NULL) { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("Unsupported JPEG color space (%s)"), - colorspace_name (cinfo.out_color_space)); - } - - jpeg_destroy_decompress (&cinfo); - return NULL; - } - } - - jpeg_finish_decompress (&cinfo); - jpeg_destroy_decompress (&cinfo); - - return pixbuf; -} - - -/**** Progressive image loading handling *****/ - -/* these routines required because we are acting as a source manager for */ -/* libjpeg. */ -static void -init_source (j_decompress_ptr cinfo) -{ - my_src_ptr src = (my_src_ptr) cinfo->src; - - src->skip_next = 0; -} - - -static void -term_source (j_decompress_ptr cinfo) -{ - /* XXXX - probably should scream something has happened */ -} - - -/* for progressive loading (called "I/O Suspension" by libjpeg docs) */ -/* we do nothing except return "FALSE" */ -static boolean -fill_input_buffer (j_decompress_ptr cinfo) -{ - return FALSE; -} - - -static void -skip_input_data (j_decompress_ptr cinfo, long num_bytes) -{ - my_src_ptr src = (my_src_ptr) cinfo->src; - long num_can_do; - - /* move as far as we can into current buffer */ - /* then set skip_next to catch the rest */ - if (num_bytes > 0) { - num_can_do = MIN (src->pub.bytes_in_buffer, num_bytes); - src->pub.next_input_byte += (size_t) num_can_do; - src->pub.bytes_in_buffer -= (size_t) num_can_do; - - src->skip_next = num_bytes - num_can_do; - } -} - - -/* - * func - called when we have pixmap created (but no image data) - * user_data - passed as arg 1 to func - * return context (opaque to user) - */ - -static gpointer -gdk_pixbuf__jpeg_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error) -{ - JpegProgContext *context; - my_source_mgr *src; - - context = g_new0 (JpegProgContext, 1); - context->size_func = size_func; - context->prepared_func = prepared_func; - context->updated_func = updated_func; - context->user_data = user_data; - context->pixbuf = NULL; - context->got_header = FALSE; - context->did_prescan = FALSE; - context->src_initialized = FALSE; - context->in_output = FALSE; - - /* From jpeglib.h: "NB: you must set up the error-manager - * BEFORE calling jpeg_create_xxx". */ - context->cinfo.err = jpeg_std_error (&context->jerr.pub); - context->jerr.pub.error_exit = fatal_error_handler; - context->jerr.pub.output_message = output_message_handler; - context->jerr.error = error; - - /* create libjpeg structures */ - jpeg_create_decompress (&context->cinfo); - - context->cinfo.src = (struct jpeg_source_mgr *) g_try_malloc (sizeof (my_source_mgr)); - if (!context->cinfo.src) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Couldn't allocate memory for loading JPEG file")); - return NULL; - } - memset (context->cinfo.src, 0, sizeof (my_source_mgr)); - - src = (my_src_ptr) context->cinfo.src; - src->pub.init_source = init_source; - src->pub.fill_input_buffer = fill_input_buffer; - src->pub.skip_input_data = skip_input_data; - src->pub.resync_to_restart = jpeg_resync_to_restart; - src->pub.term_source = term_source; - src->pub.bytes_in_buffer = 0; - src->pub.next_input_byte = NULL; - - context->jerr.error = NULL; - - return (gpointer) context; -} - -/* - * context - returned from image_begin_load - * - * free context, unref gdk_pixbuf - */ -static gboolean -gdk_pixbuf__jpeg_image_stop_load (gpointer data, GError **error) -{ - JpegProgContext *context = (JpegProgContext *) data; - gboolean retval; - - g_return_val_if_fail (context != NULL, TRUE); - - /* FIXME this thing needs to report errors if - * we have unused image data - */ - - if (context->pixbuf) - g_object_unref (context->pixbuf); - - /* if we have an error? */ - context->jerr.error = error; - if (sigsetjmp (context->jerr.setjmp_buffer, 1)) { - retval = FALSE; - } else { - jpeg_finish_decompress (&context->cinfo); - retval = TRUE; - } - - jpeg_destroy_decompress (&context->cinfo); - - if (context->cinfo.src) { - my_src_ptr src = (my_src_ptr) context->cinfo.src; - - g_free (src); - } - - g_free (context); - - return retval; -} - - -static gboolean -gdk_pixbuf__jpeg_image_load_lines (JpegProgContext *context, - GError **error) -{ - struct jpeg_decompress_struct *cinfo = &context->cinfo; - guchar *lines[4]; - guchar **lptr; - guchar *rowptr; - gint nlines, i; - - /* keep going until we've done all scanlines */ - while (cinfo->output_scanline < cinfo->output_height) { - lptr = lines; - rowptr = context->dptr; - for (i=0; i < cinfo->rec_outbuf_height; i++) { - *lptr++ = rowptr; - rowptr += context->pixbuf->rowstride; - } - - nlines = jpeg_read_scanlines (cinfo, lines, - cinfo->rec_outbuf_height); - if (nlines == 0) - break; - - switch (cinfo->out_color_space) { - case JCS_GRAYSCALE: - explode_gray_into_buf (cinfo, lines); - break; - case JCS_RGB: - /* do nothing */ - break; - case JCS_CMYK: - convert_cmyk_to_rgb (cinfo, lines); - break; - default: - if (error && *error == NULL) { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("Unsupported JPEG color space (%s)"), - colorspace_name (cinfo->out_color_space)); - } - - return FALSE; - } - - context->dptr += nlines * context->pixbuf->rowstride; - - /* send updated signal */ - if (context->updated_func) - (* context->updated_func) (context->pixbuf, - 0, - cinfo->output_scanline - 1, - cinfo->image_width, - nlines, - context->user_data); - } - - return TRUE; -} - - -/* - * context - from image_begin_load - * buf - new image data - * size - length of new image data - * - * append image data onto inrecrementally built output image - */ -static gboolean -gdk_pixbuf__jpeg_image_load_increment (gpointer data, - const guchar *buf, guint size, - GError **error) -{ - JpegProgContext *context = (JpegProgContext *)data; - struct jpeg_decompress_struct *cinfo; - my_src_ptr src; - guint num_left, num_copy; - guint last_num_left, last_bytes_left; - guint spinguard; - gboolean first; - const guchar *bufhd; - gint width, height; - int is_otag; - char otag_str[5]; - - g_return_val_if_fail (context != NULL, FALSE); - g_return_val_if_fail (buf != NULL, FALSE); - - src = (my_src_ptr) context->cinfo.src; - - cinfo = &context->cinfo; - - context->jerr.error = error; - - /* check for fatal error */ - if (sigsetjmp (context->jerr.setjmp_buffer, 1)) { - return FALSE; - } - - /* skip over data if requested, handle unsigned int sizes cleanly */ - /* only can happen if we've already called jpeg_get_header once */ - if (context->src_initialized && src->skip_next) { - if (src->skip_next > size) { - src->skip_next -= size; - return TRUE; - } else { - num_left = size - src->skip_next; - bufhd = buf + src->skip_next; - src->skip_next = 0; - } - } else { - num_left = size; - bufhd = buf; - } - - if (num_left == 0) - return TRUE; - - last_num_left = num_left; - last_bytes_left = 0; - spinguard = 0; - first = TRUE; - while (TRUE) { - - /* handle any data from caller we haven't processed yet */ - if (num_left > 0) { - if(src->pub.bytes_in_buffer && - src->pub.next_input_byte != src->buffer) - memmove(src->buffer, src->pub.next_input_byte, - src->pub.bytes_in_buffer); - - - num_copy = MIN (JPEG_PROG_BUF_SIZE - src->pub.bytes_in_buffer, - num_left); - - memcpy(src->buffer + src->pub.bytes_in_buffer, bufhd,num_copy); - src->pub.next_input_byte = src->buffer; - src->pub.bytes_in_buffer += num_copy; - bufhd += num_copy; - num_left -= num_copy; - } - - /* did anything change from last pass, if not return */ - if (first) { - last_bytes_left = src->pub.bytes_in_buffer; - first = FALSE; - } else if (src->pub.bytes_in_buffer == last_bytes_left - && num_left == last_num_left) { - spinguard++; - } else { - last_bytes_left = src->pub.bytes_in_buffer; - last_num_left = num_left; - } - - /* should not go through twice and not pull bytes out of buf */ - if (spinguard > 2) - return TRUE; - - /* try to load jpeg header */ - if (!context->got_header) { - int rc; - - jpeg_save_markers (cinfo, EXIF_JPEG_MARKER, 0xffff); - rc = jpeg_read_header (cinfo, TRUE); - context->src_initialized = TRUE; - - if (rc == JPEG_SUSPENDED) - continue; - - context->got_header = TRUE; - - /* check for orientation tag */ - is_otag = get_orientation (cinfo); - - width = cinfo->image_width; - height = cinfo->image_height; - if (context->size_func) { - (* context->size_func) (&width, &height, context->user_data); - if (width == 0 || height == 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Transformed JPEG has zero width or height.")); - return FALSE; - } - } - - cinfo->scale_num = 1; - for (cinfo->scale_denom = 2; cinfo->scale_denom <= 8; cinfo->scale_denom *= 2) { - jpeg_calc_output_dimensions (cinfo); - if (cinfo->output_width < width || cinfo->output_height < height) { - cinfo->scale_denom /= 2; - break; - } - } - jpeg_calc_output_dimensions (cinfo); - - context->pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, - cinfo->output_components == 4 ? TRUE : FALSE, - 8, - cinfo->output_width, - cinfo->output_height); - - if (context->pixbuf == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Couldn't allocate memory for loading JPEG file")); - return FALSE; - } - - /* if orientation tag was found set an option to remember its value */ - if (is_otag) { - g_snprintf (otag_str, sizeof (otag_str), "%d", is_otag); - gdk_pixbuf_set_option (context->pixbuf, "orientation", otag_str); - } - - /* Use pixbuf buffer to store decompressed data */ - context->dptr = context->pixbuf->pixels; - - /* Notify the client that we are ready to go */ - if (context->prepared_func) - (* context->prepared_func) (context->pixbuf, - NULL, - context->user_data); - - } else if (!context->did_prescan) { - int rc; - - /* start decompression */ - cinfo->buffered_image = cinfo->progressive_mode; - rc = jpeg_start_decompress (cinfo); - cinfo->do_fancy_upsampling = FALSE; - cinfo->do_block_smoothing = FALSE; - - if (rc == JPEG_SUSPENDED) - continue; - - context->did_prescan = TRUE; - } else if (!cinfo->buffered_image) { - /* we're decompressing unbuffered so - * simply get scanline by scanline from jpeg lib - */ - if (! gdk_pixbuf__jpeg_image_load_lines (context, - error)) - return FALSE; - - if (cinfo->output_scanline >= cinfo->output_height) - return TRUE; - } else { - /* we're decompressing buffered (progressive) - * so feed jpeg lib scanlines - */ - - /* keep going until we've done all passes */ - while (!jpeg_input_complete (cinfo)) { - if (!context->in_output) { - if (jpeg_start_output (cinfo, cinfo->input_scan_number)) { - context->in_output = TRUE; - context->dptr = context->pixbuf->pixels; - } - else - break; - } - - /* get scanlines from jpeg lib */ - if (! gdk_pixbuf__jpeg_image_load_lines (context, - error)) - return FALSE; - - if (cinfo->output_scanline >= cinfo->output_height && - jpeg_finish_output (cinfo)) - context->in_output = FALSE; - else - break; - } - if (jpeg_input_complete (cinfo)) - /* did entire image */ - return TRUE; - else - continue; - } - } -} - -/* Save */ - -#define TO_FUNCTION_BUF_SIZE 4096 - -typedef struct { - struct jpeg_destination_mgr pub; - JOCTET *buffer; - GdkPixbufSaveFunc save_func; - gpointer user_data; - GError **error; -} ToFunctionDestinationManager; - -void -to_callback_init (j_compress_ptr cinfo) -{ - ToFunctionDestinationManager *destmgr; - - destmgr = (ToFunctionDestinationManager*) cinfo->dest; - destmgr->pub.next_output_byte = destmgr->buffer; - destmgr->pub.free_in_buffer = TO_FUNCTION_BUF_SIZE; -} - -static void -to_callback_do_write (j_compress_ptr cinfo, gsize length) -{ - ToFunctionDestinationManager *destmgr; - - destmgr = (ToFunctionDestinationManager*) cinfo->dest; - if (!destmgr->save_func ((gchar *)destmgr->buffer, - length, - destmgr->error, - destmgr->user_data)) { - struct error_handler_data *errmgr; - - errmgr = (struct error_handler_data *) cinfo->err; - /* Use a default error message if the callback didn't set one, - * which it should have. - */ - if (errmgr->error && *errmgr->error == NULL) { - g_set_error_literal (errmgr->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - "write function failed"); - } - siglongjmp (errmgr->setjmp_buffer, 1); - g_assert_not_reached (); - } -} - -static boolean -to_callback_empty_output_buffer (j_compress_ptr cinfo) -{ - ToFunctionDestinationManager *destmgr; - - destmgr = (ToFunctionDestinationManager*) cinfo->dest; - to_callback_do_write (cinfo, TO_FUNCTION_BUF_SIZE); - destmgr->pub.next_output_byte = destmgr->buffer; - destmgr->pub.free_in_buffer = TO_FUNCTION_BUF_SIZE; - return TRUE; -} - -void -to_callback_terminate (j_compress_ptr cinfo) -{ - ToFunctionDestinationManager *destmgr; - - destmgr = (ToFunctionDestinationManager*) cinfo->dest; - to_callback_do_write (cinfo, TO_FUNCTION_BUF_SIZE - destmgr->pub.free_in_buffer); -} - -static gboolean -real_save_jpeg (GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error, - gboolean to_callback, - FILE *f, - GdkPixbufSaveFunc save_func, - gpointer user_data) -{ - /* FIXME error handling is broken */ - - struct jpeg_compress_struct cinfo; - guchar *buf = NULL; - guchar *ptr; - guchar *pixels = NULL; - JSAMPROW *jbuf; - int y = 0; - volatile int quality = 75; /* default; must be between 0 and 100 */ - int i, j; - int w, h = 0; - int rowstride = 0; - int n_channels; - struct error_handler_data jerr; - ToFunctionDestinationManager to_callback_destmgr; - - to_callback_destmgr.buffer = NULL; - - if (keys && *keys) { - gchar **kiter = keys; - gchar **viter = values; - - while (*kiter) { - if (strcmp (*kiter, "quality") == 0) { - char *endptr = NULL; - quality = strtol (*viter, &endptr, 10); - - if (endptr == *viter) { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("JPEG quality must be a value between 0 and 100; value '%s' could not be parsed."), - *viter); - - return FALSE; - } - - if (quality < 0 || - quality > 100) { - /* This is a user-visible error; - * lets people skip the range-checking - * in their app. - */ - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("JPEG quality must be a value between 0 and 100; value '%d' is not allowed."), - quality); - - return FALSE; - } - } else { - g_warning ("Unrecognized parameter (%s) passed to JPEG saver.", *kiter); - } - - ++kiter; - ++viter; - } - } - - rowstride = gdk_pixbuf_get_rowstride (pixbuf); - n_channels = gdk_pixbuf_get_n_channels (pixbuf); - - w = gdk_pixbuf_get_width (pixbuf); - h = gdk_pixbuf_get_height (pixbuf); - pixels = gdk_pixbuf_get_pixels (pixbuf); - - /* Allocate a small buffer to convert image data, - * and a larger buffer if doing to_callback save. - */ - buf = g_try_malloc (w * 3 * sizeof (guchar)); - if (!buf) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Couldn't allocate memory for loading JPEG file")); - return FALSE; - } - if (to_callback) { - to_callback_destmgr.buffer = g_try_malloc (TO_FUNCTION_BUF_SIZE); - if (!to_callback_destmgr.buffer) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Couldn't allocate memory for loading JPEG file")); - g_free (buf); - return FALSE; - } - } - - /* set up error handling */ - cinfo.err = jpeg_std_error (&(jerr.pub)); - jerr.pub.error_exit = fatal_error_handler; - jerr.pub.output_message = output_message_handler; - jerr.error = error; - - if (sigsetjmp (jerr.setjmp_buffer, 1)) { - jpeg_destroy_compress (&cinfo); - g_free (buf); - g_free (to_callback_destmgr.buffer); - return FALSE; - } - - /* setup compress params */ - jpeg_create_compress (&cinfo); - if (to_callback) { - to_callback_destmgr.pub.init_destination = to_callback_init; - to_callback_destmgr.pub.empty_output_buffer = to_callback_empty_output_buffer; - to_callback_destmgr.pub.term_destination = to_callback_terminate; - to_callback_destmgr.error = error; - to_callback_destmgr.save_func = save_func; - to_callback_destmgr.user_data = user_data; - cinfo.dest = (struct jpeg_destination_mgr*) &to_callback_destmgr; - } else { - jpeg_stdio_dest (&cinfo, f); - } - cinfo.image_width = w; - cinfo.image_height = h; - cinfo.input_components = 3; - cinfo.in_color_space = JCS_RGB; - - /* set up jepg compression parameters */ - jpeg_set_defaults (&cinfo); - jpeg_set_quality (&cinfo, quality, TRUE); - jpeg_start_compress (&cinfo, TRUE); - /* get the start pointer */ - ptr = pixels; - /* go one scanline at a time... and save */ - i = 0; - while (cinfo.next_scanline < cinfo.image_height) { - /* convert scanline from ARGB to RGB packed */ - for (j = 0; j < w; j++) - memcpy (&(buf[j*3]), &(ptr[i*rowstride + j*n_channels]), 3); - - /* write scanline */ - jbuf = (JSAMPROW *)(&buf); - jpeg_write_scanlines (&cinfo, jbuf, 1); - i++; - y++; - - } - - /* finish off */ - jpeg_finish_compress (&cinfo); - jpeg_destroy_compress(&cinfo); - g_free (buf); - g_free (to_callback_destmgr.buffer); - return TRUE; -} - -static gboolean -gdk_pixbuf__jpeg_image_save (FILE *f, - GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error) -{ - return real_save_jpeg (pixbuf, keys, values, error, - FALSE, f, NULL, NULL); -} - -static gboolean -gdk_pixbuf__jpeg_image_save_to_callback (GdkPixbufSaveFunc save_func, - gpointer user_data, - GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error) -{ - return real_save_jpeg (pixbuf, keys, values, error, - TRUE, NULL, save_func, user_data); -} - -#ifndef INCLUDE_jpeg -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__jpeg_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->load = gdk_pixbuf__jpeg_image_load; - module->begin_load = gdk_pixbuf__jpeg_image_begin_load; - module->stop_load = gdk_pixbuf__jpeg_image_stop_load; - module->load_increment = gdk_pixbuf__jpeg_image_load_increment; - module->save = gdk_pixbuf__jpeg_image_save; - module->save_to_callback = gdk_pixbuf__jpeg_image_save_to_callback; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "\xff\xd8", NULL, 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/jpeg", - NULL - }; - static gchar * extensions[] = { - "jpeg", - "jpe", - "jpg", - NULL - }; - - info->name = "jpeg"; - info->signature = signature; - info->description = N_("The JPEG image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_WRITABLE | GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-pcx.c b/gdk-pixbuf/io-pcx.c deleted file mode 100644 index 584240db31..0000000000 --- a/gdk-pixbuf/io-pcx.c +++ /dev/null @@ -1,761 +0,0 @@ -/* - * GdkPixbuf library - PCX image loader - * - * Copyright (C) 2003 Josh A. Beam - * - * Authors: Josh A. Beam <josh@joshbeam.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <stdio.h> -#include <string.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - -#undef PCX_DEBUG - -#define PCX_TASK_DONE 0 -#define PCX_TASK_LOAD_HEADER 1 -#define PCX_TASK_LOAD_DATA 2 -#define PCX_TASK_LOAD_PALETTE 3 - -struct pcx_header { - guint8 manufacturer; - guint8 version; - guint8 encoding; - guint8 bitsperpixel; - gint16 xmin; - gint16 ymin; - gint16 xmax; - gint16 ymax; - guint16 horizdpi; - guint16 vertdpi; - guint8 palette[48]; - guint8 reserved; - guint8 colorplanes; - guint16 bytesperline; - guint16 palettetype; - guint16 hscrsize; - guint16 vscrsize; - guint8 filler[54]; -}; - -struct pcx_context { - GdkPixbuf *pixbuf; - gint rowstride; - - GdkPixbufModuleSizeFunc size_func; - GdkPixbufModuleUpdatedFunc updated_func; - GdkPixbufModulePreparedFunc prepared_func; - gpointer user_data; - - guchar current_task; - - gboolean header_loaded; - struct pcx_header *header; - guint bpp; - gint width, height; - guint num_planes; - guint bytesperline; - - guchar *buf; - guint buf_size; - guint buf_pos; - guchar *data; - guchar *line; - guint current_line; - guchar *p_data; -}; - -/* - * set context's image information based on the header - */ -static void -fill_pcx_context(struct pcx_context *context) -{ - struct pcx_header *header = context->header; - - context->bpp = header->bitsperpixel; - context->width = header->xmax - header->xmin + 1; - context->height = header->ymax - header->ymin + 1; - context->num_planes = header->colorplanes; - context->bytesperline = header->bytesperline; - - if(header->version == 5 && context->bpp == 8 && context->num_planes == 3) - context->bpp = 24; -} - -static void -free_pcx_context(struct pcx_context *context, gboolean unref_pixbuf) -{ - g_free(context->header); - g_free(context->buf); - if(unref_pixbuf && context->pixbuf) - g_object_unref(context->pixbuf); - g_free(context->line); - g_free(context->p_data); - - g_free(context); -} - -/* - * read each plane of a single scanline. store_planes is - * the number of planes that can be stored in the planes array. - * data is the pointer to the block of memory to read - * from, size is the length of that data, and line_bytes - * is where the number of bytes read will be stored. - */ -static gboolean -read_scanline_data(guchar *data, guint size, guchar *planes[], - guint store_planes, guint num_planes, guint bytesperline, - guint *line_bytes) -{ - guint i, j; - guint p, count; - guint d = 0; - guint8 byte; - - for(p = 0; p < num_planes; p++) { - for(i = 0; i < bytesperline;) { /* i incremented when line byte set */ - if(d >= size) - return FALSE; - byte = data[d++]; - - if(byte >> 6 == 0x3) { - count = byte & ~(0x3 << 6); - if(count == 0) - return FALSE; - if(d >= size) - return FALSE; - byte = data[d++]; - } else { - count = 1; - } - - for(j = 0; j < count; j++) { - if(p < store_planes) - planes[p][i++] = byte; - else - i++; - - if(i >= bytesperline) { - p++; - if(p >= num_planes) { - *line_bytes = d; - return TRUE; - } - i = 0; - } - } - } - } - - *line_bytes = d; /* number of bytes read for scanline */ - return TRUE; -} - -static gpointer -gdk_pixbuf__pcx_begin_load(GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, GError **error) -{ - struct pcx_context *context; - - context = g_new0(struct pcx_context, 1); - if(!context) - return NULL; - - context->header = g_try_malloc(sizeof(struct pcx_header)); - if(!context->header) { - g_free(context); - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, _("Couldn't allocate memory for header")); - return NULL; - } - - context->size_func = size_func; - context->updated_func = updated_func; - context->prepared_func = prepared_func; - context->user_data = user_data; - - context->current_task = PCX_TASK_LOAD_HEADER; - - context->buf = g_try_malloc(sizeof(guchar) * 512); - if(!context->buf) { - g_free(context->header); - g_free(context); - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, _("Couldn't allocate memory for context buffer")); - return NULL; - } - context->buf_size = 512; - - context->header_loaded = FALSE; - - return context; -} - -static gboolean -pcx_resize_context_buf(struct pcx_context *context, guint size) -{ - guchar *new_buf; - - new_buf = g_try_realloc(context->buf, size); - if(!new_buf) - return FALSE; - - context->buf = new_buf; - context->buf_size = size; - return TRUE; -} - -/* - * remove a number of bytes (specified by size) from the - * beginning of a context's buf - */ -static gboolean -pcx_chop_context_buf(struct pcx_context *context, guint size) -{ - guint i, j; - - if (size > context->buf_pos) - return FALSE; - else if (size == 0) - return TRUE; - - for (i = 0, j = size; j < context->buf_pos; i++, j++) - context->buf[i] = context->buf[j]; - - context->buf_pos -= size; - - return TRUE; -} - -static guchar -read_pixel_1(guchar *data, guint offset) -{ - guchar retval; - guint bit_offset; - - if(!(offset % 8)) { - offset /= 8; - retval = data[offset] >> 7; - } else { - bit_offset = offset % 8; - offset -= bit_offset; - offset /= 8; - retval = (data[offset] >> (7 - bit_offset)) & 0x1; - } - - return retval; -} - -static guchar -read_pixel_4(guchar *data, guint offset) -{ - guchar retval; - - if(!(offset % 2)) { - offset /= 2; - retval = data[offset] >> 4; - } else { - offset--; - offset /= 2; - retval = data[offset] & 0xf; - } - - return retval; -} - -static gboolean -pcx_increment_load_data_1(struct pcx_context *context) -{ - guint i; - guchar *planes[4]; - guint line_bytes; - guint store_planes; - - if(context->num_planes == 4) { - planes[0] = context->line; - planes[1] = planes[0] + context->bytesperline; - planes[2] = planes[1] + context->bytesperline; - planes[3] = planes[2] + context->bytesperline; - store_planes = 4; - } else if(context->num_planes == 3) { - planes[0] = context->line; - planes[1] = planes[0] + context->bytesperline; - planes[2] = planes[1] + context->bytesperline; - store_planes = 3; - } else if(context->num_planes == 2) { - planes[0] = context->line; - planes[1] = planes[0] + context->bytesperline; - store_planes = 2; - } else if(context->num_planes == 1) { - planes[0] = context->line; - store_planes = 1; - } else { - return FALSE; - } - - while(read_scanline_data(context->buf, context->buf_pos, planes, store_planes, context->num_planes, context->bytesperline, &line_bytes)) { - pcx_chop_context_buf(context, line_bytes); - - for(i = 0; i < context->width; i++) { - guchar p; - - if(context->num_planes == 4) { - p = read_pixel_1(planes[3], i); - p <<= 1; - p |= read_pixel_1(planes[2], i); - p <<= 1; - p |= read_pixel_1(planes[1], i); - p <<= 1; - p |= read_pixel_1(planes[0], i); - } else if(context->num_planes == 3) { - p = read_pixel_1(planes[2], i); - p <<= 1; - p |= read_pixel_1(planes[1], i); - p <<= 1; - p |= read_pixel_1(planes[0], i); - } else if(context->num_planes == 2) { - p = read_pixel_1(planes[1], i); - p <<= 1; - p |= read_pixel_1(planes[0], i); - } else if(context->num_planes == 1) { - p = read_pixel_1(planes[0], i); - } else { - return FALSE; - } - p &= 0xf; - context->data[context->current_line * context->rowstride + i * 3 + 0] = context->header->palette[p * 3 + 0]; - context->data[context->current_line * context->rowstride + i * 3 + 1] = context->header->palette[p * 3 + 1]; - context->data[context->current_line * context->rowstride + i * 3 + 2] = context->header->palette[p * 3 + 2]; - } - - if(context->updated_func) - context->updated_func(context->pixbuf, 0, context->current_line, context->width, 1, context->user_data); - - context->current_line++; - - if(context->current_line == context->height) { - context->current_task = PCX_TASK_DONE; - return TRUE; - } - } - - return TRUE; -} - -static gboolean -pcx_increment_load_data_2(struct pcx_context *context) -{ - guint i; - guchar *planes[1]; - guint line_bytes; - guint shift, h; - - planes[0] = context->line; - - while(read_scanline_data(context->buf, context->buf_pos, planes, 1, context->num_planes, context->bytesperline, &line_bytes)) { - pcx_chop_context_buf(context, line_bytes); - - for(i = 0; i < context->width; i++) { - shift = 6 - 2 * (i % 4); - h = (planes[0][i / 4] >> shift) & 0x3; - context->data[context->current_line * context->rowstride + i * 3 + 0] = context->header->palette[h * 3 + 0]; - context->data[context->current_line * context->rowstride + i * 3 + 1] = context->header->palette[h * 3 + 1]; - context->data[context->current_line * context->rowstride + i * 3 + 2] = context->header->palette[h * 3 + 2]; - } - - if(context->updated_func) - context->updated_func(context->pixbuf, 0, context->current_line, context->width, 1, context->user_data); - - context->current_line++; - - if(context->current_line == context->height) { - context->current_task = PCX_TASK_DONE; - return TRUE; - } - } - - return TRUE; -} - -static gboolean -pcx_increment_load_data_4(struct pcx_context *context) -{ - guint i; - guchar *planes[1]; - guint line_bytes; - - planes[0] = context->line; - - while(read_scanline_data(context->buf, context->buf_pos, planes, 1, context->num_planes, context->bytesperline, &line_bytes)) { - pcx_chop_context_buf(context, line_bytes); - - for(i = 0; i < context->width; i++) { - guchar p; - - p = read_pixel_4(planes[0], i) & 0xf; - context->data[context->current_line * context->rowstride + i * 3 + 0] = context->header->palette[p * 3 + 0]; - context->data[context->current_line * context->rowstride + i * 3 + 1] = context->header->palette[p * 3 + 1]; - context->data[context->current_line * context->rowstride + i * 3 + 2] = context->header->palette[p * 3 + 2]; - } - - if(context->updated_func) - context->updated_func(context->pixbuf, 0, context->current_line, context->width, 1, context->user_data); - - context->current_line++; - - if(context->current_line == context->height) { - context->current_task = PCX_TASK_DONE; - return TRUE; - } - } - - return TRUE; -} - -/* - * for loading 8-bit pcx images, we keep a buffer containing - * each pixel's palette number; once we've loaded each scanline, - * we wait for loading to stop and call pcx_load_palette_8, - * which finds the palette at the end of the pcx data and sets the - * RGB data. - */ -static gboolean -pcx_increment_load_data_8(struct pcx_context *context) -{ - guint i; - guchar *planes[1]; - guint line_bytes; - - planes[0] = context->line; - - while(read_scanline_data(context->buf, context->buf_pos, planes, 1, context->num_planes, context->bytesperline, &line_bytes)) { - pcx_chop_context_buf(context, line_bytes); - - for(i = 0; i < context->width; i++) - context->p_data[context->current_line * context->width + i + 0] = planes[0][i]; - - context->current_line++; - - if(context->current_line == context->height) { - context->current_task = PCX_TASK_LOAD_PALETTE; - return TRUE; - } - } - - return TRUE; -} - -/* - * read the palette and set the RGB data - */ -static gboolean -pcx_load_palette_8(struct pcx_context *context) -{ - guint i, j; - - if(context->current_line < context->height) - return FALSE; - - if(context->buf_pos >= 769) { - guchar *palette = context->buf + (context->buf_pos - 769); - - if(palette[0] == 12) { - palette++; - for(i = 0; i < context->height; i++) { - for(j = 0; j < context->width; j++) { - context->data[i * context->rowstride + j * 3 + 0] = palette[(context->p_data[i * context->width + j]) * 3 + 0]; - context->data[i * context->rowstride + j * 3 + 1] = palette[(context->p_data[i * context->width + j]) * 3 + 1]; - context->data[i * context->rowstride + j * 3 + 2] = palette[(context->p_data[i * context->width + j]) * 3 + 2]; - } - - if(context->updated_func) - context->updated_func(context->pixbuf, 0, i, context->width, 1, context->user_data); - } - -#ifdef PCX_DEBUG - g_print("read palette\n"); -#endif - - context->current_task = PCX_TASK_DONE; - return TRUE; - } else { -#ifdef PCX_DEBUG - g_print("this ain't a palette\n"); -#endif - return FALSE; - } - } - - return FALSE; -} - -/* - * in 24-bit images, each scanline has three color planes - * for red, green, and blue, respectively. - */ -static gboolean -pcx_increment_load_data_24(struct pcx_context *context) -{ - guint i; - guchar *planes[3]; - guint line_bytes; - - planes[0] = context->line; - planes[1] = planes[0] + context->bytesperline; - planes[2] = planes[1] + context->bytesperline; - - while(read_scanline_data(context->buf, context->buf_pos, planes, 3, context->num_planes, context->bytesperline, &line_bytes)) { - pcx_chop_context_buf(context, line_bytes); - - for(i = 0; i < context->width; i++) { - context->data[context->current_line * context->rowstride + i * 3 + 0] = planes[0][i]; - context->data[context->current_line * context->rowstride + i * 3 + 1] = planes[1][i]; - context->data[context->current_line * context->rowstride + i * 3 + 2] = planes[2][i]; - } - - if(context->updated_func) - context->updated_func(context->pixbuf, 0, context->current_line, context->width, 1, context->user_data); - - context->current_line++; - - if(context->current_line == context->height) { - context->current_task = PCX_TASK_DONE; - return TRUE; - } - } - - return TRUE; -} - -static gboolean -gdk_pixbuf__pcx_load_increment(gpointer data, const guchar *buf, guint size, - GError **error) -{ - struct pcx_context *context = (struct pcx_context *)data; - struct pcx_header *header; - guint i; - gboolean retval = TRUE; - - /* if context's buf isn't large enough to hold its current data plus the passed buf, increase its size */ - if(context->buf_pos + size > context->buf_size) { - if(!pcx_resize_context_buf(context, sizeof(guchar) * (context->buf_pos + size))) { - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, _("Couldn't allocate memory for context buffer")); - return FALSE; - } - } - - for(i = 0; i < size; i++) - context->buf[context->buf_pos++] = buf[i]; - - if(context->current_task == PCX_TASK_LOAD_HEADER) { - if(!context->header_loaded && context->buf_pos > sizeof(struct pcx_header)) { /* set header */ - gint width, height; - - memcpy(context->header, context->buf, sizeof(struct pcx_header)); - pcx_chop_context_buf(context, sizeof(struct pcx_header)); - header = context->header; - - /* convert the multi-byte header variables that will be used */ - header->xmin = GINT16_FROM_LE(header->xmin); - header->ymin = GINT16_FROM_LE(header->ymin); - header->xmax = GINT16_FROM_LE(header->xmax); - header->ymax = GINT16_FROM_LE(header->ymax); - header->bytesperline = GUINT16_FROM_LE(header->bytesperline); - -#ifdef PCX_DEBUG - g_print ("Manufacturer %d\n" - "Version %d\n" - "Encoding %d\n" - "Bits/Pixel %d\n" - "Planes %d\n" - "Palette %d\n", - header->manufacturer, header->version, - header->encoding, header->bitsperpixel, - header->colorplanes, header->palettetype); -#endif - - context->header_loaded = TRUE; - fill_pcx_context(context); - - width = context->width; - height = context->height; - if(width <= 0 || height <= 0) { - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_CORRUPT_IMAGE, _("Image has invalid width and/or height")); - return FALSE; - } - if (context->size_func) - { - (*context->size_func) (&width, &height, context->user_data); - if (width == 0 || height == 0) - return TRUE; - } - - switch(context->bpp) { - default: - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_UNKNOWN_TYPE, _("Image has unsupported bpp")); - return FALSE; - break; - case 1: - if(context->num_planes < 1 || context->num_planes > 4) { - g_set_error(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_UNKNOWN_TYPE, _("Image has unsupported number of %d-bit planes"), 1); - return FALSE; - } - break; - case 2: - case 4: - case 8: - if(context->num_planes != 1) { - g_set_error(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_UNKNOWN_TYPE, _("Image has unsupported number of %d-bit planes"), (gint)context->bpp); - return FALSE; - } - break; - case 24: - break; /* context's bpp is set to 24 if there are three 8-bit planes */ - } - -#ifdef PCX_DEBUG - g_print("io-pcx: header loaded\n"); - g_print("bpp: %u\n", context->bpp); - g_print("dimensions: %ux%u\n", context->width, context->height); -#endif - - context->pixbuf = gdk_pixbuf_new(GDK_COLORSPACE_RGB, FALSE, 8, context->width, context->height); - if(!context->pixbuf) { - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, _("Couldn't create new pixbuf")); - return FALSE; - } - context->data = gdk_pixbuf_get_pixels(context->pixbuf); - context->rowstride = gdk_pixbuf_get_rowstride(context->pixbuf); - - context->line = g_try_malloc(sizeof(guchar) * context->bytesperline * context->num_planes); - if(!context->line) { - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, _("Couldn't allocate memory for line data")); - return FALSE; - } - - if(context->bpp == 8) { - context->p_data = g_try_malloc(sizeof(guchar) * context->width * context->height); - if(!context->p_data) { - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, _("Couldn't allocate memory for paletted data")); - return FALSE; - } - } - - if(context->prepared_func) - context->prepared_func(context->pixbuf, NULL, context->user_data); - - context->current_task = PCX_TASK_LOAD_DATA; - } - - retval = TRUE; - } - - if(context->current_task == PCX_TASK_LOAD_DATA) { - switch(context->bpp) { - default: - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_UNKNOWN_TYPE, _("Image has unsupported bpp")); - retval = FALSE; - break; - case 1: - retval = pcx_increment_load_data_1(context); - break; - case 2: - retval = pcx_increment_load_data_2(context); - break; - case 4: - retval = pcx_increment_load_data_4(context); - break; - case 8: - retval = pcx_increment_load_data_8(context); - break; - case 24: - retval = pcx_increment_load_data_24(context); - break; - } - } - - return retval; -} - -static gboolean -gdk_pixbuf__pcx_stop_load(gpointer data, GError **error) -{ - struct pcx_context *context = (struct pcx_context *)data; - - if(context->current_line != context->height) { - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_FAILED, _("Didn't get all lines of PCX image")); - free_pcx_context(context, FALSE); - return FALSE; - } - - if(context->current_task == PCX_TASK_LOAD_PALETTE) { - if(!pcx_load_palette_8(context)) { - g_set_error_literal(error, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_FAILED, _("No palette found at end of PCX data")); - free_pcx_context(context, FALSE); - return FALSE; - } - } - - free_pcx_context(context, FALSE); - - return TRUE; -} - -#ifndef INCLUDE_pcx -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__pcx_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->begin_load = gdk_pixbuf__pcx_begin_load; - module->stop_load = gdk_pixbuf__pcx_stop_load; - module->load_increment = gdk_pixbuf__pcx_load_increment; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "\x0a \x01", NULL, 100 }, - { "\x0a\x02\x01", NULL, 100 }, - { "\x0a\x03\x01", NULL, 100 }, - { "\x0a\x04\x01", NULL, 100 }, - { "\x0a\x05\x01", NULL, 100 }, - { NULL, NULL, 0 } - }; - static gchar *mime_types[] = { - "image/x-pcx", - NULL, - }; - static gchar *extensions[] = { - "pcx", - NULL, - }; - - info->name = "pcx"; - info->signature = signature; - info->description = N_("The PCX image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-png.c b/gdk-pixbuf/io-png.c deleted file mode 100644 index 844064a748..0000000000 --- a/gdk-pixbuf/io-png.c +++ /dev/null @@ -1,1117 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - PNG image loader - * - * Copyright (C) 1999 Mark Crichton - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Federico Mena-Quintero <federico@gimp.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <stdio.h> -#include <stdlib.h> -#include <png.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - - - -static gboolean -setup_png_transformations(png_structp png_read_ptr, png_infop png_info_ptr, - GError **error, - png_uint_32* width_p, png_uint_32* height_p, - int* color_type_p) -{ - png_uint_32 width, height; - int bit_depth, color_type, interlace_type, compression_type, filter_type; - int channels; - - /* Get the image info */ - - /* Must check bit depth, since png_get_IHDR generates an - FPE on bit_depth 0. - */ - bit_depth = png_get_bit_depth (png_read_ptr, png_info_ptr); - if (bit_depth < 1 || bit_depth > 16) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Bits per channel of PNG image is invalid.")); - return FALSE; - } - png_get_IHDR (png_read_ptr, png_info_ptr, - &width, &height, - &bit_depth, - &color_type, - &interlace_type, - &compression_type, - &filter_type); - - /* set_expand() basically needs to be called unless - we are already in RGB/RGBA mode - */ - if (color_type == PNG_COLOR_TYPE_PALETTE && - bit_depth <= 8) { - - /* Convert indexed images to RGB */ - png_set_expand (png_read_ptr); - - } else if (color_type == PNG_COLOR_TYPE_GRAY && - bit_depth < 8) { - - /* Convert grayscale to RGB */ - png_set_expand (png_read_ptr); - - } else if (png_get_valid (png_read_ptr, - png_info_ptr, PNG_INFO_tRNS)) { - - /* If we have transparency header, convert it to alpha - channel */ - png_set_expand(png_read_ptr); - - } else if (bit_depth < 8) { - - /* If we have < 8 scale it up to 8 */ - png_set_expand(png_read_ptr); - - - /* Conceivably, png_set_packing() is a better idea; - * God only knows how libpng works - */ - } - - /* If we are 16-bit, convert to 8-bit */ - if (bit_depth == 16) { - png_set_strip_16(png_read_ptr); - } - - /* If gray scale, convert to RGB */ - if (color_type == PNG_COLOR_TYPE_GRAY || - color_type == PNG_COLOR_TYPE_GRAY_ALPHA) { - png_set_gray_to_rgb(png_read_ptr); - } - - /* If interlaced, handle that */ - if (interlace_type != PNG_INTERLACE_NONE) { - png_set_interlace_handling(png_read_ptr); - } - - /* Update the info the reflect our transformations */ - png_read_update_info(png_read_ptr, png_info_ptr); - - png_get_IHDR (png_read_ptr, png_info_ptr, - &width, &height, - &bit_depth, - &color_type, - &interlace_type, - &compression_type, - &filter_type); - - *width_p = width; - *height_p = height; - *color_type_p = color_type; - - /* Check that the new info is what we want */ - - if (width == 0 || height == 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Transformed PNG has zero width or height.")); - return FALSE; - } - - if (bit_depth != 8) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Bits per channel of transformed PNG is not 8.")); - return FALSE; - } - - if ( ! (color_type == PNG_COLOR_TYPE_RGB || - color_type == PNG_COLOR_TYPE_RGB_ALPHA) ) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Transformed PNG not RGB or RGBA.")); - return FALSE; - } - - channels = png_get_channels(png_read_ptr, png_info_ptr); - if ( ! (channels == 3 || channels == 4) ) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Transformed PNG has unsupported number of channels, must be 3 or 4.")); - return FALSE; - } - return TRUE; -} - -static void -png_simple_error_callback(png_structp png_save_ptr, - png_const_charp error_msg) -{ - GError **error; - - error = png_get_error_ptr(png_save_ptr); - - /* I don't trust libpng to call the error callback only once, - * so check for already-set error - */ - if (error && *error == NULL) { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Fatal error in PNG image file: %s"), - error_msg); - } - - longjmp (png_save_ptr->jmpbuf, 1); -} - -static void -png_simple_warning_callback(png_structp png_save_ptr, - png_const_charp warning_msg) -{ - /* Don't print anything; we should not be dumping junk to - * stderr, since that may be bad for some apps. If it's - * important enough to display, we need to add a GError - * **warning return location wherever we have an error return - * location. - */ -} - -static gboolean -png_text_to_pixbuf_option (png_text text_ptr, - gchar **key, - gchar **value) -{ - gboolean is_ascii = TRUE; - int i; - - /* Avoid loading iconv if the text is plain ASCII */ - for (i = 0; i < text_ptr.text_length; i++) - if (text_ptr.text[i] & 0x80) { - is_ascii = FALSE; - break; - } - - if (is_ascii) { - *value = g_strdup (text_ptr.text); - } else { - *value = g_convert (text_ptr.text, -1, - "UTF-8", "ISO-8859-1", - NULL, NULL, NULL); - } - - if (*value) { - *key = g_strconcat ("tEXt::", text_ptr.key, NULL); - return TRUE; - } else { - g_warning ("Couldn't convert text chunk value to UTF-8."); - *key = NULL; - return FALSE; - } -} - -static png_voidp -png_malloc_callback (png_structp o, png_size_t size) -{ - return g_try_malloc (size); -} - -static void -png_free_callback (png_structp o, png_voidp x) -{ - g_free (x); -} - -/* Shared library entry point */ -static GdkPixbuf * -gdk_pixbuf__png_image_load (FILE *f, GError **error) -{ - GdkPixbuf * volatile pixbuf = NULL; - png_structp png_ptr; - png_infop info_ptr; - png_textp text_ptr; - gint i, ctype; - png_uint_32 w, h; - png_bytepp volatile rows = NULL; - gint num_texts; - gchar *key; - gchar *value; - gchar *icc_profile_base64; - const gchar *icc_profile_title; - const gchar *icc_profile; - png_uint_32 icc_profile_size; - guint32 retval; - gint compression_type; - -#ifdef PNG_USER_MEM_SUPPORTED - png_ptr = png_create_read_struct_2 (PNG_LIBPNG_VER_STRING, - error, - png_simple_error_callback, - png_simple_warning_callback, - NULL, - png_malloc_callback, - png_free_callback); -#else - png_ptr = png_create_read_struct (PNG_LIBPNG_VER_STRING, - error, - png_simple_error_callback, - png_simple_warning_callback); -#endif - if (!png_ptr) - return NULL; - - info_ptr = png_create_info_struct (png_ptr); - if (!info_ptr) { - png_destroy_read_struct (&png_ptr, NULL, NULL); - return NULL; - } - - if (setjmp (png_ptr->jmpbuf)) { - g_free (rows); - - if (pixbuf) - g_object_unref (pixbuf); - - png_destroy_read_struct (&png_ptr, &info_ptr, NULL); - return NULL; - } - - png_init_io (png_ptr, f); - png_read_info (png_ptr, info_ptr); - - if (!setup_png_transformations(png_ptr, info_ptr, error, &w, &h, &ctype)) { - png_destroy_read_struct (&png_ptr, &info_ptr, NULL); - return NULL; - } - - pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, ctype & PNG_COLOR_MASK_ALPHA, 8, w, h); - - if (!pixbuf) { - if (error && *error == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to load PNG file")); - } - - - png_destroy_read_struct (&png_ptr, &info_ptr, NULL); - return NULL; - } - - rows = g_new (png_bytep, h); - - for (i = 0; i < h; i++) - rows[i] = pixbuf->pixels + i * pixbuf->rowstride; - - png_read_image (png_ptr, rows); - png_read_end (png_ptr, info_ptr); - - if (png_get_text (png_ptr, info_ptr, &text_ptr, &num_texts)) { - for (i = 0; i < num_texts; i++) { - png_text_to_pixbuf_option (text_ptr[i], &key, &value); - gdk_pixbuf_set_option (pixbuf, key, value); - g_free (key); - g_free (value); - } - } - -#if defined(PNG_cHRM_SUPPORTED) - /* Extract embedded ICC profile */ - retval = png_get_iCCP (png_ptr, info_ptr, - (png_charpp) &icc_profile_title, &compression_type, - (png_charpp) &icc_profile, (png_uint_32*) &icc_profile_size); - if (retval != 0) { - icc_profile_base64 = g_base64_encode ((const guchar *) icc_profile, (gsize)icc_profile_size); - gdk_pixbuf_set_option (pixbuf, "icc-profile", icc_profile_base64); - g_free (icc_profile_base64); - } -#endif - - g_free (rows); - png_destroy_read_struct (&png_ptr, &info_ptr, NULL); - - return pixbuf; -} - -/* I wish these avoided the setjmp()/longjmp() crap in libpng instead - just allow you to change the error reporting. */ -static void png_error_callback (png_structp png_read_ptr, - png_const_charp error_msg); - -static void png_warning_callback (png_structp png_read_ptr, - png_const_charp warning_msg); - -/* Called at the start of the progressive load */ -static void png_info_callback (png_structp png_read_ptr, - png_infop png_info_ptr); - -/* Called for each row; note that you will get duplicate row numbers - for interlaced PNGs */ -static void png_row_callback (png_structp png_read_ptr, - png_bytep new_row, - png_uint_32 row_num, - int pass_num); - -/* Called after reading the entire image */ -static void png_end_callback (png_structp png_read_ptr, - png_infop png_info_ptr); - -typedef struct _LoadContext LoadContext; - -struct _LoadContext { - png_structp png_read_ptr; - png_infop png_info_ptr; - - GdkPixbufModuleSizeFunc size_func; - GdkPixbufModulePreparedFunc prepare_func; - GdkPixbufModuleUpdatedFunc update_func; - gpointer notify_user_data; - - GdkPixbuf* pixbuf; - - /* row number of first row seen, or -1 if none yet seen */ - - gint first_row_seen_in_chunk; - - /* pass number for the first row seen */ - - gint first_pass_seen_in_chunk; - - /* row number of last row seen */ - gint last_row_seen_in_chunk; - - gint last_pass_seen_in_chunk; - - /* highest row number seen */ - gint max_row_seen_in_chunk; - - guint fatal_error_occurred : 1; - - GError **error; -}; - -static gpointer -gdk_pixbuf__png_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepare_func, - GdkPixbufModuleUpdatedFunc update_func, - gpointer user_data, - GError **error) -{ - LoadContext* lc; - - lc = g_new0(LoadContext, 1); - - lc->fatal_error_occurred = FALSE; - - lc->size_func = size_func; - lc->prepare_func = prepare_func; - lc->update_func = update_func; - lc->notify_user_data = user_data; - - lc->first_row_seen_in_chunk = -1; - lc->last_row_seen_in_chunk = -1; - lc->first_pass_seen_in_chunk = -1; - lc->last_pass_seen_in_chunk = -1; - lc->max_row_seen_in_chunk = -1; - lc->error = error; - - /* Create the main PNG context struct */ - -#ifdef PNG_USER_MEM_SUPPORTED - lc->png_read_ptr = png_create_read_struct_2 (PNG_LIBPNG_VER_STRING, - lc, /* error/warning callback data */ - png_error_callback, - png_warning_callback, - NULL, - png_malloc_callback, - png_free_callback); -#else - lc->png_read_ptr = png_create_read_struct(PNG_LIBPNG_VER_STRING, - lc, /* error/warning callback data */ - png_error_callback, - png_warning_callback); -#endif - if (lc->png_read_ptr == NULL) { - g_free(lc); - /* error callback should have set the error */ - return NULL; - } - - if (setjmp (lc->png_read_ptr->jmpbuf)) { - if (lc->png_info_ptr) - png_destroy_read_struct(&lc->png_read_ptr, NULL, NULL); - g_free(lc); - /* error callback should have set the error */ - return NULL; - } - - /* Create the auxiliary context struct */ - - lc->png_info_ptr = png_create_info_struct(lc->png_read_ptr); - - if (lc->png_info_ptr == NULL) { - png_destroy_read_struct(&lc->png_read_ptr, NULL, NULL); - g_free(lc); - /* error callback should have set the error */ - return NULL; - } - - png_set_progressive_read_fn(lc->png_read_ptr, - lc, /* callback data */ - png_info_callback, - png_row_callback, - png_end_callback); - - - /* We don't want to keep modifying error after returning here, - * it may no longer be valid. - */ - lc->error = NULL; - - return lc; -} - -static gboolean -gdk_pixbuf__png_image_stop_load (gpointer context, GError **error) -{ - LoadContext* lc = context; - - g_return_val_if_fail(lc != NULL, TRUE); - - /* FIXME this thing needs to report errors if - * we have unused image data - */ - - if (lc->pixbuf) - g_object_unref (lc->pixbuf); - - png_destroy_read_struct(&lc->png_read_ptr, &lc->png_info_ptr, NULL); - g_free(lc); - - return TRUE; -} - -static gboolean -gdk_pixbuf__png_image_load_increment(gpointer context, - const guchar *buf, guint size, - GError **error) -{ - LoadContext* lc = context; - - g_return_val_if_fail(lc != NULL, FALSE); - - /* reset */ - lc->first_row_seen_in_chunk = -1; - lc->last_row_seen_in_chunk = -1; - lc->first_pass_seen_in_chunk = -1; - lc->last_pass_seen_in_chunk = -1; - lc->max_row_seen_in_chunk = -1; - lc->error = error; - - /* Invokes our callbacks as needed */ - if (setjmp (lc->png_read_ptr->jmpbuf)) { - lc->error = NULL; - return FALSE; - } else { - png_process_data(lc->png_read_ptr, lc->png_info_ptr, - (guchar*) buf, size); - } - - if (lc->fatal_error_occurred) { - lc->error = NULL; - return FALSE; - } else { - if (lc->first_row_seen_in_chunk >= 0 && lc->update_func) { - /* We saw at least one row */ - gint pass_diff = lc->last_pass_seen_in_chunk - lc->first_pass_seen_in_chunk; - - g_assert(pass_diff >= 0); - - if (pass_diff == 0) { - /* start and end row were in the same pass */ - (lc->update_func)(lc->pixbuf, 0, - lc->first_row_seen_in_chunk, - lc->pixbuf->width, - (lc->last_row_seen_in_chunk - - lc->first_row_seen_in_chunk) + 1, - lc->notify_user_data); - } else if (pass_diff == 1) { - /* We have from the first row seen to - the end of the image (max row - seen), then from the top of the - image to the last row seen */ - /* first row to end */ - (lc->update_func)(lc->pixbuf, 0, - lc->first_row_seen_in_chunk, - lc->pixbuf->width, - (lc->max_row_seen_in_chunk - - lc->first_row_seen_in_chunk) + 1, - lc->notify_user_data); - /* top to last row */ - (lc->update_func)(lc->pixbuf, - 0, 0, - lc->pixbuf->width, - lc->last_row_seen_in_chunk + 1, - lc->notify_user_data); - } else { - /* We made at least one entire pass, so update the - whole image */ - (lc->update_func)(lc->pixbuf, - 0, 0, - lc->pixbuf->width, - lc->max_row_seen_in_chunk + 1, - lc->notify_user_data); - } - } - - lc->error = NULL; - - return TRUE; - } -} - -/* Called at the start of the progressive load, once we have image info */ -static void -png_info_callback (png_structp png_read_ptr, - png_infop png_info_ptr) -{ - LoadContext* lc; - png_uint_32 width, height; - png_textp png_text_ptr; - int i, num_texts; - int color_type; - gboolean have_alpha = FALSE; - gchar *icc_profile_base64; - const gchar *icc_profile_title; - const gchar *icc_profile; - png_uint_32 icc_profile_size; - guint32 retval; - gint compression_type; - - lc = png_get_progressive_ptr(png_read_ptr); - - if (lc->fatal_error_occurred) - return; - - if (!setup_png_transformations(lc->png_read_ptr, - lc->png_info_ptr, - lc->error, - &width, &height, &color_type)) { - lc->fatal_error_occurred = TRUE; - return; - } - - /* If we have alpha, set a flag */ - if (color_type & PNG_COLOR_MASK_ALPHA) - have_alpha = TRUE; - - if (lc->size_func) { - gint w = width; - gint h = height; - (* lc->size_func) (&w, &h, lc->notify_user_data); - - if (w == 0 || h == 0) { - lc->fatal_error_occurred = TRUE; - if (lc->error && *lc->error == NULL) { - g_set_error_literal (lc->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Transformed PNG has zero width or height.")); - } - return; - } - } - - lc->pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, have_alpha, 8, width, height); - - if (lc->pixbuf == NULL) { - /* Failed to allocate memory */ - lc->fatal_error_occurred = TRUE; - if (lc->error && *lc->error == NULL) { - g_set_error (lc->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to store a %ld by %ld image; try exiting some applications to reduce memory usage"), - width, height); - } - return; - } - - /* Extract text chunks and attach them as pixbuf options */ - - if (png_get_text (png_read_ptr, png_info_ptr, &png_text_ptr, &num_texts)) { - for (i = 0; i < num_texts; i++) { - gchar *key, *value; - - if (png_text_to_pixbuf_option (png_text_ptr[i], - &key, &value)) { - gdk_pixbuf_set_option (lc->pixbuf, key, value); - g_free (key); - g_free (value); - } - } - } - -#if defined(PNG_cHRM_SUPPORTED) - /* Extract embedded ICC profile */ - retval = png_get_iCCP (png_read_ptr, png_info_ptr, - (png_charpp) &icc_profile_title, &compression_type, - (png_charpp) &icc_profile, &icc_profile_size); - if (retval != 0) { - icc_profile_base64 = g_base64_encode ((const guchar *) icc_profile, (gsize)icc_profile_size); - gdk_pixbuf_set_option (lc->pixbuf, "icc-profile", icc_profile_base64); - g_free (icc_profile_base64); - } -#endif - - /* Notify the client that we are ready to go */ - - if (lc->prepare_func) - (* lc->prepare_func) (lc->pixbuf, NULL, lc->notify_user_data); - - return; -} - -/* Called for each row; note that you will get duplicate row numbers - for interlaced PNGs */ -static void -png_row_callback (png_structp png_read_ptr, - png_bytep new_row, - png_uint_32 row_num, - int pass_num) -{ - LoadContext* lc; - guchar* old_row = NULL; - - lc = png_get_progressive_ptr(png_read_ptr); - - if (lc->fatal_error_occurred) - return; - - if (row_num >= lc->pixbuf->height) { - lc->fatal_error_occurred = TRUE; - if (lc->error && *lc->error == NULL) { - g_set_error_literal (lc->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Fatal error reading PNG image file")); - } - return; - } - - if (lc->first_row_seen_in_chunk < 0) { - lc->first_row_seen_in_chunk = row_num; - lc->first_pass_seen_in_chunk = pass_num; - } - - lc->max_row_seen_in_chunk = MAX(lc->max_row_seen_in_chunk, ((gint)row_num)); - lc->last_row_seen_in_chunk = row_num; - lc->last_pass_seen_in_chunk = pass_num; - - old_row = lc->pixbuf->pixels + (row_num * lc->pixbuf->rowstride); - - png_progressive_combine_row(lc->png_read_ptr, old_row, new_row); -} - -/* Called after reading the entire image */ -static void -png_end_callback (png_structp png_read_ptr, - png_infop png_info_ptr) -{ - LoadContext* lc; - - lc = png_get_progressive_ptr(png_read_ptr); - - if (lc->fatal_error_occurred) - return; -} - -static void -png_error_callback(png_structp png_read_ptr, - png_const_charp error_msg) -{ - LoadContext* lc; - - lc = png_get_error_ptr(png_read_ptr); - - lc->fatal_error_occurred = TRUE; - - /* I don't trust libpng to call the error callback only once, - * so check for already-set error - */ - if (lc->error && *lc->error == NULL) { - g_set_error (lc->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Fatal error reading PNG image file: %s"), - error_msg); - } - - longjmp (png_read_ptr->jmpbuf, 1); -} - -static void -png_warning_callback (png_structp png_read_ptr, - png_const_charp warning_msg) -{ - LoadContext* lc; - - lc = png_get_error_ptr(png_read_ptr); - - /* Don't print anything; we should not be dumping junk to - * stderr, since that may be bad for some apps. If it's - * important enough to display, we need to add a GError - * **warning return location wherever we have an error return - * location. - */ -} - - -/* Save */ - -typedef struct { - GdkPixbufSaveFunc save_func; - gpointer user_data; - GError **error; -} SaveToFunctionIoPtr; - -static void -png_save_to_callback_write_func (png_structp png_ptr, - png_bytep data, - png_size_t length) -{ - SaveToFunctionIoPtr *ioptr = png_get_io_ptr (png_ptr); - - if (!ioptr->save_func ((gchar *)data, length, ioptr->error, ioptr->user_data)) { - /* If save_func has already set an error, which it - should have done, this won't overwrite it. */ - png_error (png_ptr, "write function failed"); - } -} - -static void -png_save_to_callback_flush_func (png_structp png_ptr) -{ - ; -} - -static gboolean real_save_png (GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error, - gboolean to_callback, - FILE *f, - GdkPixbufSaveFunc save_func, - gpointer user_data) -{ - png_structp png_ptr = NULL; - png_infop info_ptr; - png_textp text_ptr = NULL; - guchar *ptr; - guchar *pixels; - int y; - int i; - png_bytep row_ptr; - png_color_8 sig_bit; - int w, h, rowstride; - int has_alpha; - int bpc; - int num_keys; - int compression = -1; - gboolean success = TRUE; - guchar *icc_profile = NULL; - gsize icc_profile_size = 0; - SaveToFunctionIoPtr to_callback_ioptr; - - num_keys = 0; - - if (keys && *keys) { - gchar **kiter = keys; - gchar **viter = values; - - while (*kiter) { - if (strncmp (*kiter, "tEXt::", 6) == 0) { - gchar *key = *kiter + 6; - int len = strlen (key); - if (len <= 1 || len > 79) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("Keys for PNG text chunks must have at least 1 and at most 79 characters.")); - success = FALSE; - goto cleanup; - } - for (i = 0; i < len; i++) { - if ((guchar) key[i] > 127) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("Keys for PNG text chunks must be ASCII characters.")); - success = FALSE; - goto cleanup; - } - } - num_keys++; - } else if (strcmp (*kiter, "icc-profile") == 0) { - /* decode from base64 */ - icc_profile = g_base64_decode (*viter, &icc_profile_size); - if (icc_profile_size < 127) { - /* This is a user-visible error */ - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("Color profile has invalid length %d."), - (gint)icc_profile_size); - success = FALSE; - goto cleanup; - } - } else if (strcmp (*kiter, "compression") == 0) { - char *endptr = NULL; - compression = strtol (*viter, &endptr, 10); - - if (endptr == *viter) { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("PNG compression level must be a value between 0 and 9; value '%s' could not be parsed."), - *viter); - success = FALSE; - goto cleanup; - } - if (compression < 0 || compression > 9) { - /* This is a user-visible error; - * lets people skip the range-checking - * in their app. - */ - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("PNG compression level must be a value between 0 and 9; value '%d' is not allowed."), - compression); - success = FALSE; - goto cleanup; - } - } else { - g_warning ("Unrecognized parameter (%s) passed to PNG saver.", *kiter); - } - - ++kiter; - ++viter; - } - } - - if (num_keys > 0) { - text_ptr = g_new0 (png_text, num_keys); - for (i = 0; i < num_keys; i++) { - text_ptr[i].compression = PNG_TEXT_COMPRESSION_NONE; - text_ptr[i].key = keys[i] + 6; - text_ptr[i].text = g_convert (values[i], -1, - "ISO-8859-1", "UTF-8", - NULL, &text_ptr[i].text_length, - NULL); - -#ifdef PNG_iTXt_SUPPORTED - if (!text_ptr[i].text) { - text_ptr[i].compression = PNG_ITXT_COMPRESSION_NONE; - text_ptr[i].text = g_strdup (values[i]); - text_ptr[i].text_length = 0; - text_ptr[i].itxt_length = strlen (text_ptr[i].text); - text_ptr[i].lang = NULL; - text_ptr[i].lang_key = NULL; - } -#endif - - if (!text_ptr[i].text) { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("Value for PNG text chunk %s cannot be converted to ISO-8859-1 encoding."), keys[i] + 6); - num_keys = i; - for (i = 0; i < num_keys; i++) - g_free (text_ptr[i].text); - g_free (text_ptr); - return FALSE; - } - } - } - - bpc = gdk_pixbuf_get_bits_per_sample (pixbuf); - w = gdk_pixbuf_get_width (pixbuf); - h = gdk_pixbuf_get_height (pixbuf); - rowstride = gdk_pixbuf_get_rowstride (pixbuf); - has_alpha = gdk_pixbuf_get_has_alpha (pixbuf); - pixels = gdk_pixbuf_get_pixels (pixbuf); - - png_ptr = png_create_write_struct (PNG_LIBPNG_VER_STRING, - error, - png_simple_error_callback, - png_simple_warning_callback); - if (png_ptr == NULL) { - success = FALSE; - goto cleanup; - } - - info_ptr = png_create_info_struct (png_ptr); - if (info_ptr == NULL) { - success = FALSE; - goto cleanup; - } - if (setjmp (png_ptr->jmpbuf)) { - success = FALSE; - goto cleanup; - } - - if (num_keys > 0) { - png_set_text (png_ptr, info_ptr, text_ptr, num_keys); - } - - if (to_callback) { - to_callback_ioptr.save_func = save_func; - to_callback_ioptr.user_data = user_data; - to_callback_ioptr.error = error; - png_set_write_fn (png_ptr, &to_callback_ioptr, - png_save_to_callback_write_func, - png_save_to_callback_flush_func); - } else { - png_init_io (png_ptr, f); - } - - if (compression >= 0) - png_set_compression_level (png_ptr, compression); - -#if defined(PNG_iCCP_SUPPORTED) - /* the proper ICC profile title is encoded in the profile */ - if (icc_profile != NULL) { - png_set_iCCP (png_ptr, info_ptr, - "ICC profile", PNG_COMPRESSION_TYPE_BASE, - (gchar*) icc_profile, icc_profile_size); - } -#endif - - if (has_alpha) { - png_set_IHDR (png_ptr, info_ptr, w, h, bpc, - PNG_COLOR_TYPE_RGB_ALPHA, PNG_INTERLACE_NONE, - PNG_COMPRESSION_TYPE_BASE, PNG_FILTER_TYPE_BASE); - } else { - png_set_IHDR (png_ptr, info_ptr, w, h, bpc, - PNG_COLOR_TYPE_RGB, PNG_INTERLACE_NONE, - PNG_COMPRESSION_TYPE_BASE, PNG_FILTER_TYPE_BASE); - } - sig_bit.red = bpc; - sig_bit.green = bpc; - sig_bit.blue = bpc; - sig_bit.alpha = bpc; - png_set_sBIT (png_ptr, info_ptr, &sig_bit); - png_write_info (png_ptr, info_ptr); - png_set_shift (png_ptr, &sig_bit); - png_set_packing (png_ptr); - - ptr = pixels; - for (y = 0; y < h; y++) { - row_ptr = (png_bytep)ptr; - png_write_rows (png_ptr, &row_ptr, 1); - ptr += rowstride; - } - - png_write_end (png_ptr, info_ptr); - -cleanup: - if (png_ptr != NULL) - png_destroy_write_struct (&png_ptr, &info_ptr); - - g_free (icc_profile); - - if (text_ptr != NULL) { - for (i = 0; i < num_keys; i++) - g_free (text_ptr[i].text); - g_free (text_ptr); - } - - return success; -} - -static gboolean -gdk_pixbuf__png_image_save (FILE *f, - GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error) -{ - return real_save_png (pixbuf, keys, values, error, - FALSE, f, NULL, NULL); -} - -static gboolean -gdk_pixbuf__png_image_save_to_callback (GdkPixbufSaveFunc save_func, - gpointer user_data, - GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error) -{ - return real_save_png (pixbuf, keys, values, error, - TRUE, NULL, save_func, user_data); -} - -#ifndef INCLUDE_png -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__png_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->load = gdk_pixbuf__png_image_load; - module->begin_load = gdk_pixbuf__png_image_begin_load; - module->stop_load = gdk_pixbuf__png_image_stop_load; - module->load_increment = gdk_pixbuf__png_image_load_increment; - module->save = gdk_pixbuf__png_image_save; - module->save_to_callback = gdk_pixbuf__png_image_save_to_callback; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "\x89PNG\r\n\x1a\x0a", NULL, 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/png", - NULL - }; - static gchar * extensions[] = { - "png", - NULL - }; - - info->name = "png"; - info->signature = signature; - info->description = N_("The PNG image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_WRITABLE | GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-pnm.c b/gdk-pixbuf/io-pnm.c deleted file mode 100644 index f86826e678..0000000000 --- a/gdk-pixbuf/io-pnm.c +++ /dev/null @@ -1,1086 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - PNM image loader - * - * Copyright (C) 1999 Red Hat, Inc. - * - * Authors: Jeffrey Stedfast <fejj@helixcode.com> - * Michael Fulbright <drmike@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <setjmp.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - - -#define PNM_BUF_SIZE 4096 - -#define PNM_FATAL_ERR -1 -#define PNM_SUSPEND 0 -#define PNM_OK 1 - -typedef enum { - PNM_FORMAT_PGM = 1, - PNM_FORMAT_PGM_RAW, - PNM_FORMAT_PPM, - PNM_FORMAT_PPM_RAW, - PNM_FORMAT_PBM, - PNM_FORMAT_PBM_RAW -} PnmFormat; - -typedef struct { - guchar buffer[PNM_BUF_SIZE]; - guchar *byte; - guint nbytes; -} PnmIOBuffer; - -typedef struct { - GdkPixbufModuleUpdatedFunc updated_func; - GdkPixbufModulePreparedFunc prepared_func; - GdkPixbufModuleSizeFunc size_func; - gpointer user_data; - - GdkPixbuf *pixbuf; - guchar *pixels; /* incoming pixel data buffer */ - guchar *dptr; /* current position in pixbuf */ - - PnmIOBuffer inbuf; - - guint width; - guint height; - guint maxval; - guint rowstride; - PnmFormat type; - - guint output_row; /* last row to be completed */ - guint output_col; - gboolean did_prescan; /* are we in image data yet? */ - gboolean got_header; /* have we loaded pnm header? */ - - guint scan_state; - - GError **error; - -} PnmLoaderContext; - -static GdkPixbuf *gdk_pixbuf__pnm_image_load (FILE *f, GError **error); -static gpointer gdk_pixbuf__pnm_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc func, - GdkPixbufModuleUpdatedFunc func2, - gpointer user_data, - GError **error); -static gboolean gdk_pixbuf__pnm_image_stop_load (gpointer context, GError **error); -static gboolean gdk_pixbuf__pnm_image_load_increment (gpointer context, - const guchar *buf, guint size, - GError **error); - -static void explode_bitmap_into_buf (PnmLoaderContext *context); -static void explode_gray_into_buf (PnmLoaderContext *context); - - -/* explode bitmap data into rgb components */ -/* we need to know what the row so we can */ -/* do sub-byte expansion (since 1 byte = 8 pixels) */ -/* context->dptr MUST point at first byte in incoming data */ -/* which corresponds to first pixel of row y */ -static void -explode_bitmap_into_buf (PnmLoaderContext *context) -{ - gint j; - guchar *from, *to, data; - gint bit; - guchar *dptr; - gint wid, x; - - g_return_if_fail (context != NULL); - g_return_if_fail (context->dptr != NULL); - - /* I'm no clever bit-hacker so I'm sure this can be optimized */ - dptr = context->dptr; - wid = context->width; - - from = dptr + ((wid - 1) / 8); - to = dptr + (wid - 1) * 3; - bit = 7 - ((wid-1) % 8); - - /* get first byte and align properly */ - data = from[0]; - for (j = 0; j < bit; j++, data >>= 1); - - for (x = wid-1; x >= 0; x--) { -/* g_print ("%c", (data & 1) ? '*' : ' '); */ - - to[0] = to[1] = to[2] = (data & 0x01) ? 0x00 : 0xff; - - to -= 3; - bit++; - - if (bit > 7 && x > 0) { - from--; - data = from[0]; - bit = 0; - } else { - data >>= 1; - } - } - -/* g_print ("\n"); */ -} - -/* explode gray image row into rgb components in pixbuf */ -static void -explode_gray_into_buf (PnmLoaderContext *context) -{ - gint j; - guchar *from, *to; - guint w; - - g_return_if_fail (context != NULL); - g_return_if_fail (context->dptr != NULL); - - /* Expand grey->colour. Expand from the end of the - * memory down, so we can use the same buffer. - */ - w = context->width; - from = context->dptr + w - 1; - to = context->dptr + (w - 1) * 3; - for (j = w - 1; j >= 0; j--) { - to[0] = from[0]; - to[1] = from[0]; - to[2] = from[0]; - to -= 3; - from--; - } -} - -/* skip over whitespace and comments in input buffer */ -static gint -pnm_skip_whitespace (PnmIOBuffer *inbuf, GError **error) -{ - register guchar *inptr; - guchar *inend; - - g_return_val_if_fail (inbuf != NULL, PNM_FATAL_ERR); - g_return_val_if_fail (inbuf->byte != NULL, PNM_FATAL_ERR); - - inend = inbuf->byte + inbuf->nbytes; - inptr = inbuf->byte; - - for ( ; inptr < inend; inptr++) { - if (*inptr == '#') { - /* in comment - skip to the end of this line */ - for ( ; *inptr != '\n' && inptr < inend; inptr++) - ; - - if ( inptr == inend || *inptr != '\n' ) { - /* couldn't read whole comment */ - return PNM_SUSPEND; - } - - } else if (!g_ascii_isspace (*inptr)) { - inbuf->byte = inptr; - inbuf->nbytes = (guint) (inend - inptr); - return PNM_OK; - } - } - - inbuf->byte = inptr; - inbuf->nbytes = (guint) (inend - inptr); - - return PNM_SUSPEND; -} - -/* read next number from buffer */ -static gint -pnm_read_next_value (PnmIOBuffer *inbuf, gint max_length, guint *value, GError **error) -{ - register guchar *inptr, *word, *p; - guchar *inend, buf[129]; - gchar *endptr; - gint retval; - glong result; - - g_return_val_if_fail (inbuf != NULL, PNM_FATAL_ERR); - g_return_val_if_fail (inbuf->byte != NULL, PNM_FATAL_ERR); - g_return_val_if_fail (value != NULL, PNM_FATAL_ERR); - - if (max_length < 0) - max_length = 128; - - /* skip white space */ - if ((retval = pnm_skip_whitespace (inbuf, error)) != PNM_OK) - return retval; - - inend = inbuf->byte + inbuf->nbytes; - inptr = inbuf->byte; - - /* copy this pnm 'word' into a temp buffer */ - for (p = inptr, word = buf; (p < inend) && !g_ascii_isspace (*p) && (*p != '#') && (p - inptr < max_length); p++, word++) - *word = *p; - *word = '\0'; - - /* hmmm, there must be more data to this 'word' */ - if (p == inend || (!g_ascii_isspace (*p) && (*p != '#') && (p - inptr < max_length))) - return PNM_SUSPEND; - - /* get the value */ - result = strtol ((gchar *)buf, &endptr, 10); - if (*endptr != '\0' || result < 0 || result > G_MAXUINT) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("PNM loader expected to find an integer, but didn't")); - return PNM_FATAL_ERR; - } - *value = result; - - inbuf->byte = p; - inbuf->nbytes = (guint) (inend - p); - - return PNM_OK; -} - -/* returns PNM_OK, PNM_SUSPEND, or PNM_FATAL_ERR */ -static gint -pnm_read_header (PnmLoaderContext *context) -{ - PnmIOBuffer *inbuf; - gint retval; - - g_return_val_if_fail (context != NULL, PNM_FATAL_ERR); - - inbuf = &context->inbuf; - - if (!context->type) { - /* file must start with a 'P' followed by a numeral */ - /* so loop till we get enough data to determine type */ - if (inbuf->nbytes < 2) - return PNM_SUSPEND; - - if (*inbuf->byte != 'P') { - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("PNM file has an incorrect initial byte")); - return PNM_FATAL_ERR; - } - - inbuf->byte++; - inbuf->nbytes--; - - switch (*inbuf->byte) { - case '1': - context->type = PNM_FORMAT_PBM; - break; - case '2': - context->type = PNM_FORMAT_PGM; - break; - case '3': - context->type = PNM_FORMAT_PPM; - break; - case '4': - context->type = PNM_FORMAT_PBM_RAW; - break; - case '5': - context->type = PNM_FORMAT_PGM_RAW; - break; - case '6': - context->type = PNM_FORMAT_PPM_RAW; - break; - default: - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("PNM file is not in a recognized PNM subformat")); - return PNM_FATAL_ERR; - } - - if (!inbuf->nbytes) - return PNM_SUSPEND; - - inbuf->byte++; - inbuf->nbytes--; - } - - if (!context->width) { - /* read the pixmap width */ - guint width = 0; - - retval = pnm_read_next_value (inbuf, -1, &width, - context->error); - - if (retval != PNM_OK) - return retval; - - if (!width) { - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("PNM file has an image width of 0")); - return PNM_FATAL_ERR; - } - - context->width = width; - } - - if (!context->height) { - /* read the pixmap height */ - guint height = 0; - - retval = pnm_read_next_value (inbuf, -1, &height, - context->error); - - if (retval != PNM_OK) - return retval; - - if (!height) { - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("PNM file has an image height of 0")); - return PNM_FATAL_ERR; - } - - context->height = height; - } - - switch (context->type) { - case PNM_FORMAT_PPM: - case PNM_FORMAT_PPM_RAW: - case PNM_FORMAT_PGM: - case PNM_FORMAT_PGM_RAW: - if (!context->maxval) { - retval = pnm_read_next_value (inbuf, -1, &context->maxval, - context->error); - - if (retval != PNM_OK) - return retval; - - if (context->maxval == 0) { - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Maximum color value in PNM file is 0")); - return PNM_FATAL_ERR; - } - - if (context->maxval > 65535) { - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Maximum color value in PNM file is too large")); - return PNM_FATAL_ERR; - } - - } - break; - default: - break; - } - - return PNM_OK; -} - -static gint -pnm_read_raw_scanline (PnmLoaderContext *context) -{ - PnmIOBuffer *inbuf; - guint numbytes, offset; - guint numpix = 0; - guchar *dest; - guint i; - - g_return_val_if_fail (context != NULL, PNM_FATAL_ERR); - - inbuf = &context->inbuf; - - switch (context->type) { - case PNM_FORMAT_PBM_RAW: - numpix = inbuf->nbytes * 8; - break; - case PNM_FORMAT_PGM_RAW: - numpix = inbuf->nbytes; - break; - case PNM_FORMAT_PPM_RAW: - numpix = inbuf->nbytes / 3; - break; - default: - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Raw PNM image type is invalid")); - return PNM_FATAL_ERR; - } - if(context->maxval>255) - numpix/=2; - - numpix = MIN (numpix, context->width - context->output_col); - - if (!numpix) - return PNM_SUSPEND; - - context->dptr = context->pixels + context->output_row * context->rowstride; - - switch (context->type) { - case PNM_FORMAT_PBM_RAW: - numbytes = (numpix / 8) + ((numpix % 8) ? 1 : 0); - offset = context->output_col / 8; - break; - case PNM_FORMAT_PGM_RAW: - numbytes = numpix; - offset = context->output_col; - break; - case PNM_FORMAT_PPM_RAW: - numbytes = numpix * 3; - offset = context->output_col * 3; - break; - default: - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Raw PNM image type is invalid")); - return PNM_FATAL_ERR; - } - if(context->maxval>255) - numbytes*=2; - - switch (context->type) { - case PNM_FORMAT_PBM_RAW: - dest = context->dptr + offset; - memcpy (dest, inbuf->byte, numbytes); - break; - case PNM_FORMAT_PGM_RAW: - case PNM_FORMAT_PPM_RAW: - dest = context->dptr + offset; - - if (context->maxval == 255) { - /* special-case optimization */ - memcpy (dest, inbuf->byte, numbytes); - } else if(context->maxval == 65535) { - /* optimized version of the next case */ - for(i=0; i < numbytes ; i+=2) { - *dest++=inbuf->byte[i]; - } - } else if(context->maxval > 255) { - /* scale down to 256 colors */ - for(i=0; i < numbytes ; i+=2) { - guint v=inbuf->byte[i]*256+inbuf->byte[i+1]; - *dest++=v*255/context->maxval; - } - } else { - for (i = 0; i < numbytes; i++) { - guchar *byte = inbuf->byte + i; - - /* scale the color to an 8-bit color depth */ - if (*byte > context->maxval) - *dest++ = 255; - else - *dest++ = (guchar) (255 * *byte / context->maxval); - } - } - break; - default: - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Raw PNM image type is invalid")); - return PNM_FATAL_ERR; - } - - inbuf->byte += numbytes; - inbuf->nbytes -= numbytes; - - context->output_col += numpix; - if (context->output_col == context->width) { - if (context->type == PNM_FORMAT_PBM_RAW) - explode_bitmap_into_buf (context); - else if (context->type == PNM_FORMAT_PGM_RAW) - explode_gray_into_buf (context); - - context->output_col = 0; - context->output_row++; - } else { - return PNM_SUSPEND; - } - - return PNM_OK; -} - -static gint -pnm_read_ascii_mono_scanline (PnmLoaderContext *context) -{ - PnmIOBuffer *inbuf; - guint value; - gint retval; - guchar *dptr; - gint max_length; - - if (context->type == PNM_FORMAT_PBM) - max_length = 1; - else - max_length = -1; - - inbuf = &context->inbuf; - - context->dptr = context->pixels + context->output_row * context->rowstride; - - dptr = context->dptr + context->output_col * 3; - - while (TRUE) { - retval = pnm_read_next_value (inbuf, max_length, &value, context->error); - if (retval != PNM_OK) - return retval; - - if (context->type == PNM_FORMAT_PBM) { - value = value ? 0 : 0xff; - } - else { - /* scale the color up or down to an 8-bit color depth */ - if (value > context->maxval) - value = 255; - else - value = (guchar)(255 * value / context->maxval); - } - - *dptr++ = value; - *dptr++ = value; - *dptr++ = value; - - context->output_col++; - - if (context->output_col == context->width) { - context->output_col = 0; - context->output_row++; - break; - } - } - - return PNM_OK; -} - -static gint -pnm_read_ascii_color_scanline (PnmLoaderContext *context) -{ - PnmIOBuffer *inbuf; - guint value, i; - guchar *dptr; - gint retval; - - inbuf = &context->inbuf; - - context->dptr = context->pixels + context->output_row * context->rowstride; - - dptr = context->dptr + context->output_col * 3 + context->scan_state; - - while (TRUE) { - for (i = context->scan_state; i < 3; i++) { - retval = pnm_read_next_value (inbuf, -1, &value, context->error); - if (retval != PNM_OK) { - /* save state and return */ - context->scan_state = i; - return retval; - } - - if (value > context->maxval) - *dptr++ = 255; - else - *dptr++ = (guchar)(255 * value / context->maxval); - } - - context->scan_state = 0; - context->output_col++; - - if (context->output_col == context->width) { - context->output_col = 0; - context->output_row++; - break; - } - } - - return PNM_OK; -} - -/* returns 1 if a scanline was converted, 0 means we ran out of data */ -static gint -pnm_read_scanline (PnmLoaderContext *context) -{ - gint retval; - - g_return_val_if_fail (context != NULL, PNM_FATAL_ERR); - - /* read in image data */ - /* for raw formats this is trivial */ - switch (context->type) { - case PNM_FORMAT_PBM_RAW: - case PNM_FORMAT_PGM_RAW: - case PNM_FORMAT_PPM_RAW: - retval = pnm_read_raw_scanline (context); - if (retval != PNM_OK) - return retval; - break; - case PNM_FORMAT_PBM: - case PNM_FORMAT_PGM: - retval = pnm_read_ascii_mono_scanline (context); - if (retval != PNM_OK) - return retval; - break; - case PNM_FORMAT_PPM: - retval = pnm_read_ascii_color_scanline (context); - if (retval != PNM_OK) - return retval; - break; - default: - g_set_error_literal (context->error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("PNM image loader does not support this PNM subformat")); - - return PNM_FATAL_ERR; - } - - return PNM_OK; -} - -/* Shared library entry point */ -static GdkPixbuf * -gdk_pixbuf__pnm_image_load (FILE *f, GError **error) -{ - PnmLoaderContext context; - PnmIOBuffer *inbuf; - gint nbytes; - gint retval; - - /* pretend to be doing progressive loading */ - context.updated_func = NULL; - context.prepared_func = NULL; - context.user_data = NULL; - context.type = 0; - context.inbuf.nbytes = 0; - context.inbuf.byte = NULL; - context.width = 0; - context.height = 0; - context.maxval = 0; - context.pixels = NULL; - context.pixbuf = NULL; - context.got_header = FALSE; - context.did_prescan = FALSE; - context.scan_state = 0; - context.error = error; - - inbuf = &context.inbuf; - - while (TRUE) { - guint num_to_read; - - /* keep buffer as full as possible */ - num_to_read = PNM_BUF_SIZE - inbuf->nbytes; - - if (inbuf->byte != NULL && inbuf->nbytes > 0) - memmove (inbuf->buffer, inbuf->byte, inbuf->nbytes); - - nbytes = fread (inbuf->buffer + inbuf->nbytes, 1, num_to_read, f); - - /* error checking */ - if (nbytes == 0) { - /* we ran out of data? */ - if (context.pixbuf) - g_object_unref (context.pixbuf); - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Premature end-of-file encountered")); - return NULL; - } - - inbuf->nbytes += nbytes; - inbuf->byte = inbuf->buffer; - - /* get header if needed */ - if (!context.got_header) { - retval = pnm_read_header (&context); - if (retval == PNM_FATAL_ERR) - return NULL; - else if (retval == PNM_SUSPEND) - continue; - - context.got_header = TRUE; - } - - /* scan until we hit image data */ - if (!context.did_prescan) { - switch (context.type) { - case PNM_FORMAT_PBM_RAW: - case PNM_FORMAT_PGM_RAW: - case PNM_FORMAT_PPM_RAW: - if (inbuf->nbytes <= 0) - continue; - /* raw formats require exactly one whitespace */ - if (!g_ascii_isspace(*(inbuf->byte))) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Raw PNM formats require exactly one whitespace before sample data")); - return NULL; - } - inbuf->nbytes--; - inbuf->byte++; - break; - default: - retval = pnm_skip_whitespace (inbuf, - context.error); - if (retval == PNM_FATAL_ERR) - return NULL; - else if (retval == PNM_SUSPEND) - continue; - break; - } - context.did_prescan = TRUE; - context.output_row = 0; - context.output_col = 0; - - context.pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, FALSE, 8, - context.width, context.height); - - if (!context.pixbuf) { - /* Failed to allocate memory */ - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate memory for loading PNM image")); - return NULL; - } - - context.rowstride = context.pixbuf->rowstride; - context.pixels = context.pixbuf->pixels; - } - - /* if we got here we're reading image data */ - while (context.output_row < context.height) { - retval = pnm_read_scanline (&context); - - if (retval == PNM_SUSPEND) { - break; - } else if (retval == PNM_FATAL_ERR) { - if (context.pixbuf) - g_object_unref (context.pixbuf); - - return NULL; - } - } - - if (context.output_row < context.height) - continue; - else - break; - } - - return context.pixbuf; -} - -/* - * func - called when we have pixmap created (but no image data) - * user_data - passed as arg 1 to func - * return context (opaque to user) - */ - -static gpointer -gdk_pixbuf__pnm_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error) -{ - PnmLoaderContext *context; - - context = g_try_malloc (sizeof (PnmLoaderContext)); - if (!context) { - g_set_error_literal (error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to load PNM context struct")); - return NULL; - } - memset (context, 0, sizeof (PnmLoaderContext)); - context->size_func = size_func; - context->prepared_func = prepared_func; - context->updated_func = updated_func; - context->user_data = user_data; - context->width = 0; - context->height = 0; - context->maxval = 0; - context->pixbuf = NULL; - context->pixels = NULL; - context->got_header = FALSE; - context->did_prescan = FALSE; - context->scan_state = 0; - - context->inbuf.nbytes = 0; - context->inbuf.byte = NULL; - - context->error = error; - - return (gpointer) context; -} - -/* - * context - returned from image_begin_load - * - * free context, unref gdk_pixbuf - */ -static gboolean -gdk_pixbuf__pnm_image_stop_load (gpointer data, - GError **error) -{ - PnmLoaderContext *context = (PnmLoaderContext *) data; - gboolean retval = TRUE; - - g_return_val_if_fail (context != NULL, TRUE); - - if (context->pixbuf) - g_object_unref (context->pixbuf); - -#if 0 - /* We should ignore trailing newlines and we can't - generally complain about trailing stuff at all, since - pnm allows to put multiple images in a file - */ - if (context->inbuf.nbytes > 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Unexpected end of PNM image data")); - retval = FALSE; - } -#endif - - g_free (context); - - return retval; -} - -/* - * context - from image_begin_load - * buf - new image data - * size - length of new image data - * - * append image data onto inrecrementally built output image - */ -static gboolean -gdk_pixbuf__pnm_image_load_increment (gpointer data, - const guchar *buf, guint size, - GError **error) -{ - PnmLoaderContext *context = (PnmLoaderContext *)data; - PnmIOBuffer *inbuf; - const guchar *bufhd; - guint num_left, spinguard; - gint retval; - - g_return_val_if_fail (context != NULL, FALSE); - g_return_val_if_fail (buf != NULL, FALSE); - - context->error = error; - - bufhd = buf; - inbuf = &context->inbuf; - - num_left = size; - spinguard = 0; - while (TRUE) { - guint num_to_copy; - - /* keep buffer as full as possible */ - num_to_copy = MIN (PNM_BUF_SIZE - inbuf->nbytes, num_left); - - if (num_to_copy == 0) - spinguard++; - - if (spinguard > 1) - return TRUE; - - if (inbuf->byte != NULL && inbuf->nbytes > 0) - memmove (inbuf->buffer, inbuf->byte, inbuf->nbytes); - - memcpy (inbuf->buffer + inbuf->nbytes, bufhd, num_to_copy); - bufhd += num_to_copy; - inbuf->nbytes += num_to_copy; - inbuf->byte = inbuf->buffer; - num_left -= num_to_copy; - - /* ran out of data and we haven't exited main loop */ - if (inbuf->nbytes == 0) - return TRUE; - - /* get header if needed */ - if (!context->got_header) { - retval = pnm_read_header (context); - - if (retval == PNM_FATAL_ERR) - return FALSE; - else if (retval == PNM_SUSPEND) - continue; - - context->got_header = TRUE; - } - - if (context->size_func) { - gint w = context->width; - gint h = context->height; - (*context->size_func) (&w, &h, context->user_data); - - if (w == 0 || h == 0) - return FALSE; - } - - - /* scan until we hit image data */ - if (!context->did_prescan) { - switch (context->type) { - case PNM_FORMAT_PBM_RAW: - case PNM_FORMAT_PGM_RAW: - case PNM_FORMAT_PPM_RAW: - if (inbuf->nbytes <= 0) - continue; - /* raw formats require exactly one whitespace */ - if (!g_ascii_isspace(*(inbuf->byte))) - { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Raw PNM formats require exactly one whitespace before sample data")); - return FALSE; - } - inbuf->nbytes--; - inbuf->byte++; - break; - default: - retval = pnm_skip_whitespace (inbuf, - context->error); - if (retval == PNM_FATAL_ERR) - return FALSE; - else if (retval == PNM_SUSPEND) - continue; - break; - } - context->did_prescan = TRUE; - context->output_row = 0; - context->output_col = 0; - - context->pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, - FALSE, - 8, - context->width, - context->height); - - if (context->pixbuf == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to load PNM file")); - return FALSE; - } - - context->pixels = context->pixbuf->pixels; - context->rowstride = context->pixbuf->rowstride; - - /* Notify the client that we are ready to go */ - if (context->prepared_func) - (* context->prepared_func) (context->pixbuf, - NULL, - context->user_data); - } - - /* if we got here we're reading image data */ - while (context->output_row < context->height) { - retval = pnm_read_scanline (context); - - if (retval == PNM_SUSPEND) { - break; - } else if (retval == PNM_FATAL_ERR) { - return FALSE; - } else if (retval == PNM_OK && context->updated_func) { - /* send updated signal */ - (* context->updated_func) (context->pixbuf, - 0, - context->output_row-1, - context->width, - 1, - context->user_data); - } - } - - if (context->output_row < context->height) - continue; - else - break; - } - - return TRUE; -} - -#ifndef INCLUDE_pnm -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__pnm_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->load = gdk_pixbuf__pnm_image_load; - module->begin_load = gdk_pixbuf__pnm_image_begin_load; - module->stop_load = gdk_pixbuf__pnm_image_stop_load; - module->load_increment = gdk_pixbuf__pnm_image_load_increment; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "P1", NULL, 100 }, - { "P2", NULL, 100 }, - { "P3", NULL, 100 }, - { "P4", NULL, 100 }, - { "P5", NULL, 100 }, - { "P6", NULL, 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/x-portable-anymap", - "image/x-portable-bitmap", - "image/x-portable-graymap", - "image/x-portable-pixmap", - NULL - }; - static gchar * extensions[] = { - "pnm", - "pbm", - "pgm", - "ppm", - NULL - }; - - info->name = "pnm"; - info->signature = signature; - info->description = N_("The PNM/PBM/PGM/PPM image format family"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-qtif.c b/gdk-pixbuf/io-qtif.c deleted file mode 100644 index a1c57ba08e..0000000000 --- a/gdk-pixbuf/io-qtif.c +++ /dev/null @@ -1,608 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* GdkPixbuf library - QTIF image loader - * - * This module extracts image data from QTIF format and uses - * other GDK pixbuf modules to decode the image data. - * - * Copyright (C) 2008 Kevin Peng - * - * Authors: Kevin Peng <kevin@zycomtech.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - - -#include "config.h" -#include <errno.h> -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <setjmp.h> -#include "gdk-pixbuf.h" -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - -/*** - * Definitions - */ -/* Read buffer size */ -#define READ_BUFFER_SIZE 8192 - -/* Only allow atom of size up to 10MB. */ -#define ATOM_SIZE_MAX 100000000 - -/* Aborts after going to through this many atoms. */ -#define QTIF_ATOM_COUNT_MAX 10u - -/* QTIF static image data tag "idat". */ -#define QTIF_TAG_IDATA 0x69646174u - - -/*** - * Types - */ -/* QTIF State */ -typedef enum { - STATE_READY, - STATE_DATA, - STATE_OTHER -} QTIFState; - -/* QTIF Atom Header */ -typedef struct { - guint32 length; - guint32 tag; -} QtHeader; - -/* QTIF loader context */ -typedef struct { - GdkPixbufLoader *loader; - gpointer user_data; - QTIFState state; - guint32 run_length; - gint atom_count; - - guchar header_buffer[sizeof(QtHeader)]; - - GdkPixbufModuleSizeFunc size_func; - GdkPixbufModulePreparedFunc prepare_func; - GdkPixbufModuleUpdatedFunc update_func; - gint cb_prepare_count; - gint cb_update_count; -} QTIFContext; - -/*** - * Local function prototypes - */ -static GdkPixbuf *gdk_pixbuf__qtif_image_load (FILE *f, GError **error); -static gpointer gdk_pixbuf__qtif_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepare_func, - GdkPixbufModuleUpdatedFunc update_func, - gpointer user_data, - GError **error); -static gboolean gdk_pixbuf__qtif_image_stop_load (gpointer context, GError **error); -static gboolean gdk_pixbuf__qtif_image_load_increment(gpointer context, - const guchar *buf, guint size, - GError **error); -static gboolean gdk_pixbuf__qtif_image_create_loader (QTIFContext *context, GError **error); -static gboolean gdk_pixbuf__qtif_image_free_loader (QTIFContext *context, GError **error); - -static void gdk_pixbuf__qtif_cb_size_prepared(GdkPixbufLoader *loader, - gint width, - gint height, - gpointer user_data); -static void gdk_pixbuf__qtif_cb_area_prepared(GdkPixbufLoader *loader, gpointer user_data); -static void gdk_pixbuf__qtif_cb_area_updated(GdkPixbufLoader *loader, - gint x, - gint y, - gint width, - gint height, - gpointer user_data); - -/*** - * Function definitions. - */ - -/* Load QTIF from a file handler. */ -static GdkPixbuf *gdk_pixbuf__qtif_image_load (FILE *f, GError **error) -{ - guint count; - - if(f == NULL) - { - g_set_error_literal (error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("Input file descriptor is NULL.")); - return NULL; - } - - for(count = QTIF_ATOM_COUNT_MAX; count != 0u; count--) - { - QtHeader hdr; - size_t rd; - - /* Read QtHeader. */ - rd = fread(&hdr, 1, sizeof(QtHeader), f); - if(rd != sizeof(QtHeader)) - { - g_set_error_literal(error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Failed to read QTIF header")); - return NULL; - } - - hdr.length = GUINT32_FROM_BE(hdr.length) - sizeof(QtHeader); - if(hdr.length > ATOM_SIZE_MAX) - { - g_set_error(error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("QTIF atom size too large (%d bytes)"), hdr.length); - return NULL; - } - - switch(GUINT32_FROM_BE(hdr.tag)) - { - case QTIF_TAG_IDATA: /* "idat" data atom. */ - { - /* Load image using GdkPixbufLoader. */ - guchar *buf; - GdkPixbufLoader *loader; - GdkPixbuf *pixbuf = NULL; - GError *tmp = NULL; - - /* Allocate read buffer. */ - buf = g_try_malloc(READ_BUFFER_SIZE); - if(buf == NULL) - { - g_set_error(error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Failed to allocate %d bytes for file read buffer"), READ_BUFFER_SIZE); - return NULL; - } - - /* Create GdkPixbufLoader. */ - loader = gdk_pixbuf_loader_new(); - if(loader == NULL) - { - g_set_error(error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("QTIF atom size too large (%d bytes)"), hdr.length); - goto clean_up; - } - - /* Read atom data. */ - while(hdr.length != 0u) - { - rd = (hdr.length > READ_BUFFER_SIZE) ? READ_BUFFER_SIZE : hdr.length; - - rd = fread(buf, 1, rd, f); - if(rd < 0) - { - g_set_error(error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("File error when reading QTIF atom: %s"), g_strerror(errno)); - break; - } - - if(!gdk_pixbuf_loader_write(loader, buf, rd, &tmp)) - { - g_propagate_error (error, tmp); - break; - } - hdr.length -= rd; - } - -clean_up: - /* Release loader */ - if(loader != NULL) - { - gdk_pixbuf_loader_close(loader, NULL); - pixbuf = gdk_pixbuf_loader_get_pixbuf(loader); - if(pixbuf != NULL) - { - g_object_ref(pixbuf); - } - g_object_unref(loader); - } - if(buf != NULL) - { - g_free(buf); - } - return pixbuf; - } - - default: - /* Skip any other types of atom. */ - if(!fseek(f, hdr.length, SEEK_CUR)) - { - g_set_error(error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Failed to skip the next %d bytes with seek()."), hdr.length); - return NULL; - } - break; - } - } - return NULL; -} - -/* Incremental load begin. */ -static gpointer gdk_pixbuf__qtif_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepare_func, - GdkPixbufModuleUpdatedFunc update_func, - gpointer user_data, - GError **error) -{ - QTIFContext *context; - - /* Create context struct. */ - context = g_new0(QTIFContext, 1); - if(context == NULL) - { - g_set_error_literal (error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Failed to allocate QTIF context structure.")); - return NULL; - } - - /* Fill context parameters. */ - context->loader = NULL; - context->user_data = user_data; - context->state = STATE_READY; - context->run_length = 0u; - context->atom_count = QTIF_ATOM_COUNT_MAX; - context->size_func = size_func; - context->prepare_func = prepare_func; - context->update_func = update_func; - - return context; -} - -/* Incremental load clean up. */ -static gboolean gdk_pixbuf__qtif_image_stop_load (gpointer data, GError **error) -{ - QTIFContext *context = (QTIFContext *)data; - gboolean ret = TRUE; - - if(context->loader != NULL) - { - GError *tmp = NULL; - - ret = gdk_pixbuf__qtif_image_free_loader(context, &tmp); - if(!ret) - { - g_propagate_error (error, tmp); - } - } - g_free(context); - - return ret; -} - -/* Create a new GdkPixbufLoader and connect to its signals. */ -static gboolean gdk_pixbuf__qtif_image_create_loader (QTIFContext *context, GError **error) -{ - GError *tmp = NULL; - - if(context == NULL) - { - return FALSE; - } - - /* Free existing loader. */ - if(context->loader != NULL) - { - gdk_pixbuf__qtif_image_free_loader(context, &tmp); - } - - /* Create GdkPixbufLoader object. */ - context->loader = gdk_pixbuf_loader_new(); - if(context->loader == NULL) - { - g_set_error_literal (error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Failed to create GdkPixbufLoader object.")); - return FALSE; - } - - /* Connect signals. */ - context->cb_prepare_count = 0; - context->cb_update_count = 0; - if(context->size_func != NULL) - { - g_signal_connect(context->loader, "size-prepared", - G_CALLBACK(gdk_pixbuf__qtif_cb_size_prepared), - context); - } - if(context->prepare_func != NULL) - { - g_signal_connect(context->loader, "area-prepared", - G_CALLBACK(gdk_pixbuf__qtif_cb_area_prepared), - context); - } - if(context->update_func != NULL) - { - g_signal_connect(context->loader, "area-updated", - G_CALLBACK(gdk_pixbuf__qtif_cb_area_updated), - context); - } - return TRUE; -} - -/* Free the GdkPixbufLoader and perform callback if haven't done so. */ -static gboolean gdk_pixbuf__qtif_image_free_loader (QTIFContext *context, GError **error) -{ - GdkPixbuf *pixbuf; - GError *tmp = NULL; - gboolean ret; - - if((context == NULL) || (context->loader == NULL)) - { - return FALSE; - } - - /* Close GdkPixbufLoader. */ - ret = gdk_pixbuf_loader_close(context->loader, &tmp); - if(!ret) - { - g_propagate_error (error, tmp); - } - - - /* Get GdkPixbuf from GdkPixbufLoader. */ - pixbuf = gdk_pixbuf_loader_get_pixbuf(context->loader); - if(pixbuf != NULL) - { - g_object_ref(pixbuf); - } - - /* Free GdkPixbufLoader. */ - g_object_ref(context->loader); - context->loader = NULL; - - if(pixbuf != NULL) - { - /* Callback functions should be called for at least once. */ - if((context->prepare_func != NULL) && (context->cb_prepare_count == 0)) - { - (context->prepare_func)(pixbuf, NULL, context->user_data); - } - - if((context->update_func != NULL) && (context->cb_update_count == 0)) - { - gint width; - gint height; - - width = gdk_pixbuf_get_width(pixbuf); - height = gdk_pixbuf_get_height(pixbuf); - (context->update_func)(pixbuf, 0, 0, width, height, context->user_data); - } - - /* Free GdkPixbuf (callback function should ref it). */ - g_object_ref(pixbuf); - } - - return ret; -} - - -/* Incrementally load the next chunk of data. */ -static gboolean gdk_pixbuf__qtif_image_load_increment (gpointer data, - const guchar *buf, guint size, - GError **error) -{ - QTIFContext *context = (QTIFContext *)data; - GError *tmp = NULL; - gboolean ret = TRUE; /* Return TRUE for insufficient data. */ - - while(ret && (size != 0u)) - { - switch(context->state) - { - case STATE_READY: - /* Abort if we have seen too mant atoms. */ - if(context->atom_count == 0u) - { - g_set_error_literal (error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Failed to find an image data atom.")); - return FALSE; - } - context->atom_count--; - - /* Copy to header buffer in context, in case supplied data is not enough. */ - while(context->run_length < sizeof(QtHeader)) - { - context->header_buffer[context->run_length] = *buf; - context->run_length++; - buf++; - size--; - } - - /* Parse buffer as QT header. */ - if(context->run_length == sizeof(QtHeader)) - { - QtHeader *hdr = (QtHeader *)context->header_buffer; - context->run_length = GUINT32_FROM_BE(hdr->length) - sizeof(QtHeader); - - /* Atom max size check. */ - if(context->run_length > ATOM_SIZE_MAX) - { - g_set_error(error, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("QTIF atom size too large (%d bytes)"), hdr->length); - return FALSE; - } - - /* Set state according to atom type. */ - if(GUINT32_FROM_BE(hdr->tag) == QTIF_TAG_IDATA) - { - GError *tmp = NULL; - - context->state = STATE_DATA; - - /* Create GdkPixbufLoader for this image data. */ - ret = gdk_pixbuf__qtif_image_create_loader(context, &tmp); - if(!ret) - { - g_propagate_error (error, tmp); - } - } - else - { - context->state = STATE_OTHER; - } - } - break; - - default: /* Both STATE_DATA and STATE_OTHER will come here. */ - /* Check for atom boundary. */ - if(context->run_length > size) - { - /* Supply image data to GdkPixbufLoader if in STATE_DATA. */ - if(context->state == STATE_DATA) - { - tmp = NULL; - ret = gdk_pixbuf_loader_write(context->loader, buf, size, &tmp); - if(!ret && (error != NULL) && (*error == NULL)) - { - g_propagate_error (error, tmp); - } - } - context->run_length -= size; - size = 0u; - } - else - { - /* Supply image data to GdkPixbufLoader if in STATE_DATA. */ - if(context->state == STATE_DATA) - { - gboolean r; - - /* Here we should have concluded a complete image atom. */ - tmp = NULL; - ret = gdk_pixbuf_loader_write(context->loader, buf, context->run_length, &tmp); - if(!ret && (error != NULL) && (*error == NULL)) - { - g_propagate_error (error, tmp); - } - - /* Free GdkPixbufLoader and handle callback. */ - tmp = NULL; - r = gdk_pixbuf__qtif_image_free_loader(context, &tmp); - if(!r) - { - if((error != NULL) && (*error == NULL)) - { - g_propagate_error (error, tmp); - } - ret = FALSE; - } - } - buf = &buf[context->run_length]; - size -= context->run_length; - context->run_length = 0u; - context->state = STATE_READY; - } - break; - } - } - - return ret; -} - -/* Event handlers */ -static void gdk_pixbuf__qtif_cb_size_prepared(GdkPixbufLoader *loader, - gint width, - gint height, - gpointer user_data) -{ - QTIFContext *context = (QTIFContext *)user_data; - if((context != NULL) && (context->size_func != NULL)) - { - (context->size_func)(&width, &height, context->user_data); - context->cb_prepare_count++; - } -} - -static void gdk_pixbuf__qtif_cb_area_prepared(GdkPixbufLoader *loader, gpointer user_data) -{ - QTIFContext *context = (QTIFContext *)user_data; - if((loader != NULL) && (context != NULL) && (context->prepare_func != NULL)) - { - GdkPixbuf *pixbuf = gdk_pixbuf_loader_get_pixbuf(context->loader); - (context->prepare_func)(pixbuf, NULL, context->user_data); - context->cb_update_count++; - } -} - -static void gdk_pixbuf__qtif_cb_area_updated(GdkPixbufLoader *loader, - gint x, - gint y, - gint width, - gint height, - gpointer user_data) -{ - QTIFContext *context = (QTIFContext *)user_data; - if((loader != NULL) && (context != NULL) && (context->update_func != NULL)) - { - GdkPixbuf *pixbuf = gdk_pixbuf_loader_get_pixbuf(context->loader); - (context->update_func)(pixbuf, x, y, width, height, context->user_data); - } -} - - -#ifndef INCLUDE_qtif -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__qtif_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->load = gdk_pixbuf__qtif_image_load; - module->begin_load = gdk_pixbuf__qtif_image_begin_load; - module->stop_load = gdk_pixbuf__qtif_image_stop_load; - module->load_increment = gdk_pixbuf__qtif_image_load_increment; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "abcdidsc", "xxxx ", 100 }, - { "abcdidat", "xxxx ", 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/x-quicktime", - "image/qtif", - NULL - }; - static gchar * extensions[] = { - "qtif", - "qif", - NULL - }; - - info->name = "qtif"; - info->signature = signature; - info->description = N_("The QTIF image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} - diff --git a/gdk-pixbuf/io-ras.c b/gdk-pixbuf/io-ras.c deleted file mode 100644 index 2a5dae8964..0000000000 --- a/gdk-pixbuf/io-ras.c +++ /dev/null @@ -1,551 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* GdkPixbuf library - SUNRAS image loader - * - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Arjan van de Ven <arjan@fenrus.demon.nl> - * Federico Mena-Quintero <federico@gimp.org> - * - * Based on io-gif.c, io-tiff.c and io-png.c - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -/* - -Known bugs: - * Compressed rasterfiles don't work yet - -*/ - -#include "config.h" -#include <stdio.h> -#ifdef HAVE_UNISTD_H -#include <unistd.h> -#endif -#include <string.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - - - -/* - Header structure for sunras files. - All values are in big-endian order on disk - - Note: Every scanline is padded to be a multiple of 16 bits - */ - -struct rasterfile { - guint magic; - guint width; - guint height; - guint depth; - guint length; - guint type; - guint maptype; - guint maplength; -}; - -/* - This does a byte-order swap. Does glib have something like - be32_to_cpu() ?? -*/ - -/* Progressive loading */ - -struct ras_progressive_state { - GdkPixbufModuleSizeFunc size_func; - GdkPixbufModulePreparedFunc prepared_func; - GdkPixbufModuleUpdatedFunc updated_func; - gpointer user_data; - - gint HeaderSize; /* The size of the header-part (incl colormap) */ - guchar *HeaderBuf; /* The buffer for the header (incl colormap) */ - gint HeaderDone; /* The nr of bytes actually in HeaderBuf */ - - gint LineWidth; /* The width of a line in bytes */ - guchar *LineBuf; /* Buffer for 1 line */ - gint LineDone; /* # of bytes in LineBuf */ - gint Lines; /* # of finished lines */ - - gint RasType; /* 32 = BGRA - 24 = BGR - 8 = 8 bit colormapped - 1 = 1 bit bitonal - */ - gint DecoderState; - - struct rasterfile Header; /* Decoded (BE->CPU) header */ - - - GdkPixbuf *pixbuf; /* Our "target" */ -}; - -static gpointer -gdk_pixbuf__ras_image_begin_load(GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error); -static gboolean gdk_pixbuf__ras_image_stop_load(gpointer data, GError **error); -static gboolean gdk_pixbuf__ras_image_load_increment(gpointer data, - const guchar * buf, guint size, - GError **error); - -static gboolean RAS2State(struct rasterfile *RAS, - struct ras_progressive_state *State, - GError **error) -{ - State->Header.width = GUINT32_FROM_BE(RAS->width); - State->Header.height = GUINT32_FROM_BE(RAS->height); - State->Header.depth = GUINT32_FROM_BE(RAS->depth); - State->Header.type = GUINT32_FROM_BE(RAS->type); - State->Header.maptype = GUINT32_FROM_BE(RAS->maptype); - State->Header.maplength = GUINT32_FROM_BE(RAS->maplength); - - if ((gint)State->Header.width <= 0 || - (gint)State->Header.height <= 0 || - State->Header.maplength > 768) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("RAS image has bogus header data")); - return FALSE; - } - - State->RasType = State->Header.depth; /* This may be less trivial someday */ - State->HeaderSize = 32 + State->Header.maplength; - - if (State->RasType == 32) - State->LineWidth = State->Header.width * 4; - else if (State->RasType == 24) - State->LineWidth = State->Header.width * 3; - else if (State->RasType == 8) - State->LineWidth = State->Header.width * 1; - else if (State->RasType == 1) { - State->LineWidth = State->Header.width / 8; - if ((State->Header.width & 7) != 0) - State->LineWidth++; - } - else { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("RAS image has unknown type")); - return FALSE; - } - - if (State->Header.type > 2 || State->Header.maptype > 1) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("unsupported RAS image variation")); - return FALSE; - } - - /* Now pad the line to be a multiple of 16 bits */ - if ((State->LineWidth & 1) != 0) - State->LineWidth++; - - if (!State->LineBuf) { - State->LineBuf = g_try_malloc (State->LineWidth); - - if (!State->LineBuf) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load RAS image")); - return FALSE; - } - } - - - if (!State->pixbuf) { - if (State->size_func) { - gint width = State->Header.width; - gint height = State->Header.height; - - (*State->size_func) (&width, &height, State->user_data); - if (width == 0 || height == 0) - return FALSE; - } - - if (State->RasType == 32) - State->pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, TRUE, 8, - (gint) State->Header.width, - (gint) State->Header.height); - else - State->pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, FALSE, 8, - (gint) State->Header.width, - (gint) State->Header.height); - - if (!State->pixbuf) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load RAS image")); - return FALSE; - } - - if (State->prepared_func != NULL) - /* Notify the client that we are ready to go */ - (*State->prepared_func) (State->pixbuf, - NULL, - State->user_data); - - } - - if ((State->Header.maplength == 0) && (State->RasType == 1)) { - State->HeaderBuf[32] = 255; - State->HeaderBuf[33] = 0; - State->HeaderBuf[34] = 255; - State->HeaderBuf[35] = 0; - State->HeaderBuf[36] = 255; - State->HeaderBuf[37] = 0; - } - - return TRUE; -} - -/* - * func - called when we have pixmap created (but no image data) - * user_data - passed as arg 1 to func - * return context (opaque to user) - */ - -static gpointer -gdk_pixbuf__ras_image_begin_load(GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error) -{ - struct ras_progressive_state *context; - - context = g_new0(struct ras_progressive_state, 1); - context->size_func = size_func; - context->prepared_func = prepared_func; - context->updated_func = updated_func; - context->user_data = user_data; - - context->HeaderSize = 32; - context->HeaderBuf = g_malloc(32 + 768); /* 32 for rasheader, - 768 for the colormap */ - context->HeaderDone = 0; - - context->LineWidth = 0; - context->LineBuf = NULL; - context->LineDone = 0; - context->Lines = 0; - - context->RasType = 0; - context->DecoderState = 0; - - memset(&context->Header, 0, sizeof(struct rasterfile)); - - - context->pixbuf = NULL; - - - return (gpointer) context; -} - -/* - * context - returned from image_begin_load - * - * free context, unref gdk_pixbuf - */ -static gboolean -gdk_pixbuf__ras_image_stop_load(gpointer data, GError **error) -{ - struct ras_progressive_state *context = - (struct ras_progressive_state *) data; - - /* FIXME this thing needs to report errors if - * we have unused image data - */ - - g_return_val_if_fail(context != NULL, TRUE); - - g_free(context->LineBuf); - g_free(context->HeaderBuf); - - if (context->pixbuf) - g_object_unref(context->pixbuf); - - g_free(context); - - return TRUE; -} - -/* - OneLine is called when enough data is received to process 1 line - of pixels - */ - -static void OneLine32(struct ras_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - Pixels = context->pixbuf->pixels + context->pixbuf->rowstride * context->Lines; - while (X < context->Header.width) { - /* The joys of having a BGR byteorder */ - Pixels[X * 4 + 0] = context->LineBuf[X * 4 + 2]; - Pixels[X * 4 + 1] = context->LineBuf[X * 4 + 1]; - Pixels[X * 4 + 2] = context->LineBuf[X * 4 + 0]; - Pixels[X * 4 + 3] = context->LineBuf[X * 4 + 3]; - X++; - } -} - -static void OneLine24(struct ras_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - Pixels = context->pixbuf->pixels + context->pixbuf->rowstride * context->Lines; - while (X < context->Header.width) { - /* The joys of having a BGR byteorder */ - Pixels[X * 3 + 0] = context->LineBuf[X * 3 + 2]; - Pixels[X * 3 + 1] = context->LineBuf[X * 3 + 1]; - Pixels[X * 3 + 2] = context->LineBuf[X * 3 + 0]; - X++; - } - -} - -static void OneLine8(struct ras_progressive_state *context) -{ - gint X; - guchar *Pixels; - int offset = context->Header.maplength / 3; - - X = 0; - Pixels = context->pixbuf->pixels + context->pixbuf->rowstride * context->Lines; - while (X < context->Header.width) { - /* The joys of having a BGR byteorder */ - Pixels[X * 3 + 0] = - context->HeaderBuf[context->LineBuf[X] + 32]; - Pixels[X * 3 + 1] = - context->HeaderBuf[context->LineBuf[X] + offset + 32]; - Pixels[X * 3 + 2] = - context->HeaderBuf[context->LineBuf[X] + 2*offset + 32]; - X++; - } -} - -static void OneLine1(struct ras_progressive_state *context) -{ - gint X; - guchar *Pixels; - - X = 0; - Pixels = context->pixbuf->pixels + context->pixbuf->rowstride * context->Lines; - while (X < context->Header.width) { - int Bit; - - Bit = (context->LineBuf[X/8])>>(7-(X&7)); - Bit = Bit & 1; - /* The joys of having a BGR byteorder */ - Pixels[X * 3 + 0] = - context->HeaderBuf[Bit + 32]; - Pixels[X * 3 + 1] = - context->HeaderBuf[Bit + 2 + 32]; - Pixels[X * 3 + 2] = - context->HeaderBuf[Bit + 4 + 32]; - X++; - } -} - - -static void OneLine(struct ras_progressive_state *context) -{ - context->LineDone = 0; - if (context->Lines >= context->Header.height) - return; - if (context->RasType == 32) - OneLine32(context); - if (context->RasType == 24) - OneLine24(context); - if (context->RasType == 8) - OneLine8(context); - if (context->RasType == 1) - OneLine1(context); - - context->LineDone = 0; - context->Lines++; - - if (context->updated_func != NULL) { - (*context->updated_func) (context->pixbuf, - 0, - context->Lines, - context->Header.width, - 1, - context->user_data); - - } -} - -static gboolean -DoCompressed (struct ras_progressive_state *context, - const guchar * buf, guint size, - GError **error) -{ - int i; - - for (i = 0; i < size; i++) { - switch (context->DecoderState) { - case 0: - if (buf[i] == 0x80) - context->DecoderState = 1; - else - context->LineBuf[context->LineDone++] = buf[i]; - break; - case 1: - if (buf[i] == 0) { - context->LineBuf[context->LineDone++] = 0x80; - context->DecoderState = 0; - } - else - context->DecoderState = buf[i] + 1; - break; - default: - for (; context->DecoderState; context->DecoderState--) { - context->LineBuf[context->LineDone++] = buf[i]; - if ((context->LineDone >= context->LineWidth) && (context->LineWidth > 0)) - OneLine(context); - } - } - if ((context->LineDone >= context->LineWidth) && (context->LineWidth > 0)) - OneLine(context); - } - return TRUE; -} - -/* - * context - from image_begin_load - * buf - new image data - * size - length of new image data - * - * append image data onto incrementally built output image - */ -static gboolean -gdk_pixbuf__ras_image_load_increment(gpointer data, - const guchar * buf, guint size, - GError **error) -{ - struct ras_progressive_state *context = - (struct ras_progressive_state *) data; - - gint BytesToCopy; - - while (size > 0) { - if (context->HeaderDone < context->HeaderSize) { /* We still - have headerbytes to do */ - BytesToCopy = - context->HeaderSize - context->HeaderDone; - if (BytesToCopy > size) - BytesToCopy = size; - - memmove(context->HeaderBuf + context->HeaderDone, - buf, BytesToCopy); - - size -= BytesToCopy; - buf += BytesToCopy; - context->HeaderDone += BytesToCopy; - - } else if (context->Header.type == 2) { - if (!DoCompressed (context, buf, size, error)) { - return FALSE; - } - size = 0; - } - else { - BytesToCopy = - context->LineWidth - context->LineDone; - if (BytesToCopy > size) - BytesToCopy = size; - - if (BytesToCopy > 0) { - memmove(context->LineBuf + - context->LineDone, buf, - BytesToCopy); - - size -= BytesToCopy; - buf += BytesToCopy; - context->LineDone += BytesToCopy; - } - if ((context->LineDone >= context->LineWidth) && - (context->LineWidth > 0)) - OneLine(context); - - - } - - if (context->HeaderDone >= 32) - if (!RAS2State((struct rasterfile *) context->HeaderBuf, - context, error)) { - return FALSE; - } - - - } - - return TRUE; -} - -#ifndef INCLUDE_ras -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__ras_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->begin_load = gdk_pixbuf__ras_image_begin_load; - module->stop_load = gdk_pixbuf__ras_image_stop_load; - module->load_increment = gdk_pixbuf__ras_image_load_increment; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "\x59\xa6\x6a\x95", NULL, 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/x-cmu-raster", - "image/x-sun-raster", - NULL - }; - static gchar * extensions[] = { - "ras", - NULL - }; - - info->name = "ras"; - info->signature = signature; - info->description = N_("The Sun raster image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} - diff --git a/gdk-pixbuf/io-tga.c b/gdk-pixbuf/io-tga.c deleted file mode 100644 index 0391e1eec9..0000000000 --- a/gdk-pixbuf/io-tga.c +++ /dev/null @@ -1,1013 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* - * GdkPixbuf library - TGA image loader - * Copyright (C) 1999 Nicola Girardi <nikke@swlibero.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - * - */ - -/* - * Some NOTES about the TGA loader (2001/06/07, nikke@swlibero.org) - * - * - The TGAFooter isn't present in all TGA files. In fact, there's an older - * format specification, still in use, which doesn't cover the TGAFooter. - * Actually, most TGA files I have are of the older type. Anyway I put the - * struct declaration here for completeness. - * - * - Error handling was designed to be very paranoid. - */ - -#include "config.h" -#include <stdio.h> -#include <string.h> - -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - -#undef DEBUG_TGA - -#define TGA_INTERLEAVE_MASK 0xc0 -#define TGA_INTERLEAVE_NONE 0x00 -#define TGA_INTERLEAVE_2WAY 0x40 -#define TGA_INTERLEAVE_4WAY 0x80 - -#define TGA_ORIGIN_MASK 0x30 -#define TGA_ORIGIN_RIGHT 0x10 -#define TGA_ORIGIN_UPPER 0x20 - -enum { - TGA_TYPE_NODATA = 0, - TGA_TYPE_PSEUDOCOLOR = 1, - TGA_TYPE_TRUECOLOR = 2, - TGA_TYPE_GRAYSCALE = 3, - TGA_TYPE_RLE_PSEUDOCOLOR = 9, - TGA_TYPE_RLE_TRUECOLOR = 10, - TGA_TYPE_RLE_GRAYSCALE = 11 -}; - -#define LE16(p) ((p)[0] + ((p)[1] << 8)) - -typedef struct _IOBuffer IOBuffer; - -typedef struct _TGAHeader TGAHeader; -typedef struct _TGAFooter TGAFooter; - -typedef struct _TGAColormap TGAColormap; -typedef struct _TGAColor TGAColor; - -typedef struct _TGAContext TGAContext; - -struct _TGAHeader { - guint8 infolen; - guint8 has_cmap; - guint8 type; - - guint8 cmap_start[2]; - guint8 cmap_n_colors[2]; - guint8 cmap_bpp; - - guint8 x_origin[2]; - guint8 y_origin[2]; - - guint8 width[2]; - guint8 height[2]; - guint8 bpp; - - guint8 flags; -}; - -struct _TGAFooter { - guint32 extension_area_offset; - guint32 developer_directory_offset; - - /* Standard TGA signature, "TRUEVISION-XFILE.\0". */ - union { - gchar sig_full[18]; - struct { - gchar sig_chunk[16]; - gchar dot, null; - } sig_struct; - } sig; -}; - -struct _TGAColormap { - gint size; - TGAColor *cols; -}; - -struct _TGAColor { - guchar r, g, b, a; -}; - -struct _TGAContext { - TGAHeader *hdr; - guint rowstride; - guint completed_lines; - gboolean run_length_encoded; - - TGAColormap *cmap; - guint cmap_size; - - GdkPixbuf *pbuf; - guint pbuf_bytes; - guint pbuf_bytes_done; - guchar *pptr; - - IOBuffer *in; - - gboolean skipped_info; - gboolean prepared; - gboolean done; - - GdkPixbufModuleSizeFunc sfunc; - GdkPixbufModulePreparedFunc pfunc; - GdkPixbufModuleUpdatedFunc ufunc; - gpointer udata; -}; - -struct _IOBuffer { - guchar *data; - guint size; -}; - -static IOBuffer *io_buffer_new(GError **err) -{ - IOBuffer *buffer; - buffer = g_try_malloc(sizeof(IOBuffer)); - if (!buffer) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate memory for IOBuffer struct")); - return NULL; - } - buffer->data = NULL; - buffer->size = 0; - return buffer; -} - -static IOBuffer *io_buffer_append(IOBuffer *buffer, - const guchar *data, guint len, - GError **err) -{ - if (!buffer) - return NULL; - if (!buffer->data) { - buffer->data = g_try_malloc(len); - if (!buffer->data) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate memory for IOBuffer data")); - g_free(buffer); - return NULL; - } - g_memmove(buffer->data, data, len); - buffer->size = len; - } else { - guchar *tmp = g_try_realloc (buffer->data, buffer->size + len); - if (!tmp) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot realloc IOBuffer data")); - g_free(buffer); - return NULL; - } - buffer->data = tmp; - g_memmove(&buffer->data[buffer->size], data, len); - buffer->size += len; - } - return buffer; -} - -static IOBuffer *io_buffer_free_segment(IOBuffer *buffer, - guint count, - GError **err) -{ - g_return_val_if_fail(buffer != NULL, NULL); - g_return_val_if_fail(buffer->data != NULL, NULL); - if (count == buffer->size) { - g_free(buffer->data); - buffer->data = NULL; - buffer->size = 0; - } else { - guchar *new_buf; - guint new_size; - - new_size = buffer->size - count; - new_buf = g_try_malloc(new_size); - if (!new_buf) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate temporary IOBuffer data")); - g_free(buffer->data); - g_free(buffer); - return NULL; - } - - g_memmove(new_buf, &buffer->data[count], new_size); - g_free(buffer->data); - buffer->data = new_buf; - buffer->size = new_size; - } - return buffer; -} - -static void io_buffer_free(IOBuffer *buffer) -{ - g_return_if_fail(buffer != NULL); - g_free(buffer->data); - g_free(buffer); -} - -static void free_buffer(guchar *pixels, gpointer data) -{ - g_free(pixels); -} - -static GdkPixbuf *get_contiguous_pixbuf (guint width, - guint height, - gboolean has_alpha) -{ - guchar *pixels; - guint channels, rowstride, bytes; - - if (has_alpha) - channels = 4; - else - channels = 3; - - rowstride = width * channels; - - if (rowstride / channels != width) - return NULL; - - bytes = height * rowstride; - - if (bytes / rowstride != height) - return NULL; - - pixels = g_try_malloc (bytes); - - if (!pixels) - return NULL; - - return gdk_pixbuf_new_from_data (pixels, GDK_COLORSPACE_RGB, has_alpha, 8, - width, height, rowstride, free_buffer, NULL); -} - -static void pixbuf_flip_row (GdkPixbuf *pixbuf, guchar *ph) -{ - guchar *p, *s; - guchar tmp; - gint count; - - p = ph; - s = p + pixbuf->n_channels * (pixbuf->width - 1); - while (p < s) { - for (count = pixbuf->n_channels; count > 0; count--, p++, s++) { - tmp = *p; - *p = *s; - *s = tmp; - } - s -= 2 * pixbuf->n_channels; - } -} - -static void pixbuf_flip_vertically (GdkPixbuf *pixbuf) -{ - guchar *ph, *sh, *p, *s; - guchar tmp; - gint count; - - ph = pixbuf->pixels; - sh = pixbuf->pixels + pixbuf->height*pixbuf->rowstride; - while (ph < sh - pixbuf->rowstride) { - p = ph; - s = sh - pixbuf->rowstride; - for (count = pixbuf->n_channels * pixbuf->width; count > 0; count--, p++, s++) { - tmp = *p; - *p = *s; - *s = tmp; - } - sh -= pixbuf->rowstride; - ph += pixbuf->rowstride; - } -} - -static gboolean fill_in_context(TGAContext *ctx, GError **err) -{ - gboolean alpha; - guint w, h; - - g_return_val_if_fail(ctx != NULL, FALSE); - - ctx->run_length_encoded = - ((ctx->hdr->type == TGA_TYPE_RLE_PSEUDOCOLOR) - || (ctx->hdr->type == TGA_TYPE_RLE_TRUECOLOR) - || (ctx->hdr->type == TGA_TYPE_RLE_GRAYSCALE)); - - if (ctx->hdr->has_cmap) - ctx->cmap_size = ((ctx->hdr->cmap_bpp + 7) >> 3) * - LE16(ctx->hdr->cmap_n_colors); - - alpha = ((ctx->hdr->bpp == 16) || - (ctx->hdr->bpp == 32) || - (ctx->hdr->has_cmap && (ctx->hdr->cmap_bpp == 32))); - - w = LE16(ctx->hdr->width); - h = LE16(ctx->hdr->height); - - if (ctx->sfunc) { - gint wi = w; - gint hi = h; - - (*ctx->sfunc) (&wi, &hi, ctx->udata); - - if (wi == 0 || hi == 0) - return FALSE; - } - - ctx->pbuf = get_contiguous_pixbuf (w, h, alpha); - - if (!ctx->pbuf) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate new pixbuf")); - return FALSE; - } - - ctx->pbuf_bytes = ctx->pbuf->rowstride * ctx->pbuf->height; - if ((ctx->hdr->flags & TGA_ORIGIN_UPPER) || ctx->run_length_encoded) - ctx->pptr = ctx->pbuf->pixels; - else - ctx->pptr = ctx->pbuf->pixels + (ctx->pbuf->height - 1)*ctx->pbuf->rowstride; - - if (ctx->hdr->type == TGA_TYPE_PSEUDOCOLOR) - ctx->rowstride = ctx->pbuf->width; - else if (ctx->hdr->type == TGA_TYPE_GRAYSCALE) - ctx->rowstride = (alpha ? ctx->pbuf->width * 2 : ctx->pbuf->width); - else if (ctx->hdr->type == TGA_TYPE_TRUECOLOR) - ctx->rowstride = ctx->pbuf->rowstride; - - ctx->completed_lines = 0; - return TRUE; -} - -static void parse_data_for_row_pseudocolor(TGAContext *ctx) -{ - guchar *s = ctx->in->data; - guint upper_bound = ctx->pbuf->width; - guchar *p = ctx->pptr; - - for (; upper_bound; upper_bound--, s++) { - *p++ = ctx->cmap->cols[*s].r; - *p++ = ctx->cmap->cols[*s].g; - *p++ = ctx->cmap->cols[*s].b; - if (ctx->hdr->cmap_bpp == 32) - *p++ = ctx->cmap->cols[*s].a; - } -} - -static void swap_channels(TGAContext *ctx) -{ - guchar swap; - guint count; - guchar *p = ctx->pptr; - for (count = ctx->pbuf->width; count; count--) { - swap = p[0]; - p[0] = p[2]; - p[2] = swap; - p += ctx->pbuf->n_channels; - } -} - -static void parse_data_for_row_truecolor(TGAContext *ctx) -{ - g_memmove(ctx->pptr, ctx->in->data, ctx->pbuf->rowstride); - swap_channels(ctx); -} - -static void parse_data_for_row_grayscale(TGAContext *ctx) -{ - guchar *s = ctx->in->data; - guint upper_bound = ctx->pbuf->width; - - guchar *p = ctx->pptr; - for (; upper_bound; upper_bound--) { - p[0] = p[1] = p[2] = *s++; - if (ctx->pbuf->n_channels == 4) - p[3] = *s++; - p += ctx->pbuf->n_channels; - } -} - -static gboolean parse_data_for_row(TGAContext *ctx, GError **err) -{ - guint row; - - if (ctx->hdr->type == TGA_TYPE_PSEUDOCOLOR) - parse_data_for_row_pseudocolor(ctx); - else if (ctx->hdr->type == TGA_TYPE_TRUECOLOR) - parse_data_for_row_truecolor(ctx); - else if (ctx->hdr->type == TGA_TYPE_GRAYSCALE) - parse_data_for_row_grayscale(ctx); - - if (ctx->hdr->flags & TGA_ORIGIN_RIGHT) - pixbuf_flip_row (ctx->pbuf, ctx->pptr); - if (ctx->hdr->flags & TGA_ORIGIN_UPPER) - ctx->pptr += ctx->pbuf->rowstride; - else - ctx->pptr -= ctx->pbuf->rowstride; - ctx->pbuf_bytes_done += ctx->pbuf->rowstride; - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) - ctx->done = TRUE; - - ctx->in = io_buffer_free_segment(ctx->in, ctx->rowstride, err); - if (!ctx->in) - return FALSE; - row = (ctx->pptr - ctx->pbuf->pixels) / ctx->pbuf->rowstride - 1; - if (ctx->ufunc) - (*ctx->ufunc) (ctx->pbuf, 0, row, ctx->pbuf->width, 1, ctx->udata); - return TRUE; -} - -static void write_rle_data(TGAContext *ctx, TGAColor *color, guint *rle_count) -{ - for (; *rle_count; (*rle_count)--) { - g_memmove(ctx->pptr, (guchar *) color, ctx->pbuf->n_channels); - ctx->pptr += ctx->pbuf->n_channels; - ctx->pbuf_bytes_done += ctx->pbuf->n_channels; - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) - return; - } -} - -static guint parse_rle_data_pseudocolor(TGAContext *ctx) -{ - guint rle_num, raw_num; - guchar *s, tag; - guint n; - - g_return_val_if_fail(ctx->in->size > 0, 0); - s = ctx->in->data; - - for (n = 0; n < ctx->in->size; ) { - tag = *s; - s++, n++; - if (tag & 0x80) { - if (n == ctx->in->size) { - return --n; - } else { - rle_num = (tag & 0x7f) + 1; - write_rle_data(ctx, &ctx->cmap->cols[*s], &rle_num); - s++, n++; - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) { - ctx->done = TRUE; - return n; - } - } - } else { - raw_num = tag + 1; - if (n + raw_num >= ctx->in->size) { - return --n; - } else { - for (; raw_num; raw_num--) { - *ctx->pptr++ = - ctx->cmap->cols[*s].r; - *ctx->pptr++ = - ctx->cmap->cols[*s].g; - *ctx->pptr++ = - ctx->cmap->cols[*s].b; - if (ctx->pbuf->n_channels == 4) - *ctx->pptr++ = ctx->cmap->cols[*s].a; - s++, n++; - ctx->pbuf_bytes_done += ctx->pbuf->n_channels; - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) { - ctx->done = TRUE; - return n; - } - } - } - } - } - - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) - ctx->done = TRUE; - - return n; -} - -static guint parse_rle_data_truecolor(TGAContext *ctx) -{ - TGAColor col; - guint rle_num, raw_num; - guchar *s, tag; - guint n = 0; - - g_return_val_if_fail(ctx->in->size > 0, 0); - s = ctx->in->data; - - for (n = 0; n < ctx->in->size; ) { - tag = *s; - s++, n++; - if (tag & 0x80) { - if (n + ctx->pbuf->n_channels >= ctx->in->size) { - return --n; - } else { - rle_num = (tag & 0x7f) + 1; - col.b = *s++; - col.g = *s++; - col.r = *s++; - if (ctx->hdr->bpp == 32) - col.a = *s++; - n += ctx->pbuf->n_channels; - write_rle_data(ctx, &col, &rle_num); - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) { - ctx->done = TRUE; - return n; - } - } - } else { - raw_num = tag + 1; - if (n + (raw_num * ctx->pbuf->n_channels) >= ctx->in->size) { - return --n; - } else { - for (; raw_num; raw_num--) { - ctx->pptr[2] = *s++; - ctx->pptr[1] = *s++; - ctx->pptr[0] = *s++; - if (ctx->hdr->bpp == 32) - ctx->pptr[3] = *s++; - n += ctx->pbuf->n_channels; - ctx->pptr += ctx->pbuf->n_channels; - ctx->pbuf_bytes_done += ctx->pbuf->n_channels; - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) { - ctx->done = TRUE; - return n; - } - } - - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) { - ctx->done = TRUE; - return n; - } - } - } - } - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) - ctx->done = TRUE; - return n; -} - -static guint parse_rle_data_grayscale(TGAContext *ctx) -{ - TGAColor tone; - guint rle_num, raw_num; - guchar *s, tag; - guint n; - - g_return_val_if_fail(ctx->in->size > 0, 0); - s = ctx->in->data; - - for (n = 0; n < ctx->in->size; ) { - tag = *s; - s++, n++; - if (tag & 0x80) { - if (n + (ctx->pbuf->n_channels == 4 ? 2 : 1) >= ctx->in->size) { - return --n; - } else { - rle_num = (tag & 0x7f) + 1; - tone.r = tone.g = tone.b = *s; - s++, n++; - if (ctx->pbuf->n_channels == 4) { - tone.a = *s++; - n++; - } - write_rle_data(ctx, &tone, &rle_num); - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) { - ctx->done = TRUE; - return n; - } - } - } else { - raw_num = tag + 1; - if (n + raw_num * (ctx->pbuf->n_channels == 4 ? 2 : 1) >= ctx->in->size) { - return --n; - } else { - for (; raw_num; raw_num--) { - ctx->pptr[0] = ctx->pptr[1] = ctx->pptr[2] = *s; - s++, n++; - if (ctx->pbuf->n_channels == 4) { - ctx->pptr[3] = *s++; - n++; - } - ctx->pptr += ctx->pbuf->n_channels; - ctx->pbuf_bytes_done += ctx->pbuf->n_channels; - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) { - ctx->done = TRUE; - return n; - } - } - } - } - } - if (ctx->pbuf_bytes_done == ctx->pbuf_bytes) - ctx->done = TRUE; - return n; -} - -static gboolean parse_rle_data(TGAContext *ctx, GError **err) -{ - guint rows = 0; - guint count = 0; - guint bytes_done_before = ctx->pbuf_bytes_done; - - if (ctx->hdr->type == TGA_TYPE_RLE_PSEUDOCOLOR) - count = parse_rle_data_pseudocolor(ctx); - else if (ctx->hdr->type == TGA_TYPE_RLE_TRUECOLOR) - count = parse_rle_data_truecolor(ctx); - else if (ctx->hdr->type == TGA_TYPE_RLE_GRAYSCALE) - count = parse_rle_data_grayscale(ctx); - - if (ctx->hdr->flags & TGA_ORIGIN_RIGHT) { - guchar *row = ctx->pbuf->pixels + (bytes_done_before / ctx->pbuf->rowstride) * ctx->pbuf->rowstride; - guchar *row_after = ctx->pbuf->pixels + (ctx->pbuf_bytes_done / ctx->pbuf->rowstride) * ctx->pbuf->rowstride; - for (; row < row_after; row += ctx->pbuf->rowstride) - pixbuf_flip_row (ctx->pbuf, row); - } - - ctx->in = io_buffer_free_segment(ctx->in, count, err); - if (!ctx->in) - return FALSE; - - if (ctx->done) { - /* FIXME doing the vertical flipping afterwards is not - * perfect, but doing it during the rle decoding in place - * is considerably more work. - */ - if (!(ctx->hdr->flags & TGA_ORIGIN_UPPER)) { - pixbuf_flip_vertically (ctx->pbuf); - ctx->hdr->flags |= TGA_ORIGIN_UPPER; - } - - } - - rows = ctx->pbuf_bytes_done / ctx->pbuf->rowstride - bytes_done_before / ctx->pbuf->rowstride; - if (ctx->ufunc) - (*ctx->ufunc) (ctx->pbuf, 0, bytes_done_before / ctx->pbuf->rowstride, - ctx->pbuf->width, rows, - ctx->udata); - - return TRUE; -} - -static gboolean try_colormap(TGAContext *ctx, GError **err) -{ - static guchar *p; - static guint n; - - g_return_val_if_fail(ctx != NULL, FALSE); - - if (ctx->cmap_size == 0) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Image is corrupted or truncated")); - return FALSE; - } - - ctx->cmap = g_try_malloc(sizeof(TGAColormap)); - if (!ctx->cmap) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate colormap structure")); - return FALSE; - } - ctx->cmap->size = LE16(ctx->hdr->cmap_n_colors); - ctx->cmap->cols = g_try_malloc(sizeof(TGAColor) * ctx->cmap->size); - if (!ctx->cmap->cols) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate colormap entries")); - return FALSE; - } - - p = ctx->in->data; - for (n = 0; n < ctx->cmap->size; n++) { - if ((ctx->hdr->cmap_bpp == 15) || (ctx->hdr->cmap_bpp == 16)) { - guint16 col = p[0] + (p[1] << 8); - ctx->cmap->cols[n].b = (col >> 7) & 0xf8; - ctx->cmap->cols[n].g = (col >> 2) & 0xf8; - ctx->cmap->cols[n].r = col << 3; - p += 2; - } - else if ((ctx->hdr->cmap_bpp == 24) || (ctx->hdr->cmap_bpp == 32)) { - ctx->cmap->cols[n].b = *p++; - ctx->cmap->cols[n].g = *p++; - ctx->cmap->cols[n].r = *p++; - if (ctx->hdr->cmap_bpp == 32) - ctx->cmap->cols[n].a = *p++; - } else { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Unexpected bitdepth for colormap entries")); - return FALSE; - } - } - ctx->in = io_buffer_free_segment(ctx->in, ctx->cmap_size, err); - if (!ctx->in) - return FALSE; - return TRUE; -} - -static gboolean try_preload(TGAContext *ctx, GError **err) -{ - if (!ctx->hdr) { - if (ctx->in->size >= sizeof(TGAHeader)) { - ctx->hdr = g_try_malloc(sizeof(TGAHeader)); - if (!ctx->hdr) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate TGA header memory")); - return FALSE; - } - g_memmove(ctx->hdr, ctx->in->data, sizeof(TGAHeader)); - ctx->in = io_buffer_free_segment(ctx->in, sizeof(TGAHeader), err); -#ifdef DEBUG_TGA - g_print ("infolen %d " - "has_cmap %d " - "type %d " - "cmap_start %d " - "cmap_n_colors %d " - "cmap_bpp %d " - "x %d y %d width %d height %d bpp %d " - "flags %#x", - ctx->hdr->infolen, - ctx->hdr->has_cmap, - ctx->hdr->type, - LE16(ctx->hdr->cmap_start), - LE16(ctx->hdr->cmap_n_colors), - ctx->hdr->cmap_bpp, - LE16(ctx->hdr->x_origin), - LE16(ctx->hdr->y_origin), - LE16(ctx->hdr->width), - LE16(ctx->hdr->height), - ctx->hdr->bpp, - ctx->hdr->flags); -#endif - if (!ctx->in) - return FALSE; - if (LE16(ctx->hdr->width) == 0 || - LE16(ctx->hdr->height) == 0) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("TGA image has invalid dimensions")); - return FALSE; - } - if ((ctx->hdr->flags & TGA_INTERLEAVE_MASK) != TGA_INTERLEAVE_NONE) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("TGA image type not supported")); - return FALSE; - } - switch (ctx->hdr->type) { - case TGA_TYPE_PSEUDOCOLOR: - case TGA_TYPE_RLE_PSEUDOCOLOR: - if (ctx->hdr->bpp != 8) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("TGA image type not supported")); - return FALSE; - } - break; - case TGA_TYPE_TRUECOLOR: - case TGA_TYPE_RLE_TRUECOLOR: - if (ctx->hdr->bpp != 24 && - ctx->hdr->bpp != 32) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("TGA image type not supported")); - return FALSE; - } - break; - case TGA_TYPE_GRAYSCALE: - case TGA_TYPE_RLE_GRAYSCALE: - if (ctx->hdr->bpp != 8 && - ctx->hdr->bpp != 16) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("TGA image type not supported")); - return FALSE; - } - break; - default: - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_UNKNOWN_TYPE, - _("TGA image type not supported")); - return FALSE; - } - if (!fill_in_context(ctx, err)) - return FALSE; - } else { - return TRUE; - } - } - if (!ctx->skipped_info) { - if (ctx->in->size >= ctx->hdr->infolen) { - ctx->in = io_buffer_free_segment(ctx->in, ctx->hdr->infolen, err); - if (!ctx->in) - return FALSE; - ctx->skipped_info = TRUE; - } else { - return TRUE; - } - } - if (ctx->hdr->has_cmap && !ctx->cmap) { - if (ctx->in->size >= ctx->cmap_size) { - if (!try_colormap(ctx, err)) - return FALSE; - } else { - return TRUE; - } - } - if (!ctx->prepared) { - if (ctx->pfunc) - (*ctx->pfunc) (ctx->pbuf, NULL, ctx->udata); - ctx->prepared = TRUE; - } - /* We shouldn't get here anyway. */ - return TRUE; -} - -static gpointer gdk_pixbuf__tga_begin_load(GdkPixbufModuleSizeFunc f0, - GdkPixbufModulePreparedFunc f1, - GdkPixbufModuleUpdatedFunc f2, - gpointer udata, GError **err) -{ - TGAContext *ctx; - - ctx = g_try_malloc(sizeof(TGAContext)); - if (!ctx) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate memory for TGA context struct")); - return NULL; - } - - ctx->hdr = NULL; - ctx->rowstride = 0; - ctx->run_length_encoded = FALSE; - - ctx->cmap = NULL; - ctx->cmap_size = 0; - - ctx->pbuf = NULL; - ctx->pbuf_bytes = 0; - ctx->pbuf_bytes_done = 0; - ctx->pptr = NULL; - - ctx->in = io_buffer_new(err); - if (!ctx->in) { - g_free(ctx); - return NULL; - } - - ctx->skipped_info = FALSE; - ctx->prepared = FALSE; - ctx->done = FALSE; - - ctx->sfunc = f0; - ctx->pfunc = f1; - ctx->ufunc = f2; - ctx->udata = udata; - - return ctx; -} - -static gboolean gdk_pixbuf__tga_load_increment(gpointer data, - const guchar *buffer, - guint size, - GError **err) -{ - TGAContext *ctx = (TGAContext*) data; - g_return_val_if_fail(ctx != NULL, FALSE); - - if (ctx->done) - return TRUE; - - g_return_val_if_fail(buffer != NULL, TRUE); - ctx->in = io_buffer_append(ctx->in, buffer, size, err); - if (!ctx->in) - return FALSE; - if (!ctx->prepared) { - if (!try_preload(ctx, err)) - return FALSE; - if (!ctx->prepared) - return TRUE; - if (ctx->in->size == 0) - return TRUE; - } - - if (ctx->run_length_encoded) { - if (!parse_rle_data(ctx, err)) - return FALSE; - } else { - while (ctx->in->size >= ctx->rowstride) { - if (ctx->completed_lines >= ctx->pbuf->height) { - g_set_error_literal(err, GDK_PIXBUF_ERROR, GDK_PIXBUF_ERROR_FAILED, - _("Excess data in file")); - return FALSE; - } - if (!parse_data_for_row(ctx, err)) - return FALSE; - ctx->completed_lines++; - } - } - - return TRUE; -} - -static gboolean gdk_pixbuf__tga_stop_load(gpointer data, GError **err) -{ - TGAContext *ctx = (TGAContext *) data; - g_return_val_if_fail(ctx != NULL, FALSE); - - if (ctx->hdr && - (ctx->hdr->flags & TGA_ORIGIN_UPPER) == 0 && - ctx->run_length_encoded && - ctx->pbuf) { - pixbuf_flip_vertically (ctx->pbuf); - if (ctx->ufunc) - (*ctx->ufunc) (ctx->pbuf, 0, 0, - ctx->pbuf->width, ctx->pbuf->height, - ctx->udata); - } - g_free (ctx->hdr); - if (ctx->cmap) { - g_free (ctx->cmap->cols); - g_free (ctx->cmap); - } - if (ctx->pbuf) - g_object_unref (ctx->pbuf); - if (ctx->in && ctx->in->size) - ctx->in = io_buffer_free_segment (ctx->in, ctx->in->size, err); - if (!ctx->in) { - g_free (ctx); - return FALSE; - } - io_buffer_free (ctx->in); - g_free (ctx); - return TRUE; -} - -#ifndef INCLUDE_tga -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__tga_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->begin_load = gdk_pixbuf__tga_begin_load; - module->stop_load = gdk_pixbuf__tga_stop_load; - module->load_increment = gdk_pixbuf__tga_load_increment; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { " \x1\x1", "x ", 100 }, - { " \x1\x9", "x ", 100 }, - { " \x2", "xz ", 99 }, /* only 99 since .CUR also matches this */ - { " \x3", "xz ", 100 }, - { " \xa", "xz ", 100 }, - { " \xb", "xz ", 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/x-tga", - NULL - }; - static gchar * extensions[] = { - "tga", - "targa", - NULL - }; - - info->name = "tga"; - info->signature = signature; - info->description = N_("The Targa image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-tiff.c b/gdk-pixbuf/io-tiff.c deleted file mode 100644 index 7128a5c080..0000000000 --- a/gdk-pixbuf/io-tiff.c +++ /dev/null @@ -1,875 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - TIFF image loader - * - * Copyright (C) 1999 Mark Crichton - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Federico Mena-Quintero <federico@gimp.org> - * Jonathan Blandford <jrb@redhat.com> - * S�ren Sandmann <sandmann@daimi.au.dk> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -/* Following code (almost) blatantly ripped from Imlib */ - -#include "config.h" -#include <stdlib.h> -#include <string.h> -#ifdef HAVE_UNISTD_H -#include <unistd.h> -#endif -#include <tiffio.h> -#include <errno.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - -#ifdef G_OS_WIN32 -#include <fcntl.h> -#include <io.h> -#define lseek(a,b,c) _lseek(a,b,c) -#define O_RDWR _O_RDWR -#endif - - -typedef struct _TiffContext TiffContext; -struct _TiffContext -{ - GdkPixbufModuleSizeFunc size_func; - GdkPixbufModulePreparedFunc prepare_func; - GdkPixbufModuleUpdatedFunc update_func; - gpointer user_data; - - guchar *buffer; - guint allocated; - guint used; - guint pos; -}; - - - -static char *global_error = NULL; -static TIFFErrorHandler orig_error_handler = NULL; -static TIFFErrorHandler orig_warning_handler = NULL; - -static void -tiff_warning_handler (const char *mod, const char *fmt, va_list ap) -{ - /* Don't print anything; we should not be dumping junk to - * stderr, since that may be bad for some apps. - */ - - /* libTIFF seems to occasionally warn about things that - * are really errors, so maybe we should just call tiff_error_handler - * here. - */ -} - -static void -tiff_error_handler (const char *mod, const char *fmt, va_list ap) -{ - if (global_error) { - /* Blah, loader called us twice */ - return; - } - - global_error = g_strdup_vprintf (fmt, ap); -} - -static void -tiff_push_handlers (void) -{ - if (global_error) - g_warning ("TIFF loader left crufty global_error around, FIXME"); - - orig_error_handler = TIFFSetErrorHandler (tiff_error_handler); - orig_warning_handler = TIFFSetWarningHandler (tiff_warning_handler); -} - -static void -tiff_pop_handlers (void) -{ - if (global_error) - g_warning ("TIFF loader left crufty global_error around, FIXME"); - - TIFFSetErrorHandler (orig_error_handler); - TIFFSetWarningHandler (orig_warning_handler); -} - -static void -tiff_set_error (GError **error, - int error_code, - const char *msg) -{ - /* Take the error message from libtiff and merge it with - * some context we provide. - */ - if (global_error) { - g_set_error (error, - GDK_PIXBUF_ERROR, - error_code, - "%s%s%s", msg, ": ", global_error); - - g_free (global_error); - global_error = NULL; - } - else { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - error_code, msg); - } -} - - - -static void free_buffer (guchar *pixels, gpointer data) -{ - g_free (pixels); -} - -static GdkPixbuf * -tiff_image_parse (TIFF *tiff, TiffContext *context, GError **error) -{ - guchar *pixels = NULL; - gint width, height, rowstride, bytes; - GdkPixbuf *pixbuf; - uint16 orientation = 0; - uint16 transform = 0; - uint16 codec; - gchar *icc_profile_base64; - const gchar *icc_profile; - guint icc_profile_size; - gint retval; - - /* We're called with the lock held. */ - - g_return_val_if_fail (global_error == NULL, NULL); - - if (!TIFFGetField (tiff, TIFFTAG_IMAGEWIDTH, &width) || global_error) { - tiff_set_error (error, - GDK_PIXBUF_ERROR_FAILED, - _("Could not get image width (bad TIFF file)")); - return NULL; - } - - if (!TIFFGetField (tiff, TIFFTAG_IMAGELENGTH, &height) || global_error) { - tiff_set_error (error, - GDK_PIXBUF_ERROR_FAILED, - _("Could not get image height (bad TIFF file)")); - return NULL; - } - - if (width <= 0 || height <= 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Width or height of TIFF image is zero")); - return NULL; - } - - rowstride = width * 4; - if (rowstride / 4 != width) { /* overflow */ - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Dimensions of TIFF image too large")); - return NULL; - } - - bytes = height * rowstride; - if (bytes / rowstride != height) { /* overflow */ - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Dimensions of TIFF image too large")); - return NULL; - } - - if (context && context->size_func) { - gint w = width; - gint h = height; - (* context->size_func) (&w, &h, context->user_data); - - /* This is a signal that this function is being called - to support gdk_pixbuf_get_file_info, so we can stop - parsing the tiff file at this point. It is not an - error condition. */ - - if (w == 0 || h == 0) - return NULL; - } - - pixels = g_try_malloc (bytes); - - if (!pixels) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to open TIFF file")); - return NULL; - } - - pixbuf = gdk_pixbuf_new_from_data (pixels, GDK_COLORSPACE_RGB, TRUE, 8, - width, height, rowstride, - free_buffer, NULL); - if (!pixbuf) { - g_free (pixels); - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to open TIFF file")); - return NULL; - } - - /* Set the "orientation" key associated with this image. libtiff - orientation handling is odd, so further processing is required - by higher-level functions based on this tag. If the embedded - orientation tag is 1-4, libtiff flips/mirrors the image as - required, and no client processing is required - so we report - no orientation. Orientations 5-8 require rotations which would - swap the width and height of the image. libtiff does not do this. - Instead it interprets orientations 5-8 the same as 1-4. - See http://bugzilla.remotesensing.org/show_bug.cgi?id=1548. - To correct for this, the client must apply the transform normally - used for orientation 5 to both orientations 5 and 7, and apply - the transform normally used for orientation 7 for both - orientations 6 and 8. Then everythings works out OK! */ - - TIFFGetField (tiff, TIFFTAG_ORIENTATION, &orientation); - - switch (orientation) { - case 5: - case 7: - transform = 5; - break; - case 6: - case 8: - transform = 7; - break; - default: - transform = 0; - break; - } - - if (transform > 0 ) { - gchar str[5]; - g_snprintf (str, sizeof (str), "%d", transform); - gdk_pixbuf_set_option (pixbuf, "orientation", str); - } - - TIFFGetField (tiff, TIFFTAG_COMPRESSION, &codec); - if (codec > 0) { - gchar str[5]; - g_snprintf (str, sizeof (str), "%d", codec); - gdk_pixbuf_set_option (pixbuf, "compression", str); - } - - /* Extract embedded ICC profile */ - retval = TIFFGetField (tiff, TIFFTAG_ICCPROFILE, &icc_profile_size, &icc_profile); - if (retval == 1) { - icc_profile_base64 = g_base64_encode ((const guchar *) icc_profile, icc_profile_size); - gdk_pixbuf_set_option (pixbuf, "icc-profile", icc_profile_base64); - g_free (icc_profile_base64); - } - - if (context && context->prepare_func) - (* context->prepare_func) (pixbuf, NULL, context->user_data); - - if (!TIFFReadRGBAImageOriented (tiff, width, height, (uint32 *)pixels, ORIENTATION_TOPLEFT, 1) || global_error) { - tiff_set_error (error, - GDK_PIXBUF_ERROR_FAILED, - _("Failed to load RGB data from TIFF file")); - g_object_unref (pixbuf); - return NULL; - } - -#if G_BYTE_ORDER == G_BIG_ENDIAN - /* Turns out that the packing used by TIFFRGBAImage depends on - * the host byte order... - */ - while (pixels < pixbuf->pixels + bytes) { - uint32 pixel = *(uint32 *)pixels; - int r = TIFFGetR(pixel); - int g = TIFFGetG(pixel); - int b = TIFFGetB(pixel); - int a = TIFFGetA(pixel); - *pixels++ = r; - *pixels++ = g; - *pixels++ = b; - *pixels++ = a; - } -#endif - - if (context && context->update_func) - (* context->update_func) (pixbuf, 0, 0, width, height, context->user_data); - - return pixbuf; -} - - - -/* Static loader */ - -static GdkPixbuf * -gdk_pixbuf__tiff_image_load (FILE *f, GError **error) -{ - TIFF *tiff; - int fd; - GdkPixbuf *pixbuf; - - g_return_val_if_fail (f != NULL, NULL); - - tiff_push_handlers (); - - fd = fileno (f); - - /* On OSF, apparently fseek() works in some on-demand way, so - * the fseek gdk_pixbuf_new_from_file() doesn't work here - * since we are using the raw file descriptor. So, we call lseek() on the fd - * before using it. (#60840) - */ - lseek (fd, 0, SEEK_SET); - tiff = TIFFFdOpen (fd, "libpixbuf-tiff", "r"); - - if (!tiff || global_error) { - tiff_set_error (error, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Failed to open TIFF image")); - tiff_pop_handlers (); - - return NULL; - } - - pixbuf = tiff_image_parse (tiff, NULL, error); - - TIFFClose (tiff); - if (global_error) { - tiff_set_error (error, - GDK_PIXBUF_ERROR_FAILED, - _("TIFFClose operation failed")); - } - - tiff_pop_handlers (); - - return pixbuf; -} - - - -/* Progressive loader */ - -static gpointer -gdk_pixbuf__tiff_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepare_func, - GdkPixbufModuleUpdatedFunc update_func, - gpointer user_data, - GError **error) -{ - TiffContext *context; - - context = g_new0 (TiffContext, 1); - context->size_func = size_func; - context->prepare_func = prepare_func; - context->update_func = update_func; - context->user_data = user_data; - context->buffer = NULL; - context->allocated = 0; - context->used = 0; - context->pos = 0; - - return context; -} - -static tsize_t -tiff_load_read (thandle_t handle, tdata_t buf, tsize_t size) -{ - TiffContext *context = (TiffContext *)handle; - - if (context->pos + size > context->used) - return 0; - - memcpy (buf, context->buffer + context->pos, size); - context->pos += size; - return size; -} - -static tsize_t -tiff_load_write (thandle_t handle, tdata_t buf, tsize_t size) -{ - return -1; -} - -static toff_t -tiff_load_seek (thandle_t handle, toff_t offset, int whence) -{ - TiffContext *context = (TiffContext *)handle; - - switch (whence) { - case SEEK_SET: - if (offset > context->used) - return -1; - context->pos = offset; - break; - case SEEK_CUR: - if (offset + context->pos >= context->used) - return -1; - context->pos += offset; - break; - case SEEK_END: - if (offset + context->used > context->used) - return -1; - context->pos = context->used + offset; - break; - default: - return -1; - } - return context->pos; -} - -static int -tiff_load_close (thandle_t context) -{ - return 0; -} - -static toff_t -tiff_load_size (thandle_t handle) -{ - TiffContext *context = (TiffContext *)handle; - - return context->used; -} - -static int -tiff_load_map_file (thandle_t handle, tdata_t *buf, toff_t *size) -{ - TiffContext *context = (TiffContext *)handle; - - *buf = context->buffer; - *size = context->used; - - return 0; -} - -static void -tiff_load_unmap_file (thandle_t handle, tdata_t data, toff_t offset) -{ -} - -static gboolean -gdk_pixbuf__tiff_image_stop_load (gpointer data, - GError **error) -{ - TiffContext *context = data; - TIFF *tiff; - gboolean retval; - - g_return_val_if_fail (data != NULL, FALSE); - - tiff_push_handlers (); - - tiff = TIFFClientOpen ("libtiff-pixbuf", "r", data, - tiff_load_read, tiff_load_write, - tiff_load_seek, tiff_load_close, - tiff_load_size, - tiff_load_map_file, tiff_load_unmap_file); - if (!tiff || global_error) { - tiff_set_error (error, - GDK_PIXBUF_ERROR_FAILED, - _("Failed to load TIFF image")); - retval = FALSE; - } else { - GdkPixbuf *pixbuf; - - pixbuf = tiff_image_parse (tiff, context, error); - if (pixbuf) - g_object_unref (pixbuf); - retval = pixbuf != NULL; - if (global_error) - { - tiff_set_error (error, - GDK_PIXBUF_ERROR_FAILED, - _("Failed to load TIFF image")); - tiff_pop_handlers (); - - retval = FALSE; - } - } - - if (tiff) - TIFFClose (tiff); - - g_assert (!global_error); - - g_free (context->buffer); - g_free (context); - - tiff_pop_handlers (); - - return retval; -} - -static gboolean -make_available_at_least (TiffContext *context, guint needed) -{ - guchar *new_buffer = NULL; - guint need_alloc; - - need_alloc = context->used + needed; - if (need_alloc > context->allocated) { - guint new_size = 1; - while (new_size < need_alloc) - new_size *= 2; - - new_buffer = g_try_realloc (context->buffer, new_size); - if (new_buffer) { - context->buffer = new_buffer; - context->allocated = new_size; - return TRUE; - } - return FALSE; - } - return TRUE; -} - -static gboolean -gdk_pixbuf__tiff_image_load_increment (gpointer data, const guchar *buf, - guint size, GError **error) -{ - TiffContext *context = (TiffContext *) data; - - g_return_val_if_fail (data != NULL, FALSE); - - if (!make_available_at_least (context, size)) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to open TIFF file")); - return FALSE; - } - - memcpy (context->buffer + context->used, buf, size); - context->used += size; - return TRUE; -} - -typedef struct { - gchar *buffer; - guint allocated; - guint used; - guint pos; -} TiffSaveContext; - -static tsize_t -tiff_save_read (thandle_t handle, tdata_t buf, tsize_t size) -{ - return -1; -} - -static tsize_t -tiff_save_write (thandle_t handle, tdata_t buf, tsize_t size) -{ - TiffSaveContext *context = (TiffSaveContext *)handle; - - /* Modify buffer length */ - if (context->pos + size > context->used) - context->used = context->pos + size; - - /* Realloc */ - if (context->used > context->allocated) { - context->buffer = g_realloc (context->buffer, context->pos + size); - context->allocated = context->used; - } - - /* Now copy the data */ - memcpy (context->buffer + context->pos, buf, size); - - /* Update pos */ - context->pos += size; - - return size; -} - -static toff_t -tiff_save_seek (thandle_t handle, toff_t offset, int whence) -{ - TiffSaveContext *context = (TiffSaveContext *)handle; - - switch (whence) { - case SEEK_SET: - context->pos = offset; - break; - case SEEK_CUR: - context->pos += offset; - break; - case SEEK_END: - context->pos = context->used + offset; - break; - default: - return -1; - } - return context->pos; -} - -static int -tiff_save_close (thandle_t context) -{ - return 0; -} - -static toff_t -tiff_save_size (thandle_t handle) -{ - return -1; -} - -static TiffSaveContext * -create_save_context (void) -{ - TiffSaveContext *context; - - context = g_new (TiffSaveContext, 1); - context->buffer = NULL; - context->allocated = 0; - context->used = 0; - context->pos = 0; - - return context; -} - -static void -free_save_context (TiffSaveContext *context) -{ - g_free (context->buffer); - g_free (context); -} - -static gboolean -gdk_pixbuf__tiff_image_save_to_callback (GdkPixbufSaveFunc save_func, - gpointer user_data, - GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error) -{ - TIFF *tiff; - gint width, height, rowstride; - guchar *pixels; - gboolean has_alpha; - gushort alpha_samples[1] = { EXTRASAMPLE_UNASSALPHA }; - int y; - TiffSaveContext *context; - gboolean retval; - guchar *icc_profile = NULL; - gsize icc_profile_size = 0; - - tiff_push_handlers (); - - context = create_save_context (); - tiff = TIFFClientOpen ("libtiff-pixbuf", "w", context, - tiff_save_read, tiff_save_write, - tiff_save_seek, tiff_save_close, - tiff_save_size, - NULL, NULL); - - if (!tiff || global_error) { - tiff_set_error (error, - GDK_PIXBUF_ERROR_FAILED, - _("Failed to save TIFF image")); - - tiff_pop_handlers (); - - free_save_context (context); - return FALSE; - } - - rowstride = gdk_pixbuf_get_rowstride (pixbuf); - pixels = gdk_pixbuf_get_pixels (pixbuf); - - has_alpha = gdk_pixbuf_get_has_alpha (pixbuf); - - height = gdk_pixbuf_get_height (pixbuf); - width = gdk_pixbuf_get_width (pixbuf); - - TIFFSetField (tiff, TIFFTAG_IMAGEWIDTH, width); - TIFFSetField (tiff, TIFFTAG_IMAGELENGTH, height); - TIFFSetField (tiff, TIFFTAG_BITSPERSAMPLE, 8); - TIFFSetField (tiff, TIFFTAG_SAMPLESPERPIXEL, has_alpha ? 4 : 3); - TIFFSetField (tiff, TIFFTAG_ROWSPERSTRIP, height); - - /* libtiff supports a number of 'codecs' such as: - 1 None, 2 Huffman, 5 LZW, 7 JPEG, 8 Deflate, see tiff.h */ - if (keys && *keys && values && *values) { - guint i = 0; - - while (keys[i]) { - if (g_str_equal (keys[i], "compression")) { - guint16 codec = strtol (values[i], NULL, 0); - if (TIFFIsCODECConfigured (codec)) - TIFFSetField (tiff, TIFFTAG_COMPRESSION, codec); - else { - tiff_set_error (error, - GDK_PIXBUF_ERROR_FAILED, - _("TIFF compression doesn't refer to a valid codec.")); - retval = FALSE; - goto cleanup; - } - } else if (g_str_equal (keys[i], "icc-profile")) { - /* decode from base64 */ - icc_profile = g_base64_decode (values[i], &icc_profile_size); - if (icc_profile_size < 127) { - g_set_error (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_BAD_OPTION, - _("Color profile has invalid length %d."), - (gint)icc_profile_size); - retval = FALSE; - goto cleanup; - } - } - i++; - } - } - - if (has_alpha) - TIFFSetField (tiff, TIFFTAG_EXTRASAMPLES, 1, alpha_samples); - - TIFFSetField (tiff, TIFFTAG_PHOTOMETRIC, PHOTOMETRIC_RGB); - TIFFSetField (tiff, TIFFTAG_FILLORDER, FILLORDER_MSB2LSB); - TIFFSetField (tiff, TIFFTAG_PLANARCONFIG, PLANARCONFIG_CONTIG); - - if (icc_profile != NULL) - TIFFSetField (tiff, TIFFTAG_ICCPROFILE, icc_profile_size, icc_profile); - - for (y = 0; y < height; y++) { - if (TIFFWriteScanline (tiff, pixels + y * rowstride, y, 0) == -1 || - global_error) - break; - } - - if (global_error) { - tiff_set_error (error, - GDK_PIXBUF_ERROR_FAILED, - _("Failed to write TIFF data")); - - TIFFClose (tiff); - retval = FALSE; - goto cleanup; - } - - TIFFClose (tiff); - if (global_error) { - tiff_set_error (error, - GDK_PIXBUF_ERROR_FAILED, - _("TIFFClose operation failed")); - retval = FALSE; - goto cleanup; - } - - - /* Now call the callback */ - retval = save_func (context->buffer, context->used, error, user_data); - -cleanup: - g_free (icc_profile); - tiff_pop_handlers (); - free_save_context (context); - return retval; -} - -static gboolean -save_to_file_cb (const gchar *buf, - gsize count, - GError **error, - gpointer data) -{ - gint bytes; - - while (count > 0) { - bytes = fwrite (buf, sizeof (gchar), count, (FILE *) data); - if (bytes <= 0) - break; - count -= bytes; - buf += bytes; - } - - if (count) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_FAILED, - _("Couldn't write to TIFF file")); - return FALSE; - } - - return TRUE; -} - -static gboolean -gdk_pixbuf__tiff_image_save (FILE *f, - GdkPixbuf *pixbuf, - gchar **keys, - gchar **values, - GError **error) -{ - return gdk_pixbuf__tiff_image_save_to_callback (save_to_file_cb, - f, pixbuf, keys, - values, error); -} - -#ifndef INCLUDE_tiff -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__tiff_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->load = gdk_pixbuf__tiff_image_load; - module->begin_load = gdk_pixbuf__tiff_image_begin_load; - module->stop_load = gdk_pixbuf__tiff_image_stop_load; - module->load_increment = gdk_pixbuf__tiff_image_load_increment; - module->save = gdk_pixbuf__tiff_image_save; - module->save_to_callback = gdk_pixbuf__tiff_image_save_to_callback; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "MM \x2a", " z ", 100 }, - { "II\x2a ", " z", 100 }, - { "II* \020 CR\002 ", " z zzz z", 0 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/tiff", - NULL - }; - static gchar * extensions[] = { - "tiff", - "tif", - NULL - }; - - info->name = "tiff"; - info->signature = signature; - info->description = N_("The TIFF image format"); - info->mime_types = mime_types; - info->extensions = extensions; - /* not threadsafe, due to the error handler handling */ - info->flags = GDK_PIXBUF_FORMAT_WRITABLE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-wbmp.c b/gdk-pixbuf/io-wbmp.c deleted file mode 100644 index a4575b682d..0000000000 --- a/gdk-pixbuf/io-wbmp.c +++ /dev/null @@ -1,380 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* GdkPixbuf library - Wireless Bitmap image loader - * - * Copyright (C) 2000 Red Hat, Inc. - * - * Authors: Elliot Lee <sopwith@redhat.com - * - * Based on io-bmp.c - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -/* - -Known bugs: - * Since this is based off the libgd implementation, no extended headers implemented (not required for a WAP client) -*/ - -#include "config.h" -#include <stdio.h> -#ifdef HAVE_UNISTD_H -#include <unistd.h> -#endif -#include <string.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" - - - -/* Progressive loading */ - -struct wbmp_progressive_state { - GdkPixbufModulePreparedFunc prepared_func; - GdkPixbufModuleUpdatedFunc updated_func; - gpointer user_data; - - guint need_type : 1; - guint need_header : 1; - guint need_width : 1; - guint need_height : 1; - guint needmore : 1; - guint call_progressive_updates : 1; - - guchar last_buf[16]; /* Just needs to be big enough to hold the largest datum requestable via 'getin' */ - guint last_len; - - int type; - int width, height, curx, cury; - - GdkPixbuf *pixbuf; /* Our "target" */ -}; - -static gpointer -gdk_pixbuf__wbmp_image_begin_load(GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error); - -static gboolean gdk_pixbuf__wbmp_image_stop_load(gpointer data, GError **error); -static gboolean gdk_pixbuf__wbmp_image_load_increment(gpointer data, - const guchar * buf, - guint size, - GError **error); - -/* - * func - called when we have pixmap created (but no image data) - * user_data - passed as arg 1 to func - * return context (opaque to user) - */ - -static gpointer -gdk_pixbuf__wbmp_image_begin_load(GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepared_func, - GdkPixbufModuleUpdatedFunc updated_func, - gpointer user_data, - GError **error) -{ - struct wbmp_progressive_state *context; - - context = g_new0(struct wbmp_progressive_state, 1); - context->prepared_func = prepared_func; - context->updated_func = updated_func; - context->user_data = user_data; - - context->needmore = context->need_type = context->need_header = context->need_width = context->need_height = TRUE; - context->call_progressive_updates = TRUE; - context->pixbuf = NULL; - - return (gpointer) context; -} - -/* - * context - returned from image_begin_load - * - * free context, unref gdk_pixbuf - */ -static gboolean gdk_pixbuf__wbmp_image_stop_load(gpointer data, - GError **error) -{ - struct wbmp_progressive_state *context = - (struct wbmp_progressive_state *) data; - - /* FIXME this thing needs to report errors if - * we have unused image data - */ - - g_return_val_if_fail(context != NULL, TRUE); - if (context->pixbuf) - g_object_unref(context->pixbuf); - - g_free(context); - - return TRUE; -} - -static gboolean -getin(struct wbmp_progressive_state *context, const guchar **buf, guint *buf_size, guchar *ptr, int datum_size) -{ - int last_num, buf_num; - - if((context->last_len + *buf_size) < datum_size) - return FALSE; - - /* We know we can pull it out of there */ - last_num = MIN(datum_size, context->last_len); - buf_num = MIN(datum_size-last_num, *buf_size); - memcpy(ptr, context->last_buf, last_num); - memcpy(ptr+last_num, *buf, buf_num); - - context->last_len -= last_num; - if(context->last_len) - memmove(context->last_buf, context->last_buf+last_num, context->last_len); - *buf_size -= buf_num; - *buf += buf_num; - - return TRUE; -} - -static gboolean -save_rest(struct wbmp_progressive_state *context, const guchar *buf, guint buf_size) -{ - if(buf_size > (sizeof(context->last_buf) - context->last_len)) - return FALSE; - - memcpy(context->last_buf+context->last_len, buf, buf_size); - context->last_len += buf_size; - - return TRUE; -} - -static gboolean -get_mbi(struct wbmp_progressive_state *context, const guchar **buf, guint *buf_size, int *val) -{ - guchar intbuf[16]; - int n; - gboolean rv; - - *val = 0; - n = 0; - do { - rv = getin(context, buf, buf_size, intbuf+n, 1); - if(!rv) - goto out; - *val <<= 7; - *val |= intbuf[n] & 0x7F; - n++; - } while(n < sizeof(intbuf) && (intbuf[n-1] & 0x80)); - - out: - if(!rv || (intbuf[n-1] & 0x80)) - { - rv = save_rest(context, intbuf, n); - - if(!rv) - g_error("Couldn't save_rest of intbuf"); - return FALSE; - } - - return TRUE; -} - -/* - * context - from image_begin_load - * buf - new image data - * size - length of new image data - * - * append image data onto inrecrementally built output image - */ -static gboolean gdk_pixbuf__wbmp_image_load_increment(gpointer data, - const guchar * buf, - guint size, GError **error) -{ - struct wbmp_progressive_state *context = - (struct wbmp_progressive_state *) data; - gboolean bv = FALSE; - - do - { - if(context->need_type) - { - guchar val; - - bv = getin(context, &buf, &size, &val, 1); - if(bv) - { - context->type = val; - context->need_type = FALSE; - } - } - else if(context->need_header) - { - guchar val; - - bv = getin(context, &buf, &size, &val, 1); - if(bv) - { - /* We skip over the extended header - val is unused */ - if(!(val & 0x80)) - context->need_header = FALSE; - } - } - else if(context->need_width) - { - bv = get_mbi(context, &buf, &size, &context->width); - if(bv) { - context->need_width = FALSE; - - if (context->width <= 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Image has zero width")); - - return FALSE; - } - } - - } - else if(context->need_height) - { - bv = get_mbi(context, &buf, &size, &context->height); - if(bv) - { - context->need_height = FALSE; - - if (context->height <= 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Image has zero height")); - - return FALSE; - } - - context->pixbuf = gdk_pixbuf_new(GDK_COLORSPACE_RGB, FALSE, 8, context->width, context->height); - - if (!context->pixbuf) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Not enough memory to load image")); - return FALSE; - } - - - if(context->prepared_func) - context->prepared_func(context->pixbuf, NULL, context->user_data); - } - } - else if(context->needmore) - { - int first_row; - first_row = context->cury; - for( ; context->cury < context->height; context->cury++, context->curx = 0) - { - for( ; context->curx < context->width; context->curx += 8) - { - guchar byte; - guchar *ptr; - int xoff; - bv = getin(context, &buf, &size, &byte, 1); - if(!bv) - goto out; - - ptr = context->pixbuf->pixels + context->pixbuf->rowstride * context->cury + context->curx * 3; - for(xoff = 7; xoff >= 0; xoff--, ptr += 3) - { - guchar pixval; - - if (context->curx + (7 - xoff) == context->width) - break; - - if(byte & (1<<xoff)) - pixval = 0xFF; - else - pixval = 0x0; - - ptr[0] = ptr[1] = ptr[2] = pixval; - } - } - } - context->needmore = FALSE; - - out: - if(context->updated_func) - context->updated_func(context->pixbuf, 0, first_row, context->width, context->cury - first_row + 1, - context->user_data); - } - else - bv = FALSE; /* Nothing left to do, stop feeding me data! */ - - } while(bv); - - if(size) { - bv = save_rest(context, buf, size); - if (!bv) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Couldn't save the rest")); - - return FALSE; - } - } - return TRUE; -} - -#ifndef INCLUDE_wbmp -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__wbmp_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->begin_load = gdk_pixbuf__wbmp_image_begin_load; - module->stop_load = gdk_pixbuf__wbmp_image_stop_load; - module->load_increment = gdk_pixbuf__wbmp_image_load_increment; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { " ", "zz", 1 }, - { " \140", "z ", 1 }, - { " \100", "z ", 1 }, - { " \040", "z ", 1 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/vnd.wap.wbmp", - NULL - }; - static gchar * extensions[] = { - "wbmp", - NULL - }; - - info->name = "wbmp"; - info->signature = signature; - info->description = N_("The WBMP image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-xbm.c b/gdk-pixbuf/io-xbm.c deleted file mode 100644 index 05c45ac97c..0000000000 --- a/gdk-pixbuf/io-xbm.c +++ /dev/null @@ -1,497 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* GdkPixbuf library - XBM image loader - * - * Copyright (C) 1999 Mark Crichton - * Copyright (C) 1999 The Free Software Foundation - * Copyright (C) 2001 Eazel, Inc. - * - * Authors: Mark Crichton <crichton@gimp.org> - * Federico Mena-Quintero <federico@gimp.org> - * Jonathan Blandford <jrb@redhat.com> - * John Harper <jsh@eazel.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -/* Following code adapted from io-tiff.c, which was ``(almost) blatantly - ripped from Imlib'' */ - -#include "config.h" -#include <stdlib.h> -#include <string.h> -#ifdef HAVE_UNISTD_H -#include <unistd.h> -#endif -#include <stdio.h> -#include <errno.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" -#include <glib/gstdio.h> - - -typedef struct _XBMData XBMData; -struct _XBMData -{ - GdkPixbufModulePreparedFunc prepare_func; - GdkPixbufModuleUpdatedFunc update_func; - gpointer user_data; - - gchar *tempname; - FILE *file; - gboolean all_okay; -}; - - -/* xbm parser borrowed from xc/lib/X11/RdBitF.c */ - -#define MAX_SIZE 255 - -/* shared data for the image read/parse logic */ -static short hex_table[256]; /* conversion value */ -static gboolean initialized = FALSE; /* easier to fill in at run time */ - - -/* Table index for the hex values. Initialized once, first time. - * Used for translation value or delimiter significance lookup. - */ -static void -init_hex_table (void) -{ - /* - * We build the table at run time for several reasons: - * - * 1. portable to non-ASCII machines. - * 2. still reentrant since we set the init flag after setting table. - * 3. easier to extend. - * 4. less prone to bugs. - */ - hex_table['0'] = 0; - hex_table['1'] = 1; - hex_table['2'] = 2; - hex_table['3'] = 3; - hex_table['4'] = 4; - hex_table['5'] = 5; - hex_table['6'] = 6; - hex_table['7'] = 7; - hex_table['8'] = 8; - hex_table['9'] = 9; - hex_table['A'] = 10; - hex_table['B'] = 11; - hex_table['C'] = 12; - hex_table['D'] = 13; - hex_table['E'] = 14; - hex_table['F'] = 15; - hex_table['a'] = 10; - hex_table['b'] = 11; - hex_table['c'] = 12; - hex_table['d'] = 13; - hex_table['e'] = 14; - hex_table['f'] = 15; - - /* delimiters of significance are flagged w/ negative value */ - hex_table[' '] = -1; - hex_table[','] = -1; - hex_table['}'] = -1; - hex_table['\n'] = -1; - hex_table['\t'] = -1; - - initialized = TRUE; -} - -/* Read next hex value in the input stream, return -1 if EOF */ -static int -next_int (FILE *fstream) -{ - int ch; - int value = 0; - int gotone = 0; - int done = 0; - - /* loop, accumulate hex value until find delimiter - skip any initial delimiters found in read stream */ - - while (!done) { - ch = getc (fstream); - if (ch == EOF) { - value = -1; - done++; - } else { - /* trim high bits, check type and accumulate */ - ch &= 0xff; - if (g_ascii_isxdigit (ch)) { - value = (value << 4) + g_ascii_xdigit_value (ch); - gotone++; - } else if ((hex_table[ch]) < 0 && gotone) { - done++; - } - } - } - return value; -} - -static gboolean -read_bitmap_file_data (FILE *fstream, - guint *width, - guint *height, - guchar **data, - int *x_hot, - int *y_hot) -{ - guchar *bits = NULL; /* working variable */ - char line[MAX_SIZE]; /* input line from file */ - int size; /* number of bytes of data */ - char name_and_type[MAX_SIZE]; /* an input line */ - char *type; /* for parsing */ - int value; /* from an input line */ - int version10p; /* boolean, old format */ - int padding; /* to handle alignment */ - int bytes_per_line; /* per scanline of data */ - guint ww = 0; /* width */ - guint hh = 0; /* height */ - int hx = -1; /* x hotspot */ - int hy = -1; /* y hotspot */ - - /* first time initialization */ - if (!initialized) { - init_hex_table (); - } - - /* error cleanup and return macro */ -#define RETURN(code) { g_free (bits); return code; } - - while (fgets (line, MAX_SIZE, fstream)) { - if (strlen (line) == MAX_SIZE-1) - RETURN (FALSE); - if (sscanf (line,"#define %s %d",name_and_type,&value) == 2) { - if (!(type = strrchr (name_and_type, '_'))) - type = name_and_type; - else { - type++; - } - - if (!strcmp ("width", type)) - ww = (unsigned int) value; - if (!strcmp ("height", type)) - hh = (unsigned int) value; - if (!strcmp ("hot", type)) { - if (type-- == name_and_type - || type-- == name_and_type) - continue; - if (!strcmp ("x_hot", type)) - hx = value; - if (!strcmp ("y_hot", type)) - hy = value; - } - continue; - } - - if (sscanf (line, "static short %s = {", name_and_type) == 1) - version10p = 1; - else if (sscanf (line,"static const unsigned char %s = {",name_and_type) == 1) - version10p = 0; - else if (sscanf (line,"static unsigned char %s = {",name_and_type) == 1) - version10p = 0; - else if (sscanf (line, "static const char %s = {", name_and_type) == 1) - version10p = 0; - else if (sscanf (line, "static char %s = {", name_and_type) == 1) - version10p = 0; - else - continue; - - if (!(type = strrchr (name_and_type, '_'))) - type = name_and_type; - else - type++; - - if (strcmp ("bits[]", type)) - continue; - - if (!ww || !hh) - RETURN (FALSE); - - if ((ww % 16) && ((ww % 16) < 9) && version10p) - padding = 1; - else - padding = 0; - - bytes_per_line = (ww+7)/8 + padding; - - size = bytes_per_line * hh; - bits = g_malloc (size); - - if (version10p) { - unsigned char *ptr; - int bytes; - - for (bytes = 0, ptr = bits; bytes < size; (bytes += 2)) { - if ((value = next_int (fstream)) < 0) - RETURN (FALSE); - *(ptr++) = value; - if (!padding || ((bytes+2) % bytes_per_line)) - *(ptr++) = value >> 8; - } - } else { - unsigned char *ptr; - int bytes; - - for (bytes = 0, ptr = bits; bytes < size; bytes++, ptr++) { - if ((value = next_int (fstream)) < 0) - RETURN (FALSE); - *ptr=value; - } - } - break; - } - - if (!bits) - RETURN (FALSE); - - *data = bits; - *width = ww; - *height = hh; - if (x_hot) - *x_hot = hx; - if (y_hot) - *y_hot = hy; - - return TRUE; -} - - - -static GdkPixbuf * -gdk_pixbuf__xbm_image_load_real (FILE *f, - XBMData *context, - GError **error) -{ - guint w, h; - int x_hot, y_hot; - guchar *data, *ptr; - guchar *pixels; - guint row_stride; - int x, y; - int reg = 0; /* Quiet compiler */ - int bits; - - GdkPixbuf *pixbuf; - - if (!read_bitmap_file_data (f, &w, &h, &data, &x_hot, &y_hot)) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid XBM file")); - return NULL; - } - - pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, FALSE, 8, w, h); - - if (pixbuf == NULL) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Insufficient memory to load XBM image file")); - return NULL; - } - - if (x_hot != -1 && y_hot != -1) { - gchar hot[10]; - g_snprintf (hot, 10, "%d", x_hot); - gdk_pixbuf_set_option (pixbuf, "x_hot", hot); - g_snprintf (hot, 10, "%d", y_hot); - gdk_pixbuf_set_option (pixbuf, "y_hot", hot); - } - - pixels = gdk_pixbuf_get_pixels (pixbuf); - row_stride = gdk_pixbuf_get_rowstride (pixbuf); - - if (context && context->prepare_func) - (* context->prepare_func) (pixbuf, NULL, context->user_data); - - - /* Initialize PIXBUF */ - - ptr = data; - for (y = 0; y < h; y++) { - bits = 0; - for (x = 0; x < w; x++) { - guchar channel; - if (bits == 0) { - reg = *ptr++; - bits = 8; - } - - channel = (reg & 1) ? 0 : 255; - reg >>= 1; - bits--; - - pixels[x*3+0] = channel; - pixels[x*3+1] = channel; - pixels[x*3+2] = channel; - } - pixels += row_stride; - } - g_free (data); - - if (context) { - if (context->update_func) - (* context->update_func) (pixbuf, 0, 0, w, h, context->user_data); - } - - return pixbuf; -} - - -/* Static loader */ - -static GdkPixbuf * -gdk_pixbuf__xbm_image_load (FILE *f, - GError **error) -{ - return gdk_pixbuf__xbm_image_load_real (f, NULL, error); -} - - -/* Progressive loader */ - -/* - * Proper XBM progressive loading isn't implemented. Instead we write - * it to a file, then load the file when it's done. It's not pretty. - */ - -static gpointer -gdk_pixbuf__xbm_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepare_func, - GdkPixbufModuleUpdatedFunc update_func, - gpointer user_data, - GError **error) -{ - XBMData *context; - gint fd; - - context = g_new (XBMData, 1); - context->prepare_func = prepare_func; - context->update_func = update_func; - context->user_data = user_data; - context->all_okay = TRUE; - fd = g_file_open_tmp ("gdkpixbuf-xbm-tmp.XXXXXX", - &context->tempname, - NULL); - if (fd < 0) { - g_free (context); - return NULL; - } - - context->file = fdopen (fd, "w+"); - if (context->file == NULL) { - g_free (context->tempname); - g_free (context); - return NULL; - } - - return context; -} - -static gboolean -gdk_pixbuf__xbm_image_stop_load (gpointer data, - GError **error) -{ - XBMData *context = (XBMData*) data; - gboolean retval = TRUE; - - g_return_val_if_fail (data != NULL, TRUE); - - fflush (context->file); - rewind (context->file); - if (context->all_okay) { - GdkPixbuf *pixbuf; - pixbuf = gdk_pixbuf__xbm_image_load_real (context->file, - context, - error); - if (pixbuf == NULL) - retval = FALSE; - else - g_object_unref (pixbuf); - } - - fclose (context->file); - g_unlink (context->tempname); - g_free (context->tempname); - g_free ((XBMData *) context); - - return retval; -} - -static gboolean -gdk_pixbuf__xbm_image_load_increment (gpointer data, - const guchar *buf, - guint size, - GError **error) -{ - XBMData *context = (XBMData *) data; - - g_return_val_if_fail (data != NULL, FALSE); - - if (fwrite (buf, sizeof (guchar), size, context->file) != size) { - gint save_errno = errno; - context->all_okay = FALSE; - g_set_error_literal (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Failed to write to temporary file when loading XBM image")); - return FALSE; - } - - return TRUE; -} - -#ifndef INCLUDE_xbm -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__xbm_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->load = gdk_pixbuf__xbm_image_load; - module->begin_load = gdk_pixbuf__xbm_image_begin_load; - module->stop_load = gdk_pixbuf__xbm_image_stop_load; - module->load_increment = gdk_pixbuf__xbm_image_load_increment; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "#define ", NULL, 100 }, - { "/*", NULL, 50 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/x-xbitmap", - NULL - }; - static gchar * extensions[] = { - "xbm", - NULL - }; - - info->name = "xbm"; - info->signature = signature; - info->description = N_("The XBM image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/io-xpm.c b/gdk-pixbuf/io-xpm.c deleted file mode 100644 index b8a02d84cc..0000000000 --- a/gdk-pixbuf/io-xpm.c +++ /dev/null @@ -1,821 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ -/* GdkPixbuf library - XPM image loader - * - * Copyright (C) 1999 Mark Crichton - * Copyright (C) 1999 The Free Software Foundation - * - * Authors: Mark Crichton <crichton@gimp.org> - * Federico Mena-Quintero <federico@gimp.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <glib.h> -#ifdef HAVE_UNISTD_H -#include <unistd.h> /* for unlink */ -#endif -#include <errno.h> -#include "gdk-pixbuf-private.h" -#include "gdk-pixbuf-io.h" -#include <glib/gstdio.h> - - -/* I have must have done something to deserve this. - * XPM is such a crappy format to handle. - * This code is an ugly hybred from gdkpixmap.c - * modified to respect transparent colors. - * It's still a mess, though. - */ - -enum buf_op { - op_header, - op_cmap, - op_body -}; - -typedef struct { - gchar *color_string; - guint16 red; - guint16 green; - guint16 blue; - gint transparent; -} XPMColor; - -struct file_handle { - FILE *infile; - gchar *buffer; - guint buffer_size; -}; - -struct mem_handle { - const gchar **data; - int offset; -}; - -/* The following 2 routines (parse_color, find_color) come from Tk, via the Win32 - * port of GDK. The licensing terms on these (longer than the functions) is: - * - * This software is copyrighted by the Regents of the University of - * California, Sun Microsystems, Inc., and other parties. The following - * terms apply to all files associated with the software unless explicitly - * disclaimed in individual files. - * - * The authors hereby grant permission to use, copy, modify, distribute, - * and license this software and its documentation for any purpose, provided - * that existing copyright notices are retained in all copies and that this - * notice is included verbatim in any distributions. No written agreement, - * license, or royalty fee is required for any of the authorized uses. - * Modifications to this software may be copyrighted by their authors - * and need not follow the licensing terms described here, provided that - * the new terms are clearly indicated on the first page of each file where - * they apply. - * - * IN NO EVENT SHALL THE AUTHORS OR DISTRIBUTORS BE LIABLE TO ANY PARTY - * FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES - * ARISING OUT OF THE USE OF THIS SOFTWARE, ITS DOCUMENTATION, OR ANY - * DERIVATIVES THEREOF, EVEN IF THE AUTHORS HAVE BEEN ADVISED OF THE - * POSSIBILITY OF SUCH DAMAGE. - * - * THE AUTHORS AND DISTRIBUTORS SPECIFICALLY DISCLAIM ANY WARRANTIES, - * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT. THIS SOFTWARE - * IS PROVIDED ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE - * NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR - * MODIFICATIONS. - * - * GOVERNMENT USE: If you are acquiring this software on behalf of the - * U.S. government, the Government shall have only "Restricted Rights" - * in the software and related documentation as defined in the Federal - * Acquisition Regulations (FARs) in Clause 52.227.19 (c) (2). If you - * are acquiring the software on behalf of the Department of Defense, the - * software shall be classified as "Commercial Computer Software" and the - * Government shall have only "Restricted Rights" as defined in Clause - * 252.227-7013 (c) (1) of DFARs. Notwithstanding the foregoing, the - * authors grant the U.S. Government and others acting in its behalf - * permission to use and distribute the software in accordance with the - * terms specified in this license. - */ - -#include "xpm-color-table.h" - -/* - *---------------------------------------------------------------------- - * - * find_color -- - * - * This routine finds the color entry that corresponds to the - * specified color. - * - * Results: - * Returns non-zero on success. The RGB values of the XColor - * will be initialized to the proper values on success. - * - * Side effects: - * None. - * - *---------------------------------------------------------------------- - */ - -static int -compare_xcolor_entries (const void *a, const void *b) -{ - return g_ascii_strcasecmp ((const char *) a, - color_names + ((const XPMColorEntry *)b)->name_offset); -} - -static gboolean -find_color(const char *name, - XPMColor *colorPtr) -{ - XPMColorEntry *found; - - found = bsearch (name, xColors, G_N_ELEMENTS (xColors), sizeof (XPMColorEntry), - compare_xcolor_entries); - if (found == NULL) - return FALSE; - - colorPtr->red = (found->red * 65535) / 255; - colorPtr->green = (found->green * 65535) / 255; - colorPtr->blue = (found->blue * 65535) / 255; - - return TRUE; -} - -/* - *---------------------------------------------------------------------- - * - * parse_color -- - * - * Partial implementation of X color name parsing interface. - * - * Results: - * Returns TRUE on success. - * - * Side effects: - * None. - * - *---------------------------------------------------------------------- - */ - -static gboolean -parse_color (const char *spec, - XPMColor *colorPtr) -{ - if (spec[0] == '#') { - char fmt[16]; - int i, red, green, blue; - - if ((i = strlen (spec + 1)) % 3) { - return FALSE; - } - i /= 3; - - g_snprintf (fmt, 16, "%%%dx%%%dx%%%dx", i, i, i); - - if (sscanf (spec + 1, fmt, &red, &green, &blue) != 3) { - return FALSE; - } - if (i == 4) { - colorPtr->red = red; - colorPtr->green = green; - colorPtr->blue = blue; - } else if (i == 1) { - colorPtr->red = (red * 65535) / 15; - colorPtr->green = (green * 65535) / 15; - colorPtr->blue = (blue * 65535) / 15; - } else if (i == 2) - { - colorPtr->red = (red * 65535) / 255; - colorPtr->green = (green * 65535) / 255; - colorPtr->blue = (blue * 65535) / 255; - } else /* if (i == 3) */ { - colorPtr->red = (red * 65535) / 4095; - colorPtr->green = (green * 65535) / 4095; - colorPtr->blue = (blue * 65535) / 4095; - } - } else { - if (!find_color(spec, colorPtr)) - return FALSE; - } - return TRUE; -} - -static gint -xpm_seek_string (FILE *infile, const gchar *str) -{ - char instr[1024]; - - while (!feof (infile)) { - if (fscanf (infile, "%1023s", instr) < 0) - return FALSE; - if (strcmp (instr, str) == 0) - return TRUE; - } - - return FALSE; -} - -static gint -xpm_seek_char (FILE *infile, gchar c) -{ - gint b, oldb; - - while ((b = getc (infile)) != EOF) { - if (c != b && b == '/') { - b = getc (infile); - if (b == EOF) - return FALSE; - - else if (b == '*') { /* we have a comment */ - b = -1; - do { - oldb = b; - b = getc (infile); - if (b == EOF) - return FALSE; - } while (!(oldb == '*' && b == '/')); - } - } else if (c == b) - return TRUE; - } - - return FALSE; -} - -static gint -xpm_read_string (FILE *infile, gchar **buffer, guint *buffer_size) -{ - gint c; - guint cnt = 0, bufsiz, ret = FALSE; - gchar *buf; - - buf = *buffer; - bufsiz = *buffer_size; - if (buf == NULL) { - bufsiz = 10 * sizeof (gchar); - buf = g_new (gchar, bufsiz); - } - - do { - c = getc (infile); - } while (c != EOF && c != '"'); - - if (c != '"') - goto out; - - while ((c = getc (infile)) != EOF) { - if (cnt == bufsiz) { - guint new_size = bufsiz * 2; - - if (new_size > bufsiz) - bufsiz = new_size; - else - goto out; - - buf = g_realloc (buf, bufsiz); - buf[bufsiz - 1] = '\0'; - } - - if (c != '"') - buf[cnt++] = c; - else { - buf[cnt] = 0; - ret = TRUE; - break; - } - } - - out: - buf[bufsiz - 1] = '\0'; /* ensure null termination for errors */ - *buffer = buf; - *buffer_size = bufsiz; - return ret; -} - -static gchar * -xpm_extract_color (const gchar *buffer) -{ - const gchar *p = &buffer[0]; - gint new_key = 0; - gint key = 0; - gint current_key = 1; - gint space = 128; - gchar word[129], color[129], current_color[129]; - gchar *r; - - word[0] = '\0'; - color[0] = '\0'; - current_color[0] = '\0'; - while (1) { - /* skip whitespace */ - for (; *p != '\0' && g_ascii_isspace (*p); p++) { - } - /* copy word */ - for (r = word; *p != '\0' && !g_ascii_isspace (*p) && r - word < sizeof (word) - 1; p++, r++) { - *r = *p; - } - *r = '\0'; - if (*word == '\0') { - if (color[0] == '\0') /* incomplete colormap entry */ - return NULL; - else /* end of entry, still store the last color */ - new_key = 1; - } - else if (key > 0 && color[0] == '\0') /* next word must be a color name part */ - new_key = 0; - else { - if (strcmp (word, "c") == 0) - new_key = 5; - else if (strcmp (word, "g") == 0) - new_key = 4; - else if (strcmp (word, "g4") == 0) - new_key = 3; - else if (strcmp (word, "m") == 0) - new_key = 2; - else if (strcmp (word, "s") == 0) - new_key = 1; - else - new_key = 0; - } - if (new_key == 0) { /* word is a color name part */ - if (key == 0) /* key expected */ - return NULL; - /* accumulate color name */ - if (color[0] != '\0') { - strncat (color, " ", space); - space -= MIN (space, 1); - } - strncat (color, word, space); - space -= MIN (space, strlen (word)); - } - else { /* word is a key */ - if (key > current_key) { - current_key = key; - strcpy (current_color, color); - } - space = 128; - color[0] = '\0'; - key = new_key; - if (*p == '\0') break; - } - - } - if (current_key > 1) - return g_strdup (current_color); - else - return NULL; -} - -/* (almost) direct copy from gdkpixmap.c... loads an XPM from a file */ - -static const gchar * -file_buffer (enum buf_op op, gpointer handle) -{ - struct file_handle *h = handle; - - switch (op) { - case op_header: - if (xpm_seek_string (h->infile, "XPM") != TRUE) - break; - - if (xpm_seek_char (h->infile, '{') != TRUE) - break; - /* Fall through to the next xpm_seek_char. */ - - case op_cmap: - xpm_seek_char (h->infile, '"'); - fseek (h->infile, -1, SEEK_CUR); - /* Fall through to the xpm_read_string. */ - - case op_body: - if(!xpm_read_string (h->infile, &h->buffer, &h->buffer_size)) - return NULL; - return h->buffer; - - default: - g_assert_not_reached (); - } - - return NULL; -} - -/* This reads from memory */ -static const gchar * -mem_buffer (enum buf_op op, gpointer handle) -{ - struct mem_handle *h = handle; - switch (op) { - case op_header: - case op_cmap: - case op_body: - if (h->data[h->offset]) { - const gchar* retval; - - retval = h->data[h->offset]; - h->offset += 1; - return retval; - } - break; - - default: - g_assert_not_reached (); - break; - } - - return NULL; -} - -/* This function does all the work. */ -static GdkPixbuf * -pixbuf_create_from_xpm (const gchar * (*get_buf) (enum buf_op op, gpointer handle), gpointer handle, - GError **error) -{ - gint w, h, n_col, cpp, x_hot, y_hot, items; - gint cnt, xcnt, ycnt, wbytes, n; - gint is_trans = FALSE; - const gchar *buffer; - gchar *name_buf; - gchar pixel_str[32]; - GHashTable *color_hash; - XPMColor *colors, *color, *fallbackcolor; - guchar *pixtmp; - GdkPixbuf *pixbuf; - - fallbackcolor = NULL; - - buffer = (*get_buf) (op_header, handle); - if (!buffer) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("No XPM header found")); - return NULL; - } - items = sscanf (buffer, "%d %d %d %d %d %d", &w, &h, &n_col, &cpp, &x_hot, &y_hot); - - if (items != 4 && items != 6) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Invalid XPM header")); - return NULL; - } - - if (w <= 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("XPM file has image width <= 0")); - return NULL; - - } - if (h <= 0) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("XPM file has image height <= 0")); - return NULL; - - } - if (cpp <= 0 || cpp >= 32) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("XPM has invalid number of chars per pixel")); - return NULL; - } - if (n_col <= 0 || - n_col >= G_MAXINT / (cpp + 1) || - n_col >= G_MAXINT / sizeof (XPMColor)) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("XPM file has invalid number of colors")); - return NULL; - } - - /* The hash is used for fast lookups of color from chars */ - color_hash = g_hash_table_new (g_str_hash, g_str_equal); - - name_buf = g_try_malloc (n_col * (cpp + 1)); - if (!name_buf) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate memory for loading XPM image")); - g_hash_table_destroy (color_hash); - return NULL; - } - colors = (XPMColor *) g_try_malloc (sizeof (XPMColor) * n_col); - if (!colors) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate memory for loading XPM image")); - g_hash_table_destroy (color_hash); - g_free (name_buf); - return NULL; - } - - for (cnt = 0; cnt < n_col; cnt++) { - gchar *color_name; - - buffer = (*get_buf) (op_cmap, handle); - if (!buffer) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_CORRUPT_IMAGE, - _("Cannot read XPM colormap")); - g_hash_table_destroy (color_hash); - g_free (name_buf); - g_free (colors); - return NULL; - } - - color = &colors[cnt]; - color->color_string = &name_buf[cnt * (cpp + 1)]; - strncpy (color->color_string, buffer, cpp); - color->color_string[cpp] = 0; - buffer += strlen (color->color_string); - color->transparent = FALSE; - - color_name = xpm_extract_color (buffer); - - if ((color_name == NULL) || (g_ascii_strcasecmp (color_name, "None") == 0) - || (parse_color (color_name, color) == FALSE)) { - color->transparent = TRUE; - color->red = 0; - color->green = 0; - color->blue = 0; - is_trans = TRUE; - } - - g_free (color_name); - g_hash_table_insert (color_hash, color->color_string, color); - - if (cnt == 0) - fallbackcolor = color; - } - - pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, is_trans, 8, w, h); - - if (!pixbuf) { - g_set_error_literal (error, - GDK_PIXBUF_ERROR, - GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY, - _("Cannot allocate memory for loading XPM image")); - g_hash_table_destroy (color_hash); - g_free (colors); - g_free (name_buf); - return NULL; - } - - wbytes = w * cpp; - - for (ycnt = 0; ycnt < h; ycnt++) { - pixtmp = pixbuf->pixels + ycnt * pixbuf->rowstride; - - buffer = (*get_buf) (op_body, handle); - if ((!buffer) || (strlen (buffer) < wbytes)) - continue; - - for (n = 0, xcnt = 0; n < wbytes; n += cpp, xcnt++) { - strncpy (pixel_str, &buffer[n], cpp); - pixel_str[cpp] = 0; - - color = g_hash_table_lookup (color_hash, pixel_str); - - /* Bad XPM...punt */ - if (!color) - color = fallbackcolor; - - *pixtmp++ = color->red >> 8; - *pixtmp++ = color->green >> 8; - *pixtmp++ = color->blue >> 8; - - if (is_trans && color->transparent) - *pixtmp++ = 0; - else if (is_trans) - *pixtmp++ = 0xFF; - } - } - - g_hash_table_destroy (color_hash); - g_free (colors); - g_free (name_buf); - - if (items == 6) { - gchar hot[10]; - g_snprintf (hot, 10, "%d", x_hot); - gdk_pixbuf_set_option (pixbuf, "x_hot", hot); - g_snprintf (hot, 10, "%d", y_hot); - gdk_pixbuf_set_option (pixbuf, "y_hot", hot); - - } - - return pixbuf; -} - -/* Shared library entry point for file loading */ -static GdkPixbuf * -gdk_pixbuf__xpm_image_load (FILE *f, - GError **error) -{ - GdkPixbuf *pixbuf; - struct file_handle h; - - memset (&h, 0, sizeof (h)); - h.infile = f; - pixbuf = pixbuf_create_from_xpm (file_buffer, &h, error); - g_free (h.buffer); - - return pixbuf; -} - -/* Shared library entry point for memory loading */ -static GdkPixbuf * -gdk_pixbuf__xpm_image_load_xpm_data (const gchar **data) -{ - GdkPixbuf *pixbuf; - struct mem_handle h; - GError *error = NULL; - - h.data = data; - h.offset = 0; - - pixbuf = pixbuf_create_from_xpm (mem_buffer, &h, &error); - - if (error) { - g_warning ("Inline XPM data is broken: %s", error->message); - g_error_free (error); - error = NULL; - } - - return pixbuf; -} - -/* Progressive loader */ -typedef struct _XPMContext XPMContext; -struct _XPMContext -{ - GdkPixbufModulePreparedFunc prepare_func; - GdkPixbufModuleUpdatedFunc update_func; - gpointer user_data; - - gchar *tempname; - FILE *file; - gboolean all_okay; -}; - -/* - * FIXME xpm loading progressively is not properly implemented. - * Instead we will buffer to a file then load that file when done. - * This is very broken but it should be relayively simple to fix - * in the future. - */ -static gpointer -gdk_pixbuf__xpm_image_begin_load (GdkPixbufModuleSizeFunc size_func, - GdkPixbufModulePreparedFunc prepare_func, - GdkPixbufModuleUpdatedFunc update_func, - gpointer user_data, - GError **error) -{ - XPMContext *context; - gint fd; - - context = g_new (XPMContext, 1); - context->prepare_func = prepare_func; - context->update_func = update_func; - context->user_data = user_data; - context->all_okay = TRUE; - fd = g_file_open_tmp ("gdkpixbuf-xpm-tmp.XXXXXX", &context->tempname, - NULL); - if (fd < 0) { - g_free (context); - return NULL; - } - - context->file = fdopen (fd, "w+"); - if (context->file == NULL) { - g_free (context->tempname); - g_free (context); - return NULL; - } - - return context; -} - -static gboolean -gdk_pixbuf__xpm_image_stop_load (gpointer data, - GError **error) -{ - XPMContext *context = (XPMContext*) data; - GdkPixbuf *pixbuf; - gboolean retval = FALSE; - - g_return_val_if_fail (data != NULL, FALSE); - - fflush (context->file); - rewind (context->file); - if (context->all_okay) { - pixbuf = gdk_pixbuf__xpm_image_load (context->file, error); - - if (pixbuf != NULL) { - if (context->prepare_func) - (* context->prepare_func) (pixbuf, - NULL, - context->user_data); - if (context->update_func) - (* context->update_func) (pixbuf, 0, 0, pixbuf->width, pixbuf->height, context->user_data); - g_object_unref (pixbuf); - - retval = TRUE; - } - } - - fclose (context->file); - g_unlink (context->tempname); - g_free (context->tempname); - g_free ((XPMContext *) context); - - return retval; -} - -static gboolean -gdk_pixbuf__xpm_image_load_increment (gpointer data, - const guchar *buf, - guint size, - GError **error) -{ - XPMContext *context = (XPMContext *) data; - - g_return_val_if_fail (data != NULL, FALSE); - - if (fwrite (buf, sizeof (guchar), size, context->file) != size) { - gint save_errno = errno; - context->all_okay = FALSE; - g_set_error_literal (error, - G_FILE_ERROR, - g_file_error_from_errno (save_errno), - _("Failed to write to temporary file when loading XPM image")); - return FALSE; - } - - return TRUE; -} - -#ifndef INCLUDE_xpm -#define MODULE_ENTRY(function) G_MODULE_EXPORT void function -#else -#define MODULE_ENTRY(function) void _gdk_pixbuf__xpm_ ## function -#endif - -MODULE_ENTRY (fill_vtable) (GdkPixbufModule *module) -{ - module->load = gdk_pixbuf__xpm_image_load; - module->load_xpm_data = gdk_pixbuf__xpm_image_load_xpm_data; - module->begin_load = gdk_pixbuf__xpm_image_begin_load; - module->stop_load = gdk_pixbuf__xpm_image_stop_load; - module->load_increment = gdk_pixbuf__xpm_image_load_increment; -} - -MODULE_ENTRY (fill_info) (GdkPixbufFormat *info) -{ - static GdkPixbufModulePattern signature[] = { - { "/* XPM */", NULL, 100 }, - { NULL, NULL, 0 } - }; - static gchar * mime_types[] = { - "image/x-xpixmap", - NULL - }; - static gchar * extensions[] = { - "xpm", - NULL - }; - - info->name = "xpm"; - info->signature = signature; - info->description = N_("The XPM image format"); - info->mime_types = mime_types; - info->extensions = extensions; - info->flags = GDK_PIXBUF_FORMAT_THREADSAFE; - info->license = "LGPL"; -} diff --git a/gdk-pixbuf/make-inline-pixbuf.c b/gdk-pixbuf/make-inline-pixbuf.c deleted file mode 100644 index e2e1f6100d..0000000000 --- a/gdk-pixbuf/make-inline-pixbuf.c +++ /dev/null @@ -1,230 +0,0 @@ -/* Program to convert an image file to inline C data - * - * Copyright (C) 2000 Red Hat, Inc. - * - * Developed by Havoc Pennington <hp@redhat.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" -#include "gdk-pixbuf-private.h" -#include <glib/gstdio.h> -#include <errno.h> -#include <string.h> -#include <stdlib.h> - -void -output_int (FILE *outfile, guint32 num, const char *comment) -{ - guchar bytes[4]; - - /* Note, most significant bytes first */ - bytes[0] = num >> 24; - bytes[1] = num >> 16; - bytes[2] = num >> 8; - bytes[3] = num; - - g_fprintf (outfile, " /* %s (%u) */\n 0x%.2x, 0x%.2x, 0x%.2x, 0x%.2x,\n", - comment, num, - bytes[0], bytes[1], bytes[2], bytes[3]); -} - -void -output_bool (FILE *outfile, gboolean val, const char *comment) -{ - g_fprintf (outfile, " /* %s (%s) */\n 0x%.2x,\n", - comment, - val ? "TRUE" : "FALSE", - val ? 1 : 0); -} - -void -output_pixbuf (FILE *outfile, gboolean ext_symbols, - const char *varname, - GdkPixbuf *pixbuf) -{ - const char *modifier; - const guchar *p; - const guchar *end; - gboolean has_alpha; - int column; - - modifier = "static "; - if (ext_symbols) - modifier = ""; - - g_fprintf (outfile, "%sconst guchar ", modifier); - fputs (varname, outfile); - fputs ("[] =\n", outfile); - fputs ("{\n", outfile); - - p = gdk_pixbuf_get_pixels (pixbuf); - end = p + gdk_pixbuf_get_rowstride (pixbuf) * gdk_pixbuf_get_height (pixbuf); - has_alpha = gdk_pixbuf_get_has_alpha (pixbuf); - - /* Sync the order of writing with the order of reading in - * gdk-pixbuf-data.c - */ - output_int (outfile, GDK_PIXBUF_INLINE_MAGIC_NUMBER, "File magic"); - output_int (outfile, GDK_PIXBUF_INLINE_RAW, "Format of following stuff"); - output_int (outfile, gdk_pixbuf_get_rowstride (pixbuf), "Rowstride"); - output_int (outfile, gdk_pixbuf_get_width (pixbuf), "Width"); - output_int (outfile, gdk_pixbuf_get_height (pixbuf), "Height"); - - output_bool (outfile, has_alpha, "Has an alpha channel"); - - output_int (outfile, gdk_pixbuf_get_colorspace (pixbuf), "Colorspace (0 == RGB, no other options implemented)"); - - output_int (outfile, gdk_pixbuf_get_n_channels (pixbuf), "Number of channels"); - - output_int (outfile, gdk_pixbuf_get_bits_per_sample (pixbuf), "Bits per sample"); - - fputs (" /* Image data */\n", outfile); - - /* Copy the data in the pixbuf */ - column = 0; - while (p != end) - { - guchar r, g, b, a; - - r = *p; - ++p; - g = *p; - ++p; - b = *p; - ++p; - if (has_alpha) - { - a = *p; - ++p; - } - else - a = 0; - - - if (has_alpha) - g_fprintf (outfile, " 0x%.2x, 0x%.2x, 0x%.2x, 0x%.2x", r, g, b, a); - else - g_fprintf (outfile, " 0x%.2x, 0x%.2x, 0x%.2x", r, g, b); - - if (p != end) - fputs (",", outfile); - else - fputs ("\n", outfile); - - ++column; - - if (column > 2) - { - fputs ("\n", outfile); - column = 0; - } - } - - fputs ("};\n\n", outfile); -} - -void -usage (void) -{ - g_fprintf (stderr, "Usage: make-inline-pixbuf [--extern-symbols] OUTFILE varname1 imagefile1 varname2 imagefile2 ...\n"); - exit (1); -} - -int -main (int argc, char **argv) -{ - gboolean ext_symbols = FALSE; - FILE *outfile; - gchar *outfilename; - int i; - - g_type_init (); - - - if (argc < 4) - usage (); - - i = 1; - if (strcmp (argv[i], "--extern-symbols") == 0) - { - ext_symbols = TRUE; - ++i; - if (argc < 5) - usage (); - } - -#ifdef G_OS_WIN32 - outfilename = g_locale_to_utf8 (argv[i], -1, NULL, NULL, NULL) -#else - outfilename = argv[i]; -#endif - - outfile = g_fopen (outfilename, "w"); - if (outfile == NULL) - { - g_fprintf (stderr, "Failed to open output file `%s': %s\n", - argv[i], strerror (errno)); - exit (1); - } - - ++i; - - fputs ("/* This file was automatically generated by the make-inline-pixbuf program.\n" - " * It contains inline RGB image data.\n" - " */\n\n", outfile); - - /* Check for matched pairs of images/names */ - if (((argc - i) % 2) != 0) - usage (); - - while (i < argc) - { - GdkPixbuf *pixbuf = NULL; - GError *error; - gchar *infilename; - - g_assert ((i + 1) < argc); - - error = NULL; -#ifdef G_OS_WIN32 - infilename = g_locale_to_utf8 (argv[i+1], -1, NULL, NULL, &error); -#else - infilename = argv[i+1]; -#endif - if (infilename) - pixbuf = gdk_pixbuf_new_from_file (infilename, &error); - - if (pixbuf == NULL) - { - g_fprintf (stderr, "%s\n", error->message); - fclose (outfile); - g_remove (outfilename); - exit (1); - } - - output_pixbuf (outfile, ext_symbols, argv[i], pixbuf); - - g_object_unref (pixbuf); - - i += 2; - } - - fclose (outfile); - - return 0; -} diff --git a/gdk-pixbuf/makefile.msc b/gdk-pixbuf/makefile.msc deleted file mode 100644 index 7f6486afa1..0000000000 --- a/gdk-pixbuf/makefile.msc +++ /dev/null @@ -1,197 +0,0 @@ -TOP = ..\.. -PRJ_TOP = .. -PACKAGE = gdk_pixbuf -PKG_VER = $(GDK_PIXBUF_VER) - -!INCLUDE $(TOP)/glib/build/win32/make.msc - -!IFNDEF PERL -PERL = perl -!ENDIF - -GDK_PIXBUF_VER = 2.0 - -# -DINCLUDE_gdiplus _replaces_ -DINCLUDE_bmp -DINCLUDE_gif -DINCLUDE_ico -DINCLUDE_jpeg -DINCLUDE_tiff -# but not yet -DINCLUDE_png -##USEGDIP=1 -# to get _working_ include modules we need respective defines ... -# -BUILT_IN_FORMATS = \ -!IFDEF USEGDIP - -DINCLUDE_gdiplus \ -!ELSE - -DINCLUDE_bmp -DINCLUDE_gif -DINCLUDE_ico -DINCLUDE_jpeg -DINCLUDE_tiff \ -!ENDIF - -DINCLUDE_png \ - -DINCLUDE_xpm -DINCLUDE_wbmp \ - -DINCLUDE_pnm -DINCLUDE_ras - -PKG_CFLAGS = -FImsvc_recommended_pragmas.h \ -!IFNDEF USEGDIP - $(JPEG_CFLAGS) $(TIFF_CFLAGS) \ -!ENDIF - -I. -I.. $(GLIB_CFLAGS) \ - $(BUILT_IN_FORMATS) \ - $(PNG_CFLAGS) $(INTL_CFLAGS) \ - $(G_DEBUGGING) \ - -DGDK_PIXBUF_ENABLE_BACKEND \ - -DGTK_PREFIX=\"/just/some/non/existing/path/\" \ - -UUSE_GMODULE # use built-in -# -DUSE_GMODULE -DPIXBUF_LIBDIR=\".\" - -PKG_LINK = $(GLIB_LIBS) \ -!IFNDEF USEGDIP - $(TIFF_LIBS) $(JPEG_LIBS) \ -!ENDIF - $(PNG_LIBS) $(INTL_LIBS) \ - pixops\pixops.lib \ - -OBJECTS_NON_NATIVE = \ - io-bmp.obj \ - io-gif.obj \ - io-ico.obj \ - io-tiff.obj \ - io-jpeg.obj \ - -OBJECTS_NATIVE = \ - io-gdip-animation.obj \ - io-gdip-bmp.obj \ - io-gdip-emf.obj \ - io-gdip-gif.obj \ - io-gdip-ico.obj \ - io-gdip-jpeg.obj \ - io-gdip-tiff.obj \ - io-gdip-utils.obj \ - io-gdip-wmf.obj - -OBJECTS = \ - gdk-pixbuf-enum-types.obj \ - gdk-pixbuf-animation.obj \ - gdk-pixbuf-data.obj \ - gdk-pixbuf-io.obj \ - gdk-pixbuf-loader.obj \ - gdk-pixbuf-scale.obj \ - gdk-pixbuf-scaled-anim.obj \ - gdk-pixbuf-util.obj \ - gdk-pixbuf.obj \ - gdk-pixbuf-simple-anim.obj \ - gdk-pixdata.obj \ - io-wbmp.obj \ - io-gif-animation.obj \ - io-png.obj \ - io-pnm.obj \ - io-ras.obj \ - io-xpm.obj \ -!IFDEF USEGDIP - $(OBJECTS_NATIVE) -!ELSE - $(OBJECTS_NON_NATIVE) -!ENDIF - -gdk_pixbuf_headers = \ - gdk-pixbuf.h \ - gdk-pixbuf-core.h \ - gdk-pixbuf-loader.h \ - gdk-pixbuf-transform.h - -gdk-pixbuf-marshal.h: gdk-pixbuf-marshal.list - ..\..\glib\gobject\glib-genmarshal --prefix=_gdk_pixbuf_marshal gdk-pixbuf-marshal.list --header >gdk-pixbuf-marshal.h - -gdk-pixbuf-marshal.c: gdk-pixbuf-marshal.h gdk-pixbuf-marshal.list - ..\..\glib\gobject\glib-genmarshal --prefix=_gdk_pixbuf_marshal gdk-pixbuf-marshal.list --body >gdk-pixbuf-marshal.c - -gdk-pixbuf-alias.h: gdk-pixbuf.symbols - perl makegdkpixbufalias.pl < gdk-pixbuf.symbols > gdk-pixbuf-alias.h - -gdk_pixbuf.def: gdk-pixbuf.symbols makefile.msc - echo EXPORTS > gdk_pixbuf.def - cl /EP -DINCLUDE_VARIABLES -DG_OS_WIN32 -DALL_FILES \ - -DG_GNUC_MALLOC= -DG_GNUC_CONST= -DG_GNUC_NULL_TERMINATED= -DG_GNUC_NORETURN= -DG_GNUC_PRINTF=;G_GNUC_PRINTF \ - gdk-pixbuf.symbols >> gdk_pixbuf.def - -gdk-pixbuf-aliasdef.c: gdk-pixbuf.symbols - perl makegdkpixbufalias.pl -def < gdk-pixbuf.symbols > gdk-pixbuf-aliasdef.c - -## common stuff - -INSTALL = copy - -CFLAGS = -I. -DHAVE_CONFIG_H - -sub-pixops : - cd pixops - nmake -f makefile.msc - cd .. - -## targets -all : \ - $(PRJ_TOP)\config.h \ - gdk-pixbuf-alias.h \ - gdk-pixbuf-aliasdef.c \ - gdk-pixbuf-marshal.h \ - gdk-pixbuf-marshal.c \ - sub-pixops \ - lib$(PACKAGE)-$(PKG_VER)-0.dll \ - $(PACKAGE)-$(PKG_VER)s.lib \ -# make-inline-pixbuf.exe \ - gdk-pixbuf-csource.exe \ - test-gdk-pixbuf.exe - -$(PACKAGE).res : $(PACKAGE).rc - rc -DBUILDNUMBER=0 -r -fo $(PACKAGE).res $(PACKAGE).rc - -$(PACKAGE)-$(PKG_VER)s.lib : $(OBJECTS) - lib /out:$(PACKAGE)-$(PKG_VER)s.lib $(OBJECTS) pixops\pixops.lib - -lib$(PACKAGE)-$(PKG_VER)-0.dll : $(OBJECTS) $(PACKAGE).def $(PACKAGE).res - $(CC) $(CFLAGS) -LD -Fe$@ $(OBJECTS) $(PKG_LINK) user32.lib advapi32.lib ole32.lib wsock32.lib $(PACKAGE).res \ - $(LDFLAGS) /implib:$(PACKAGE)-$(PKG_VER).lib /def:$(PACKAGE).def - -make-inline-pixbuf.exe : make-inline-pixbuf.c - $(CC) $(PKG_CFLAGS) -Femake-inline-pixbuf.exe make-inline-pixbuf.c $(PKG_LINK) $(PACKAGE)-$(PKG_VER).lib - -gdk-pixbuf-csource.exe : gdk-pixbuf-csource.c - $(CC) $(PKG_CFLAGS) -Fegdk-pixbuf-csource.exe gdk-pixbuf-csource.c $(PKG_LINK) $(PACKAGE)-$(PKG_VER).lib - -test-gdk-pixbuf.exe : test-gdk-pixbuf.c - $(CC) $(PKG_CFLAGS) -Fetest-gdk-pixbuf.exe test-gdk-pixbuf.c $(PKG_LINK) $(PACKAGE)-$(PKG_VER).lib - -# -# gdk-pixbuf-enum-types.h -# -gdk-pixbuf-enum-types.h : $(gdk_pixbuf_headers) makefile.msc - $(PERL) $(GLIB)\gobject\glib-mkenums \ - --fhead "#ifndef __GDK_PIXBUF__ENUM_TYPES_H__\n#define __GDK_PIXBUF_ENUM_TYPES_H__\n" \ - --fprod "/* enumerations from \"@filename@\" */\n" \ - --vhead "GType @enum_name@_get_type (void);\n#define GDK_TYPE_@ENUMSHORT@ (@enum_name@_get_type())\n" \ - --ftail "#endif /* __GDK_PIXBUF_ENUM_TYPES_H__ */" \ - $(gdk_pixbuf_headers) ) > gdk-pixbuf-enum-types.h - -# -# gdk-pixbuf-enum-types.c -# -gdk-pixbuf-enum-types.c: $(gdk_pixbuf_headers) makefile.msc - $(PERL) $(GLIB)\gobject\glib-mkenums \ - --fhead "#include <gdk-pixbuf/gdk-pixbuf.h>" \ - --fprod "\n/* enumerations from \"@filename@\" */" \ - --vhead "GType\n@enum_name@_get_type (void)\n{\n static GType etype = 0;\n if (etype == 0) {\n static const G@Type@Value values[] = {" \ - --vprod " { @VALUENAME@, \"@VALUENAME@\", \"@valuenick@\" }," \ - --vtail " { 0, NULL, NULL }\n };\n etype = g_@type@_register_static (\"@EnumName@\", values);\n }\n return etype;\n}\n" \ - $(gdk_pixbuf_headers) > gdk-pixbuf-enum-types.c - -gdk-pixbuf-enum-types.obj : gdk-pixbuf-enum-types.c gdk-pixbuf-enum-types.h - -$(PRJ_TOP)\config.h: $(PRJ_TOP)\config.h.win32 - copy $(PRJ_TOP)\config.h.win32 $(PRJ_TOP)\config.h - -.c.obj : - $(CC) $(CFLAGS) -GD -c $(PKG_CFLAGS) $< - -clean:: - del config.h - del gdk-pixbuf-marshal.h - del gdk-pixbuf-marshal.c - del gdk-pixbuf-alaias.h - - - diff --git a/gdk-pixbuf/makegdkpixbufalias.pl b/gdk-pixbuf/makegdkpixbufalias.pl deleted file mode 100755 index a03da363e9..0000000000 --- a/gdk-pixbuf/makegdkpixbufalias.pl +++ /dev/null @@ -1,137 +0,0 @@ -#!/usr/bin/perl -w - -my $do_def = 0; - -if (($#ARGV >= 0) && ($ARGV[0] eq "-def")) { - shift; - $do_def = 1; -} - -print <<EOF; -/* Generated by makegdkpixbufalias.pl */ - -#ifndef DISABLE_VISIBILITY - -#include <glib.h> - -#ifdef G_HAVE_GNUC_VISIBILITY - -EOF - -if ($do_def) { - print <<EOF -#undef IN_FILE -#define IN_FILE defined - -#undef IN_HEADER -#define IN_HEADER(x) 1 - -EOF -} -else { - print <<EOF -#define IN_FILE(x) 1 -#define IN_HEADER defined - -EOF -} - -my $in_comment = 0; -my $in_skipped_section = 0; - -while (<>) { - - # ignore empty lines - next if /^\s*$/; - - # skip comments - if ($_ =~ /^\s*\/\*/) - { - $in_comment = 1; - } - - if ($in_comment) - { - if ($_ =~ /\*\/\s$/) - { - $in_comment = 0; - } - - next; - } - - # handle ifdefs - if ($_ =~ /^\#endif/) - { - if (!$in_skipped_section) - { - print $_; - } - - $in_skipped_section = 0; - - next; - } - - if ($_ =~ /^\#ifdef\s+INCLUDE_VARIABLES|INCLUDE_INTERNAL_SYMBOLS|ALL_FILES/) - { - $in_skipped_section = 1; - } - - if ($in_skipped_section) - { - next; - } - - if ($_ =~ /^\#ifn?def\s+G/) - { - print $_; - - next; - } - - if ($_ =~ /^\#if.*(IN_FILE|IN_HEADER|IN_FILE)/) - { - print $_; - - next; - } - - chop; - my $str = $_; - my @words; - my $attributes = ""; - - @words = split(/ /, $str); - $str = shift(@words); - chomp($str); - my $alias = "IA__".$str; - - # Drop any Win32 specific .def file syntax, but keep attributes - foreach $word (@words) { - $attributes = "$attributes $word" unless $word eq "PRIVATE"; - } - - if (!$do_def) { - print <<EOF -extern __typeof ($str) $alias __attribute((visibility("hidden")))$attributes; -\#define $str $alias - -EOF - } - else { - print <<EOF -\#undef $str -extern __typeof ($str) $str __attribute((alias("$alias"), visibility("default"))); - -EOF - } -} - -print <<EOF; - -#endif /* G_HAVE_GNUC_VISIBILITY */ -#endif /* DISABLE_VISIBILITY */ -EOF - - diff --git a/gdk-pixbuf/pixops/DETAILS b/gdk-pixbuf/pixops/DETAILS deleted file mode 100644 index acf16f57e7..0000000000 --- a/gdk-pixbuf/pixops/DETAILS +++ /dev/null @@ -1,355 +0,0 @@ -General ideas of Pixops -======================= - - - Gain speed by special-casing the common case, and using - generic code to handle the uncommon case. - - - Most of the time in scaling an image is in the center; - however code that can handle edges properly is slow - because it needs to deal with the possibility of running - off the edge. So make the fast case code only handle - the centers, and use generic, slow, code for the edges, - -Structure of Pixops -=================== - -The code of pixops can roughly be grouped into four parts: - - - Filter computation functions - - - Functions for scaling or compositing lines and pixels - using precomputed filters - - - pixops process, the central driver that iterates through - the image calling pixel or line functions as necessary - - - Wrapper functions (pixops_scale/composite/composite_color) - that compute the filter, chooses the line and pixel functions - and then call pixops_processs with the filter, line, - and pixel functions. - - -pixops process is a pretty scary looking function: - -static void -pixops_process (guchar *dest_buf, - int render_x0, - int render_y0, - int render_x1, - int render_y1, - int dest_rowstride, - int dest_channels, - gboolean dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - gboolean src_has_alpha, - double scale_x, - double scale_y, - int check_x, - int check_y, - int check_size, - guint32 color1, - guint32 color2, - PixopsFilter *filter, - PixopsLineFunc line_func, - PixopsPixelFunc pixel_func) - -(Some of the arguments should be moved into structures. It's basically -"all the arguments to pixops_composite_color plus three more") The -arguments can be divided up into: - - -Information about the destination buffer - - guchar *dest_buf, int dest_rowstride, int dest_channels, gboolean dest_has_alpha, - -Information about the source buffer - - guchar *src_buf, int src_rowstride, int src_channels, gboolean src_has_alpha, - int src_width, int src_height, - -Information on how to scale the source buf and the region of the scaled source -to render onto the destination buffer - - int render_x0, int render_y0, int render_x1, int render_y1 - double scale_x, double scale_y - -Information about a constant color or check pattern onto which to to composite - - int check_x, int check_y, int check_size, guint32 color1, guint32 color2 - -Information precomputed to use during the scale operation - - PixopsFilter *filter, PixopsLineFunc line_func, OixopsPixelFunc pixel_func - - -Filter computation -================== - -The PixopsFilter structure looks like: - -struct _PixopsFilter -{ - int *weights; - int n_x; - int n_y; - double x_offset; - double y_offset; -}; - - -'weights' is an array of size: - - weights[SUBSAMPLE][SUBSAMPLE][n_x][n_y] - -SUBSAMPLE is a constant - currently 16 in pixops.c. - - -In order to compute a scaled destination pixel we convolve -an array of n_x by n_y source pixels with one of -the SUBSAMPLE * SUBSAMPLE filter matrices stored -in weights. The choice of filter matrix is determined -by the fractional part of the source location. - -To compute dest[i,j] we do the following: - - x = i * scale_x + x_offset; - y = i * scale_x + y_offset; - x_int = floor(x) - y_int = floor(y) - - C = weights[SUBSAMPLE*(x - x_int)][SUBSAMPLE*(y - y_int)] - total = sum[l=0..n_x-1, j=0..n_y-1] (C[l,m] * src[x_int + l, x_int + m]) - -The filter weights are integers scaled so that the total of the -weights in the weights array is equal to 65536. - -When the source does not have alpha, we simply compute each channel -as above, so total is in the range [0,255*65536] - - dest = src / 65536 - -When the source does have alpha, then we need to compute using -"pre-multiplied alpha": - - a_total = sum (C[l,m] * src_a[x_int + l, x_int + m]) - c_total = sum (C[l,m] * src_a[x_int + l, x_int + m] * src_c[x_int + l, x_int + m]) - -This gives us a result for c_total in the range of [0,255*a_total] - - c_dest = c_total / a_total - - -Mathematical aside: - -The process of producing a destination filter consists -of: - - - Producing a continuous approximation to the source - image via interpolation. - - - Sampling that continuous approximation with filter. - -This is representable as: - - S(x,y) = sum[i=-inf,inf; j=-inf,inf] A(frac(x),frac(y))[i,j] * S[floor(x)+i,floor(y)+j] - - D[i,j] = Integral(s=-inf,inf; t=-inf,inf) B(i+x,j+y) S((i+x)/scale_x,(i+y)/scale_y) - -By reordering the sums and integrals, you get something of the form: - - D[i,j] = sum[l=-inf,inf; m=-inf;inf] C[l,m] S[i+l,j+l] - -The arrays in weights are the C[l,m] above, and are thus -determined by the interpolating algorithm in use and the -sampling filter: - - INTERPOLATE SAMPLE - ART_FILTER_NEAREST nearest neighbour point - ART_FILTER_TILES nearest neighbour box - ART_FILTER_BILINEAR (scale < 1) nearest neighbour box (scale < 1) - ART_FILTER_BILINEAR (scale > 1) bilinear point (scale > 1) - ART_FILTER_HYPER bilinear box - - -Pixel Functions -=============== - -typedef void (*PixopsPixelFunc) (guchar *dest, int dest_x, int dest_channels, int dest_has_alpha, - int src_has_alpha, - int check_size, guint32 color1, guint32 color2, - int r, int g, int b, int a); - -The arguments here are: - - dest: location to store the output pixel - dest_x: x coordinate of destination (for handling checks) - dest_has_alpha, dest_channels: Information about the destination pixbuf - src_has_alpha: Information about the source pixbuf - - check_size, color1, color2: Information for color background for composite_color variant - - r,g,b,a - scaled red, green, blue and alpha - -r,g,b are premultiplied alpha. - - a is in [0,65536*255] - r is in [0,255*a] - g is in [0,255*a] - b is in [0,255*a] - -If src_has_alpha is false, then a will be 65536*255, allowing optimization. - - -Line functions -============== - -typedef guchar *(*PixopsLineFunc) (int *weights, int n_x, int n_y, - guchar *dest, int dest_x, guchar *dest_end, int dest_channels, int dest_has_alpha, - guchar **src, int src_channels, gboolean src_has_alpha, - int x_init, int x_step, int src_width, - int check_size, guint32 color1, guint32 color2); - -The argumets are: - - weights, n_x, n_y - - Filter weights for this row - dimensions weights[SUBSAMPLE][n_x][n_y] - - dest, dest_x, dest_end, dest_channels, dest_has_alpha - - The destination buffer, function will start writing into *dest and - increment by dest_channels, until dest == dest_end. Reading from - src for these pixels is guaranteed not to go outside of the - bufer bounds - - src, src_channels, src_has_alpha - - src[n_y] - an array of pointers to the start of the source rows - for each filter coordinate. - - x_init, x_step - - Information about x positions in source image. - - src_width - unused - - check_size, color1, color2: Information for color background for composite_color variant - - The total for the destination pixel at dest + i is given by - - SUM (l=0..n_x - 1, m=0..n_y - 1) - src[m][(x_init + i * x_step)>> SCALE_SHIFT + l] * weights[m][l] - - -Algorithms for compositing -========================== - -Compositing alpha on non alpha: - - R = As * Rs + (1 - As) * Rd - G = As * Gs + (1 - As) * Gd - B = As * Bs + (1 - As) * Bd - -This can be regrouped as: - - Cd + Cs * (Cs - Rd) - -Compositing alpha on alpha: - - A = As + (1 - As) * Ad - R = (As * Rs + (1 - As) * Rd * Ad) / A - G = (As * Gs + (1 - As) * Gd * Ad) / A - B = (As * Bs + (1 - As) * Bd * Ad) / A - -The way to think of this is in terms of the "area": - -The final pixel is composed of area As of the source pixel -and (1 - As) * Ad of the target pixel. So the final pixel -is a weighted average with those weights. - -Note that the weights do not add up to one - hence the -non-constant division. - - -Integer tricks for compositing -============================== - - - -MMX Code -======== - -Line functions are provided in MMX functionsfor a few special -cases: - - n_x = n_y = 2 - - src_channels = 3 dest_channels = 3 op = scale - src_channels = 4 with alpha dest_channels = 4 no alpha op = composite - src_channels = 4 with alpha dest_channels = 4 no alpha op = composite_color - -For the case n_x = n_y = 2 - primarily hit when scaling up with bilinear -scaling, we can take advantage of the fact that multiple destination -pixels will be composed from the same source pixels. - -That is a destination pixel is a linear combination of the source -pixels around it: - - - S0 S1 - - - - - - D D' D'' ... - - - - - S2 S3 - -Each mmx register is 64 bits wide, so we can unpack a source pixel -into the low 8 bits of 4 16 bit words, and store it into a mmx -register. - -For each destination pixel, we first make sure that we have pixels S0 -... S3 loaded into registers mm0 ...mm3. (This will often involve not -doing anything or moving mm1 and mm3 into mm0 and mm1 then reloading -mm1 and mm3 with new values). - -Then we load up the appropriate weights for the 4 corner pixels -based on the offsets of the destination pixel within the source -pixels. - -We have preexpanded the weights to 64 bits wide and truncated the -range to 8 bits, so an original filter value of - - 0x5321 would be expanded to - - 0x0053005300530053 - -For source buffers without alpha, we simply do a multiply-add -of the weights, giving us a 16 bit quantity for the result -that we shift left by 8 and store in the destination buffer. - -When the source buffer has alpha, then things become more -complicated - when we load up mm0 and mm3, we premultiply -the alpha, so they contain: - - (a*ff >> 8) (r*a >> 8) (g*a >> 8) (b*a >> a) - -Then when we multiply by the weights, and add we end up -with premultiplied r,g,b,a in the range of 0 .. 0xff * 0ff, -call them A,R,G,B - -We then need to composite with the dest pixels - which -we do by: - - r_dest = (R + ((0xff * 0xff - A) >> 8) * r_dest) >> 8 - -(0xff * 0xff) diff --git a/gdk-pixbuf/pixops/Makefile.am b/gdk-pixbuf/pixops/Makefile.am deleted file mode 100644 index fe7775a293..0000000000 --- a/gdk-pixbuf/pixops/Makefile.am +++ /dev/null @@ -1,34 +0,0 @@ -include $(top_srcdir)/Makefile.decl - -noinst_LTLIBRARIES = libpixops.la - -INCLUDES = \ - -I$(top_srcdir) -I$(top_builddir) \ - $(GTK_DEBUG_FLAGS) \ - $(GDK_PIXBUF_DEP_CFLAGS) - -noinst_PROGRAMS = timescale - -timescale_SOURCES = timescale.c -timescale_LDADD = libpixops.la $(GLIB_LIBS) $(GDK_PIXBUF_DEP_LIBS) - -if USE_MMX -mmx_sources = \ - have_mmx.S \ - scale_line_22_33_mmx.S \ - composite_line_22_4a4_mmx.S \ - composite_line_color_22_4a4_mmx.S -endif - -libpixops_la_SOURCES = \ - pixops.c \ - pixops.h \ - pixops-internal.h \ - $(mmx_sources) - -EXTRA_DIST += \ - DETAILS \ - pixbuf-transform-math.ltx \ - makefile.msc - --include $(top_srcdir)/git.mk diff --git a/gdk-pixbuf/pixops/README b/gdk-pixbuf/pixops/README deleted file mode 100644 index 354c3a1977..0000000000 --- a/gdk-pixbuf/pixops/README +++ /dev/null @@ -1,163 +0,0 @@ -The code in this directory implements optimized, filtered scaling -for pixmap data. - -This code is copyright Red Hat, Inc, 2000 and licensed under the terms -of the GNU Lesser General Public License (LGPL). - -(If you want to use it in a project where that license is not -appropriate, please contact me, and most likely something can be -worked out.) - -Owen Taylor <otaylor@redhat.com> - -PRINCIPLES -========== - -The general principle of this code is that it first computes a filter -matrix for the given filtering mode, and then calls a general driver -routine, passing in functions to composite pixels and lines. - -(The pixel functions are used for handling edge cases, and the line -functions are simply used for the middle parts of the image.) - -The system is designed so that the line functions can be simple, -don't have to worry about special cases, can be selected to -be specific to the particular formats involved. This allows them -to be hyper-optimized. Since most of the compution time is -spent in these functions, this results in an overall fast design. - -MMX assembly code for Intel (and compatible) processors is included -for a number of the most common special cases: - - scaling from RGB to RGB - compositing from RGBA to RGBx - compositing against a color from RGBA and storing in a RGBx buffer - -Alpha compositing 8 bit RGBAa onto RGB is defined in terms of -rounding the exact result (real values in [0,1]): - - cc = ca * aa + (1 - aa) * Cb - - Cc = ROUND [255. * (Ca/255. * Aa/255. + (1 - Aa/255.) * Cb/255.)] - -ROUND(i / 255.) can be computed exactly for i in [0,255*255] as: - - t = i + 0x80; result = (t + (t >> 8)) >> 8; [ call this as To8(i) ] - -So, - - t = Ca * Aa + (255 - Aa) * Cb + 0x80; - Cc = (t + (t >> 8)) >> 8; - -Alpha compositing 8 bit RaGaBaAa onto RbGbBbAa is a little harder, for -non-premultiplied alpha. The premultiplied result is simple: - - ac = aa + (1 - aa) * ab - cc = ca + (1 - aa) * cb - -Which can be computed in integers terms as: - - Cc = Ca + To8 ((255 - Aa) * Cb) - Ac = Aa + To8 ((255 - Aa) * Ab) - -For non-premultiplied alpha, we need divide the color components by -the alpha: - - +- (ca * aa + (1 - aa) * ab * cb)) / ac; aa != 0 - cc = | - +- cb; aa == 0 - -To calculate this as in integer, we note the alternate form: - - cc = cb + aa * (ca - cb) / ac - -[ 'cc = ca + (ac - aa) * (cb - ca) / ac' can also be useful numerically, - but isn't important here ] - -We can express this as integers as: - - Ac_tmp = Aa * 255 + (255 - Aa) * Ab; - - +- Cb + (255 * Aa * (Ca - Cb) + Ac_tmp / 2) / Ac_tmp ; Ca > Cb - Cc = | - +- Cb - (255 * Aa * (Cb - Ca) + Ac_tmp / 2) / Ac_tmp ; ca <= Cb - -Or, playing bit tricks to avoid the conditional - - Cc = Cb + (255 * Aa * (Ca - Cb) + (((Ca - Cb) >> 8) ^ (Ac_tmp / 2)) ) / Ac_tmp - -TODO -==== - -* ART_FILTER_HYPER is not correctly implemented. It is currently - implemented as a filter that is derived by doing linear interpolation - on the source image and then averaging that with a box filter. - - It should be defined as followed (see art_filterlevel.h) - - "HYPER is the highest quality reconstruction function. It is derived - from the hyperbolic filters in Wolberg's "Digital Image Warping," - and is formally defined as the hyperbolic-filter sampling the ideal - hyperbolic-filter interpolated image (the filter is designed to be - idempotent for 1:1 pixel mapping). It is the slowest and highest - quality." - - The current HYPER is probably as slow, but lower quality. Also, there - are some subtle errors in the calculation current HYPER that show up as dark - stripes if you scale a constant-color image. - -* There are some roundoff errors in the compositing routines. - the _nearest() variants do it right, most of the other code - is wrong to some degree or another. - - For instance, in composite_line_22_4a4(), we have: - - dest[0] = ((0xff0000 - a) * dest[0] + r) >> 24; - - if a is 0 (implies r == 0), then we have: - - (0xff0000 * dest[0]) >> 24 - - which gives results which are 1 to low: - - 255 => 254, 1 => 0. - - So, this should be something like: - - ((0xff0000 - a) * dest[0] + r + 0xffffff) >> 24; - - (Not checked, caveat emptor) - - An alternatve formulation of this as: - - dest[0] + (r - a * dest[0] + 0xffffff) >> 24 - - may be better numerically, but would need consideration for overflow. - -* The generic functions could be sped up considerably by - switching around conditionals and inner loops in various - places. - -* Right now, in several of the most common cases, there are - optimized mmx routines, but no optimized C routines. - - For instance, there is a - - pixops_composite_line_22_4a4_mmx() - - But no - - pixops_composite_line_22_4a4() - - Also, it may be desirable to include a few more special cases - in particular: - - pixops_composite_line_22_4a3() - - May be desirable. - -* Scaling down images by large scale factors is _slow_ since huge filter - matrixes are computed. (e.g., to scale down by a factor of 100, we compute - 101x101 filter matrixes. At some point, it would be more efficent to - switch over to subsampling when scaling down - one should never need a filter - matrix bigger than 16x16. - diff --git a/gdk-pixbuf/pixops/composite_line_22_4a4_mmx.S b/gdk-pixbuf/pixops/composite_line_22_4a4_mmx.S deleted file mode 100644 index 232bddf407..0000000000 --- a/gdk-pixbuf/pixops/composite_line_22_4a4_mmx.S +++ /dev/null @@ -1,241 +0,0 @@ -/* - * Copyright (C) 2000 Red Hat, Inc - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - .file "composite_line_22_4a4_mmx.S" - .version "01.01" -gcc2_compiled.: -.text - .align 16 - -#if !defined(__MINGW32__) && !defined(__CYGWIN__) && !defined(__INTERIX) - -/* Magic indicating no need for an executable stack */ -#if !defined __powerpc64__ && !defined __ia64__ -.section .note.GNU-stack; .previous -#endif - -.globl _pixops_composite_line_22_4a4_mmx - .type _pixops_composite_line_22_4a4_mmx,@function -_pixops_composite_line_22_4a4_mmx: - -#else - -.globl __pixops_composite_line_22_4a4_mmx -__pixops_composite_line_22_4a4_mmx: - -#endif -/* - * Arguments - * - * weights: 8(%ebp) - * p: 12(%ebp) %esi - * q1: 16(%ebp) - * q2: 20(%ebp) - * xstep: 24(%ebp) - * p_end: 28(%ebp) - * xinit: 32(%ebp) - * -*/ -/* - * Function call entry - */ - pushl %ebp - movl %esp,%ebp - subl $28,%esp - pushl %edi - pushl %esi - pushl %ebx -/* Locals: - * int x %ebx - * int x_scaled -24(%ebp) - */ - -/* - * Setup - */ -/* Initialize variables */ - movl 32(%ebp),%ebx - movl 32(%ebp),%edx - sarl $16,%edx - movl 12(%ebp),%esi - - movl %edx,-24(%ebp) - - cmpl 28(%ebp),%esi - jnb .out - -/* Load initial values into %mm1, %mm3 */ - shll $2, %edx - - pxor %mm4, %mm4 - - movl 16(%ebp),%edi - movl (%edi, %edx), %eax - movd (%edi, %edx), %mm5 - punpcklbw %mm4, %mm5 - shrl $24, %eax - movl $0x010101, %ecx - mull %ecx - orl $0xff000000, %eax - movd %eax, %mm1 - punpcklbw %mm4, %mm1 - pmullw %mm5,%mm1 - - movl -24(%ebp),%edx - shll $2, %edx - - movl 20(%ebp),%edi - movl (%edi, %edx), %eax - movd (%edi, %edx), %mm5 - punpcklbw %mm4, %mm5 - shrl $24, %eax - movl $0x010101, %ecx - mull %ecx - orl $0xff000000, %eax - movd %eax, %mm3 - punpcklbw %mm4, %mm3 - pmullw %mm5,%mm3 - - psrlw $8,%mm1 - psrlw $8,%mm3 - - addl $65536,%ebx - movl %ebx,%edx - sarl $16,%edx - - jmp .newx - .p2align 4,,7 -.loop: -/* int x_index = (x & 0xf000) >> 12 */ - movl %ebx,%eax - andl $0xf000,%eax - shrl $7,%eax - - movq (%edi,%eax),%mm4 - pmullw %mm0,%mm4 - movq 8(%edi,%eax),%mm5 - pmullw %mm1,%mm5 - movq 16(%edi,%eax),%mm6 - movq 24(%edi,%eax),%mm7 - pmullw %mm2,%mm6 - pmullw %mm3,%mm7 - paddw %mm4, %mm5 - paddw %mm6, %mm7 - paddw %mm5, %mm7 - - movl $0xffff,%ecx - movd %ecx,%mm4 - psllq $48,%mm4 - movq %mm4,%mm6 - psubw %mm7,%mm4 - pand %mm6,%mm4 - - movq %mm4,%mm5 - psrlq $16,%mm4 - por %mm4,%mm5 - psrlq $32,%mm5 - por %mm4,%mm5 - - psrlw $8,%mm5 - - movd (%esi),%mm7 - pxor %mm4,%mm4 - punpcklbw %mm4, %mm7 - - pmullw %mm7,%mm5 - -/* x += x_step; */ - addl 24(%ebp),%ebx -/* x_scale = x >> 16; */ - movl %ebx,%edx - sarl $16,%edx - - paddw %mm5,%mm6 - - psrlw $8,%mm6 - packuswb %mm6, %mm6 - movd %mm6,(%esi) - - addl $4, %esi - - cmpl %esi,28(%ebp) - je .out - - cmpl %edx,-24(%ebp) - je .loop - -.newx: - movl %edx,-24(%ebp) -/* - * Load the two new values into %mm1, %mm3, move old values into %mm0, %mm2 - */ - movq %mm1, %mm0 - movq %mm3, %mm2 - - shll $2, %edx - -# %mm4 will always be already clear here -# pxor %mm4, %mm4 - - movl 16(%ebp),%edi - movl (%edi, %edx), %eax - movd (%edi, %edx), %mm5 - punpcklbw %mm4, %mm5 - shrl $24, %eax - movl $0x010101, %ecx - mull %ecx -/* - * mull destroyed %edx, need to reconstitute - */ - movl -24(%ebp),%edx - shll $2, %edx - - orl $0xff000000, %eax - movd %eax, %mm1 - punpcklbw %mm4, %mm1 - pmullw %mm5,%mm1 - - movl 20(%ebp),%edi - movl (%edi, %edx), %eax - movd (%edi, %edx), %mm5 - punpcklbw %mm4, %mm5 - shrl $24, %eax - movl $0x010101, %ecx - mull %ecx - orl $0xff000000, %eax - movd %eax, %mm3 - punpcklbw %mm4, %mm3 - pmullw %mm5,%mm3 - - psrlw $8,%mm1 - psrlw $8,%mm3 - - movl 8(%ebp),%edi - - jmp .loop - -.out: - movl %esi,%eax - emms - leal -40(%ebp),%esp - popl %ebx - popl %esi - popl %edi - movl %ebp,%esp - popl %ebp - ret diff --git a/gdk-pixbuf/pixops/composite_line_color_22_4a4_mmx.S b/gdk-pixbuf/pixops/composite_line_color_22_4a4_mmx.S deleted file mode 100644 index ab7c8729e2..0000000000 --- a/gdk-pixbuf/pixops/composite_line_color_22_4a4_mmx.S +++ /dev/null @@ -1,253 +0,0 @@ -/* - * Copyright (C) 2000 Red Hat, Inc - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - .file "composite_line_color_22_4a4_mmx.S" - .version "01.01" -gcc2_compiled.: -.text - .align 16 - -#if !defined(__MINGW32__) && !defined(__CYGWIN__) && !defined(__INTERIX) - -/* Magic indicating no need for an executable stack */ -#if !defined __powerpc64__ && !defined __ia64__ -.section .note.GNU-stack; .previous -#endif - -.globl _pixops_composite_line_color_22_4a4_mmx - .type _pixops_composite_line_color_22_4a4_mmx,@function -_pixops_composite_line_color_22_4a4_mmx: - -#else - -.globl __pixops_composite_line_color_22_4a4_mmx -__pixops_composite_line_color_22_4a4_mmx: - -#endif -/* - * Arguments - * - * weights: 8(%ebp) - * p: 12(%ebp) %esi - * q1: 16(%ebp) - * q2: 20(%ebp) - * xstep: 24(%ebp) - * p_end: 28(%ebp) - * xinit: 32(%ebp) - * dest_x: 36(%ebp) - * check_shift: 40(%ebp) - * colors: 44(%ebp) - * -*/ - -/* - * Function call entry - */ - pushl %ebp - movl %esp,%ebp - subl $28,%esp - pushl %edi - pushl %esi - pushl %ebx -/* Locals: - * int x %ebx - * int x_scaled -24(%ebp) - */ - -/* - * Setup - */ -/* Initialize variables */ - movl 32(%ebp),%ebx - movl 32(%ebp),%edx - sarl $16,%edx - movl 12(%ebp),%esi - - movl %edx,-24(%ebp) - - cmpl 28(%ebp),%esi - jnb .out - -/* Load initial values into %mm1, %mm3 */ - shll $2, %edx - - pxor %mm4, %mm4 - - movl 16(%ebp),%edi - movl (%edi, %edx), %eax - movd (%edi, %edx), %mm5 - punpcklbw %mm4, %mm5 - shrl $24, %eax - movl $0x010101, %ecx - mull %ecx - orl $0xff000000, %eax - movd %eax, %mm1 - punpcklbw %mm4, %mm1 - pmullw %mm5,%mm1 - -/* - * mull destroyed %edx, need to reconstitute - */ - movl -24(%ebp),%edx - shll $2, %edx - - movl 20(%ebp),%edi - movl (%edi, %edx), %eax - movd (%edi, %edx), %mm5 - punpcklbw %mm4, %mm5 - shrl $24, %eax - movl $0x010101, %ecx - mull %ecx - orl $0xff000000, %eax - movd %eax, %mm3 - punpcklbw %mm4, %mm3 - pmullw %mm5,%mm3 - - psrlw $8,%mm1 - psrlw $8,%mm3 - - addl $65536,%ebx - movl %ebx,%edx - sarl $16,%edx - - jmp .newx - .p2align 4,,7 -.loop: -/* int x_index = (x & 0xf000) >> 12 */ - movl %ebx,%eax - andl $0xf000,%eax - shrl $7,%eax - - movq (%edi,%eax),%mm4 - pmullw %mm0,%mm4 - movq 8(%edi,%eax),%mm5 - pmullw %mm1,%mm5 - movq 16(%edi,%eax),%mm6 - movq 24(%edi,%eax),%mm7 - pmullw %mm2,%mm6 - pmullw %mm3,%mm7 - paddw %mm4, %mm5 - paddw %mm6, %mm7 - paddw %mm5, %mm7 - - movl $0xffff,%ecx - movd %ecx,%mm4 - psllq $48,%mm4 - movq %mm4,%mm6 - psubw %mm7,%mm4 - pand %mm6,%mm4 - - movq %mm4,%mm5 - psrlq $16,%mm4 - por %mm4,%mm5 - psrlq $32,%mm5 - por %mm4,%mm5 - - psrlw $8,%mm5 - - movl 36(%ebp),%eax - incl 36(%ebp) - - movl 40(%ebp),%ecx - shrl %cl,%eax - andl $1,%eax - - movl 44(%ebp),%ecx - movq (%ecx,%eax,8),%mm6 - - pmullw %mm6,%mm5 - -/* x += x_step; */ - addl 24(%ebp),%ebx -/* x_scale = x >> 16; */ - movl %ebx,%edx - sarl $16,%edx - - paddw %mm5,%mm7 - - psrlw $8,%mm7 - packuswb %mm7, %mm7 - movd %mm7,(%esi) - - addl $4, %esi - - cmpl %esi,28(%ebp) - je .out - - cmpl %edx,-24(%ebp) - je .loop - -.newx: - movl %edx,-24(%ebp) -/* - * Load the two new values into %mm1, %mm3, move old values into %mm0, %mm2 - */ - movq %mm1, %mm0 - movq %mm3, %mm2 - - shll $2, %edx - - pxor %mm4, %mm4 - - movl 16(%ebp),%edi - movl (%edi, %edx), %eax - movd (%edi, %edx), %mm5 - punpcklbw %mm4, %mm5 - shrl $24, %eax - movl $0x010101, %ecx - mull %ecx -/* - * mull destroyed %edx, need to reconstitute - */ - movl -24(%ebp),%edx - shll $2, %edx - - orl $0xff000000, %eax - movd %eax, %mm1 - punpcklbw %mm4, %mm1 - pmullw %mm5,%mm1 - - movl 20(%ebp),%edi - movl (%edi, %edx), %eax - movd (%edi, %edx), %mm5 - punpcklbw %mm4, %mm5 - shrl $24, %eax - movl $0x010101, %ecx - mull %ecx - orl $0xff000000, %eax - movd %eax, %mm3 - punpcklbw %mm4, %mm3 - pmullw %mm5,%mm3 - - psrlw $8,%mm1 - psrlw $8,%mm3 - - movl 8(%ebp),%edi - - jmp .loop - -.out: - movl %esi,%eax - emms - leal -40(%ebp),%esp - popl %ebx - popl %esi - popl %edi - movl %ebp,%esp - popl %ebp - ret diff --git a/gdk-pixbuf/pixops/have_mmx.S b/gdk-pixbuf/pixops/have_mmx.S deleted file mode 100644 index eb72678050..0000000000 --- a/gdk-pixbuf/pixops/have_mmx.S +++ /dev/null @@ -1,76 +0,0 @@ -/* - * Copyright (C) 2000 Red Hat, Inc - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - .file "have_mmx.S" - .version "01.01" -gcc2_compiled.: -.text - .align 16 - -#if !defined(__MINGW32__) && !defined(__CYGWIN__) && !defined(__INTERIX) - -/* Magic indicating no need for an executable stack */ -#if !defined __powerpc64__ && !defined __ia64__ -.section .note.GNU-stack; .previous -#endif - -.globl _pixops_have_mmx - .type _pixops_have_mmx,@function -_pixops_have_mmx: - -#else - -.globl __pixops_have_mmx -__pixops_have_mmx: - -#endif - - push %ebx - -# Check if bit 21 in flags word is writeable - - pushfl - popl %eax - movl %eax,%ebx - xorl $0x00200000, %eax - pushl %eax - popfl - pushfl - popl %eax - - cmpl %eax, %ebx - - je .notfound - -# OK, we have CPUID - - movl $1, %eax - cpuid - - test $0x00800000, %edx - jz .notfound - - movl $1, %eax - jmp .out - -.notfound: - movl $0, %eax -.out: - popl %ebx - ret - diff --git a/gdk-pixbuf/pixops/makefile.msc b/gdk-pixbuf/pixops/makefile.msc deleted file mode 100644 index f7132f83e9..0000000000 --- a/gdk-pixbuf/pixops/makefile.msc +++ /dev/null @@ -1,65 +0,0 @@ -TOP = ../../.. -PACKAGE = pixops -PRJ_TOP = ..\.. - -!INCLUDE $(TOP)/glib/build/win32/make.msc - -PKG_CFLAGS = -I.. $(GLIB_CFLAGS) - -OBJECTS = \ - pixops.obj \ - -#? timescale.obj - -## common stuff -## compiler and linker switches -!IFNDEF DEBUG -# Full optimization: -OPTIMIZE = -Ox -MD -LINKDEBUG = -!ELSE -# Debugging: -OPTIMIZE = -Zi -MDd -LINKDEBUG = /debug -!ENDIF - -# cl -? describes the options -CC = cl -G5 -GF $(OPTIMIZE) -W3 -nologo - -# No general LDFLAGS needed -LDFLAGS = /link $(LINKDEBUG) -INSTALL = copy - -CFLAGS = -I. -I$(PRJ_TOP) -DHAVE_CONFIG_H - -## targets -all : \ - $(PRJ_TOP)\config.h \ - $(PACKAGE).lib - -$(PACKAGE).lib : $(OBJECTS) - lib /out:$(PACKAGE).lib $(OBJECTS) - -$(PACKAGE).dll : $(OBJECTS) $(PACKAGE).def - $(CC) $(CFLAGS) -LD -Fe$(PACKAGE).dll $(OBJECTS) $(PKG_LINK) user32.lib advapi32.lib wsock32.lib $(LDFLAGS) /def:$(PACKAGE).def - -$(PRJ_TOP)\config.h: $(PRJ_TOP)\config.h.win32 - copy $(PRJ_TOP)\config.h.win32 $(PRJ_TOP)\config.h - -.c.obj : - $(CC) $(CFLAGS) -GD -c $(PKG_CFLAGS) $< - -clean:: - del config.h - del *.exe - del *.obj - del *.dll - del *.lib - del *.err - del *.map - del *.sym - del *.exp - del *.lk1 - del *.mk1 - del *.pdb - del *.ilk diff --git a/gdk-pixbuf/pixops/pixbuf-transform-math.ltx b/gdk-pixbuf/pixops/pixbuf-transform-math.ltx deleted file mode 100644 index 19e231308d..0000000000 --- a/gdk-pixbuf/pixops/pixbuf-transform-math.ltx +++ /dev/null @@ -1,112 +0,0 @@ -\documentclass{article} - -\begin{document} - -\title{Some image transform math} -\author{Owen Taylor} -\date{18 February 2003} -\maketitle - -\section{Basics} - -The transform process is composed of three steps; -first we reconstruct a continuous image from the -source data \(A_{i,j}\): -\[a(u,v) = \sum_{i = -\infty}^{\infty} \sum_{j = -\infty}^{\infty} A_{i,j}F\left( {u - i \atop v - j} \right) \] -Then we transform from destination coordinates to source coordinates: -\[b(x,y) = a\left(u(x,y) \atop v(x,y)\right) - = a\left(t_{00}x + t_{01}y + t_{02} \atop t_{10}x + t_{11}y + t_{12} \right)\] -Finally, we resample using a sampling function \(G\): -\[B_{x_0,y_0} = \int_{-\infty}^{\infty}\int_{-\infty}^{\infty} b(x,y)G\left( {x - x_0 \atop y - y_0} \right) dxdy\] -Putting all of these together: -\[B_{x_0,y_0} = -\int_{-\infty}^{\infty}\int_{-\infty}^{\infty} -\sum_{i = -\infty}^{\infty} \sum_{j = -\infty}^{\infty} A_{i,j} -F\left( {u(x,y) - i \atop v(x,y) - j} \right) -G\left( {x - x_0 \atop y - y_0} \right) dxdy\] -We can reverse the order of the integrals and the sums: -\[B_{x_0,y_0} = -\sum_{i = -\infty}^{\infty} \sum_{j = -\infty}^{\infty} A_{i,j} -\int_{-\infty}^{\infty}\int_{-\infty}^{\infty} -F\left( {u(x,y) - i \atop v(x,y) - j} \right) -G\left( {x - x_0 \atop y - y_0} \right) dxdy\] -Which shows that the destination pixel values are a linear combination of the -source pixel values. But the coefficents depend on \(x_0\) and \(y_0\). -To simplify this a bit, define: -\[i_0 = \lfloor u(x_0,y_0) \rfloor = \lfloor {t_{00}x_0 + t_{01}y_0 + t_{02}} \rfloor \] -\[j_0 = \lfloor v(x_0,y_0) \rfloor = \lfloor {t_{10}x_0 + t_{11}y_0 + t_{12}} \rfloor \] -\[\Delta_u = u(x_0,y_0) - i_0 = t_{00}x_0 + t_{01}y_0 + t_{02} - \lfloor {t_{00}x_0 + t_{01}y_0 + t_{02}} \rfloor \] -\[\Delta_v = v(x_0,y_0) - j_0 = t_{10}x_0 + t_{11}y_0 + t_{12} - \lfloor {t_{10}x_0 + t_{11}y_0 + t_{12}} \rfloor \] -Then making the transforms \(x' = x - x_0\), \(y' = y - x_0\), \(i' = i - i_0\), \(j' = j - x_0\) -\begin{eqnarray*} -F(u,v) & = & F\left( {t_{00}x + t_{01}y + t_{02} - i \atop t_{10}x + t_{11}y + t_{12} - j} \right)\\ - & = & F\left( {t_{00}(x'+x_0) + t_{01}(y'+y_0) + t_{02} - (i'+i_0) \atop - t_{10}(x'+x_0) + t_{11}(y'+y_0) + t_{12} - (j'+j_0)} \right) \\ - & = & F\left( {\Delta_u + t_{00}x' + t_{01}y' - i' \atop - \Delta_v + t_{10}x' + t_{11}y' - j'} \right) -\end{eqnarray*} -Using that, we can then reparameterize the sums and integrals and -define coefficients that depend only on \((\Delta_u,\Delta_v)\), -which we'll call the \emph{phase} at the point \((x_0,y_0)\): -\[ -B_{x_0,y_0} = -\sum_{i = -\infty}^{\infty} \sum_{j = -\infty}^{\infty} A_{i_0+i,j_0+j} C_{i,j}(\Delta_u,\Delta_v) -\] -\[ -C_{i,j}(\Delta_u,\Delta_v) = -\int_{-\infty}^{\infty}\int_{-\infty}^{\infty} -F\left( {\Delta_u + t_{00}x + t_{01}y - i \atop - \Delta_v + t_{10}x + t_{11}y - j} \right) -G\left( {x \atop y} \right) dxdy -\] -\section{Separability} -A frequent special case is when the reconstruction and sampling functions -are of the form: -\[F(u,v) = f(u)f(v)\] -\[G(x,y) = g(x)g(y)\] -If we also have a transform that is purely a scale and translation; -(\(t_{10} = 0\), \(t_{01} = 0\)), then we can separate -\(C_{i,j}(\Delta_u,\Delta_v)\) into the product of a \(x\) portion -and a \(y\) portion: -\[C_{i,j}(\Delta_u,\Delta_v) = c_{i}(\Delta_u) c_{j}(\Delta_v)\] -\[c_{i}(\Delta_u) = \int_{-\infty}^{\infty} f(\Delta_u + t_{00}x - i)g(x)dx\] -\[c_{j}(\Delta_v) = \int_{-\infty}^{\infty} f(\Delta_v + t_{11}y - j)g(y)dy\] - -\section{Some filters} -gdk-pixbuf provides 4 standard filters for scaling, under the names ``NEAREST'', -``TILES'', ``BILINEAR'', and ``HYPER''. All of turn out to be separable -as discussed in the previous section. -For ``NEAREST'' filter, the reconstruction function is simple replication -and the sampling function is a delta function\footnote{A delta function is an infinitely narrow spike, such that: -\[\int_{-\infty}^{\infty}\delta(x)f(x) = f(0)\]}: -\[f(t) = \cases{1, & if \(0 \le t \le 1\); \cr - 0, & otherwise}\] -\[g(t) = \delta(t - 0.5)\] -For ``TILES'', the reconstruction function is again replication, but we -replace the delta-function for sampling with a box filter: -\[f(t) = \cases{1, & if \(0 \le t \le 1\); \cr - 0, & otherwise}\] -\[g(t) = \cases{1, & if \(0 \le t \le 1\); \cr - 0, & otherwise}\] -The ``HYPER'' filter (in practice, it was originally intended to be -something else) uses bilinear interpolation for reconstruction and -a box filter for sampling: -\[f(t) = \cases{1 - |t - 0.5|, & if \(-0.5 \le t \le 1.5\); \cr - 0, & otherwise}\] -\[g(t) = \cases{1, & if \(0 \le t \le 1\); \cr - 0, & otherwise}\] -The ``BILINEAR'' filter is defined in a somewhat more complicated way; -the definition depends on the scale factor in the transform (\(t_{00}\) -or \(t_{01}]\). In the \(x\) direction, for \(t_{00} < 1\), it is -the same as for ``TILES'': -\[f_u(t) = \cases{1, & if \(0 \le t \le 1\); \cr - 0, & otherwise}\] -\[g_u(t) = \cases{1, & if \(0 \le t \le 1\); \cr - 0, & otherwise}\] -but for \(t_{10} > 1\), we use bilinear reconstruction and delta-function -sampling: -\[f_u(t) = \cases{1 - |t - 0.5|, & if \(-0.5 \le t \le 1.5\); \cr - 0, & otherwise}\] -\[g_u(t) = \delta(t - 0.5)\] -The behavior in the \(y\) direction depends in the same way on \(t_{11}\). -\end{document}
\ No newline at end of file diff --git a/gdk-pixbuf/pixops/pixops-internal.h b/gdk-pixbuf/pixops/pixops-internal.h deleted file mode 100644 index a048b6983b..0000000000 --- a/gdk-pixbuf/pixops/pixops-internal.h +++ /dev/null @@ -1,25 +0,0 @@ -/* - * Copyright (C) 2000 Red Hat, Inc - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ -#ifdef USE_MMX -guchar *_pixops_scale_line_22_33_mmx (guint32 weights[16][8], guchar *p, guchar *q1, guchar *q2, int x_step, guchar *p_stop, int x_init); -guchar *_pixops_composite_line_22_4a4_mmx (guint32 weights[16][8], guchar *p, guchar *q1, guchar *q2, int x_step, guchar *p_stop, int x_init); -guchar *_pixops_composite_line_color_22_4a4_mmx (guint32 weights[16][8], guchar *p, guchar *q1, guchar *q2, int x_step, guchar *p_stop, int x_init, int dest_x, int check_shift, int *colors); -int _pixops_have_mmx (void); -#endif - diff --git a/gdk-pixbuf/pixops/pixops.c b/gdk-pixbuf/pixops/pixops.c deleted file mode 100644 index 5db165c3ab..0000000000 --- a/gdk-pixbuf/pixops/pixops.c +++ /dev/null @@ -1,2560 +0,0 @@ -/* - * Copyright (C) 2000 Red Hat, Inc - * mediaLib integration Copyright (c) 2001-2007 Sun Microsystems, Inc. - * All rights reserved. (Brian Cameron, Dmitriy Demin, James Cheng, - * Padraig O'Briain) - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ -#include "config.h" -#include <math.h> -#include <glib.h> - -#include "pixops.h" -#include "pixops-internal.h" - -#define SUBSAMPLE_BITS 4 -#define SUBSAMPLE (1 << SUBSAMPLE_BITS) -#define SUBSAMPLE_MASK ((1 << SUBSAMPLE_BITS)-1) -#define SCALE_SHIFT 16 - -static void -_pixops_scale_real (guchar *dest_buf, - int render_x0, - int render_y0, - int render_x1, - int render_y1, - int dest_rowstride, - int dest_channels, - gboolean dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - gboolean src_has_alpha, - double scale_x, - double scale_y, - PixopsInterpType interp_type); - -typedef struct _PixopsFilter PixopsFilter; -typedef struct _PixopsFilterDimension PixopsFilterDimension; - -struct _PixopsFilterDimension -{ - int n; - double offset; - double *weights; -}; - -struct _PixopsFilter -{ - PixopsFilterDimension x; - PixopsFilterDimension y; - double overall_alpha; -}; - -typedef guchar *(*PixopsLineFunc) (int *weights, int n_x, int n_y, - guchar *dest, int dest_x, guchar *dest_end, - int dest_channels, int dest_has_alpha, - guchar **src, int src_channels, - gboolean src_has_alpha, int x_init, - int x_step, int src_width, int check_size, - guint32 color1, guint32 color2); -typedef void (*PixopsPixelFunc) (guchar *dest, int dest_x, int dest_channels, - int dest_has_alpha, int src_has_alpha, - int check_size, guint32 color1, - guint32 color2, - guint r, guint g, guint b, guint a); - -#ifdef USE_MEDIALIB -#include <stdlib.h> -#include <dlfcn.h> -#include <mlib_image.h> - -#ifdef HAVE_STRINGS_H -#include <strings.h> -#endif - -#ifdef HAVE_STRING_H -#include <string.h> -#endif - -#if defined(HAVE_SYS_SYSTEMINFO_H) -#include <sys/systeminfo.h> -#elif defined(HAVE_SYS_SYSINFO_H) -#include <sys/sysinfo.h> -#endif - -static void pixops_medialib_composite (guchar *dest_buf, - int dest_width, - int dest_height, - int dest_rowstride, - int dest_channels, - int dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - int src_has_alpha, - int dest_x, - int dest_y, - int dest_region_width, - int dest_region_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - PixopsInterpType interp_type, - int overall_alpha); - -static void pixops_medialib_scale (guchar *dest_buf, - int dest_width, - int dest_height, - int dest_rowstride, - int dest_channels, - int dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - int src_has_alpha, - int dest_x, - int dest_y, - int dest_region_width, - int dest_region_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - PixopsInterpType interp_type); - -typedef struct _mlInterp mlInterp; - -struct _mlInterp -{ - double tx; - double ty; - PixopsFilter po_filter; - void *interp_table; -}; - -static gboolean medialib_initialized = FALSE; -static gboolean use_medialib = TRUE; - -/* - * Sun mediaLib(tm) support. - * - * http://www.sun.com/processors/vis/mlib.html - * - */ -static void -_pixops_use_medialib () -{ - char *mlib_version_string; - char sys_info[257]; - long count; - - medialib_initialized = TRUE; - - if (getenv ("GDK_DISABLE_MEDIALIB")) - { - use_medialib = FALSE; - return; - } - - /* - * The imaging functions we want to use were added in mediaLib version 2. - * So turn off mediaLib support if the user has an older version. - * mlib_version returns a string in this format: - * - * mediaLib:0210:20011101:v8plusa - * ^^^^^^^^ ^^^^ ^^^^^^^^ ^^^^^^^ - * libname vers build ISALIST identifier - * date (in this case sparcv8plus+vis) - * - * The first 2 digits of the version are the major version. The 3rd digit - * is the minor version, and the 4th digit is the micro version. So the - * above string corresponds to version 2.1.0. In the following test we only - * care about the major version. - */ - mlib_version_string = mlib_version (); - - count = sysinfo (SI_ARCHITECTURE, &sys_info[0], 257); - - if (count != -1) - { - if (strcmp (sys_info, "i386") == 0) - { - char *mlib_target_isa = &mlib_version_string[23]; - - /* - * For x86 processors mediaLib generic C implementation - * does not give any performance advantage so disable it - */ - if (strncmp (mlib_target_isa, "sse", 3) != 0) - { - use_medialib = FALSE; - return; - } - - /* - * For x86 processors use of libumem conflicts with - * mediaLib, so avoid using it. - */ - if (dlsym (RTLD_PROBE, "umem_alloc") != NULL) - { - use_medialib = FALSE; - return; - } - } - } - else - { - /* Failed to get system architecture, disable mediaLib anyway */ - use_medialib = FALSE; - return; - } -} -#endif - -static int -get_check_shift (int check_size) -{ - int check_shift = 0; - g_return_val_if_fail (check_size >= 0, 4); - - while (!(check_size & 1)) - { - check_shift++; - check_size >>= 1; - } - - return check_shift; -} - -static void -pixops_scale_nearest (guchar *dest_buf, - int render_x0, - int render_y0, - int render_x1, - int render_y1, - int dest_rowstride, - int dest_channels, - gboolean dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - gboolean src_has_alpha, - double scale_x, - double scale_y) -{ - int i; - int x; - int x_step = (1 << SCALE_SHIFT) / scale_x; - int y_step = (1 << SCALE_SHIFT) / scale_y; - int xmax, xstart, xstop, x_pos, y_pos; - const guchar *p; - -#define INNER_LOOP(SRC_CHANNELS,DEST_CHANNELS,ASSIGN_PIXEL) \ - xmax = x + (render_x1 - render_x0) * x_step; \ - xstart = MIN (0, xmax); \ - xstop = MIN (src_width << SCALE_SHIFT, xmax); \ - p = src + (CLAMP (x, xstart, xstop) >> SCALE_SHIFT) * SRC_CHANNELS; \ - while (x < xstart) \ - { \ - ASSIGN_PIXEL; \ - dest += DEST_CHANNELS; \ - x += x_step; \ - } \ - while (x < xstop) \ - { \ - p = src + (x >> SCALE_SHIFT) * SRC_CHANNELS; \ - ASSIGN_PIXEL; \ - dest += DEST_CHANNELS; \ - x += x_step; \ - } \ - x_pos = x >> SCALE_SHIFT; \ - p = src + CLAMP (x_pos, 0, src_width - 1) * SRC_CHANNELS; \ - while (x < xmax) \ - { \ - ASSIGN_PIXEL; \ - dest += DEST_CHANNELS; \ - x += x_step; \ - } - - for (i = 0; i < (render_y1 - render_y0); i++) - { - const guchar *src; - guchar *dest; - y_pos = ((i + render_y0) * y_step + y_step / 2) >> SCALE_SHIFT; - y_pos = CLAMP (y_pos, 0, src_height - 1); - src = src_buf + y_pos * src_rowstride; - dest = dest_buf + i * dest_rowstride; - - x = render_x0 * x_step + x_step / 2; - - if (src_channels == 3) - { - if (dest_channels == 3) - { - INNER_LOOP (3, 3, dest[0]=p[0];dest[1]=p[1];dest[2]=p[2]); - } - else - { - INNER_LOOP (3, 4, dest[0]=p[0];dest[1]=p[1];dest[2]=p[2];dest[3]=0xff); - } - } - else if (src_channels == 4) - { - if (dest_channels == 3) - { - INNER_LOOP (4, 3, dest[0]=p[0];dest[1]=p[1];dest[2]=p[2]); - } - else - { - guint32 *p32; - INNER_LOOP(4, 4, p32=(guint32*)dest;*p32=*((guint32*)p)); - } - } - } -} - -static void -pixops_composite_nearest (guchar *dest_buf, - int render_x0, - int render_y0, - int render_x1, - int render_y1, - int dest_rowstride, - int dest_channels, - gboolean dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - gboolean src_has_alpha, - double scale_x, - double scale_y, - int overall_alpha) -{ - int i; - int x; - int x_step = (1 << SCALE_SHIFT) / scale_x; - int y_step = (1 << SCALE_SHIFT) / scale_y; - int xmax, xstart, xstop, x_pos, y_pos; - const guchar *p; - unsigned int a0; - - for (i = 0; i < (render_y1 - render_y0); i++) - { - const guchar *src; - guchar *dest; - y_pos = ((i + render_y0) * y_step + y_step / 2) >> SCALE_SHIFT; - y_pos = CLAMP (y_pos, 0, src_height - 1); - src = src_buf + y_pos * src_rowstride; - dest = dest_buf + i * dest_rowstride; - - x = render_x0 * x_step + x_step / 2; - - INNER_LOOP(src_channels, dest_channels, - if (src_has_alpha) - a0 = (p[3] * overall_alpha) / 0xff; - else - a0 = overall_alpha; - - switch (a0) - { - case 0: - break; - case 255: - dest[0] = p[0]; - dest[1] = p[1]; - dest[2] = p[2]; - if (dest_has_alpha) - dest[3] = 0xff; - break; - default: - if (dest_has_alpha) - { - unsigned int w0 = 0xff * a0; - unsigned int w1 = (0xff - a0) * dest[3]; - unsigned int w = w0 + w1; - - dest[0] = (w0 * p[0] + w1 * dest[0]) / w; - dest[1] = (w0 * p[1] + w1 * dest[1]) / w; - dest[2] = (w0 * p[2] + w1 * dest[2]) / w; - dest[3] = w / 0xff; - } - else - { - unsigned int a1 = 0xff - a0; - unsigned int tmp; - - tmp = a0 * p[0] + a1 * dest[0] + 0x80; - dest[0] = (tmp + (tmp >> 8)) >> 8; - tmp = a0 * p[1] + a1 * dest[1] + 0x80; - dest[1] = (tmp + (tmp >> 8)) >> 8; - tmp = a0 * p[2] + a1 * dest[2] + 0x80; - dest[2] = (tmp + (tmp >> 8)) >> 8; - } - break; - } - ); - } -} - -static void -pixops_composite_color_nearest (guchar *dest_buf, - int render_x0, - int render_y0, - int render_x1, - int render_y1, - int dest_rowstride, - int dest_channels, - gboolean dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - gboolean src_has_alpha, - double scale_x, - double scale_y, - int overall_alpha, - int check_x, - int check_y, - int check_size, - guint32 color1, - guint32 color2) -{ - int i, j; - int x; - int x_step = (1 << SCALE_SHIFT) / scale_x; - int y_step = (1 << SCALE_SHIFT) / scale_y; - int r1, g1, b1, r2, g2, b2; - int check_shift = get_check_shift (check_size); - int xmax, xstart, xstop, x_pos, y_pos; - const guchar *p; - unsigned int a0; - - for (i = 0; i < (render_y1 - render_y0); i++) - { - const guchar *src; - guchar *dest; - y_pos = ((i + render_y0) * y_step + y_step / 2) >> SCALE_SHIFT; - y_pos = CLAMP (y_pos, 0, src_height - 1); - src = src_buf + y_pos * src_rowstride; - dest = dest_buf + i * dest_rowstride; - - x = render_x0 * x_step + x_step / 2; - - - if (((i + check_y) >> check_shift) & 1) - { - r1 = (color2 & 0xff0000) >> 16; - g1 = (color2 & 0xff00) >> 8; - b1 = color2 & 0xff; - - r2 = (color1 & 0xff0000) >> 16; - g2 = (color1 & 0xff00) >> 8; - b2 = color1 & 0xff; - } - else - { - r1 = (color1 & 0xff0000) >> 16; - g1 = (color1 & 0xff00) >> 8; - b1 = color1 & 0xff; - - r2 = (color2 & 0xff0000) >> 16; - g2 = (color2 & 0xff00) >> 8; - b2 = color2 & 0xff; - } - - j = 0; - INNER_LOOP(src_channels, dest_channels, - if (src_has_alpha) - a0 = (p[3] * overall_alpha + 0xff) >> 8; - else - a0 = overall_alpha; - - switch (a0) - { - case 0: - if (((j + check_x) >> check_shift) & 1) - { - dest[0] = r2; - dest[1] = g2; - dest[2] = b2; - } - else - { - dest[0] = r1; - dest[1] = g1; - dest[2] = b1; - } - break; - case 255: - dest[0] = p[0]; - dest[1] = p[1]; - dest[2] = p[2]; - break; - default: - { - unsigned int tmp; - if (((j + check_x) >> check_shift) & 1) - { - tmp = ((int) p[0] - r2) * a0; - dest[0] = r2 + ((tmp + (tmp >> 8) + 0x80) >> 8); - tmp = ((int) p[1] - g2) * a0; - dest[1] = g2 + ((tmp + (tmp >> 8) + 0x80) >> 8); - tmp = ((int) p[2] - b2) * a0; - dest[2] = b2 + ((tmp + (tmp >> 8) + 0x80) >> 8); - } - else - { - tmp = ((int) p[0] - r1) * a0; - dest[0] = r1 + ((tmp + (tmp >> 8) + 0x80) >> 8); - tmp = ((int) p[1] - g1) * a0; - dest[1] = g1 + ((tmp + (tmp >> 8) + 0x80) >> 8); - tmp = ((int) p[2] - b1) * a0; - dest[2] = b1 + ((tmp + (tmp >> 8) + 0x80) >> 8); - } - } - break; - } - - if (dest_channels == 4) - dest[3] = 0xff; - - j++; - ); - } -} -#undef INNER_LOOP - -static void -composite_pixel (guchar *dest, int dest_x, int dest_channels, int dest_has_alpha, - int src_has_alpha, int check_size, guint32 color1, guint32 color2, - guint r, guint g, guint b, guint a) -{ - if (dest_has_alpha) - { - unsigned int w0 = a - (a >> 8); - unsigned int w1 = ((0xff0000 - a) >> 8) * dest[3]; - unsigned int w = w0 + w1; - - if (w != 0) - { - dest[0] = (r - (r >> 8) + w1 * dest[0]) / w; - dest[1] = (g - (g >> 8) + w1 * dest[1]) / w; - dest[2] = (b - (b >> 8) + w1 * dest[2]) / w; - dest[3] = w / 0xff00; - } - else - { - dest[0] = 0; - dest[1] = 0; - dest[2] = 0; - dest[3] = 0; - } - } - else - { - dest[0] = (r + (0xff0000 - a) * dest[0]) / 0xff0000; - dest[1] = (g + (0xff0000 - a) * dest[1]) / 0xff0000; - dest[2] = (b + (0xff0000 - a) * dest[2]) / 0xff0000; - } -} - -static guchar * -composite_line (int *weights, int n_x, int n_y, - guchar *dest, int dest_x, guchar *dest_end, int dest_channels, int dest_has_alpha, - guchar **src, int src_channels, gboolean src_has_alpha, - int x_init, int x_step, int src_width, - int check_size, guint32 color1, guint32 color2) -{ - int x = x_init; - int i, j; - - while (dest < dest_end) - { - int x_scaled = x >> SCALE_SHIFT; - unsigned int r = 0, g = 0, b = 0, a = 0; - int *pixel_weights; - - pixel_weights = weights + ((x >> (SCALE_SHIFT - SUBSAMPLE_BITS)) & SUBSAMPLE_MASK) * n_x * n_y; - - for (i=0; i<n_y; i++) - { - guchar *q = src[i] + x_scaled * src_channels; - int *line_weights = pixel_weights + n_x * i; - - for (j=0; j<n_x; j++) - { - unsigned int ta; - - if (src_has_alpha) - ta = q[3] * line_weights[j]; - else - ta = 0xff * line_weights[j]; - - r += ta * q[0]; - g += ta * q[1]; - b += ta * q[2]; - a += ta; - - q += src_channels; - } - } - - if (dest_has_alpha) - { - unsigned int w0 = a - (a >> 8); - unsigned int w1 = ((0xff0000 - a) >> 8) * dest[3]; - unsigned int w = w0 + w1; - - if (w != 0) - { - dest[0] = (r - (r >> 8) + w1 * dest[0]) / w; - dest[1] = (g - (g >> 8) + w1 * dest[1]) / w; - dest[2] = (b - (b >> 8) + w1 * dest[2]) / w; - dest[3] = w / 0xff00; - } - else - { - dest[0] = 0; - dest[1] = 0; - dest[2] = 0; - dest[3] = 0; - } - } - else - { - dest[0] = (r + (0xff0000 - a) * dest[0]) / 0xff0000; - dest[1] = (g + (0xff0000 - a) * dest[1]) / 0xff0000; - dest[2] = (b + (0xff0000 - a) * dest[2]) / 0xff0000; - } - - dest += dest_channels; - x += x_step; - } - - return dest; -} - -static guchar * -composite_line_22_4a4 (int *weights, int n_x, int n_y, - guchar *dest, int dest_x, guchar *dest_end, int dest_channels, int dest_has_alpha, - guchar **src, int src_channels, gboolean src_has_alpha, - int x_init, int x_step, int src_width, - int check_size, guint32 color1, guint32 color2) -{ - int x = x_init; - guchar *src0 = src[0]; - guchar *src1 = src[1]; - - g_return_val_if_fail (src_channels != 3, dest); - g_return_val_if_fail (src_has_alpha, dest); - - while (dest < dest_end) - { - int x_scaled = x >> SCALE_SHIFT; - unsigned int r, g, b, a, ta; - int *pixel_weights; - guchar *q0, *q1; - int w1, w2, w3, w4; - - q0 = src0 + x_scaled * 4; - q1 = src1 + x_scaled * 4; - - pixel_weights = (int *)((char *)weights + - ((x >> (SCALE_SHIFT - SUBSAMPLE_BITS - 4)) & (SUBSAMPLE_MASK << 4))); - - w1 = pixel_weights[0]; - w2 = pixel_weights[1]; - w3 = pixel_weights[2]; - w4 = pixel_weights[3]; - - a = w1 * q0[3]; - r = a * q0[0]; - g = a * q0[1]; - b = a * q0[2]; - - ta = w2 * q0[7]; - r += ta * q0[4]; - g += ta * q0[5]; - b += ta * q0[6]; - a += ta; - - ta = w3 * q1[3]; - r += ta * q1[0]; - g += ta * q1[1]; - b += ta * q1[2]; - a += ta; - - ta = w4 * q1[7]; - r += ta * q1[4]; - g += ta * q1[5]; - b += ta * q1[6]; - a += ta; - - dest[0] = ((0xff0000 - a) * dest[0] + r) >> 24; - dest[1] = ((0xff0000 - a) * dest[1] + g) >> 24; - dest[2] = ((0xff0000 - a) * dest[2] + b) >> 24; - dest[3] = a >> 16; - - dest += 4; - x += x_step; - } - - return dest; -} - -#ifdef USE_MMX -static guchar * -composite_line_22_4a4_mmx_stub (int *weights, int n_x, int n_y, guchar *dest, - int dest_x, guchar *dest_end, - int dest_channels, int dest_has_alpha, - guchar **src, int src_channels, - gboolean src_has_alpha, int x_init, - int x_step, int src_width, int check_size, - guint32 color1, guint32 color2) -{ - guint32 mmx_weights[16][8]; - int j; - - for (j=0; j<16; j++) - { - mmx_weights[j][0] = 0x00010001 * (weights[4*j] >> 8); - mmx_weights[j][1] = 0x00010001 * (weights[4*j] >> 8); - mmx_weights[j][2] = 0x00010001 * (weights[4*j + 1] >> 8); - mmx_weights[j][3] = 0x00010001 * (weights[4*j + 1] >> 8); - mmx_weights[j][4] = 0x00010001 * (weights[4*j + 2] >> 8); - mmx_weights[j][5] = 0x00010001 * (weights[4*j + 2] >> 8); - mmx_weights[j][6] = 0x00010001 * (weights[4*j + 3] >> 8); - mmx_weights[j][7] = 0x00010001 * (weights[4*j + 3] >> 8); - } - - return _pixops_composite_line_22_4a4_mmx (mmx_weights, dest, src[0], src[1], - x_step, dest_end, x_init); -} -#endif /* USE_MMX */ - -static void -composite_pixel_color (guchar *dest, int dest_x, int dest_channels, - int dest_has_alpha, int src_has_alpha, int check_size, - guint32 color1, guint32 color2, guint r, guint g, - guint b, guint a) -{ - int dest_r, dest_g, dest_b; - int check_shift = get_check_shift (check_size); - - if ((dest_x >> check_shift) & 1) - { - dest_r = (color2 & 0xff0000) >> 16; - dest_g = (color2 & 0xff00) >> 8; - dest_b = color2 & 0xff; - } - else - { - dest_r = (color1 & 0xff0000) >> 16; - dest_g = (color1 & 0xff00) >> 8; - dest_b = color1 & 0xff; - } - - dest[0] = ((0xff0000 - a) * dest_r + r) >> 24; - dest[1] = ((0xff0000 - a) * dest_g + g) >> 24; - dest[2] = ((0xff0000 - a) * dest_b + b) >> 24; - - if (dest_has_alpha) - dest[3] = 0xff; - else if (dest_channels == 4) - dest[3] = a >> 16; -} - -static guchar * -composite_line_color (int *weights, int n_x, int n_y, guchar *dest, - int dest_x, guchar *dest_end, int dest_channels, - int dest_has_alpha, guchar **src, int src_channels, - gboolean src_has_alpha, int x_init, int x_step, - int src_width, int check_size, guint32 color1, - guint32 color2) -{ - int x = x_init; - int i, j; - int check_shift = get_check_shift (check_size); - int dest_r1, dest_g1, dest_b1; - int dest_r2, dest_g2, dest_b2; - - g_return_val_if_fail (check_size != 0, dest); - - dest_r1 = (color1 & 0xff0000) >> 16; - dest_g1 = (color1 & 0xff00) >> 8; - dest_b1 = color1 & 0xff; - - dest_r2 = (color2 & 0xff0000) >> 16; - dest_g2 = (color2 & 0xff00) >> 8; - dest_b2 = color2 & 0xff; - - while (dest < dest_end) - { - int x_scaled = x >> SCALE_SHIFT; - unsigned int r = 0, g = 0, b = 0, a = 0; - int *pixel_weights; - - pixel_weights = weights + ((x >> (SCALE_SHIFT - SUBSAMPLE_BITS)) & SUBSAMPLE_MASK) * n_x * n_y; - - for (i=0; i<n_y; i++) - { - guchar *q = src[i] + x_scaled * src_channels; - int *line_weights = pixel_weights + n_x * i; - - for (j=0; j<n_x; j++) - { - unsigned int ta; - - if (src_has_alpha) - ta = q[3] * line_weights[j]; - else - ta = 0xff * line_weights[j]; - - r += ta * q[0]; - g += ta * q[1]; - b += ta * q[2]; - a += ta; - - q += src_channels; - } - } - - if ((dest_x >> check_shift) & 1) - { - dest[0] = ((0xff0000 - a) * dest_r2 + r) >> 24; - dest[1] = ((0xff0000 - a) * dest_g2 + g) >> 24; - dest[2] = ((0xff0000 - a) * dest_b2 + b) >> 24; - } - else - { - dest[0] = ((0xff0000 - a) * dest_r1 + r) >> 24; - dest[1] = ((0xff0000 - a) * dest_g1 + g) >> 24; - dest[2] = ((0xff0000 - a) * dest_b1 + b) >> 24; - } - - if (dest_has_alpha) - dest[3] = 0xff; - else if (dest_channels == 4) - dest[3] = a >> 16; - - dest += dest_channels; - x += x_step; - dest_x++; - } - - return dest; -} - -#ifdef USE_MMX -static guchar * -composite_line_color_22_4a4_mmx_stub (int *weights, int n_x, int n_y, - guchar *dest, int dest_x, - guchar *dest_end, int dest_channels, - int dest_has_alpha, guchar **src, - int src_channels, gboolean src_has_alpha, - int x_init, int x_step, int src_width, - int check_size, guint32 color1, - guint32 color2) -{ - guint32 mmx_weights[16][8]; - int check_shift = get_check_shift (check_size); - int colors[4]; - int j; - - for (j=0; j<16; j++) - { - mmx_weights[j][0] = 0x00010001 * (weights[4*j] >> 8); - mmx_weights[j][1] = 0x00010001 * (weights[4*j] >> 8); - mmx_weights[j][2] = 0x00010001 * (weights[4*j + 1] >> 8); - mmx_weights[j][3] = 0x00010001 * (weights[4*j + 1] >> 8); - mmx_weights[j][4] = 0x00010001 * (weights[4*j + 2] >> 8); - mmx_weights[j][5] = 0x00010001 * (weights[4*j + 2] >> 8); - mmx_weights[j][6] = 0x00010001 * (weights[4*j + 3] >> 8); - mmx_weights[j][7] = 0x00010001 * (weights[4*j + 3] >> 8); - } - - colors[0] = (color1 & 0xff00) << 8 | (color1 & 0xff); - colors[1] = (color1 & 0xff0000) >> 16; - colors[2] = (color2 & 0xff00) << 8 | (color2 & 0xff); - colors[3] = (color2 & 0xff0000) >> 16; - - return _pixops_composite_line_color_22_4a4_mmx (mmx_weights, dest, src[0], - src[1], x_step, dest_end, x_init, dest_x, check_shift, colors); -} -#endif /* USE_MMX */ - -static void -scale_pixel (guchar *dest, int dest_x, int dest_channels, int dest_has_alpha, - int src_has_alpha, int check_size, guint32 color1, guint32 color2, - guint r, guint g, guint b, guint a) -{ - if (src_has_alpha) - { - if (a) - { - dest[0] = r / a; - dest[1] = g / a; - dest[2] = b / a; - dest[3] = a >> 16; - } - else - { - dest[0] = 0; - dest[1] = 0; - dest[2] = 0; - dest[3] = 0; - } - } - else - { - dest[0] = (r + 0xffffff) >> 24; - dest[1] = (g + 0xffffff) >> 24; - dest[2] = (b + 0xffffff) >> 24; - - if (dest_has_alpha) - dest[3] = 0xff; - } -} - -static guchar * -scale_line (int *weights, int n_x, int n_y, guchar *dest, int dest_x, - guchar *dest_end, int dest_channels, int dest_has_alpha, - guchar **src, int src_channels, gboolean src_has_alpha, int x_init, - int x_step, int src_width, int check_size, guint32 color1, - guint32 color2) -{ - int x = x_init; - int i, j; - - while (dest < dest_end) - { - int x_scaled = x >> SCALE_SHIFT; - int *pixel_weights; - - pixel_weights = weights + - ((x >> (SCALE_SHIFT - SUBSAMPLE_BITS)) & SUBSAMPLE_MASK) * n_x * n_y; - - if (src_has_alpha) - { - unsigned int r = 0, g = 0, b = 0, a = 0; - for (i=0; i<n_y; i++) - { - guchar *q = src[i] + x_scaled * src_channels; - int *line_weights = pixel_weights + n_x * i; - - for (j=0; j<n_x; j++) - { - unsigned int ta; - - ta = q[3] * line_weights[j]; - r += ta * q[0]; - g += ta * q[1]; - b += ta * q[2]; - a += ta; - - q += src_channels; - } - } - - if (a) - { - dest[0] = r / a; - dest[1] = g / a; - dest[2] = b / a; - dest[3] = a >> 16; - } - else - { - dest[0] = 0; - dest[1] = 0; - dest[2] = 0; - dest[3] = 0; - } - } - else - { - unsigned int r = 0, g = 0, b = 0; - for (i=0; i<n_y; i++) - { - guchar *q = src[i] + x_scaled * src_channels; - int *line_weights = pixel_weights + n_x * i; - - for (j=0; j<n_x; j++) - { - unsigned int ta = line_weights[j]; - - r += ta * q[0]; - g += ta * q[1]; - b += ta * q[2]; - - q += src_channels; - } - } - - dest[0] = (r + 0xffff) >> 16; - dest[1] = (g + 0xffff) >> 16; - dest[2] = (b + 0xffff) >> 16; - - if (dest_has_alpha) - dest[3] = 0xff; - } - - dest += dest_channels; - - x += x_step; - } - - return dest; -} - -#ifdef USE_MMX -static guchar * -scale_line_22_33_mmx_stub (int *weights, int n_x, int n_y, guchar *dest, - int dest_x, guchar *dest_end, int dest_channels, - int dest_has_alpha, guchar **src, int src_channels, - gboolean src_has_alpha, int x_init, int x_step, - int src_width, int check_size, guint32 color1, - guint32 color2) -{ - guint32 mmx_weights[16][8]; - int j; - - for (j=0; j<16; j++) - { - mmx_weights[j][0] = 0x00010001 * (weights[4*j] >> 8); - mmx_weights[j][1] = 0x00010001 * (weights[4*j] >> 8); - mmx_weights[j][2] = 0x00010001 * (weights[4*j + 1] >> 8); - mmx_weights[j][3] = 0x00010001 * (weights[4*j + 1] >> 8); - mmx_weights[j][4] = 0x00010001 * (weights[4*j + 2] >> 8); - mmx_weights[j][5] = 0x00010001 * (weights[4*j + 2] >> 8); - mmx_weights[j][6] = 0x00010001 * (weights[4*j + 3] >> 8); - mmx_weights[j][7] = 0x00010001 * (weights[4*j + 3] >> 8); - } - - return _pixops_scale_line_22_33_mmx (mmx_weights, dest, src[0], src[1], - x_step, dest_end, x_init); -} -#endif /* USE_MMX */ - -static guchar * -scale_line_22_33 (int *weights, int n_x, int n_y, guchar *dest, int dest_x, - guchar *dest_end, int dest_channels, int dest_has_alpha, - guchar **src, int src_channels, gboolean src_has_alpha, - int x_init, int x_step, int src_width, - int check_size, guint32 color1, guint32 color2) -{ - int x = x_init; - guchar *src0 = src[0]; - guchar *src1 = src[1]; - - while (dest < dest_end) - { - unsigned int r, g, b; - int x_scaled = x >> SCALE_SHIFT; - int *pixel_weights; - guchar *q0, *q1; - int w1, w2, w3, w4; - - q0 = src0 + x_scaled * 3; - q1 = src1 + x_scaled * 3; - - pixel_weights = weights + - ((x >> (SCALE_SHIFT - SUBSAMPLE_BITS)) & SUBSAMPLE_MASK) * 4; - - w1 = pixel_weights[0]; - w2 = pixel_weights[1]; - w3 = pixel_weights[2]; - w4 = pixel_weights[3]; - - r = w1 * q0[0]; - g = w1 * q0[1]; - b = w1 * q0[2]; - - r += w2 * q0[3]; - g += w2 * q0[4]; - b += w2 * q0[5]; - - r += w3 * q1[0]; - g += w3 * q1[1]; - b += w3 * q1[2]; - - r += w4 * q1[3]; - g += w4 * q1[4]; - b += w4 * q1[5]; - - dest[0] = (r + 0x8000) >> 16; - dest[1] = (g + 0x8000) >> 16; - dest[2] = (b + 0x8000) >> 16; - - dest += 3; - x += x_step; - } - - return dest; -} - -static void -process_pixel (int *weights, int n_x, int n_y, guchar *dest, int dest_x, - int dest_channels, int dest_has_alpha, guchar **src, - int src_channels, gboolean src_has_alpha, int x_start, - int src_width, int check_size, guint32 color1, guint32 color2, - PixopsPixelFunc pixel_func) -{ - unsigned int r = 0, g = 0, b = 0, a = 0; - int i, j; - - for (i=0; i<n_y; i++) - { - int *line_weights = weights + n_x * i; - - for (j=0; j<n_x; j++) - { - unsigned int ta; - guchar *q; - - if (x_start + j < 0) - q = src[i]; - else if (x_start + j < src_width) - q = src[i] + (x_start + j) * src_channels; - else - q = src[i] + (src_width - 1) * src_channels; - - if (src_has_alpha) - ta = q[3] * line_weights[j]; - else - ta = 0xff * line_weights[j]; - - r += ta * q[0]; - g += ta * q[1]; - b += ta * q[2]; - a += ta; - } - } - - (*pixel_func) (dest, dest_x, dest_channels, dest_has_alpha, src_has_alpha, - check_size, color1, color2, r, g, b, a); -} - -static void -correct_total (int *weights, - int n_x, - int n_y, - int total, - double overall_alpha) -{ - int correction = (int)(0.5 + 65536 * overall_alpha) - total; - int remaining, c, d, i; - - if (correction != 0) - { - remaining = correction; - for (d = 1, c = correction; c != 0 && remaining != 0; d++, c = correction / d) - for (i = n_x * n_y - 1; i >= 0 && c != 0 && remaining != 0; i--) - if (*(weights + i) + c >= 0) - { - *(weights + i) += c; - remaining -= c; - if ((0 < remaining && remaining < c) || - (0 > remaining && remaining > c)) - c = remaining; - } - } -} - -static int * -make_filter_table (PixopsFilter *filter) -{ - int i_offset, j_offset; - int n_x = filter->x.n; - int n_y = filter->y.n; - int *weights = g_new (int, SUBSAMPLE * SUBSAMPLE * n_x * n_y); - - for (i_offset=0; i_offset < SUBSAMPLE; i_offset++) - for (j_offset=0; j_offset < SUBSAMPLE; j_offset++) - { - double weight; - int *pixel_weights = weights + ((i_offset*SUBSAMPLE) + j_offset) * n_x * n_y; - int total = 0; - int i, j; - - for (i=0; i < n_y; i++) - for (j=0; j < n_x; j++) - { - weight = filter->x.weights[(j_offset * n_x) + j] * - filter->y.weights[(i_offset * n_y) + i] * - filter->overall_alpha * 65536 + 0.5; - - total += (int)weight; - - *(pixel_weights + n_x * i + j) = weight; - } - - correct_total (pixel_weights, n_x, n_y, total, filter->overall_alpha); - } - - return weights; -} - -static void -pixops_process (guchar *dest_buf, - int render_x0, - int render_y0, - int render_x1, - int render_y1, - int dest_rowstride, - int dest_channels, - gboolean dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - gboolean src_has_alpha, - double scale_x, - double scale_y, - int check_x, - int check_y, - int check_size, - guint32 color1, - guint32 color2, - PixopsFilter *filter, - PixopsLineFunc line_func, - PixopsPixelFunc pixel_func) -{ - int i, j; - int x, y; /* X and Y position in source (fixed_point) */ - - guchar **line_bufs; - int *filter_weights; - - int x_step; - int y_step; - - int check_shift; - int scaled_x_offset; - - int run_end_x; - int run_end_index; - - x_step = (1 << SCALE_SHIFT) / scale_x; /* X step in source (fixed point) */ - y_step = (1 << SCALE_SHIFT) / scale_y; /* Y step in source (fixed point) */ - - if (x_step == 0 || y_step == 0) - return; /* overflow, bail out */ - - line_bufs = g_new (guchar *, filter->y.n); - filter_weights = make_filter_table (filter); - - check_shift = check_size ? get_check_shift (check_size) : 0; - - scaled_x_offset = floor (filter->x.offset * (1 << SCALE_SHIFT)); - - /* Compute the index where we run off the end of the source buffer. The - * furthest source pixel we access at index i is: - * - * ((render_x0 + i) * x_step + scaled_x_offset) >> SCALE_SHIFT + filter->x.n - 1 - * - * So, run_end_index is the smallest i for which this pixel is src_width, - * i.e, for which: - * - * (i + render_x0) * x_step >= ((src_width - filter->x.n + 1) << SCALE_SHIFT) - scaled_x_offset - * - */ -#define MYDIV(a,b) ((a) > 0 ? (a) / (b) : ((a) - (b) + 1) / (b)) /* Division so that -1/5 = -1 */ - - run_end_x = (((src_width - filter->x.n + 1) << SCALE_SHIFT) - scaled_x_offset); - run_end_index = MYDIV (run_end_x + x_step - 1, x_step) - render_x0; - run_end_index = MIN (run_end_index, render_x1 - render_x0); - - y = render_y0 * y_step + floor (filter->y.offset * (1 << SCALE_SHIFT)); - for (i = 0; i < (render_y1 - render_y0); i++) - { - int dest_x; - int y_start = y >> SCALE_SHIFT; - int x_start; - int *run_weights = filter_weights + - ((y >> (SCALE_SHIFT - SUBSAMPLE_BITS)) & SUBSAMPLE_MASK) * - filter->x.n * filter->y.n * SUBSAMPLE; - guchar *new_outbuf; - guint32 tcolor1, tcolor2; - - guchar *outbuf = dest_buf + dest_rowstride * i; - guchar *outbuf_end = outbuf + dest_channels * (render_x1 - render_x0); - - if (((i + check_y) >> check_shift) & 1) - { - tcolor1 = color2; - tcolor2 = color1; - } - else - { - tcolor1 = color1; - tcolor2 = color2; - } - - for (j=0; j<filter->y.n; j++) - { - if (y_start < 0) - line_bufs[j] = (guchar *)src_buf; - else if (y_start < src_height) - line_bufs[j] = (guchar *)src_buf + src_rowstride * y_start; - else - line_bufs[j] = (guchar *)src_buf + src_rowstride * (src_height - 1); - - y_start++; - } - - dest_x = check_x; - x = render_x0 * x_step + scaled_x_offset; - x_start = x >> SCALE_SHIFT; - - while (x_start < 0 && outbuf < outbuf_end) - { - process_pixel (run_weights + ((x >> (SCALE_SHIFT - SUBSAMPLE_BITS)) & SUBSAMPLE_MASK) * (filter->x.n * filter->y.n), filter->x.n, filter->y.n, - outbuf, dest_x, dest_channels, dest_has_alpha, - line_bufs, src_channels, src_has_alpha, - x >> SCALE_SHIFT, src_width, - check_size, tcolor1, tcolor2, pixel_func); - - x += x_step; - x_start = x >> SCALE_SHIFT; - dest_x++; - outbuf += dest_channels; - } - - new_outbuf = (*line_func) (run_weights, filter->x.n, filter->y.n, - outbuf, dest_x, dest_buf + dest_rowstride * - i + run_end_index * dest_channels, - dest_channels, dest_has_alpha, - line_bufs, src_channels, src_has_alpha, - x, x_step, src_width, check_size, tcolor1, - tcolor2); - - dest_x += (new_outbuf - outbuf) / dest_channels; - - x = (dest_x - check_x + render_x0) * x_step + scaled_x_offset; - outbuf = new_outbuf; - - while (outbuf < outbuf_end) - { - process_pixel (run_weights + ((x >> (SCALE_SHIFT - SUBSAMPLE_BITS)) & SUBSAMPLE_MASK) * (filter->x.n * filter->y.n), filter->x.n, filter->y.n, - outbuf, dest_x, dest_channels, dest_has_alpha, - line_bufs, src_channels, src_has_alpha, - x >> SCALE_SHIFT, src_width, - check_size, tcolor1, tcolor2, pixel_func); - - x += x_step; - dest_x++; - outbuf += dest_channels; - } - - y += y_step; - } - - g_free (line_bufs); - g_free (filter_weights); -} - -/* Compute weights for reconstruction by replication followed by - * sampling with a box filter - */ -static void -tile_make_weights (PixopsFilterDimension *dim, - double scale) -{ - int n = ceil (1 / scale + 1); - double *pixel_weights = g_new (double, SUBSAMPLE * n); - int offset; - int i; - - dim->n = n; - dim->offset = 0; - dim->weights = pixel_weights; - - for (offset = 0; offset < SUBSAMPLE; offset++) - { - double x = (double)offset / SUBSAMPLE; - double a = x + 1 / scale; - - for (i = 0; i < n; i++) - { - if (i < x) - { - if (i + 1 > x) - *(pixel_weights++) = (MIN (i + 1, a) - x) * scale; - else - *(pixel_weights++) = 0; - } - else - { - if (a > i) - *(pixel_weights++) = (MIN (i + 1, a) - i) * scale; - else - *(pixel_weights++) = 0; - } - } - } -} - -/* Compute weights for a filter that, for minification - * is the same as 'tiles', and for magnification, is bilinear - * reconstruction followed by a sampling with a delta function. - */ -static void -bilinear_magnify_make_weights (PixopsFilterDimension *dim, - double scale) -{ - double *pixel_weights; - int n; - int offset; - int i; - - if (scale > 1.0) /* Linear */ - { - n = 2; - dim->offset = 0.5 * (1 / scale - 1); - } - else /* Tile */ - { - n = ceil (1.0 + 1.0 / scale); - dim->offset = 0.0; - } - - dim->n = n; - dim->weights = g_new (double, SUBSAMPLE * n); - - pixel_weights = dim->weights; - - for (offset=0; offset < SUBSAMPLE; offset++) - { - double x = (double)offset / SUBSAMPLE; - - if (scale > 1.0) /* Linear */ - { - for (i = 0; i < n; i++) - *(pixel_weights++) = (((i == 0) ? (1 - x) : x) / scale) * scale; - } - else /* Tile */ - { - double a = x + 1 / scale; - - /* x - * ---------|--.-|----|--.-|------- SRC - * ------------|---------|--------- DEST - */ - for (i = 0; i < n; i++) - { - if (i < x) - { - if (i + 1 > x) - *(pixel_weights++) = (MIN (i + 1, a) - x) * scale; - else - *(pixel_weights++) = 0; - } - else - { - if (a > i) - *(pixel_weights++) = (MIN (i + 1, a) - i) * scale; - else - *(pixel_weights++) = 0; - } - } - } - } -} - -/* Computes the integral from b0 to b1 of - * - * f(x) = x; 0 <= x < 1 - * f(x) = 0; otherwise - * - * We combine two of these to compute the convolution of - * a box filter with a triangular spike. - */ -static double -linear_box_half (double b0, double b1) -{ - double a0, a1; - double x0, x1; - - a0 = 0.; - a1 = 1.; - - if (a0 < b0) - { - if (a1 > b0) - { - x0 = b0; - x1 = MIN (a1, b1); - } - else - return 0; - } - else - { - if (b1 > a0) - { - x0 = a0; - x1 = MIN (a1, b1); - } - else - return 0; - } - - return 0.5 * (x1*x1 - x0*x0); -} - -/* Compute weights for reconstructing with bilinear - * interpolation, then sampling with a box filter - */ -static void -bilinear_box_make_weights (PixopsFilterDimension *dim, - double scale) -{ - int n = ceil (1/scale + 3.0); - double *pixel_weights = g_new (double, SUBSAMPLE * n); - double w; - int offset, i; - - dim->offset = -1.0; - dim->n = n; - dim->weights = pixel_weights; - - for (offset = 0; offset < SUBSAMPLE; offset++) - { - double x = (double)offset / SUBSAMPLE; - double a = x + 1 / scale; - - for (i = 0; i < n; i++) - { - w = linear_box_half (0.5 + i - a, 0.5 + i - x); - w += linear_box_half (1.5 + x - i, 1.5 + a - i); - - *(pixel_weights++) = w * scale; - } - } -} - -static void -make_weights (PixopsFilter *filter, - PixopsInterpType interp_type, - double scale_x, - double scale_y) -{ - switch (interp_type) - { - case PIXOPS_INTERP_NEAREST: - g_assert_not_reached (); - break; - - case PIXOPS_INTERP_TILES: - tile_make_weights (&filter->x, scale_x); - tile_make_weights (&filter->y, scale_y); - break; - - case PIXOPS_INTERP_BILINEAR: - bilinear_magnify_make_weights (&filter->x, scale_x); - bilinear_magnify_make_weights (&filter->y, scale_y); - break; - - case PIXOPS_INTERP_HYPER: - bilinear_box_make_weights (&filter->x, scale_x); - bilinear_box_make_weights (&filter->y, scale_y); - break; - } -} - -static void -_pixops_composite_color_real (guchar *dest_buf, - int render_x0, - int render_y0, - int render_x1, - int render_y1, - int dest_rowstride, - int dest_channels, - gboolean dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - gboolean src_has_alpha, - double scale_x, - double scale_y, - PixopsInterpType interp_type, - int overall_alpha, - int check_x, - int check_y, - int check_size, - guint32 color1, - guint32 color2) -{ - PixopsFilter filter; - PixopsLineFunc line_func; - -#ifdef USE_MMX - gboolean found_mmx = _pixops_have_mmx (); -#endif - - g_return_if_fail (!(dest_channels == 3 && dest_has_alpha)); - g_return_if_fail (!(src_channels == 3 && src_has_alpha)); - - if (scale_x == 0 || scale_y == 0) - return; - - if (interp_type == PIXOPS_INTERP_NEAREST) - { - pixops_composite_color_nearest (dest_buf, render_x0, render_y0, - render_x1, render_y1, dest_rowstride, - dest_channels, dest_has_alpha, src_buf, - src_width, src_height, src_rowstride, - src_channels, src_has_alpha, scale_x, - scale_y, overall_alpha, check_x, check_y, - check_size, color1, color2); - return; - } - - filter.overall_alpha = overall_alpha / 255.; - make_weights (&filter, interp_type, scale_x, scale_y); - -#ifdef USE_MMX - if (filter.x.n == 2 && filter.y.n == 2 && - dest_channels == 4 && src_channels == 4 && - src_has_alpha && !dest_has_alpha && found_mmx) - line_func = composite_line_color_22_4a4_mmx_stub; - else -#endif - line_func = composite_line_color; - - pixops_process (dest_buf, render_x0, render_y0, render_x1, render_y1, - dest_rowstride, dest_channels, dest_has_alpha, - src_buf, src_width, src_height, src_rowstride, src_channels, - src_has_alpha, scale_x, scale_y, check_x, check_y, check_size, color1, color2, - &filter, line_func, composite_pixel_color); - - g_free (filter.x.weights); - g_free (filter.y.weights); -} - -void -_pixops_composite_color (guchar *dest_buf, - int dest_width, - int dest_height, - int dest_rowstride, - int dest_channels, - gboolean dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - gboolean src_has_alpha, - int dest_x, - int dest_y, - int dest_region_width, - int dest_region_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - PixopsInterpType interp_type, - int overall_alpha, - int check_x, - int check_y, - int check_size, - guint32 color1, - guint32 color2) -{ - guchar *new_dest_buf; - int render_x0; - int render_y0; - int render_x1; - int render_y1; - - if (!src_has_alpha && overall_alpha == 255) - { - _pixops_scale (dest_buf, dest_width, dest_height, dest_rowstride, - dest_channels, dest_has_alpha, src_buf, src_width, - src_height, src_rowstride, src_channels, src_has_alpha, - dest_x, dest_y, dest_region_width, dest_region_height, - offset_x, offset_y, scale_x, scale_y, interp_type); - return; - } - - new_dest_buf = dest_buf + dest_y * dest_rowstride + dest_x * - dest_channels; - render_x0 = dest_x - offset_x; - render_y0 = dest_y - offset_y; - render_x1 = dest_x + dest_region_width - offset_x; - render_y1 = dest_y + dest_region_height - offset_y; - - _pixops_composite_color_real (new_dest_buf, render_x0, render_y0, render_x1, - render_y1, dest_rowstride, dest_channels, - dest_has_alpha, src_buf, src_width, - src_height, src_rowstride, src_channels, - src_has_alpha, scale_x, scale_y, - (PixopsInterpType)interp_type, overall_alpha, - check_x, check_y, check_size, color1, color2); -} - -/** - * _pixops_composite_real: - * @dest_buf: pointer to location to store result - * @render_x0: x0 of region of scaled source to store into @dest_buf - * @render_y0: y0 of region of scaled source to store into @dest_buf - * @render_x1: x1 of region of scaled source to store into @dest_buf - * @render_y1: y1 of region of scaled source to store into @dest_buf - * @dest_rowstride: rowstride of @dest_buf - * @dest_channels: number of channels in @dest_buf - * @dest_has_alpha: whether @dest_buf has alpha - * @src_buf: pointer to source pixels - * @src_width: width of source (used for clipping) - * @src_height: height of source (used for clipping) - * @src_rowstride: rowstride of source - * @src_channels: number of channels in @src_buf - * @src_has_alpha: whether @src_buf has alpha - * @scale_x: amount to scale source by in X direction - * @scale_y: amount to scale source by in Y direction - * @interp_type: type of enumeration - * @overall_alpha: overall alpha factor to multiply source by - * - * Scale source buffer by scale_x / scale_y, then composite a given rectangle - * of the result into the destination buffer. - **/ -static void -_pixops_composite_real (guchar *dest_buf, - int render_x0, - int render_y0, - int render_x1, - int render_y1, - int dest_rowstride, - int dest_channels, - gboolean dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - gboolean src_has_alpha, - double scale_x, - double scale_y, - PixopsInterpType interp_type, - int overall_alpha) -{ - PixopsFilter filter; - PixopsLineFunc line_func; - -#ifdef USE_MMX - gboolean found_mmx = _pixops_have_mmx (); -#endif - - g_return_if_fail (!(dest_channels == 3 && dest_has_alpha)); - g_return_if_fail (!(src_channels == 3 && src_has_alpha)); - - if (scale_x == 0 || scale_y == 0) - return; - - if (interp_type == PIXOPS_INTERP_NEAREST) - { - pixops_composite_nearest (dest_buf, render_x0, render_y0, render_x1, - render_y1, dest_rowstride, dest_channels, - dest_has_alpha, src_buf, src_width, src_height, - src_rowstride, src_channels, src_has_alpha, - scale_x, scale_y, overall_alpha); - return; - } - - filter.overall_alpha = overall_alpha / 255.; - make_weights (&filter, interp_type, scale_x, scale_y); - - if (filter.x.n == 2 && filter.y.n == 2 && dest_channels == 4 && - src_channels == 4 && src_has_alpha && !dest_has_alpha) - { -#ifdef USE_MMX - if (found_mmx) - line_func = composite_line_22_4a4_mmx_stub; - else -#endif - line_func = composite_line_22_4a4; - } - else - line_func = composite_line; - - pixops_process (dest_buf, render_x0, render_y0, render_x1, render_y1, - dest_rowstride, dest_channels, dest_has_alpha, - src_buf, src_width, src_height, src_rowstride, src_channels, - src_has_alpha, scale_x, scale_y, 0, 0, 0, 0, 0, - &filter, line_func, composite_pixel); - - g_free (filter.x.weights); - g_free (filter.y.weights); -} - -void -_pixops_composite (guchar *dest_buf, - int dest_width, - int dest_height, - int dest_rowstride, - int dest_channels, - int dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - int src_has_alpha, - int dest_x, - int dest_y, - int dest_region_width, - int dest_region_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - PixopsInterpType interp_type, - int overall_alpha) -{ - guchar *new_dest_buf; - int render_x0; - int render_y0; - int render_x1; - int render_y1; - - if (!src_has_alpha && overall_alpha == 255) - { - _pixops_scale (dest_buf, dest_width, dest_height, dest_rowstride, - dest_channels, dest_has_alpha, src_buf, src_width, - src_height, src_rowstride, src_channels, src_has_alpha, - dest_x, dest_y, dest_region_width, dest_region_height, - offset_x, offset_y, scale_x, scale_y, interp_type); - return; - } - -#ifdef USE_MEDIALIB - pixops_medialib_composite (dest_buf, dest_width, dest_height, dest_rowstride, - dest_channels, dest_has_alpha, src_buf, - src_width, src_height, src_rowstride, - src_channels, src_has_alpha, dest_x, dest_y, - dest_region_width, dest_region_height, offset_x, - offset_y, scale_x, scale_y, - (PixopsInterpType)interp_type, overall_alpha); - return; -#endif - - new_dest_buf = dest_buf + dest_y * dest_rowstride + dest_x * dest_channels; - render_x0 = dest_x - offset_x; - render_y0 = dest_y - offset_y; - render_x1 = dest_x + dest_region_width - offset_x; - render_y1 = dest_y + dest_region_height - offset_y; - - _pixops_composite_real (new_dest_buf, render_x0, render_y0, render_x1, - render_y1, dest_rowstride, dest_channels, - dest_has_alpha, src_buf, src_width, src_height, - src_rowstride, src_channels, src_has_alpha, scale_x, - scale_y, (PixopsInterpType)interp_type, - overall_alpha); -} - -#ifdef USE_MEDIALIB -static void -medialib_get_interpolation (mlInterp * ml_interp, - PixopsInterpType interp_type, - double scale_x, - double scale_y, - double overall_alpha) -{ - mlib_s32 leftPadding, topPadding; - ml_interp->interp_table = NULL; - - /* - * medialib 2.1 and later supports scaling with user-defined interpolation - * tables, so this logic is used. - * - * bilinear_magnify_make_weights builds an interpolation table of size 2x2 if - * the scale factor >= 1.0 and "ceil (1.0 + 1.0/scale)" otherwise. These map - * most closely to MLIB_BILINEAR, which uses an interpolation table of size - * 2x2. - * - * tile_make_weights builds an interpolation table of size 2x2 if the scale - * factor >= 1.0 and "ceil (1.0 + 1.0/scale)" otherwise. These map most - * closely to MLIB_BILINEAR, which uses an interpolation table of size 2x2. - * - * bilinear_box_make_weights builds an interpolation table of size 4x4 if the - * scale factor >= 1.0 and "ceil (1.0 + 1.0/scale)" otherwise. These map most - * closely to MLIB_BICUBIC, which uses an interpolation table of size 4x4. - * - * PIXOPS_INTERP_NEAREST calls pixops_scale_nearest which does not use an - * interpolation table. This maps to MLIB_NEAREST. - */ - switch (interp_type) - { - case PIXOPS_INTERP_BILINEAR: - bilinear_magnify_make_weights (&(ml_interp->po_filter.x), scale_x); - bilinear_magnify_make_weights (&(ml_interp->po_filter.y), scale_y); - leftPadding = 0; - topPadding = 0; - - if (scale_x <= 1.0) - ml_interp->tx = 0.5 * (1 - scale_x); - else - ml_interp->tx = 0.0; - - if (scale_y <= 1.0) - ml_interp->ty = 0.5 * (1 - scale_y); - else - ml_interp->ty = 0.0; - - break; - - case PIXOPS_INTERP_TILES: - tile_make_weights (&(ml_interp->po_filter.x), scale_x); - tile_make_weights (&(ml_interp->po_filter.y), scale_y); - leftPadding = 0; - topPadding = 0; - ml_interp->tx = 0.5 * (1 - scale_x); - ml_interp->ty = 0.5 * (1 - scale_y); - break; - - case PIXOPS_INTERP_HYPER: - bilinear_box_make_weights (&(ml_interp->po_filter.x), scale_x); - bilinear_box_make_weights (&(ml_interp->po_filter.y), scale_y); - leftPadding = 1; - topPadding = 1; - ml_interp->tx = 0.5 * (1 - scale_x); - ml_interp->ty = 0.5 * (1 - scale_y); - break; - - case PIXOPS_INTERP_NEAREST: - default: - /* - * Note that this function should not be called in the - * PIXOPS_INTERP_NEAREST case since it does not use an interpolation - * table. - */ - g_assert_not_reached (); - break; - } - - /* - * If overall_alpha is not 1.0, then multiply the vectors built by the - * sqrt (overall_alpha). This will cause overall_alpha to get evenly - * blended across both axis. - * - * Note there is no need to multiply the vectors built by the various - * make-weight functions by sqrt (overall_alpha) since the make-weight - * functions are called with overall_alpha hardcoded to 1.0. - */ - if (overall_alpha != 1.0) - { - double sqrt_alpha = sqrt (overall_alpha); - int i; - - for (i=0; i < SUBSAMPLE * ml_interp->po_filter.x.n; i++) - ml_interp->po_filter.x.weights[i] *= sqrt_alpha; - for (i=0; i < SUBSAMPLE * ml_interp->po_filter.y.n; i++) - ml_interp->po_filter.y.weights[i] *= sqrt_alpha; - } - - ml_interp->interp_table = (void *) mlib_ImageInterpTableCreate (MLIB_DOUBLE, - ml_interp->po_filter.x.n, ml_interp->po_filter.y.n, leftPadding, - topPadding, SUBSAMPLE_BITS, SUBSAMPLE_BITS, 8, - ml_interp->po_filter.x.weights, ml_interp->po_filter.y.weights); - - g_free (ml_interp->po_filter.x.weights); - g_free (ml_interp->po_filter.y.weights); -} - -static void -pixops_medialib_composite (guchar *dest_buf, - int dest_width, - int dest_height, - int dest_rowstride, - int dest_channels, - int dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - int src_has_alpha, - int dest_x, - int dest_y, - int dest_region_width, - int dest_region_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - PixopsInterpType interp_type, - int overall_alpha) -{ - mlib_blend blend; - g_return_if_fail (!(dest_channels == 3 && dest_has_alpha)); - g_return_if_fail (!(src_channels == 3 && src_has_alpha)); - - if (scale_x == 0 || scale_y == 0) - return; - - if (!medialib_initialized) - _pixops_use_medialib (); - - if (!use_medialib) - { - /* Use non-mediaLib version */ - _pixops_composite_real (dest_buf + dest_y * dest_rowstride + dest_x * - dest_channels, dest_x - offset_x, dest_y - - offset_y, dest_x + dest_region_width - offset_x, - dest_y + dest_region_height - offset_y, - dest_rowstride, dest_channels, dest_has_alpha, - src_buf, src_width, src_height, src_rowstride, - src_channels, src_has_alpha, scale_x, scale_y, - interp_type, overall_alpha); - } - else - { - mlInterp ml_interp; - mlib_image img_src, img_dest; - double ml_offset_x, ml_offset_y; - - if (!src_has_alpha && overall_alpha == 255 && - dest_channels <= src_channels) - { - pixops_medialib_scale (dest_buf, dest_region_width, - dest_region_height, dest_rowstride, - dest_channels, dest_has_alpha, src_buf, - src_width, src_height, src_rowstride, - src_channels, src_has_alpha, dest_x, dest_y, - dest_region_width, dest_region_height, - offset_x, offset_y, scale_x, scale_y, - interp_type); - return; - } - - mlib_ImageSetStruct (&img_src, MLIB_BYTE, src_channels, - src_width, src_height, src_rowstride, src_buf); - - if (dest_x == 0 && dest_y == 0 && - dest_width == dest_region_width && - dest_height == dest_region_height) - { - mlib_ImageSetStruct (&img_dest, MLIB_BYTE, dest_channels, - dest_width, dest_height, dest_rowstride, - dest_buf); - } - else - { - mlib_u8 *data = dest_buf + (dest_y * dest_rowstride) + - (dest_x * dest_channels); - - mlib_ImageSetStruct (&img_dest, MLIB_BYTE, dest_channels, - dest_region_width, dest_region_height, - dest_rowstride, data); - } - - ml_offset_x = floor (offset_x) - dest_x; - ml_offset_y = floor (offset_y) - dest_y; - - if (interp_type == PIXOPS_INTERP_NEAREST) - { - blend = src_has_alpha ? MLIB_BLEND_GTK_SRC_OVER2 : MLIB_BLEND_GTK_SRC; - - mlib_ImageZoomTranslateBlend (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x, - ml_offset_y, - MLIB_NEAREST, - MLIB_EDGE_SRC_EXTEND_INDEF, - blend, - overall_alpha, - 1); - } - else - { - blend = src_has_alpha ? MLIB_BLEND_GTK_SRC_OVER : MLIB_BLEND_GTK_SRC; - - if (interp_type == PIXOPS_INTERP_BILINEAR && - scale_x > 1.0 && scale_y > 1.0) - { - mlib_ImageZoomTranslateBlend (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x, - ml_offset_y, - MLIB_BILINEAR, - MLIB_EDGE_SRC_EXTEND_INDEF, - blend, - overall_alpha, - 1); - } - else - { - medialib_get_interpolation (&ml_interp, interp_type, scale_x, - scale_y, overall_alpha/255.0); - - if (ml_interp.interp_table != NULL) - { - mlib_ImageZoomTranslateTableBlend (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x + ml_interp.tx, - ml_offset_y + ml_interp.ty, - ml_interp.interp_table, - MLIB_EDGE_SRC_EXTEND_INDEF, - blend, - 1); - mlib_ImageInterpTableDelete (ml_interp.interp_table); - } - else - { - /* Should not happen - Use non-mediaLib version */ - _pixops_composite_real (dest_buf + dest_y * dest_rowstride + - dest_x * dest_channels, - dest_x - offset_x, dest_y - offset_y, - dest_x + dest_region_width - offset_x, - dest_y + dest_region_height - offset_y, - dest_rowstride, dest_channels, - dest_has_alpha, src_buf, src_width, - src_height, src_rowstride, - src_channels, src_has_alpha, scale_x, - scale_y, interp_type, overall_alpha); - } - } - } - } -} -#endif - -static void -_pixops_scale_real (guchar *dest_buf, - int render_x0, - int render_y0, - int render_x1, - int render_y1, - int dest_rowstride, - int dest_channels, - gboolean dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - gboolean src_has_alpha, - double scale_x, - double scale_y, - PixopsInterpType interp_type) -{ - PixopsFilter filter; - PixopsLineFunc line_func; - -#ifdef USE_MMX - gboolean found_mmx = _pixops_have_mmx (); -#endif - - g_return_if_fail (!(dest_channels == 3 && dest_has_alpha)); - g_return_if_fail (!(src_channels == 3 && src_has_alpha)); - g_return_if_fail (!(src_has_alpha && !dest_has_alpha)); - - if (scale_x == 0 || scale_y == 0) - return; - - if (interp_type == PIXOPS_INTERP_NEAREST) - { - pixops_scale_nearest (dest_buf, render_x0, render_y0, render_x1, - render_y1, dest_rowstride, dest_channels, - dest_has_alpha, src_buf, src_width, src_height, - src_rowstride, src_channels, src_has_alpha, - scale_x, scale_y); - return; - } - - filter.overall_alpha = 1.0; - make_weights (&filter, interp_type, scale_x, scale_y); - - if (filter.x.n == 2 && filter.y.n == 2 && dest_channels == 3 && src_channels == 3) - { -#ifdef USE_MMX - if (found_mmx) - line_func = scale_line_22_33_mmx_stub; - else -#endif - line_func = scale_line_22_33; - } - else - line_func = scale_line; - - pixops_process (dest_buf, render_x0, render_y0, render_x1, render_y1, - dest_rowstride, dest_channels, dest_has_alpha, - src_buf, src_width, src_height, src_rowstride, src_channels, - src_has_alpha, scale_x, scale_y, 0, 0, 0, 0, 0, - &filter, line_func, scale_pixel); - - g_free (filter.x.weights); - g_free (filter.y.weights); -} - -void -_pixops_scale (guchar *dest_buf, - int dest_width, - int dest_height, - int dest_rowstride, - int dest_channels, - int dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - int src_has_alpha, - int dest_x, - int dest_y, - int dest_region_width, - int dest_region_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - PixopsInterpType interp_type) -{ - guchar *new_dest_buf; - int render_x0; - int render_y0; - int render_x1; - int render_y1; - -#ifdef USE_MEDIALIB - pixops_medialib_scale (dest_buf, dest_width, dest_height, dest_rowstride, - dest_channels, dest_has_alpha, src_buf, src_width, - src_height, src_rowstride, src_channels, - src_has_alpha, dest_x, dest_y, dest_region_width, - dest_region_height, offset_x, offset_y, scale_x, - scale_y, (PixopsInterpType)interp_type); - return; -#endif - - new_dest_buf = dest_buf + dest_y * dest_rowstride + dest_x * dest_channels; - render_x0 = dest_x - offset_x; - render_y0 = dest_y - offset_y; - render_x1 = dest_x + dest_region_width - offset_x; - render_y1 = dest_y + dest_region_height - offset_y; - - _pixops_scale_real (new_dest_buf, render_x0, render_y0, render_x1, - render_y1, dest_rowstride, dest_channels, - dest_has_alpha, src_buf, src_width, src_height, - src_rowstride, src_channels, src_has_alpha, - scale_x, scale_y, (PixopsInterpType)interp_type); -} - -#ifdef USE_MEDIALIB -static void -pixops_medialib_scale (guchar *dest_buf, - int dest_width, - int dest_height, - int dest_rowstride, - int dest_channels, - int dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - int src_has_alpha, - int dest_x, - int dest_y, - int dest_region_width, - int dest_region_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - PixopsInterpType interp_type) -{ - if (scale_x == 0 || scale_y == 0) - return; - - if (!medialib_initialized) - _pixops_use_medialib (); - - /* - * We no longer support mediaLib 2.1 because it has a core dumping problem - * in the mlib_ImageZoomTranslateTable function that has been corrected in - * 2.2. Although the mediaLib_zoom function could be used, it does not - * work properly if the source and destination images have different - * values for "has_alpha" or "num_channels". The complicated if-logic - * required to support both versions is not worth supporting - * mediaLib 2.1 moving forward. - */ - if (!use_medialib) - { - _pixops_scale_real (dest_buf + dest_y * dest_rowstride + dest_x * - dest_channels, dest_x - offset_x, dest_y - offset_y, - dest_x + dest_region_width - offset_x, - dest_y + dest_region_height - offset_y, - dest_rowstride, dest_channels, dest_has_alpha, - src_buf, src_width, src_height, src_rowstride, - src_channels, src_has_alpha, scale_x, scale_y, - interp_type); - } - else - { - mlInterp ml_interp; - mlib_image img_orig_src, img_src, img_dest; - double ml_offset_x, ml_offset_y; - guchar *tmp_buf = NULL; - - mlib_ImageSetStruct (&img_orig_src, MLIB_BYTE, src_channels, src_width, - src_height, src_rowstride, src_buf); - - if (dest_x == 0 && dest_y == 0 && - dest_width == dest_region_width && - dest_height == dest_region_height) - { - mlib_ImageSetStruct (&img_dest, MLIB_BYTE, dest_channels, - dest_width, dest_height, dest_rowstride, - dest_buf); - } - else - { - mlib_u8 *data = dest_buf + (dest_y * dest_rowstride) + - (dest_x * dest_channels); - - mlib_ImageSetStruct (&img_dest, MLIB_BYTE, dest_channels, - dest_region_width, dest_region_height, - dest_rowstride, data); - } - - ml_offset_x = floor (offset_x) - dest_x; - ml_offset_y = floor (offset_y) - dest_y; - - /* - * Note that zoomTranslate and zoomTranslateTable are faster - * than zoomTranslateBlend and zoomTranslateTableBlend. However - * the faster functions only work in the following case: - * - * if (src_channels == dest_channels && - * (!src_alpha && interp_table != PIXOPS_INTERP_NEAREST)) - * - * We use the faster versions if we can. - * - * Note when the interp_type is BILINEAR and the interpolation - * table will be size 2x2 (when both x/y scale factors > 1.0), - * then we do not bother building the interpolation table. In - * this case we can just use MLIB_BILINEAR, which is faster than - * using a specified interpolation table. - */ - img_src = img_orig_src; - - if (!src_has_alpha) - { - if (src_channels > dest_channels) - { - int channels = 3; - int rowstride = (channels * src_width + 3) & ~3; - - tmp_buf = g_malloc (src_rowstride * src_height); - - if (src_buf != NULL) - { - src_channels = channels; - src_rowstride = rowstride; - - mlib_ImageSetStruct (&img_src, MLIB_BYTE, src_channels, - src_width, src_height, src_rowstride, - tmp_buf); - mlib_ImageChannelExtract (&img_src, &img_orig_src, 0xE); - } - } - } - - if (interp_type == PIXOPS_INTERP_NEAREST) - { - if (src_channels == dest_channels) - { - mlib_ImageZoomTranslate (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x, - ml_offset_y, - MLIB_NEAREST, - MLIB_EDGE_SRC_EXTEND_INDEF); - } - else - { - mlib_ImageZoomTranslateBlend (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x, - ml_offset_y, - MLIB_NEAREST, - MLIB_EDGE_SRC_EXTEND_INDEF, - MLIB_BLEND_GTK_SRC, - 1.0, - 1); - } - } - else if (src_channels == dest_channels && !src_has_alpha) - { - if (interp_type == PIXOPS_INTERP_BILINEAR && - scale_x > 1.0 && scale_y > 1.0) - { - mlib_ImageZoomTranslate (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x, - ml_offset_y, - MLIB_BILINEAR, - MLIB_EDGE_SRC_EXTEND_INDEF); - } - else - { - medialib_get_interpolation (&ml_interp, interp_type, - scale_x, scale_y, 1.0); - - if (ml_interp.interp_table != NULL) - { - mlib_ImageZoomTranslateTable (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x + ml_interp.tx, - ml_offset_y + ml_interp.ty, - ml_interp.interp_table, - MLIB_EDGE_SRC_EXTEND_INDEF); - - mlib_ImageInterpTableDelete (ml_interp.interp_table); - } - else - { - /* Should not happen. */ - mlib_filter ml_filter; - - switch (interp_type) - { - case PIXOPS_INTERP_BILINEAR: - ml_filter = MLIB_BILINEAR; - break; - - case PIXOPS_INTERP_TILES: - ml_filter = MLIB_BILINEAR; - break; - - case PIXOPS_INTERP_HYPER: - ml_filter = MLIB_BICUBIC; - break; - } - - mlib_ImageZoomTranslate (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x, - ml_offset_y, - ml_filter, - MLIB_EDGE_SRC_EXTEND_INDEF); - } - } - } - - /* Deal with case where src_channels != dest_channels || src_has_alpha */ - else if (interp_type == PIXOPS_INTERP_BILINEAR && - scale_x > 1.0 && scale_y > 1.0) - { - mlib_ImageZoomTranslateBlend (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x, - ml_offset_y, - MLIB_BILINEAR, - MLIB_EDGE_SRC_EXTEND_INDEF, - MLIB_BLEND_GTK_SRC, - 1.0, - 1); - } - else - { - medialib_get_interpolation (&ml_interp, interp_type, - scale_x, scale_y, 1.0); - - if (ml_interp.interp_table != NULL) - { - mlib_ImageZoomTranslateTableBlend (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x + ml_interp.tx, - ml_offset_y + ml_interp.ty, - ml_interp.interp_table, - MLIB_EDGE_SRC_EXTEND_INDEF, - MLIB_BLEND_GTK_SRC, - 1); - mlib_ImageInterpTableDelete (ml_interp.interp_table); - } - else - { - mlib_filter ml_filter; - - switch (interp_type) - { - case PIXOPS_INTERP_BILINEAR: - ml_filter = MLIB_BILINEAR; - break; - - case PIXOPS_INTERP_TILES: - ml_filter = MLIB_BILINEAR; - break; - - case PIXOPS_INTERP_HYPER: - ml_filter = MLIB_BICUBIC; - break; - } - - mlib_ImageZoomTranslate (&img_dest, - &img_src, - scale_x, - scale_y, - ml_offset_x, - ml_offset_y, - ml_filter, - MLIB_EDGE_SRC_EXTEND_INDEF); - } - } - - if (tmp_buf != NULL) - g_free (tmp_buf); - } -} -#endif diff --git a/gdk-pixbuf/pixops/pixops.h b/gdk-pixbuf/pixops/pixops.h deleted file mode 100644 index 56d3ff0b8b..0000000000 --- a/gdk-pixbuf/pixops/pixops.h +++ /dev/null @@ -1,120 +0,0 @@ -/* - * Copyright (C) 2000 Red Hat, Inc - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ -#ifndef PIXOPS_H -#define PIXOPS_H - -#include <glib.h> - -/* Interpolation modes; must match GdkInterpType */ -typedef enum { - PIXOPS_INTERP_NEAREST, - PIXOPS_INTERP_TILES, - PIXOPS_INTERP_BILINEAR, - PIXOPS_INTERP_HYPER -} PixopsInterpType; - -/* Scale src_buf from src_width / src_height by factors scale_x, scale_y - * and composite the portion corresponding to - * render_x, render_y, render_width, render_height in the new - * coordinate system into dest_buf starting at 0, 0 - */ -void _pixops_composite (guchar *dest_buf, - int dest_width, - int dest_height, - int dest_rowstride, - int dest_channels, - int dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - int src_has_alpha, - int dest_x, - int dest_y, - int dest_region_width, - int dest_region_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - PixopsInterpType interp_type, - int overall_alpha); - -/* Scale src_buf from src_width / src_height by factors scale_x, scale_y - * and composite the portion corresponding to - * render_x, render_y, render_width, render_height in the new - * coordinate system against a checkboard with checks of size check_size - * of the colors color1 and color2 into dest_buf starting at 0, 0 - */ -void _pixops_composite_color (guchar *dest_buf, - int dest_width, - int dest_height, - int dest_rowstride, - int dest_channels, - int dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - int src_has_alpha, - int dest_x, - int dest_y, - int dest_region_width, - int dest_region_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - PixopsInterpType interp_type, - int overall_alpha, - int check_x, - int check_y, - int check_size, - guint32 color1, - guint32 color2); - -/* Scale src_buf from src_width / src_height by factors scale_x, scale_y - * and composite the portion corresponding to - * render_x, render_y, render_width, render_height in the new - * coordinate system into dest_buf starting at 0, 0 - */ -void _pixops_scale (guchar *dest_buf, - int dest_width, - int dest_height, - int dest_rowstride, - int dest_channels, - int dest_has_alpha, - const guchar *src_buf, - int src_width, - int src_height, - int src_rowstride, - int src_channels, - int src_has_alpha, - int dest_x, - int dest_y, - int dest_region_width, - int dest_region_height, - double offset_x, - double offset_y, - double scale_x, - double scale_y, - PixopsInterpType interp_type); -#endif diff --git a/gdk-pixbuf/pixops/scale_line_22_33_mmx.S b/gdk-pixbuf/pixops/scale_line_22_33_mmx.S deleted file mode 100644 index 53144aef9d..0000000000 --- a/gdk-pixbuf/pixops/scale_line_22_33_mmx.S +++ /dev/null @@ -1,206 +0,0 @@ -/* - * Copyright (C) 2000 Red Hat, Inc - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - .file "scale_line_22_33_mmx.S" - .version "01.01" -gcc2_compiled.: -.text - .align 16 - -#if !defined(__MINGW32__) && !defined(__CYGWIN__) && !defined(__INTERIX) - -/* Magic indicating no need for an executable stack */ -#if !defined __powerpc64__ && !defined __ia64__ -.section .note.GNU-stack; .previous -#endif - -.globl _pixops_scale_line_22_33_mmx - .type _pixops_scale_line_22_33_mmx,@function -_pixops_scale_line_22_33_mmx: - -#else - -.globl __pixops_scale_line_22_33_mmx -__pixops_scale_line_22_33_mmx: - -#endif -/* - * Arguments - * - * weights: 8(%ebp) - * p: 12(%ebp) %esi - * q1: 16(%ebp) - * q2: 20(%ebp) - * xstep: 24(%ebp) - * p_end: 28(%ebp) - * xinit: 32(%ebp) - * -*/ - -/* - * Function call entry - */ - pushl %ebp - movl %esp,%ebp - subl $28,%esp - pushl %edi - pushl %esi - pushl %ebx -/* Locals: - * int x %ebx - * int x_scaled -24(%ebp) - */ - -/* - * Setup - */ -/* Initialize variables */ - movl 32(%ebp),%ebx - movl 32(%ebp),%edx - sarl $16,%edx - movl 12(%ebp),%esi - - cmpl 28(%ebp),%esi - jnb .out - -/* For the body of this loop, %mm01, %mm1, %mm2, %mm3 hold the 4 adjoining - * points we are interpolating between, as: - * - * 000000BB00GG00RR - */ - -/* Load initial values into %mm1, %mm3 */ - leal (%edx,%edx,2),%edx # Multiply by 3 - - movl 16(%ebp),%edi - pxor %mm4, %mm4 - movzbl 2(%edi,%edx),%ecx - shll $16,%ecx - movzwl (%edi,%edx),%eax - orl %eax,%ecx - movd %ecx, %mm1 - punpcklbw %mm4, %mm1 - - movl 20(%ebp),%edi - movzbl 2(%edi,%edx),%ecx - shll $16,%ecx - movzwl (%edi,%edx),%eax - orl %eax,%ecx - movd %ecx, %mm3 - punpcklbw %mm4, %mm3 - - addl $65536,%ebx - movl %ebx,%edx - sarl $16,%edx - - jmp .newx - .p2align 4,,7 -.loop: -/* short *pixel_weights = weights + ((x >> (SCALE_SHIFT - SUBSAMPLE_BITS)) & SUBSAMPLE_MASK) * n_x * n_y - * 16 4 0xf 2 2 - */ - movl %ebx,%eax - andl $0xf000,%eax - shrl $7,%eax - -/* At this point, %edi holds weights. Load the 4 weights into %mm4,%mm5,%mm6,%mm7, multiply and - * accumulate. - */ - movq (%edi,%eax),%mm4 - pmullw %mm0,%mm4 - movq 8(%edi,%eax),%mm5 - pmullw %mm1,%mm5 - movq 16(%edi,%eax),%mm6 - movq 24(%edi,%eax),%mm7 - pmullw %mm2,%mm6 - pmullw %mm3,%mm7 - paddw %mm4, %mm5 - paddw %mm6, %mm7 - paddw %mm5, %mm7 - -/* %mm7 holds the accumulated sum. Compute (C + 0x80) / 256 - */ - pxor %mm4, %mm4 - movl $8421504, %eax # 0x00808080 - movd %eax, %mm6 - punpcklbw %mm4, %mm6 - paddw %mm6, %mm7 - psrlw $8, %mm7 - -/* Pack into %eax and store result - */ - packuswb %mm7, %mm7 - movd %mm7, %eax - - movb %al, (%esi) - shrl $8, %eax - movw %ax, 1(%esi) - addl $3, %esi - - cmpl %esi,28(%ebp) - je .out - -/* x += x_step; */ - addl 24(%ebp),%ebx -/* x_scaled = x >> 16; */ - movl %ebx,%edx - sarl $16,%edx - - cmpl %edx,-24(%ebp) - je .loop - -.newx: - movl %edx,-24(%ebp) -/* - * Load the two new values into %mm1, %mm3, move old values into %mm0, %mm2 - */ - movq %mm1, %mm0 - movq %mm3, %mm2 - - leal (%edx,%edx,2),%edx # Multiply by 3 - - movl 16(%ebp),%edi - movzbl 2(%edi,%edx),%ecx - shll $16,%ecx - movzwl (%edi,%edx),%eax - orl %eax,%ecx - movd %ecx, %mm1 - punpcklbw %mm4, %mm1 - - movl 20(%ebp),%edi - movzbl 2(%edi,%edx),%ecx - shll $16,%ecx - movzwl (%edi,%edx),%eax - orl %eax,%ecx - movd %ecx, %mm3 - punpcklbw %mm4, %mm3 - - movl 8(%ebp),%edi - - jmp .loop - -.out: - movl %esi,%eax - emms - leal -40(%ebp),%esp - popl %ebx - popl %esi - popl %edi - movl %ebp,%esp - popl %ebp - ret diff --git a/gdk-pixbuf/pixops/timescale.c b/gdk-pixbuf/pixops/timescale.c deleted file mode 100644 index cac11d9c1c..0000000000 --- a/gdk-pixbuf/pixops/timescale.c +++ /dev/null @@ -1,267 +0,0 @@ -/* - * Copyright (C) 2000 Red Hat, Inc - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ -#include "config.h" -#include <glib.h> -#include <string.h> -#include <stdlib.h> -#include <stdio.h> - -#include "pixops.h" - -static GTimeVal start_time; - -static void -start_timing (void) -{ - g_get_current_time (&start_time); -} - -static double -stop_timing (const char *test, int iterations, int bytes) -{ - GTimeVal stop_time; - double msecs; - - g_get_current_time (&stop_time); - if (stop_time.tv_usec < start_time.tv_usec) - { - stop_time.tv_usec += 1000000; - stop_time.tv_sec -= 1; - } - - msecs = (stop_time.tv_sec - start_time.tv_sec) * 1000. + - (stop_time.tv_usec - start_time.tv_usec) / 1000.; - - printf("%s%d\t%.1f\t\t%.2f\t\t%.2f\n", - test, iterations, msecs, msecs / iterations, ((double)bytes * iterations) / (1000*msecs)); - - return ((double)bytes * iterations) / (1000*msecs); -} - -static void -init_array (double times[3][3][4]) -{ - int i, j, k; - - for (i=0; i<3; i++) - for (j=0; j<3; j++) - for (k=0; k<4; k++) - times[i][j][k] = -1; -} - -static void -dump_array (double times[3][3][4]) -{ - int i, j; - - printf(" 3\t4\t4a\n"); - for (i=0; i<3; i++) - { - for (j=0; j<4; j++) - { - if (j == 0) - switch (i) - { - case 0: - printf("3 "); - break; - case 1: - printf("4 "); - break; - case 2: - printf("4a "); - break; - } - else - printf(" "); - - printf("%6.2f %6.2f %6.2f", - times[i][0][j], times[i][1][j], times[i][2][j]); - - switch (j) - { - case PIXOPS_INTERP_NEAREST: - printf (" NEAREST\n"); - break; - case PIXOPS_INTERP_TILES: - printf (" TILES\n"); - break; - case PIXOPS_INTERP_BILINEAR: - printf (" BILINEAR\n"); - break; - case PIXOPS_INTERP_HYPER: - printf (" HYPER\n"); - break; - } - } - } - printf("\n"); -} - -#define ITERS 10 - -int main (int argc, char **argv) -{ - int src_width, src_height, dest_width, dest_height; - unsigned char *src_buf, *dest_buf; - int src_index, dest_index; - int i; - double scale_times[3][3][4]; - double composite_times[3][3][4]; - double composite_color_times[3][3][4]; - - if (argc == 5) - { - src_width = atoi(argv[1]); - src_height = atoi(argv[2]); - dest_width = atoi(argv[3]); - dest_height = atoi(argv[4]); - } - else if (argc == 1) - { - src_width = 343; - src_height = 343; - dest_width = 711; - dest_height = 711; - } - else - { - fprintf (stderr, "Usage: scale [src_width src_height dest_width dest_height]\n"); - exit(1); - } - - - printf ("Scaling from (%d, %d) to (%d, %d)\n\n", src_width, src_height, dest_width, dest_height); - - init_array (scale_times); - init_array (composite_times); - init_array (composite_color_times); - - for (src_index = 0; src_index < 3; src_index++) - for (dest_index = 0; dest_index < 3; dest_index++) - { - int src_channels = (src_index == 0) ? 3 : 4; - int src_has_alpha = (src_index == 2); - int dest_channels = (dest_index == 0) ? 3 : 4; - int dest_has_alpha = (dest_index == 2); - - int src_rowstride = (src_channels*src_width + 3) & ~3; - int dest_rowstride = (dest_channels *dest_width + 3) & ~3; - - int filter_level; - - src_buf = g_malloc(src_rowstride * src_height); - memset (src_buf, 0x80, src_rowstride * src_height); - - dest_buf = g_malloc(dest_rowstride * dest_height); - memset (dest_buf, 0x80, dest_rowstride * dest_height); - - for (filter_level = PIXOPS_INTERP_NEAREST ; filter_level <= PIXOPS_INTERP_HYPER; filter_level++) - { - printf ("src_channels = %d (%s); dest_channels = %d (%s); filter_level=", - src_channels, src_has_alpha ? "alpha" : "no alpha", - dest_channels, dest_has_alpha ? "alpha" : "no alpha"); - switch (filter_level) - { - case PIXOPS_INTERP_NEAREST: - printf ("PIXOPS_INTERP_NEAREST\n"); - break; - case PIXOPS_INTERP_TILES: - printf ("PIXOPS_INTERP_TILES\n"); - break; - case PIXOPS_INTERP_BILINEAR: - printf ("PIXOPS_INTERP_BILINEAR\n"); - break; - case PIXOPS_INTERP_HYPER: - printf ("PIXOPS_INTERP_HYPER\n"); - break; - } - - printf("\t\t\titers\ttotal\t\tmsecs/iter\tMpixels/sec\t\n"); - - - if (!(src_has_alpha && !dest_has_alpha)) - { - start_timing (); - for (i = 0; i < ITERS; i++) - { - _pixops_scale (dest_buf, dest_width, dest_height, - dest_rowstride, dest_channels, - dest_has_alpha, src_buf, src_width, - src_height, src_rowstride, src_channels, - src_has_alpha, 0, 0, 0, 0, 0, 0, - (double)dest_width / src_width, - (double)dest_height / src_height, - filter_level); - } - scale_times[src_index][dest_index][filter_level] = - stop_timing (" scale\t\t", ITERS, dest_height * dest_width); - } - - start_timing (); - for (i = 0; i < ITERS; i++) - { - _pixops_composite (dest_buf, dest_width, dest_height, - dest_rowstride, dest_channels, - dest_has_alpha, src_buf, src_width, - src_height, src_rowstride, src_channels, - src_has_alpha, 0, 0, 0, 0, 0, 0, - (double)dest_width / src_width, - (double)dest_height / src_height, - filter_level, 255); - } - composite_times[src_index][dest_index][filter_level] = - stop_timing (" composite\t\t", ITERS, - dest_height * dest_width); - - start_timing (); - for (i = 0; i < ITERS; i++) - { - _pixops_composite_color (dest_buf, dest_width, dest_height, - dest_rowstride, dest_channels, - dest_has_alpha, src_buf, src_width, - src_height, src_rowstride, - src_channels, src_has_alpha, 0, 0, - 0, 0, 0, 0, - (double)dest_width / src_width, - (double)dest_height / src_height, - filter_level, 255, 0, 0, 16, - 0xaaaaaa, 0x555555); - } - composite_color_times[src_index][dest_index][filter_level] = - stop_timing (" composite color\t", ITERS, dest_height * dest_width); - - printf ("\n"); - } - printf ("\n"); - - g_free (src_buf); - g_free (dest_buf); - } - - printf ("SCALE\n=====\n\n"); - dump_array (scale_times); - - printf ("COMPOSITE\n=========\n\n"); - dump_array (composite_times); - - printf ("COMPOSITE_COLOR\n===============\n\n"); - dump_array (composite_color_times); - return 0; -} diff --git a/gdk-pixbuf/pltcheck.sh b/gdk-pixbuf/pltcheck.sh deleted file mode 100755 index 7c0dd52303..0000000000 --- a/gdk-pixbuf/pltcheck.sh +++ /dev/null @@ -1,17 +0,0 @@ -#!/bin/sh - -LANG=C - -status=0 - -if ! which readelf 2>/dev/null >/dev/null; then - echo "'readelf' not found; skipping test" - exit 0 -fi - -for so in .libs/libgdk_pixbuf*.so; do - echo Checking $so for local PLT entries - readelf -r $so | grep 'JU\?MP_SLOT' | grep 'gdk_pixbuf' && status=1 -done - -exit $status diff --git a/gdk-pixbuf/queryloaders.c b/gdk-pixbuf/queryloaders.c deleted file mode 100644 index b8f993517f..0000000000 --- a/gdk-pixbuf/queryloaders.c +++ /dev/null @@ -1,361 +0,0 @@ -/* -*- mode: C; c-file-style: "linux" -*- */ -/* GdkPixbuf library - * queryloaders.c: - * - * Copyright (C) 2002 The Free Software Foundation - * - * Author: Matthias Clasen <maclas@gmx.de> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#include "config.h" - -#include <glib.h> -#include <glib/gprintf.h> -#include <gmodule.h> - -#include <errno.h> -#include <string.h> -#ifdef HAVE_UNISTD_H -#include <unistd.h> -#endif - -#include "gdk-pixbuf/gdk-pixbuf.h" -#include "gdk-pixbuf/gdk-pixbuf-private.h" -#include "gdk-pixbuf/gdk-pixbuf-io.h" - -#ifdef USE_LA_MODULES -#define SOEXT ".la" -#else -#define SOEXT ("." G_MODULE_SUFFIX) -#endif -#define SOEXT_LEN (strlen (SOEXT)) - -#ifdef G_OS_WIN32 -#include <windows.h> -#endif - -static void -print_escaped (GString *contents, const char *str) -{ - gchar *tmp = g_strescape (str, ""); - g_string_append_printf (contents, "\"%s\" ", tmp); - g_free (tmp); -} - -static int -loader_sanity_check (const char *path, GdkPixbufFormat *info, GdkPixbufModule *vtable) -{ - const GdkPixbufModulePattern *pattern; - const char *error = ""; - - for (pattern = info->signature; pattern->prefix; pattern++) - { - int prefix_len = strlen (pattern->prefix); - if (prefix_len == 0) - { - error = "empty pattern"; - - goto error; - } - if (pattern->mask) - { - int mask_len = strlen (pattern->mask); - if (mask_len != prefix_len) - { - error = "mask length mismatch"; - - goto error; - } - if (strspn (pattern->mask, " !xzn*") < mask_len) - { - error = "bad char in mask"; - - goto error; - } - } - } - - if (!vtable->load && !vtable->begin_load && !vtable->load_animation) - { - error = "no load method implemented"; - - goto error; - } - - if (vtable->begin_load && (!vtable->stop_load || !vtable->load_increment)) - { - error = "incremental loading support incomplete"; - - goto error; - } - - if ((info->flags & GDK_PIXBUF_FORMAT_WRITABLE) && !(vtable->save || vtable->save_to_callback)) - { - error = "loader claims to support saving but doesn't implement save"; - goto error; - } - - return 1; - - error: - g_fprintf (stderr, "Loader sanity check failed for %s: %s\n", - path, error); - - return 0; -} - -static void -write_loader_info (GString *contents, const char *path, GdkPixbufFormat *info) -{ - const GdkPixbufModulePattern *pattern; - char **mime; - char **ext; - - g_string_append_printf (contents, "\"%s\"\n", path); - g_string_append_printf (contents, "\"%s\" %u \"%s\" \"%s\" \"%s\"\n", - info->name, - info->flags, - info->domain ? info->domain : GETTEXT_PACKAGE, - info->description, - info->license ? info->license : ""); - for (mime = info->mime_types; *mime; mime++) { - g_string_append_printf (contents, "\"%s\" ", *mime); - } - g_string_append (contents, "\"\"\n"); - for (ext = info->extensions; *ext; ext++) { - g_string_append_printf (contents, "\"%s\" ", *ext); - } - g_string_append (contents, "\"\"\n"); - for (pattern = info->signature; pattern->prefix; pattern++) { - print_escaped (contents, pattern->prefix); - print_escaped (contents, pattern->mask ? (const char *)pattern->mask : ""); - g_string_append_printf (contents, "%d\n", pattern->relevance); - } - g_string_append_c (contents, '\n'); -} - -static void -query_module (GString *contents, const char *dir, const char *file) -{ - char *path; - GModule *module; - void (*fill_info) (GdkPixbufFormat *info); - void (*fill_vtable) (GdkPixbufModule *module); - gpointer fill_info_ptr; - gpointer fill_vtable_ptr; - - if (g_path_is_absolute (file)) - path = g_strdup (file); - else - path = g_build_filename (dir, file, NULL); - - module = g_module_open (path, 0); - if (module && - g_module_symbol (module, "fill_info", &fill_info_ptr) && - g_module_symbol (module, "fill_vtable", &fill_vtable_ptr)) { - GdkPixbufFormat *info; - GdkPixbufModule *vtable; - -#ifdef G_OS_WIN32 - /* Replace backslashes in path with forward slashes, so that - * it reads in without problems. - */ - { - char *p = path; - while (*p) { - if (*p == '\\') - *p = '/'; - p++; - } - } -#endif - info = g_new0 (GdkPixbufFormat, 1); - vtable = g_new0 (GdkPixbufModule, 1); - - vtable->module = module; - - fill_info = fill_info_ptr; - fill_vtable = fill_vtable_ptr; - - (*fill_info) (info); - (*fill_vtable) (vtable); - - if (loader_sanity_check (path, info, vtable)) - write_loader_info (contents, path, info); - - g_free (info); - g_free (vtable); - } - else { - if (module == NULL) - g_fprintf (stderr, "g_module_open() failed for %s: %s\n", path, - g_module_error()); - else - g_fprintf (stderr, "Cannot load loader %s\n", path); - } - if (module) - g_module_close (module); - g_free (path); -} - -static gchar * -gdk_pixbuf_get_module_file (void) -{ - gchar *result = g_strdup (g_getenv ("GDK_PIXBUF_MODULE_FILE")); - - if (!result) - result = g_build_filename (GTK_LIBDIR, "gtk-3.0", GTK_BINARY_VERSION, "loaders.cache", NULL); - - return result; -} - -int main (int argc, char **argv) -{ - gint i; - gchar *prgname; - GString *contents; - gchar *cache_file = NULL; - gint first_file = 1; - -#ifdef G_OS_WIN32 - gchar *libdir; - gchar *runtime_prefix; - gchar *slash; - - if (g_ascii_strncasecmp (PIXBUF_LIBDIR, GTK_PREFIX, strlen (GTK_PREFIX)) == 0 && - G_IS_DIR_SEPARATOR (PIXBUF_LIBDIR[strlen (GTK_PREFIX)])) { - /* GTK_PREFIX is a prefix of PIXBUF_LIBDIR, as it - * normally is. Replace that prefix in PIXBUF_LIBDIR - * with the installation directory on this machine. - * We assume this invokation of - * gdk-pixbuf-query-loaders is run from either a "bin" - * subdirectory of the installation directory, or in - * the installation directory itself. - */ - wchar_t fn[1000]; - GetModuleFileNameW (NULL, fn, G_N_ELEMENTS (fn)); - runtime_prefix = g_utf16_to_utf8 (fn, -1, NULL, NULL, NULL); - slash = strrchr (runtime_prefix, '\\'); - *slash = '\0'; - slash = strrchr (runtime_prefix, '\\'); - /* If running from some weird location, or from the - * build directory (either in the .libs folder where - * libtool places the real executable when using a - * wrapper, or directly from the gdk-pixbuf folder), - * use the compile-time libdir. - */ - if (slash == NULL || - g_ascii_strcasecmp (slash + 1, ".libs") == 0 || - g_ascii_strcasecmp (slash + 1, "gdk-pixbuf") == 0) { - libdir = PIXBUF_LIBDIR; - } - else { - if (slash != NULL && g_ascii_strcasecmp (slash + 1, "bin") == 0) { - *slash = '\0'; - } - - libdir = g_strconcat (runtime_prefix, - "/", - PIXBUF_LIBDIR + strlen (GTK_PREFIX) + 1, - NULL); - } - } - else { - libdir = PIXBUF_LIBDIR; - } - -#undef PIXBUF_LIBDIR -#define PIXBUF_LIBDIR libdir - -#endif - - if (argc > 1 && strcmp (argv[1], "--update-cache") == 0) { - cache_file = gdk_pixbuf_get_module_file (); - first_file = 2; - } - - contents = g_string_new (""); - - prgname = g_get_prgname (); - g_string_append_printf (contents, - "# GdkPixbuf Image Loader Modules file\n" - "# Automatically generated file, do not edit\n" - "# Created by %s from gtk+-%s\n" - "#\n", - (prgname ? prgname : "gdk-pixbuf-query-loaders-3.0"), - GDK_PIXBUF_VERSION); - - if (argc == first_file) { -#ifdef USE_GMODULE - const char *path; - GDir *dir; - - path = g_getenv ("GDK_PIXBUF_MODULEDIR"); -#ifdef G_OS_WIN32 - if (path != NULL && *path != '\0') - path = g_locale_to_utf8 (path, -1, NULL, NULL, NULL); -#endif - if (path == NULL || *path == '\0') - path = PIXBUF_LIBDIR; - - g_string_append_printf (contents, "# LoaderDir = %s\n#\n", path); - - dir = g_dir_open (path, 0, NULL); - if (dir) { - const char *dent; - - while ((dent = g_dir_read_name (dir))) { - gint len = strlen (dent); - if (len > SOEXT_LEN && - strcmp (dent + len - SOEXT_LEN, SOEXT) == 0) { - query_module (contents, path, dent); - } - } - g_dir_close (dir); - } -#else - g_string_append_printf (contents, "# dynamic loading of modules not supported\n"); -#endif - } - else { - char *cwd = g_get_current_dir (); - - for (i = 1; i < argc; i++) { - char *infilename = argv[i]; -#ifdef G_OS_WIN32 - infilename = g_locale_to_utf8 (infilename, - -1, NULL, NULL, NULL); -#endif - query_module (contents, cwd, infilename); - } - g_free (cwd); - } - - if (cache_file) { - GError *err; - - err = NULL; - if (!g_file_set_contents (cache_file, contents->str, -1, &err)) { - g_fprintf (stderr, "%s\n", err->message); - } - } - else - g_print ("%s\n", contents->str); - - return 0; -} diff --git a/gdk-pixbuf/test-gdk-pixbuf.c b/gdk-pixbuf/test-gdk-pixbuf.c deleted file mode 100644 index b2d565a902..0000000000 --- a/gdk-pixbuf/test-gdk-pixbuf.c +++ /dev/null @@ -1,241 +0,0 @@ -/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */ - -/* GdkPixbuf library - test program - * - * Copyright (C) 1999 The Free Software Foundation - * - * Author: Federico Mena-Quintero <federico@gimp.org> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA. - */ - -#include "config.h" - -#include <stdlib.h> -#include "gdk-pixbuf.h" -#include <glib-object.h> - - - -static void -store_pixel (guchar *pixels, - int pixel, - gboolean alpha) -{ - if (alpha) { - pixels[0] = pixel >> 24; - pixels[1] = pixel >> 16; - pixels[2] = pixel >> 8; - pixels[3] = pixel; - } else { - pixels[0] = pixel >> 16; - pixels[1] = pixel >> 8; - pixels[2] = pixel; - } -} - -static void -fill_with_pixel (GdkPixbuf *pixbuf, - int pixel) -{ - int x, y; - - for (x = 0; x < gdk_pixbuf_get_width (pixbuf); x++) { - for (y = 0; y < gdk_pixbuf_get_height (pixbuf); y++) { - store_pixel (gdk_pixbuf_get_pixels (pixbuf) - + y * gdk_pixbuf_get_rowstride (pixbuf) - + x * gdk_pixbuf_get_n_channels (pixbuf), - pixel, - gdk_pixbuf_get_has_alpha (pixbuf)); - } - } -} - -static int -load_pixel (const guchar *pixels, - gboolean alpha) -{ - if (alpha) - return (((((pixels[0] << 8) | pixels[1]) << 8) | pixels[2]) << 8) | pixels[3]; - else - return (((pixels[0] << 8) | pixels[1]) << 8) | pixels[2]; -} - -static gboolean -simple_composite_test_one (GdkInterpType type, - int source_pixel, - gboolean source_alpha, - int destination_pixel, - gboolean destination_alpha, - int expected_result) -{ - GdkPixbuf *source_pixbuf; - GdkPixbuf *destination_pixbuf; - int result_pixel; - - source_pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, source_alpha, 8, 32, 32); - destination_pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, destination_alpha, 8, 32, 32); - - fill_with_pixel (source_pixbuf, source_pixel); - fill_with_pixel (destination_pixbuf, destination_pixel); - - gdk_pixbuf_composite (source_pixbuf, destination_pixbuf, - 0, 0, 32, 32, 0, 0, 1, 1, type, 0xFF); - - result_pixel = load_pixel (gdk_pixbuf_get_pixels (destination_pixbuf) - + 16 * gdk_pixbuf_get_rowstride (destination_pixbuf) - + 16 * gdk_pixbuf_get_n_channels (destination_pixbuf), - destination_alpha); - - g_object_unref (source_pixbuf); - g_object_unref (destination_pixbuf); - - if (result_pixel != expected_result) { - char *interpolation_type, *source_string, *destination_string, *result_string, *expected_string; - - switch (type) { - case GDK_INTERP_NEAREST: interpolation_type = "GDK_INTERP_NEAREST"; break; - case GDK_INTERP_TILES: interpolation_type = "GDK_INTERP_TILES"; break; - case GDK_INTERP_BILINEAR: interpolation_type = "GDK_INTERP_BILINEAR"; break; - case GDK_INTERP_HYPER: interpolation_type = "GDK_INTERP_HYPER"; break; - default: interpolation_type = "???"; - } - - if (source_alpha) { - source_string = g_strdup_printf ("0x%08X", source_pixel); - } else { - source_string = g_strdup_printf ("0x%06X", source_pixel); - } - - if (destination_alpha) { - destination_string = g_strdup_printf ("0x%08X", destination_pixel); - result_string = g_strdup_printf ("0x%08X", result_pixel); - expected_string = g_strdup_printf ("0x%08X", expected_result); - } else { - destination_string = g_strdup_printf ("0x%06X", destination_pixel); - result_string = g_strdup_printf ("0x%06X", result_pixel); - expected_string = g_strdup_printf ("0x%06X", expected_result); - } - - g_message ("simple_composite_test (%s): composite %s on top of %s, expected %s, got %s", - interpolation_type, - source_string, destination_string, expected_string, result_string); - return FALSE; - } - - return TRUE; -} - -static gboolean -simple_composite_test_one_type (GdkInterpType type) -{ - gboolean success; - - success = TRUE; - - /* There are only a few trivial cases in here. - * But these were enough to expose the problems in the old composite code. - */ - - /* Non-alpha into non-alpha. */ - success &= simple_composite_test_one (type, 0x000000, FALSE, 0x000000, FALSE, 0x000000); - success &= simple_composite_test_one (type, 0x000000, FALSE, 0xFFFFFF, FALSE, 0x000000); - success &= simple_composite_test_one (type, 0xFF0000, FALSE, 0x000000, FALSE, 0xFF0000); - success &= simple_composite_test_one (type, 0x00FF00, FALSE, 0x000000, FALSE, 0x00FF00); - success &= simple_composite_test_one (type, 0x0000FF, FALSE, 0x000000, FALSE, 0x0000FF); - success &= simple_composite_test_one (type, 0x000000, FALSE, 0xFF0000, FALSE, 0x000000); - success &= simple_composite_test_one (type, 0x000000, FALSE, 0x00FF00, FALSE, 0x000000); - success &= simple_composite_test_one (type, 0x000000, FALSE, 0x0000FF, FALSE, 0x000000); - success &= simple_composite_test_one (type, 0x00FF00, FALSE, 0xFFFFFF, FALSE, 0x00FF00); - success &= simple_composite_test_one (type, 0xFFFFFF, FALSE, 0xFFFFFF, FALSE, 0xFFFFFF); - - /* Alpha into non-alpha. */ - success &= simple_composite_test_one (type, 0x00000000, TRUE, 0x000000, FALSE, 0x000000); - success &= simple_composite_test_one (type, 0x00000000, TRUE, 0xFFFFFF, FALSE, 0xFFFFFF); - success &= simple_composite_test_one (type, 0x0000007F, TRUE, 0xFFFFFF, FALSE, 0x808080); - success &= simple_composite_test_one (type, 0x00000080, TRUE, 0xFFFFFF, FALSE, 0x7F7F7F); - success &= simple_composite_test_one (type, 0x000000FF, TRUE, 0xFFFFFF, FALSE, 0x000000); - success &= simple_composite_test_one (type, 0x000000FF, TRUE, 0xFFFFFF, FALSE, 0x000000); - success &= simple_composite_test_one (type, 0xFF0000FF, TRUE, 0x000000, FALSE, 0xFF0000); - success &= simple_composite_test_one (type, 0x00FF00FF, TRUE, 0x000000, FALSE, 0x00FF00); - success &= simple_composite_test_one (type, 0x0000FFFF, TRUE, 0x000000, FALSE, 0x0000FF); - success &= simple_composite_test_one (type, 0x00000000, TRUE, 0xFF0000, FALSE, 0xFF0000); - success &= simple_composite_test_one (type, 0x00000000, TRUE, 0x00FF00, FALSE, 0x00FF00); - success &= simple_composite_test_one (type, 0x00000000, TRUE, 0x0000FF, FALSE, 0x0000FF); - success &= simple_composite_test_one (type, 0x00FF0080, TRUE, 0xFFFFFF, FALSE, 0x7FFF7F); - success &= simple_composite_test_one (type, 0xFFFFFFFF, TRUE, 0xFFFFFF, FALSE, 0xFFFFFF); - - /* Non-alpha into alpha. */ - success &= simple_composite_test_one (type, 0x000000, FALSE, 0x00000000, TRUE, 0x000000FF); - success &= simple_composite_test_one (type, 0x000000, FALSE, 0xFFFFFFFF, TRUE, 0x000000FF); - success &= simple_composite_test_one (type, 0xFF0000, FALSE, 0x00000000, TRUE, 0xFF0000FF); - success &= simple_composite_test_one (type, 0x00FF00, FALSE, 0x00000000, TRUE, 0x00FF00FF); - success &= simple_composite_test_one (type, 0x0000FF, FALSE, 0x00000000, TRUE, 0x0000FFFF); - success &= simple_composite_test_one (type, 0x000000, FALSE, 0xFF0000FF, TRUE, 0x000000FF); - success &= simple_composite_test_one (type, 0x000000, FALSE, 0x00FF00FF, TRUE, 0x000000FF); - success &= simple_composite_test_one (type, 0x000000, FALSE, 0x0000FFFF, TRUE, 0x000000FF); - success &= simple_composite_test_one (type, 0x00FF00, FALSE, 0xFFFFFF00, TRUE, 0x00FF00FF); - success &= simple_composite_test_one (type, 0xFFFFFF, FALSE, 0xFFFFFFFF, TRUE, 0xFFFFFFFF); - - /* Alpha into alpha. */ - success &= simple_composite_test_one (type, 0x00000000, TRUE, 0x00000000, TRUE, 0x00000000); - success &= simple_composite_test_one (type, 0x00000000, TRUE, 0xFFFFFFFF, TRUE, 0xFFFFFFFF); - success &= simple_composite_test_one (type, 0x0000007F, TRUE, 0xFFFFFFFF, TRUE, 0x808080FF); - success &= simple_composite_test_one (type, 0x00000080, TRUE, 0xFFFFFFFF, TRUE, 0x7F7F7FFF); - success &= simple_composite_test_one (type, 0x000000FF, TRUE, 0xFFFFFFFF, TRUE, 0x000000FF); - success &= simple_composite_test_one (type, 0xFF0000FF, TRUE, 0x00000000, TRUE, 0xFF0000FF); - success &= simple_composite_test_one (type, 0x00FF00FF, TRUE, 0x00000000, TRUE, 0x00FF00FF); - success &= simple_composite_test_one (type, 0x0000FFFF, TRUE, 0x00000000, TRUE, 0x0000FFFF); - success &= simple_composite_test_one (type, 0x00000000, TRUE, 0xFF0000FF, TRUE, 0xFF0000FF); - success &= simple_composite_test_one (type, 0x00000000, TRUE, 0x00FF00FF, TRUE, 0x00FF00FF); - success &= simple_composite_test_one (type, 0x00000000, TRUE, 0x0000FFFF, TRUE, 0x0000FFFF); - success &= simple_composite_test_one (type, 0x00FF0080, TRUE, 0xFFFFFF00, TRUE, 0x00FF0080); - success &= simple_composite_test_one (type, 0xFF000080, TRUE, 0x00FF0040, TRUE, 0xCC32009F); - success &= simple_composite_test_one (type, 0xFFFFFFFF, TRUE, 0xFFFFFFFF, TRUE, 0xFFFFFFFF); - - return success; -} - -static gboolean -simple_composite_test (void) -{ - gboolean success; - - success = TRUE; - - success &= simple_composite_test_one_type (GDK_INTERP_NEAREST); - success &= simple_composite_test_one_type (GDK_INTERP_TILES); - success &= simple_composite_test_one_type (GDK_INTERP_BILINEAR); - success &= simple_composite_test_one_type (GDK_INTERP_HYPER); - - return success; -} - -int -main (int argc, char **argv) -{ - int result; - - result = EXIT_SUCCESS; - - g_type_init (); - - /* Run some tests. */ - if (!simple_composite_test ()) { - result = EXIT_FAILURE; - } - - return result; -} diff --git a/gdk-pixbuf/xpm-color-table.h b/gdk-pixbuf/xpm-color-table.h deleted file mode 100644 index 637a27c469..0000000000 --- a/gdk-pixbuf/xpm-color-table.h +++ /dev/null @@ -1,1521 +0,0 @@ -/* xpm-color-table.h: Generated by gen-color-table.pl from rgb.txt - * - * Date: Tue Mar 8 03:54:56 2005 - * - * Do not edit. - */ -static const char color_names[] = - "alice blue\0" - "AliceBlue\0" - "antique white\0" - "AntiqueWhite\0" - "AntiqueWhite1\0" - "AntiqueWhite2\0" - "AntiqueWhite3\0" - "AntiqueWhite4\0" - "aquamarine\0" - "aquamarine1\0" - "aquamarine2\0" - "aquamarine3\0" - "aquamarine4\0" - "azure\0" - "azure1\0" - "azure2\0" - "azure3\0" - "azure4\0" - "beige\0" - "bisque\0" - "bisque1\0" - "bisque2\0" - "bisque3\0" - "bisque4\0" - "black\0" - "blanched almond\0" - "BlanchedAlmond\0" - "blue\0" - "blue violet\0" - "blue1\0" - "blue2\0" - "blue3\0" - "blue4\0" - "BlueViolet\0" - "brown\0" - "brown1\0" - "brown2\0" - "brown3\0" - "brown4\0" - "burlywood\0" - "burlywood1\0" - "burlywood2\0" - "burlywood3\0" - "burlywood4\0" - "cadet blue\0" - "CadetBlue\0" - "CadetBlue1\0" - "CadetBlue2\0" - "CadetBlue3\0" - "CadetBlue4\0" - "chartreuse\0" - "chartreuse1\0" - "chartreuse2\0" - "chartreuse3\0" - "chartreuse4\0" - "chocolate\0" - "chocolate1\0" - "chocolate2\0" - "chocolate3\0" - "chocolate4\0" - "coral\0" - "coral1\0" - "coral2\0" - "coral3\0" - "coral4\0" - "cornflower blue\0" - "CornflowerBlue\0" - "cornsilk\0" - "cornsilk1\0" - "cornsilk2\0" - "cornsilk3\0" - "cornsilk4\0" - "cyan\0" - "cyan1\0" - "cyan2\0" - "cyan3\0" - "cyan4\0" - "dark blue\0" - "dark cyan\0" - "dark goldenrod\0" - "dark gray\0" - "dark green\0" - "dark grey\0" - "dark khaki\0" - "dark magenta\0" - "dark olive green\0" - "dark orange\0" - "dark orchid\0" - "dark red\0" - "dark salmon\0" - "dark sea green\0" - "dark slate blue\0" - "dark slate gray\0" - "dark slate grey\0" - "dark turquoise\0" - "dark violet\0" - "DarkBlue\0" - "DarkCyan\0" - "DarkGoldenrod\0" - "DarkGoldenrod1\0" - "DarkGoldenrod2\0" - "DarkGoldenrod3\0" - "DarkGoldenrod4\0" - "DarkGray\0" - "DarkGreen\0" - "DarkGrey\0" - "DarkKhaki\0" - "DarkMagenta\0" - "DarkOliveGreen\0" - "DarkOliveGreen1\0" - "DarkOliveGreen2\0" - "DarkOliveGreen3\0" - "DarkOliveGreen4\0" - "DarkOrange\0" - "DarkOrange1\0" - "DarkOrange2\0" - "DarkOrange3\0" - "DarkOrange4\0" - "DarkOrchid\0" - "DarkOrchid1\0" - "DarkOrchid2\0" - "DarkOrchid3\0" - "DarkOrchid4\0" - "DarkRed\0" - "DarkSalmon\0" - "DarkSeaGreen\0" - "DarkSeaGreen1\0" - "DarkSeaGreen2\0" - "DarkSeaGreen3\0" - "DarkSeaGreen4\0" - "DarkSlateBlue\0" - "DarkSlateGray\0" - "DarkSlateGray1\0" - "DarkSlateGray2\0" - "DarkSlateGray3\0" - "DarkSlateGray4\0" - "DarkSlateGrey\0" - "DarkTurquoise\0" - "DarkViolet\0" - "deep pink\0" - "deep sky blue\0" - "DeepPink\0" - "DeepPink1\0" - "DeepPink2\0" - "DeepPink3\0" - "DeepPink4\0" - "DeepSkyBlue\0" - "DeepSkyBlue1\0" - "DeepSkyBlue2\0" - "DeepSkyBlue3\0" - "DeepSkyBlue4\0" - "dim gray\0" - "dim grey\0" - "DimGray\0" - "DimGrey\0" - "dodger blue\0" - "DodgerBlue\0" - "DodgerBlue1\0" - "DodgerBlue2\0" - "DodgerBlue3\0" - "DodgerBlue4\0" - "firebrick\0" - "firebrick1\0" - "firebrick2\0" - "firebrick3\0" - "firebrick4\0" - "floral white\0" - "FloralWhite\0" - "forest green\0" - "ForestGreen\0" - "gainsboro\0" - "ghost white\0" - "GhostWhite\0" - "gold\0" - "gold1\0" - "gold2\0" - "gold3\0" - "gold4\0" - "goldenrod\0" - "goldenrod1\0" - "goldenrod2\0" - "goldenrod3\0" - "goldenrod4\0" - "gray\0" - "gray0\0" - "gray1\0" - "gray10\0" - "gray100\0" - "gray11\0" - "gray12\0" - "gray13\0" - "gray14\0" - "gray15\0" - "gray16\0" - "gray17\0" - "gray18\0" - "gray19\0" - "gray2\0" - "gray20\0" - "gray21\0" - "gray22\0" - "gray23\0" - "gray24\0" - "gray25\0" - "gray26\0" - "gray27\0" - "gray28\0" - "gray29\0" - "gray3\0" - "gray30\0" - "gray31\0" - "gray32\0" - "gray33\0" - "gray34\0" - "gray35\0" - "gray36\0" - "gray37\0" - "gray38\0" - "gray39\0" - "gray4\0" - "gray40\0" - "gray41\0" - "gray42\0" - "gray43\0" - "gray44\0" - "gray45\0" - "gray46\0" - "gray47\0" - "gray48\0" - "gray49\0" - "gray5\0" - "gray50\0" - "gray51\0" - "gray52\0" - "gray53\0" - "gray54\0" - "gray55\0" - "gray56\0" - "gray57\0" - "gray58\0" - "gray59\0" - "gray6\0" - "gray60\0" - "gray61\0" - "gray62\0" - "gray63\0" - "gray64\0" - "gray65\0" - "gray66\0" - "gray67\0" - "gray68\0" - "gray69\0" - "gray7\0" - "gray70\0" - "gray71\0" - "gray72\0" - "gray73\0" - "gray74\0" - "gray75\0" - "gray76\0" - "gray77\0" - "gray78\0" - "gray79\0" - "gray8\0" - "gray80\0" - "gray81\0" - "gray82\0" - "gray83\0" - "gray84\0" - "gray85\0" - "gray86\0" - "gray87\0" - "gray88\0" - "gray89\0" - "gray9\0" - "gray90\0" - "gray91\0" - "gray92\0" - "gray93\0" - "gray94\0" - "gray95\0" - "gray96\0" - "gray97\0" - "gray98\0" - "gray99\0" - "green\0" - "green yellow\0" - "green1\0" - "green2\0" - "green3\0" - "green4\0" - "GreenYellow\0" - "grey\0" - "grey0\0" - "grey1\0" - "grey10\0" - "grey100\0" - "grey11\0" - "grey12\0" - "grey13\0" - "grey14\0" - "grey15\0" - "grey16\0" - "grey17\0" - "grey18\0" - "grey19\0" - "grey2\0" - "grey20\0" - "grey21\0" - "grey22\0" - "grey23\0" - "grey24\0" - "grey25\0" - "grey26\0" - "grey27\0" - "grey28\0" - "grey29\0" - "grey3\0" - "grey30\0" - "grey31\0" - "grey32\0" - "grey33\0" - "grey34\0" - "grey35\0" - "grey36\0" - "grey37\0" - "grey38\0" - "grey39\0" - "grey4\0" - "grey40\0" - "grey41\0" - "grey42\0" - "grey43\0" - "grey44\0" - "grey45\0" - "grey46\0" - "grey47\0" - "grey48\0" - "grey49\0" - "grey5\0" - "grey50\0" - "grey51\0" - "grey52\0" - "grey53\0" - "grey54\0" - "grey55\0" - "grey56\0" - "grey57\0" - "grey58\0" - "grey59\0" - "grey6\0" - "grey60\0" - "grey61\0" - "grey62\0" - "grey63\0" - "grey64\0" - "grey65\0" - "grey66\0" - "grey67\0" - "grey68\0" - "grey69\0" - "grey7\0" - "grey70\0" - "grey71\0" - "grey72\0" - "grey73\0" - "grey74\0" - "grey75\0" - "grey76\0" - "grey77\0" - "grey78\0" - "grey79\0" - "grey8\0" - "grey80\0" - "grey81\0" - "grey82\0" - "grey83\0" - "grey84\0" - "grey85\0" - "grey86\0" - "grey87\0" - "grey88\0" - "grey89\0" - "grey9\0" - "grey90\0" - "grey91\0" - "grey92\0" - "grey93\0" - "grey94\0" - "grey95\0" - "grey96\0" - "grey97\0" - "grey98\0" - "grey99\0" - "honeydew\0" - "honeydew1\0" - "honeydew2\0" - "honeydew3\0" - "honeydew4\0" - "hot pink\0" - "HotPink\0" - "HotPink1\0" - "HotPink2\0" - "HotPink3\0" - "HotPink4\0" - "indian red\0" - "IndianRed\0" - "IndianRed1\0" - "IndianRed2\0" - "IndianRed3\0" - "IndianRed4\0" - "ivory\0" - "ivory1\0" - "ivory2\0" - "ivory3\0" - "ivory4\0" - "khaki\0" - "khaki1\0" - "khaki2\0" - "khaki3\0" - "khaki4\0" - "lavender\0" - "lavender blush\0" - "LavenderBlush\0" - "LavenderBlush1\0" - "LavenderBlush2\0" - "LavenderBlush3\0" - "LavenderBlush4\0" - "lawn green\0" - "LawnGreen\0" - "lemon chiffon\0" - "LemonChiffon\0" - "LemonChiffon1\0" - "LemonChiffon2\0" - "LemonChiffon3\0" - "LemonChiffon4\0" - "light blue\0" - "light coral\0" - "light cyan\0" - "light goldenrod\0" - "light goldenrod yellow\0" - "light gray\0" - "light green\0" - "light grey\0" - "light pink\0" - "light salmon\0" - "light sea green\0" - "light sky blue\0" - "light slate blue\0" - "light slate gray\0" - "light slate grey\0" - "light steel blue\0" - "light yellow\0" - "LightBlue\0" - "LightBlue1\0" - "LightBlue2\0" - "LightBlue3\0" - "LightBlue4\0" - "LightCoral\0" - "LightCyan\0" - "LightCyan1\0" - "LightCyan2\0" - "LightCyan3\0" - "LightCyan4\0" - "LightGoldenrod\0" - "LightGoldenrod1\0" - "LightGoldenrod2\0" - "LightGoldenrod3\0" - "LightGoldenrod4\0" - "LightGoldenrodYellow\0" - "LightGray\0" - "LightGreen\0" - "LightGrey\0" - "LightPink\0" - "LightPink1\0" - "LightPink2\0" - "LightPink3\0" - "LightPink4\0" - "LightSalmon\0" - "LightSalmon1\0" - "LightSalmon2\0" - "LightSalmon3\0" - "LightSalmon4\0" - "LightSeaGreen\0" - "LightSkyBlue\0" - "LightSkyBlue1\0" - "LightSkyBlue2\0" - "LightSkyBlue3\0" - "LightSkyBlue4\0" - "LightSlateBlue\0" - "LightSlateGray\0" - "LightSlateGrey\0" - "LightSteelBlue\0" - "LightSteelBlue1\0" - "LightSteelBlue2\0" - "LightSteelBlue3\0" - "LightSteelBlue4\0" - "LightYellow\0" - "LightYellow1\0" - "LightYellow2\0" - "LightYellow3\0" - "LightYellow4\0" - "lime green\0" - "LimeGreen\0" - "linen\0" - "magenta\0" - "magenta1\0" - "magenta2\0" - "magenta3\0" - "magenta4\0" - "maroon\0" - "maroon1\0" - "maroon2\0" - "maroon3\0" - "maroon4\0" - "medium aquamarine\0" - "medium blue\0" - "medium orchid\0" - "medium purple\0" - "medium sea green\0" - "medium slate blue\0" - "medium spring green\0" - "medium turquoise\0" - "medium violet red\0" - "MediumAquamarine\0" - "MediumBlue\0" - "MediumOrchid\0" - "MediumOrchid1\0" - "MediumOrchid2\0" - "MediumOrchid3\0" - "MediumOrchid4\0" - "MediumPurple\0" - "MediumPurple1\0" - "MediumPurple2\0" - "MediumPurple3\0" - "MediumPurple4\0" - "MediumSeaGreen\0" - "MediumSlateBlue\0" - "MediumSpringGreen\0" - "MediumTurquoise\0" - "MediumVioletRed\0" - "midnight blue\0" - "MidnightBlue\0" - "mint cream\0" - "MintCream\0" - "misty rose\0" - "MistyRose\0" - "MistyRose1\0" - "MistyRose2\0" - "MistyRose3\0" - "MistyRose4\0" - "moccasin\0" - "navajo white\0" - "NavajoWhite\0" - "NavajoWhite1\0" - "NavajoWhite2\0" - "NavajoWhite3\0" - "NavajoWhite4\0" - "navy\0" - "navy blue\0" - "NavyBlue\0" - "old lace\0" - "OldLace\0" - "olive drab\0" - "OliveDrab\0" - "OliveDrab1\0" - "OliveDrab2\0" - "OliveDrab3\0" - "OliveDrab4\0" - "orange\0" - "orange red\0" - "orange1\0" - "orange2\0" - "orange3\0" - "orange4\0" - "OrangeRed\0" - "OrangeRed1\0" - "OrangeRed2\0" - "OrangeRed3\0" - "OrangeRed4\0" - "orchid\0" - "orchid1\0" - "orchid2\0" - "orchid3\0" - "orchid4\0" - "pale goldenrod\0" - "pale green\0" - "pale turquoise\0" - "pale violet red\0" - "PaleGoldenrod\0" - "PaleGreen\0" - "PaleGreen1\0" - "PaleGreen2\0" - "PaleGreen3\0" - "PaleGreen4\0" - "PaleTurquoise\0" - "PaleTurquoise1\0" - "PaleTurquoise2\0" - "PaleTurquoise3\0" - "PaleTurquoise4\0" - "PaleVioletRed\0" - "PaleVioletRed1\0" - "PaleVioletRed2\0" - "PaleVioletRed3\0" - "PaleVioletRed4\0" - "papaya whip\0" - "PapayaWhip\0" - "peach puff\0" - "PeachPuff\0" - "PeachPuff1\0" - "PeachPuff2\0" - "PeachPuff3\0" - "PeachPuff4\0" - "peru\0" - "pink\0" - "pink1\0" - "pink2\0" - "pink3\0" - "pink4\0" - "plum\0" - "plum1\0" - "plum2\0" - "plum3\0" - "plum4\0" - "powder blue\0" - "PowderBlue\0" - "purple\0" - "purple1\0" - "purple2\0" - "purple3\0" - "purple4\0" - "red\0" - "red1\0" - "red2\0" - "red3\0" - "red4\0" - "rosy brown\0" - "RosyBrown\0" - "RosyBrown1\0" - "RosyBrown2\0" - "RosyBrown3\0" - "RosyBrown4\0" - "royal blue\0" - "RoyalBlue\0" - "RoyalBlue1\0" - "RoyalBlue2\0" - "RoyalBlue3\0" - "RoyalBlue4\0" - "saddle brown\0" - "SaddleBrown\0" - "salmon\0" - "salmon1\0" - "salmon2\0" - "salmon3\0" - "salmon4\0" - "sandy brown\0" - "SandyBrown\0" - "sea green\0" - "SeaGreen\0" - "SeaGreen1\0" - "SeaGreen2\0" - "SeaGreen3\0" - "SeaGreen4\0" - "seashell\0" - "seashell1\0" - "seashell2\0" - "seashell3\0" - "seashell4\0" - "sienna\0" - "sienna1\0" - "sienna2\0" - "sienna3\0" - "sienna4\0" - "sky blue\0" - "SkyBlue\0" - "SkyBlue1\0" - "SkyBlue2\0" - "SkyBlue3\0" - "SkyBlue4\0" - "slate blue\0" - "slate gray\0" - "slate grey\0" - "SlateBlue\0" - "SlateBlue1\0" - "SlateBlue2\0" - "SlateBlue3\0" - "SlateBlue4\0" - "SlateGray\0" - "SlateGray1\0" - "SlateGray2\0" - "SlateGray3\0" - "SlateGray4\0" - "SlateGrey\0" - "snow\0" - "snow1\0" - "snow2\0" - "snow3\0" - "snow4\0" - "spring green\0" - "SpringGreen\0" - "SpringGreen1\0" - "SpringGreen2\0" - "SpringGreen3\0" - "SpringGreen4\0" - "steel blue\0" - "SteelBlue\0" - "SteelBlue1\0" - "SteelBlue2\0" - "SteelBlue3\0" - "SteelBlue4\0" - "tan\0" - "tan1\0" - "tan2\0" - "tan3\0" - "tan4\0" - "thistle\0" - "thistle1\0" - "thistle2\0" - "thistle3\0" - "thistle4\0" - "tomato\0" - "tomato1\0" - "tomato2\0" - "tomato3\0" - "tomato4\0" - "turquoise\0" - "turquoise1\0" - "turquoise2\0" - "turquoise3\0" - "turquoise4\0" - "violet\0" - "violet red\0" - "VioletRed\0" - "VioletRed1\0" - "VioletRed2\0" - "VioletRed3\0" - "VioletRed4\0" - "wheat\0" - "wheat1\0" - "wheat2\0" - "wheat3\0" - "wheat4\0" - "white\0" - "white smoke\0" - "WhiteSmoke\0" - "yellow\0" - "yellow green\0" - "yellow1\0" - "yellow2\0" - "yellow3\0" - "yellow4\0" - "YellowGreen\0"; - -typedef struct { - guint16 name_offset; - guchar red; - guchar green; - guchar blue; -} XPMColorEntry; - -static const XPMColorEntry xColors[] = { - { 0, 240, 248, 255 }, - { 11, 240, 248, 255 }, - { 21, 250, 235, 215 }, - { 35, 250, 235, 215 }, - { 48, 255, 239, 219 }, - { 62, 238, 223, 204 }, - { 76, 205, 192, 176 }, - { 90, 139, 131, 120 }, - { 104, 127, 255, 212 }, - { 115, 127, 255, 212 }, - { 127, 118, 238, 198 }, - { 139, 102, 205, 170 }, - { 151, 69, 139, 116 }, - { 163, 240, 255, 255 }, - { 169, 240, 255, 255 }, - { 176, 224, 238, 238 }, - { 183, 193, 205, 205 }, - { 190, 131, 139, 139 }, - { 197, 245, 245, 220 }, - { 203, 255, 228, 196 }, - { 210, 255, 228, 196 }, - { 218, 238, 213, 183 }, - { 226, 205, 183, 158 }, - { 234, 139, 125, 107 }, - { 242, 0, 0, 0 }, - { 248, 255, 235, 205 }, - { 264, 255, 235, 205 }, - { 279, 0, 0, 255 }, - { 284, 138, 43, 226 }, - { 296, 0, 0, 255 }, - { 302, 0, 0, 238 }, - { 308, 0, 0, 205 }, - { 314, 0, 0, 139 }, - { 320, 138, 43, 226 }, - { 331, 165, 42, 42 }, - { 337, 255, 64, 64 }, - { 344, 238, 59, 59 }, - { 351, 205, 51, 51 }, - { 358, 139, 35, 35 }, - { 365, 222, 184, 135 }, - { 375, 255, 211, 155 }, - { 386, 238, 197, 145 }, - { 397, 205, 170, 125 }, - { 408, 139, 115, 85 }, - { 419, 95, 158, 160 }, - { 430, 95, 158, 160 }, - { 440, 152, 245, 255 }, - { 451, 142, 229, 238 }, - { 462, 122, 197, 205 }, - { 473, 83, 134, 139 }, - { 484, 127, 255, 0 }, - { 495, 127, 255, 0 }, - { 507, 118, 238, 0 }, - { 519, 102, 205, 0 }, - { 531, 69, 139, 0 }, - { 543, 210, 105, 30 }, - { 553, 255, 127, 36 }, - { 564, 238, 118, 33 }, - { 575, 205, 102, 29 }, - { 586, 139, 69, 19 }, - { 597, 255, 127, 80 }, - { 603, 255, 114, 86 }, - { 610, 238, 106, 80 }, - { 617, 205, 91, 69 }, - { 624, 139, 62, 47 }, - { 631, 100, 149, 237 }, - { 647, 100, 149, 237 }, - { 662, 255, 248, 220 }, - { 671, 255, 248, 220 }, - { 681, 238, 232, 205 }, - { 691, 205, 200, 177 }, - { 701, 139, 136, 120 }, - { 711, 0, 255, 255 }, - { 716, 0, 255, 255 }, - { 722, 0, 238, 238 }, - { 728, 0, 205, 205 }, - { 734, 0, 139, 139 }, - { 740, 0, 0, 139 }, - { 750, 0, 139, 139 }, - { 760, 184, 134, 11 }, - { 775, 169, 169, 169 }, - { 785, 0, 100, 0 }, - { 796, 169, 169, 169 }, - { 806, 189, 183, 107 }, - { 817, 139, 0, 139 }, - { 830, 85, 107, 47 }, - { 847, 255, 140, 0 }, - { 859, 153, 50, 204 }, - { 871, 139, 0, 0 }, - { 880, 233, 150, 122 }, - { 892, 143, 188, 143 }, - { 907, 72, 61, 139 }, - { 923, 47, 79, 79 }, - { 939, 47, 79, 79 }, - { 955, 0, 206, 209 }, - { 970, 148, 0, 211 }, - { 982, 0, 0, 139 }, - { 991, 0, 139, 139 }, - { 1000, 184, 134, 11 }, - { 1014, 255, 185, 15 }, - { 1029, 238, 173, 14 }, - { 1044, 205, 149, 12 }, - { 1059, 139, 101, 8 }, - { 1074, 169, 169, 169 }, - { 1083, 0, 100, 0 }, - { 1093, 169, 169, 169 }, - { 1102, 189, 183, 107 }, - { 1112, 139, 0, 139 }, - { 1124, 85, 107, 47 }, - { 1139, 202, 255, 112 }, - { 1155, 188, 238, 104 }, - { 1171, 162, 205, 90 }, - { 1187, 110, 139, 61 }, - { 1203, 255, 140, 0 }, - { 1214, 255, 127, 0 }, - { 1226, 238, 118, 0 }, - { 1238, 205, 102, 0 }, - { 1250, 139, 69, 0 }, - { 1262, 153, 50, 204 }, - { 1273, 191, 62, 255 }, - { 1285, 178, 58, 238 }, - { 1297, 154, 50, 205 }, - { 1309, 104, 34, 139 }, - { 1321, 139, 0, 0 }, - { 1329, 233, 150, 122 }, - { 1340, 143, 188, 143 }, - { 1353, 193, 255, 193 }, - { 1367, 180, 238, 180 }, - { 1381, 155, 205, 155 }, - { 1395, 105, 139, 105 }, - { 1409, 72, 61, 139 }, - { 1423, 47, 79, 79 }, - { 1437, 151, 255, 255 }, - { 1452, 141, 238, 238 }, - { 1467, 121, 205, 205 }, - { 1482, 82, 139, 139 }, - { 1497, 47, 79, 79 }, - { 1511, 0, 206, 209 }, - { 1525, 148, 0, 211 }, - { 1536, 255, 20, 147 }, - { 1546, 0, 191, 255 }, - { 1560, 255, 20, 147 }, - { 1569, 255, 20, 147 }, - { 1579, 238, 18, 137 }, - { 1589, 205, 16, 118 }, - { 1599, 139, 10, 80 }, - { 1609, 0, 191, 255 }, - { 1621, 0, 191, 255 }, - { 1634, 0, 178, 238 }, - { 1647, 0, 154, 205 }, - { 1660, 0, 104, 139 }, - { 1673, 105, 105, 105 }, - { 1682, 105, 105, 105 }, - { 1691, 105, 105, 105 }, - { 1699, 105, 105, 105 }, - { 1707, 30, 144, 255 }, - { 1719, 30, 144, 255 }, - { 1730, 30, 144, 255 }, - { 1742, 28, 134, 238 }, - { 1754, 24, 116, 205 }, - { 1766, 16, 78, 139 }, - { 1778, 178, 34, 34 }, - { 1788, 255, 48, 48 }, - { 1799, 238, 44, 44 }, - { 1810, 205, 38, 38 }, - { 1821, 139, 26, 26 }, - { 1832, 255, 250, 240 }, - { 1845, 255, 250, 240 }, - { 1857, 34, 139, 34 }, - { 1870, 34, 139, 34 }, - { 1882, 220, 220, 220 }, - { 1892, 248, 248, 255 }, - { 1904, 248, 248, 255 }, - { 1915, 255, 215, 0 }, - { 1920, 255, 215, 0 }, - { 1926, 238, 201, 0 }, - { 1932, 205, 173, 0 }, - { 1938, 139, 117, 0 }, - { 1944, 218, 165, 32 }, - { 1954, 255, 193, 37 }, - { 1965, 238, 180, 34 }, - { 1976, 205, 155, 29 }, - { 1987, 139, 105, 20 }, - { 1998, 190, 190, 190 }, - { 2003, 0, 0, 0 }, - { 2009, 3, 3, 3 }, - { 2015, 26, 26, 26 }, - { 2022, 255, 255, 255 }, - { 2030, 28, 28, 28 }, - { 2037, 31, 31, 31 }, - { 2044, 33, 33, 33 }, - { 2051, 36, 36, 36 }, - { 2058, 38, 38, 38 }, - { 2065, 41, 41, 41 }, - { 2072, 43, 43, 43 }, - { 2079, 46, 46, 46 }, - { 2086, 48, 48, 48 }, - { 2093, 5, 5, 5 }, - { 2099, 51, 51, 51 }, - { 2106, 54, 54, 54 }, - { 2113, 56, 56, 56 }, - { 2120, 59, 59, 59 }, - { 2127, 61, 61, 61 }, - { 2134, 64, 64, 64 }, - { 2141, 66, 66, 66 }, - { 2148, 69, 69, 69 }, - { 2155, 71, 71, 71 }, - { 2162, 74, 74, 74 }, - { 2169, 8, 8, 8 }, - { 2175, 77, 77, 77 }, - { 2182, 79, 79, 79 }, - { 2189, 82, 82, 82 }, - { 2196, 84, 84, 84 }, - { 2203, 87, 87, 87 }, - { 2210, 89, 89, 89 }, - { 2217, 92, 92, 92 }, - { 2224, 94, 94, 94 }, - { 2231, 97, 97, 97 }, - { 2238, 99, 99, 99 }, - { 2245, 10, 10, 10 }, - { 2251, 102, 102, 102 }, - { 2258, 105, 105, 105 }, - { 2265, 107, 107, 107 }, - { 2272, 110, 110, 110 }, - { 2279, 112, 112, 112 }, - { 2286, 115, 115, 115 }, - { 2293, 117, 117, 117 }, - { 2300, 120, 120, 120 }, - { 2307, 122, 122, 122 }, - { 2314, 125, 125, 125 }, - { 2321, 13, 13, 13 }, - { 2327, 127, 127, 127 }, - { 2334, 130, 130, 130 }, - { 2341, 133, 133, 133 }, - { 2348, 135, 135, 135 }, - { 2355, 138, 138, 138 }, - { 2362, 140, 140, 140 }, - { 2369, 143, 143, 143 }, - { 2376, 145, 145, 145 }, - { 2383, 148, 148, 148 }, - { 2390, 150, 150, 150 }, - { 2397, 15, 15, 15 }, - { 2403, 153, 153, 153 }, - { 2410, 156, 156, 156 }, - { 2417, 158, 158, 158 }, - { 2424, 161, 161, 161 }, - { 2431, 163, 163, 163 }, - { 2438, 166, 166, 166 }, - { 2445, 168, 168, 168 }, - { 2452, 171, 171, 171 }, - { 2459, 173, 173, 173 }, - { 2466, 176, 176, 176 }, - { 2473, 18, 18, 18 }, - { 2479, 179, 179, 179 }, - { 2486, 181, 181, 181 }, - { 2493, 184, 184, 184 }, - { 2500, 186, 186, 186 }, - { 2507, 189, 189, 189 }, - { 2514, 191, 191, 191 }, - { 2521, 194, 194, 194 }, - { 2528, 196, 196, 196 }, - { 2535, 199, 199, 199 }, - { 2542, 201, 201, 201 }, - { 2549, 20, 20, 20 }, - { 2555, 204, 204, 204 }, - { 2562, 207, 207, 207 }, - { 2569, 209, 209, 209 }, - { 2576, 212, 212, 212 }, - { 2583, 214, 214, 214 }, - { 2590, 217, 217, 217 }, - { 2597, 219, 219, 219 }, - { 2604, 222, 222, 222 }, - { 2611, 224, 224, 224 }, - { 2618, 227, 227, 227 }, - { 2625, 23, 23, 23 }, - { 2631, 229, 229, 229 }, - { 2638, 232, 232, 232 }, - { 2645, 235, 235, 235 }, - { 2652, 237, 237, 237 }, - { 2659, 240, 240, 240 }, - { 2666, 242, 242, 242 }, - { 2673, 245, 245, 245 }, - { 2680, 247, 247, 247 }, - { 2687, 250, 250, 250 }, - { 2694, 252, 252, 252 }, - { 2701, 0, 255, 0 }, - { 2707, 173, 255, 47 }, - { 2720, 0, 255, 0 }, - { 2727, 0, 238, 0 }, - { 2734, 0, 205, 0 }, - { 2741, 0, 139, 0 }, - { 2748, 173, 255, 47 }, - { 2760, 190, 190, 190 }, - { 2765, 0, 0, 0 }, - { 2771, 3, 3, 3 }, - { 2777, 26, 26, 26 }, - { 2784, 255, 255, 255 }, - { 2792, 28, 28, 28 }, - { 2799, 31, 31, 31 }, - { 2806, 33, 33, 33 }, - { 2813, 36, 36, 36 }, - { 2820, 38, 38, 38 }, - { 2827, 41, 41, 41 }, - { 2834, 43, 43, 43 }, - { 2841, 46, 46, 46 }, - { 2848, 48, 48, 48 }, - { 2855, 5, 5, 5 }, - { 2861, 51, 51, 51 }, - { 2868, 54, 54, 54 }, - { 2875, 56, 56, 56 }, - { 2882, 59, 59, 59 }, - { 2889, 61, 61, 61 }, - { 2896, 64, 64, 64 }, - { 2903, 66, 66, 66 }, - { 2910, 69, 69, 69 }, - { 2917, 71, 71, 71 }, - { 2924, 74, 74, 74 }, - { 2931, 8, 8, 8 }, - { 2937, 77, 77, 77 }, - { 2944, 79, 79, 79 }, - { 2951, 82, 82, 82 }, - { 2958, 84, 84, 84 }, - { 2965, 87, 87, 87 }, - { 2972, 89, 89, 89 }, - { 2979, 92, 92, 92 }, - { 2986, 94, 94, 94 }, - { 2993, 97, 97, 97 }, - { 3000, 99, 99, 99 }, - { 3007, 10, 10, 10 }, - { 3013, 102, 102, 102 }, - { 3020, 105, 105, 105 }, - { 3027, 107, 107, 107 }, - { 3034, 110, 110, 110 }, - { 3041, 112, 112, 112 }, - { 3048, 115, 115, 115 }, - { 3055, 117, 117, 117 }, - { 3062, 120, 120, 120 }, - { 3069, 122, 122, 122 }, - { 3076, 125, 125, 125 }, - { 3083, 13, 13, 13 }, - { 3089, 127, 127, 127 }, - { 3096, 130, 130, 130 }, - { 3103, 133, 133, 133 }, - { 3110, 135, 135, 135 }, - { 3117, 138, 138, 138 }, - { 3124, 140, 140, 140 }, - { 3131, 143, 143, 143 }, - { 3138, 145, 145, 145 }, - { 3145, 148, 148, 148 }, - { 3152, 150, 150, 150 }, - { 3159, 15, 15, 15 }, - { 3165, 153, 153, 153 }, - { 3172, 156, 156, 156 }, - { 3179, 158, 158, 158 }, - { 3186, 161, 161, 161 }, - { 3193, 163, 163, 163 }, - { 3200, 166, 166, 166 }, - { 3207, 168, 168, 168 }, - { 3214, 171, 171, 171 }, - { 3221, 173, 173, 173 }, - { 3228, 176, 176, 176 }, - { 3235, 18, 18, 18 }, - { 3241, 179, 179, 179 }, - { 3248, 181, 181, 181 }, - { 3255, 184, 184, 184 }, - { 3262, 186, 186, 186 }, - { 3269, 189, 189, 189 }, - { 3276, 191, 191, 191 }, - { 3283, 194, 194, 194 }, - { 3290, 196, 196, 196 }, - { 3297, 199, 199, 199 }, - { 3304, 201, 201, 201 }, - { 3311, 20, 20, 20 }, - { 3317, 204, 204, 204 }, - { 3324, 207, 207, 207 }, - { 3331, 209, 209, 209 }, - { 3338, 212, 212, 212 }, - { 3345, 214, 214, 214 }, - { 3352, 217, 217, 217 }, - { 3359, 219, 219, 219 }, - { 3366, 222, 222, 222 }, - { 3373, 224, 224, 224 }, - { 3380, 227, 227, 227 }, - { 3387, 23, 23, 23 }, - { 3393, 229, 229, 229 }, - { 3400, 232, 232, 232 }, - { 3407, 235, 235, 235 }, - { 3414, 237, 237, 237 }, - { 3421, 240, 240, 240 }, - { 3428, 242, 242, 242 }, - { 3435, 245, 245, 245 }, - { 3442, 247, 247, 247 }, - { 3449, 250, 250, 250 }, - { 3456, 252, 252, 252 }, - { 3463, 240, 255, 240 }, - { 3472, 240, 255, 240 }, - { 3482, 224, 238, 224 }, - { 3492, 193, 205, 193 }, - { 3502, 131, 139, 131 }, - { 3512, 255, 105, 180 }, - { 3521, 255, 105, 180 }, - { 3529, 255, 110, 180 }, - { 3538, 238, 106, 167 }, - { 3547, 205, 96, 144 }, - { 3556, 139, 58, 98 }, - { 3565, 205, 92, 92 }, - { 3576, 205, 92, 92 }, - { 3586, 255, 106, 106 }, - { 3597, 238, 99, 99 }, - { 3608, 205, 85, 85 }, - { 3619, 139, 58, 58 }, - { 3630, 255, 255, 240 }, - { 3636, 255, 255, 240 }, - { 3643, 238, 238, 224 }, - { 3650, 205, 205, 193 }, - { 3657, 139, 139, 131 }, - { 3664, 240, 230, 140 }, - { 3670, 255, 246, 143 }, - { 3677, 238, 230, 133 }, - { 3684, 205, 198, 115 }, - { 3691, 139, 134, 78 }, - { 3698, 230, 230, 250 }, - { 3707, 255, 240, 245 }, - { 3722, 255, 240, 245 }, - { 3736, 255, 240, 245 }, - { 3751, 238, 224, 229 }, - { 3766, 205, 193, 197 }, - { 3781, 139, 131, 134 }, - { 3796, 124, 252, 0 }, - { 3807, 124, 252, 0 }, - { 3817, 255, 250, 205 }, - { 3831, 255, 250, 205 }, - { 3844, 255, 250, 205 }, - { 3858, 238, 233, 191 }, - { 3872, 205, 201, 165 }, - { 3886, 139, 137, 112 }, - { 3900, 173, 216, 230 }, - { 3911, 240, 128, 128 }, - { 3923, 224, 255, 255 }, - { 3934, 238, 221, 130 }, - { 3950, 250, 250, 210 }, - { 3973, 211, 211, 211 }, - { 3984, 144, 238, 144 }, - { 3996, 211, 211, 211 }, - { 4007, 255, 182, 193 }, - { 4018, 255, 160, 122 }, - { 4031, 32, 178, 170 }, - { 4047, 135, 206, 250 }, - { 4062, 132, 112, 255 }, - { 4079, 119, 136, 153 }, - { 4096, 119, 136, 153 }, - { 4113, 176, 196, 222 }, - { 4130, 255, 255, 224 }, - { 4143, 173, 216, 230 }, - { 4153, 191, 239, 255 }, - { 4164, 178, 223, 238 }, - { 4175, 154, 192, 205 }, - { 4186, 104, 131, 139 }, - { 4197, 240, 128, 128 }, - { 4208, 224, 255, 255 }, - { 4218, 224, 255, 255 }, - { 4229, 209, 238, 238 }, - { 4240, 180, 205, 205 }, - { 4251, 122, 139, 139 }, - { 4262, 238, 221, 130 }, - { 4277, 255, 236, 139 }, - { 4293, 238, 220, 130 }, - { 4309, 205, 190, 112 }, - { 4325, 139, 129, 76 }, - { 4341, 250, 250, 210 }, - { 4362, 211, 211, 211 }, - { 4372, 144, 238, 144 }, - { 4383, 211, 211, 211 }, - { 4393, 255, 182, 193 }, - { 4403, 255, 174, 185 }, - { 4414, 238, 162, 173 }, - { 4425, 205, 140, 149 }, - { 4436, 139, 95, 101 }, - { 4447, 255, 160, 122 }, - { 4459, 255, 160, 122 }, - { 4472, 238, 149, 114 }, - { 4485, 205, 129, 98 }, - { 4498, 139, 87, 66 }, - { 4511, 32, 178, 170 }, - { 4525, 135, 206, 250 }, - { 4538, 176, 226, 255 }, - { 4552, 164, 211, 238 }, - { 4566, 141, 182, 205 }, - { 4580, 96, 123, 139 }, - { 4594, 132, 112, 255 }, - { 4609, 119, 136, 153 }, - { 4624, 119, 136, 153 }, - { 4639, 176, 196, 222 }, - { 4654, 202, 225, 255 }, - { 4670, 188, 210, 238 }, - { 4686, 162, 181, 205 }, - { 4702, 110, 123, 139 }, - { 4718, 255, 255, 224 }, - { 4730, 255, 255, 224 }, - { 4743, 238, 238, 209 }, - { 4756, 205, 205, 180 }, - { 4769, 139, 139, 122 }, - { 4782, 50, 205, 50 }, - { 4793, 50, 205, 50 }, - { 4803, 250, 240, 230 }, - { 4809, 255, 0, 255 }, - { 4817, 255, 0, 255 }, - { 4826, 238, 0, 238 }, - { 4835, 205, 0, 205 }, - { 4844, 139, 0, 139 }, - { 4853, 176, 48, 96 }, - { 4860, 255, 52, 179 }, - { 4868, 238, 48, 167 }, - { 4876, 205, 41, 144 }, - { 4884, 139, 28, 98 }, - { 4892, 102, 205, 170 }, - { 4910, 0, 0, 205 }, - { 4922, 186, 85, 211 }, - { 4936, 147, 112, 219 }, - { 4950, 60, 179, 113 }, - { 4967, 123, 104, 238 }, - { 4985, 0, 250, 154 }, - { 5005, 72, 209, 204 }, - { 5022, 199, 21, 133 }, - { 5040, 102, 205, 170 }, - { 5057, 0, 0, 205 }, - { 5068, 186, 85, 211 }, - { 5081, 224, 102, 255 }, - { 5095, 209, 95, 238 }, - { 5109, 180, 82, 205 }, - { 5123, 122, 55, 139 }, - { 5137, 147, 112, 219 }, - { 5150, 171, 130, 255 }, - { 5164, 159, 121, 238 }, - { 5178, 137, 104, 205 }, - { 5192, 93, 71, 139 }, - { 5206, 60, 179, 113 }, - { 5221, 123, 104, 238 }, - { 5237, 0, 250, 154 }, - { 5255, 72, 209, 204 }, - { 5271, 199, 21, 133 }, - { 5287, 25, 25, 112 }, - { 5301, 25, 25, 112 }, - { 5314, 245, 255, 250 }, - { 5325, 245, 255, 250 }, - { 5335, 255, 228, 225 }, - { 5346, 255, 228, 225 }, - { 5356, 255, 228, 225 }, - { 5367, 238, 213, 210 }, - { 5378, 205, 183, 181 }, - { 5389, 139, 125, 123 }, - { 5400, 255, 228, 181 }, - { 5409, 255, 222, 173 }, - { 5422, 255, 222, 173 }, - { 5434, 255, 222, 173 }, - { 5447, 238, 207, 161 }, - { 5460, 205, 179, 139 }, - { 5473, 139, 121, 94 }, - { 5486, 0, 0, 128 }, - { 5491, 0, 0, 128 }, - { 5501, 0, 0, 128 }, - { 5510, 253, 245, 230 }, - { 5519, 253, 245, 230 }, - { 5527, 107, 142, 35 }, - { 5538, 107, 142, 35 }, - { 5548, 192, 255, 62 }, - { 5559, 179, 238, 58 }, - { 5570, 154, 205, 50 }, - { 5581, 105, 139, 34 }, - { 5592, 255, 165, 0 }, - { 5599, 255, 69, 0 }, - { 5610, 255, 165, 0 }, - { 5618, 238, 154, 0 }, - { 5626, 205, 133, 0 }, - { 5634, 139, 90, 0 }, - { 5642, 255, 69, 0 }, - { 5652, 255, 69, 0 }, - { 5663, 238, 64, 0 }, - { 5674, 205, 55, 0 }, - { 5685, 139, 37, 0 }, - { 5696, 218, 112, 214 }, - { 5703, 255, 131, 250 }, - { 5711, 238, 122, 233 }, - { 5719, 205, 105, 201 }, - { 5727, 139, 71, 137 }, - { 5735, 238, 232, 170 }, - { 5750, 152, 251, 152 }, - { 5761, 175, 238, 238 }, - { 5776, 219, 112, 147 }, - { 5792, 238, 232, 170 }, - { 5806, 152, 251, 152 }, - { 5816, 154, 255, 154 }, - { 5827, 144, 238, 144 }, - { 5838, 124, 205, 124 }, - { 5849, 84, 139, 84 }, - { 5860, 175, 238, 238 }, - { 5874, 187, 255, 255 }, - { 5889, 174, 238, 238 }, - { 5904, 150, 205, 205 }, - { 5919, 102, 139, 139 }, - { 5934, 219, 112, 147 }, - { 5948, 255, 130, 171 }, - { 5963, 238, 121, 159 }, - { 5978, 205, 104, 137 }, - { 5993, 139, 71, 93 }, - { 6008, 255, 239, 213 }, - { 6020, 255, 239, 213 }, - { 6031, 255, 218, 185 }, - { 6042, 255, 218, 185 }, - { 6052, 255, 218, 185 }, - { 6063, 238, 203, 173 }, - { 6074, 205, 175, 149 }, - { 6085, 139, 119, 101 }, - { 6096, 205, 133, 63 }, - { 6101, 255, 192, 203 }, - { 6106, 255, 181, 197 }, - { 6112, 238, 169, 184 }, - { 6118, 205, 145, 158 }, - { 6124, 139, 99, 108 }, - { 6130, 221, 160, 221 }, - { 6135, 255, 187, 255 }, - { 6141, 238, 174, 238 }, - { 6147, 205, 150, 205 }, - { 6153, 139, 102, 139 }, - { 6159, 176, 224, 230 }, - { 6171, 176, 224, 230 }, - { 6182, 160, 32, 240 }, - { 6189, 155, 48, 255 }, - { 6197, 145, 44, 238 }, - { 6205, 125, 38, 205 }, - { 6213, 85, 26, 139 }, - { 6221, 255, 0, 0 }, - { 6225, 255, 0, 0 }, - { 6230, 238, 0, 0 }, - { 6235, 205, 0, 0 }, - { 6240, 139, 0, 0 }, - { 6245, 188, 143, 143 }, - { 6256, 188, 143, 143 }, - { 6266, 255, 193, 193 }, - { 6277, 238, 180, 180 }, - { 6288, 205, 155, 155 }, - { 6299, 139, 105, 105 }, - { 6310, 65, 105, 225 }, - { 6321, 65, 105, 225 }, - { 6331, 72, 118, 255 }, - { 6342, 67, 110, 238 }, - { 6353, 58, 95, 205 }, - { 6364, 39, 64, 139 }, - { 6375, 139, 69, 19 }, - { 6388, 139, 69, 19 }, - { 6400, 250, 128, 114 }, - { 6407, 255, 140, 105 }, - { 6415, 238, 130, 98 }, - { 6423, 205, 112, 84 }, - { 6431, 139, 76, 57 }, - { 6439, 244, 164, 96 }, - { 6451, 244, 164, 96 }, - { 6462, 46, 139, 87 }, - { 6472, 46, 139, 87 }, - { 6481, 84, 255, 159 }, - { 6491, 78, 238, 148 }, - { 6501, 67, 205, 128 }, - { 6511, 46, 139, 87 }, - { 6521, 255, 245, 238 }, - { 6530, 255, 245, 238 }, - { 6540, 238, 229, 222 }, - { 6550, 205, 197, 191 }, - { 6560, 139, 134, 130 }, - { 6570, 160, 82, 45 }, - { 6577, 255, 130, 71 }, - { 6585, 238, 121, 66 }, - { 6593, 205, 104, 57 }, - { 6601, 139, 71, 38 }, - { 6609, 135, 206, 235 }, - { 6618, 135, 206, 235 }, - { 6626, 135, 206, 255 }, - { 6635, 126, 192, 238 }, - { 6644, 108, 166, 205 }, - { 6653, 74, 112, 139 }, - { 6662, 106, 90, 205 }, - { 6673, 112, 128, 144 }, - { 6684, 112, 128, 144 }, - { 6695, 106, 90, 205 }, - { 6705, 131, 111, 255 }, - { 6716, 122, 103, 238 }, - { 6727, 105, 89, 205 }, - { 6738, 71, 60, 139 }, - { 6749, 112, 128, 144 }, - { 6759, 198, 226, 255 }, - { 6770, 185, 211, 238 }, - { 6781, 159, 182, 205 }, - { 6792, 108, 123, 139 }, - { 6803, 112, 128, 144 }, - { 6813, 255, 250, 250 }, - { 6818, 255, 250, 250 }, - { 6824, 238, 233, 233 }, - { 6830, 205, 201, 201 }, - { 6836, 139, 137, 137 }, - { 6842, 0, 255, 127 }, - { 6855, 0, 255, 127 }, - { 6867, 0, 255, 127 }, - { 6880, 0, 238, 118 }, - { 6893, 0, 205, 102 }, - { 6906, 0, 139, 69 }, - { 6919, 70, 130, 180 }, - { 6930, 70, 130, 180 }, - { 6940, 99, 184, 255 }, - { 6951, 92, 172, 238 }, - { 6962, 79, 148, 205 }, - { 6973, 54, 100, 139 }, - { 6984, 210, 180, 140 }, - { 6988, 255, 165, 79 }, - { 6993, 238, 154, 73 }, - { 6998, 205, 133, 63 }, - { 7003, 139, 90, 43 }, - { 7008, 216, 191, 216 }, - { 7016, 255, 225, 255 }, - { 7025, 238, 210, 238 }, - { 7034, 205, 181, 205 }, - { 7043, 139, 123, 139 }, - { 7052, 255, 99, 71 }, - { 7059, 255, 99, 71 }, - { 7067, 238, 92, 66 }, - { 7075, 205, 79, 57 }, - { 7083, 139, 54, 38 }, - { 7091, 64, 224, 208 }, - { 7101, 0, 245, 255 }, - { 7112, 0, 229, 238 }, - { 7123, 0, 197, 205 }, - { 7134, 0, 134, 139 }, - { 7145, 238, 130, 238 }, - { 7152, 208, 32, 144 }, - { 7163, 208, 32, 144 }, - { 7173, 255, 62, 150 }, - { 7184, 238, 58, 140 }, - { 7195, 205, 50, 120 }, - { 7206, 139, 34, 82 }, - { 7217, 245, 222, 179 }, - { 7223, 255, 231, 186 }, - { 7230, 238, 216, 174 }, - { 7237, 205, 186, 150 }, - { 7244, 139, 126, 102 }, - { 7251, 255, 255, 255 }, - { 7257, 245, 245, 245 }, - { 7269, 245, 245, 245 }, - { 7280, 255, 255, 0 }, - { 7287, 154, 205, 50 }, - { 7300, 255, 255, 0 }, - { 7308, 238, 238, 0 }, - { 7316, 205, 205, 0 }, - { 7324, 139, 139, 0 }, - { 7332, 154, 205, 50 } -}; |