gosu 0.7.10.3 → 0.7.11
Sign up to get free protection for your applications and to get access to all the features.
- data/Gosu/AutoLink.hpp +0 -0
- data/Gosu/ButtonsMac.hpp +26 -0
- data/Gosu/ButtonsWin.hpp +26 -0
- data/Gosu/ButtonsX.hpp +26 -0
- data/Gosu/Gosu.hpp +1 -0
- data/Gosu/Graphics.hpp +1 -1
- data/Gosu/Input.hpp +4 -5
- data/Gosu/Math.hpp +11 -0
- data/Gosu/Text.hpp +59 -47
- data/Gosu/Utility.hpp +6 -5
- data/GosuImpl/Graphics/DrawOp.hpp +0 -0
- data/GosuImpl/Graphics/Font.cpp +45 -4
- data/GosuImpl/Graphics/Graphics.cpp +25 -0
- data/GosuImpl/Graphics/TexChunk.cpp +0 -0
- data/GosuImpl/Graphics/TexChunk.hpp +0 -0
- data/GosuImpl/Graphics/Text.cpp +26 -2
- data/GosuImpl/Graphics/TextMac.cpp +8 -2
- data/GosuImpl/Graphics/TextPangoFT.cpp +0 -0
- data/GosuImpl/Graphics/Texture.cpp +0 -0
- data/GosuImpl/Graphics/Texture.hpp +0 -0
- data/GosuImpl/Iconv.hpp +62 -0
- data/GosuImpl/InputMac.mm +3 -0
- data/GosuImpl/InputWin.cpp +5 -1
- data/GosuImpl/InputX.cpp +50 -8
- data/GosuImpl/Math.cpp +1 -1
- data/GosuImpl/RubyGosu.swg +24 -5
- data/GosuImpl/RubyGosu_wrap.cxx +181 -10
- data/GosuImpl/Utility.cpp +32 -75
- data/GosuImpl/Utility.cpp~RF6c566.TMP +95 -0
- data/GosuImpl/WindowX.cpp +2 -2
- data/Rakefile +57 -10
- data/examples/Tutorial.cpp +0 -0
- data/examples/media/Beep.wav +0 -0
- data/examples/media/CptnRuby Map.txt b/data/examples/media/CptnRuby → Map.txt +0 -0
- data/examples/media/Explosion.wav +0 -0
- data/examples/media/Space.png +0 -0
- data/examples/media/Star.png +0 -0
- data/examples/media/Starfighter.bmp +0 -0
- data/linux/Makefile.in +0 -0
- data/linux/configure +0 -0
- data/linux/configure.ac +0 -0
- data/mac/Gosu.xcodeproj/jlnr.mode1v3 +1421 -0
- data/mac/Gosu.xcodeproj/jlnr.mode2v3 +1464 -0
- data/mac/Gosu.xcodeproj/jlnr.pbxuser +733 -0
- data/mac/Gosu.xcodeproj/project.pbxproj +4 -2
- data/reference/Async_8hpp-source.html +1 -1
- data/reference/Audio_8hpp-source.html +1 -1
- data/reference/Audio_8hpp.html +1 -1
- data/reference/AutoLink_8hpp-source.html +1 -1
- data/reference/AutoLink_8hpp.html +1 -1
- data/reference/Bitmap_8hpp-source.html +1 -1
- data/reference/Bitmap_8hpp.html +1 -1
- data/reference/ButtonsMac_8hpp-source.html +107 -81
- data/reference/ButtonsWin_8hpp-source.html +84 -58
- data/reference/ButtonsX_8hpp-source.html +131 -105
- data/reference/Color_8hpp-source.html +1 -1
- data/reference/Color_8hpp.html +1 -1
- data/reference/Directories_8hpp-source.html +1 -1
- data/reference/Directories_8hpp.html +1 -1
- data/reference/Font_8hpp-source.html +1 -1
- data/reference/Font_8hpp.html +1 -1
- data/reference/Fwd_8hpp-source.html +1 -1
- data/reference/Fwd_8hpp.html +1 -1
- data/reference/Gosu_8hpp-source.html +5 -4
- data/reference/Gosu_8hpp.html +1 -1
- data/reference/GraphicsBase_8hpp-source.html +1 -1
- data/reference/GraphicsBase_8hpp.html +1 -1
- data/reference/Graphics_8hpp-source.html +2 -2
- data/reference/Graphics_8hpp.html +1 -1
- data/reference/IO_8hpp-source.html +1 -1
- data/reference/IO_8hpp.html +1 -1
- data/reference/ImageData_8hpp-source.html +1 -1
- data/reference/ImageData_8hpp.html +1 -1
- data/reference/Image_8hpp-source.html +1 -1
- data/reference/Image_8hpp.html +1 -1
- data/reference/Input_8hpp-source.html +43 -43
- data/reference/Input_8hpp.html +2 -2
- data/reference/Math_8hpp-source.html +51 -42
- data/reference/Math_8hpp.html +5 -1
- data/reference/Platform_8hpp-source.html +1 -1
- data/reference/Platform_8hpp.html +1 -1
- data/reference/RotFlip_8hpp-source.html +1 -1
- data/reference/RotFlip_8hpp.html +1 -1
- data/reference/Sockets_8hpp-source.html +1 -1
- data/reference/Sockets_8hpp.html +1 -1
- data/reference/TextInput_8hpp-source.html +1 -1
- data/reference/TextInput_8hpp.html +1 -1
- data/reference/Text_8hpp-source.html +12 -8
- data/reference/Text_8hpp.html +3 -1
- data/reference/Timing_8hpp-source.html +1 -1
- data/reference/Timing_8hpp.html +1 -1
- data/reference/Utility_8hpp-source.html +9 -10
- data/reference/Utility_8hpp.html +5 -7
- data/reference/WinUtility_8hpp-source.html +1 -1
- data/reference/WinUtility_8hpp.html +1 -1
- data/reference/Window_8hpp-source.html +3 -3
- data/reference/Window_8hpp.html +1 -1
- data/reference/annotated.html +2 -2
- data/reference/classGosu_1_1Audio-members.html +1 -1
- data/reference/classGosu_1_1Audio.html +1 -1
- data/reference/classGosu_1_1Bitmap-members.html +1 -1
- data/reference/classGosu_1_1Bitmap.html +1 -1
- data/reference/classGosu_1_1Buffer-members.html +1 -1
- data/reference/classGosu_1_1Buffer.html +1 -1
- data/reference/classGosu_1_1Button-members.html +1 -1
- data/reference/classGosu_1_1Button.html +1 -1
- data/reference/classGosu_1_1Color-members.html +1 -1
- data/reference/classGosu_1_1Color.html +1 -1
- data/reference/classGosu_1_1File-members.html +1 -1
- data/reference/classGosu_1_1File.html +1 -1
- data/reference/classGosu_1_1Font-members.html +1 -1
- data/reference/classGosu_1_1Font.html +1 -1
- data/reference/classGosu_1_1Graphics-members.html +1 -1
- data/reference/classGosu_1_1Graphics.html +1 -1
- data/reference/classGosu_1_1Image-members.html +1 -1
- data/reference/classGosu_1_1Image.html +1 -1
- data/reference/classGosu_1_1ImageData-members.html +1 -1
- data/reference/classGosu_1_1ImageData.html +1 -1
- data/reference/classGosu_1_1Input-members.html +1 -1
- data/reference/classGosu_1_1Input.html +4 -4
- data/reference/classGosu_1_1MessageSocket-members.html +1 -1
- data/reference/classGosu_1_1MessageSocket.html +1 -1
- data/reference/classGosu_1_1Resource-members.html +1 -1
- data/reference/classGosu_1_1Resource.html +1 -1
- data/reference/classGosu_1_1Sample-members.html +1 -1
- data/reference/classGosu_1_1Sample.html +1 -1
- data/reference/classGosu_1_1SampleInstance-members.html +1 -1
- data/reference/classGosu_1_1SampleInstance.html +1 -1
- data/reference/classGosu_1_1Song-members.html +1 -1
- data/reference/classGosu_1_1Song.html +1 -1
- data/reference/classGosu_1_1TextInput-members.html +1 -1
- data/reference/classGosu_1_1TextInput.html +1 -1
- data/reference/classGosu_1_1Window-members.html +1 -1
- data/reference/classGosu_1_1Window.html +1 -1
- data/reference/files.html +1 -1
- data/reference/functions.html +1 -1
- data/reference/functions_enum.html +1 -1
- data/reference/functions_func.html +1 -1
- data/reference/functions_vars.html +1 -1
- data/reference/hierarchy.html +1 -1
- data/reference/index.html +1 -1
- data/reference/namespaceGosu.html +935 -492
- data/reference/namespaceGosu_1_1Colors.html +1 -1
- data/reference/namespaceGosu_1_1Win.html +1 -1
- data/reference/namespacemembers.html +13 -2
- data/reference/namespacemembers_enum.html +1 -1
- data/reference/namespacemembers_eval.html +1 -1
- data/reference/namespacemembers_func.html +13 -2
- data/reference/namespacemembers_type.html +1 -1
- data/reference/namespacemembers_vars.html +1 -1
- data/reference/namespaces.html +1 -1
- data/windows/Gosu.vcproj +4 -4
- data/windows/RubyGosu.vcproj +2 -1
- data/windows/zlib, libpng/libpng/ANNOUNCE +61 -0
- data/windows/zlib, libpng/libpng/CHANGES +2173 -0
- data/windows/zlib, libpng/libpng/INSTALL +199 -0
- data/windows/zlib, libpng/libpng/KNOWNBUG +22 -0
- data/windows/zlib, libpng/libpng/LICENSE +109 -0
- data/windows/zlib, libpng/libpng/README +264 -0
- data/windows/zlib, libpng/libpng/TODO +24 -0
- data/windows/zlib, libpng/libpng/Y2KINFO +55 -0
- data/windows/zlib, libpng/libpng/configure +13 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/COPYING +340 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/LICENSE +50 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/Makefile.mingw32 +130 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/Makefile.sgi +104 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/Makefile.unx +132 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/Makefile.w32 +113 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/README +186 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/makevms.com +132 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/readpng.c +304 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/readpng.h +88 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/readpng2.c +645 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/readpng2.h +121 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/readppm.c +179 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/rpng-win.c +684 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/rpng-x.c +904 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/rpng2-win.c +1225 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/rpng2-x.c +2127 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/toucan.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/wpng.c +853 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/writepng.c +392 -0
- data/windows/zlib, libpng/libpng/contrib/gregbook/writepng.h +133 -0
- data/windows/zlib, libpng/libpng/contrib/pngminim/decoder/README +6 -0
- data/windows/zlib, libpng/libpng/contrib/pngminim/decoder/gather.sh +8 -0
- data/windows/zlib, libpng/libpng/contrib/pngminim/decoder/makefile.std +44 -0
- data/windows/zlib, libpng/libpng/contrib/pngminim/decoder/pngusr.h +67 -0
- data/windows/zlib, libpng/libpng/contrib/pngminim/encoder/README +6 -0
- data/windows/zlib, libpng/libpng/contrib/pngminim/encoder/dummy_inflate.c +27 -0
- data/windows/zlib, libpng/libpng/contrib/pngminim/encoder/gather.sh +9 -0
- data/windows/zlib, libpng/libpng/contrib/pngminim/encoder/makefile.std +43 -0
- data/windows/zlib, libpng/libpng/contrib/pngminim/encoder/pngusr.h +66 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/README +153 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/makefile.std +65 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/makefile.tc3 +38 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/makevms.com +92 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/png2pnm.bat +41 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/png2pnm.c +430 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/png2pnm.sh +42 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/pngminus.bat +4 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/pngminus.sh +5 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/pnm2png.bat +41 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/pnm2png.c +533 -0
- data/windows/zlib, libpng/libpng/contrib/pngminus/pnm2png.sh +42 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn0g01.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn0g02.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn0g04.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn0g08.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn0g16.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn2c08.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn2c16.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn3p01.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn3p02.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn3p04.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn3p08.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn4a08.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn4a16.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn6a08.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/pngsuite/basn6a16.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/PngFile.c +439 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/PngFile.h +27 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/README.txt +58 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/VisualPng.c +961 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/VisualPng.dsp +147 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/VisualPng.dsw +29 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/VisualPng.ico +0 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/VisualPng.png +0 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/VisualPng.rc +152 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/cexcept.h +243 -0
- data/windows/zlib, libpng/libpng/contrib/visupng/resource.h +23 -0
- data/windows/zlib, libpng/libpng/example.c +814 -0
- data/windows/zlib, libpng/libpng/libpng-1.2.29.txt +2906 -0
- data/windows/zlib, libpng/libpng/libpng.3 +3680 -0
- data/windows/zlib, libpng/libpng/libpngpf.3 +274 -0
- data/windows/zlib, libpng/libpng/png.5 +74 -0
- data/windows/zlib, libpng/libpng/png.c +798 -0
- data/windows/zlib, libpng/libpng/png.h +3569 -0
- data/windows/zlib, libpng/libpng/pngbar.jpg +0 -0
- data/windows/zlib, libpng/libpng/pngbar.png +0 -0
- data/windows/zlib, libpng/libpng/pngconf.h +1481 -0
- data/windows/zlib, libpng/libpng/pngerror.c +343 -0
- data/windows/zlib, libpng/libpng/pnggccrd.c +103 -0
- data/windows/zlib, libpng/libpng/pngget.c +901 -0
- data/windows/zlib, libpng/libpng/pngmem.c +608 -0
- data/windows/zlib, libpng/libpng/pngnow.png +0 -0
- data/windows/zlib, libpng/libpng/pngpread.c +1598 -0
- data/windows/zlib, libpng/libpng/pngread.c +1479 -0
- data/windows/zlib, libpng/libpng/pngrio.c +167 -0
- data/windows/zlib, libpng/libpng/pngrtran.c +4292 -0
- data/windows/zlib, libpng/libpng/pngrutil.c +3183 -0
- data/windows/zlib, libpng/libpng/pngset.c +1268 -0
- data/windows/zlib, libpng/libpng/pngtest.c +1563 -0
- data/windows/zlib, libpng/libpng/pngtest.png +0 -0
- data/windows/zlib, libpng/libpng/pngtrans.c +662 -0
- data/windows/zlib, libpng/libpng/pngvcrd.c +1 -0
- data/windows/zlib, libpng/libpng/pngwio.c +234 -0
- data/windows/zlib, libpng/libpng/pngwrite.c +1532 -0
- data/windows/zlib, libpng/libpng/pngwtran.c +572 -0
- data/windows/zlib, libpng/libpng/pngwutil.c +2802 -0
- data/windows/zlib, libpng/libpng/projects/beos/x86-shared.proj +0 -0
- data/windows/zlib, libpng/libpng/projects/beos/x86-shared.txt +22 -0
- data/windows/zlib, libpng/libpng/projects/beos/x86-static.proj +0 -0
- data/windows/zlib, libpng/libpng/projects/beos/x86-static.txt +22 -0
- data/windows/zlib, libpng/libpng/projects/cbuilder5/libpng.bpf +22 -0
- data/windows/zlib, libpng/libpng/projects/cbuilder5/libpng.bpg +25 -0
- data/windows/zlib, libpng/libpng/projects/cbuilder5/libpng.bpr +157 -0
- data/windows/zlib, libpng/libpng/projects/cbuilder5/libpng.cpp +29 -0
- data/windows/zlib, libpng/libpng/projects/cbuilder5/libpng.readme.txt +25 -0
- data/windows/zlib, libpng/libpng/projects/cbuilder5/libpngstat.bpf +22 -0
- data/windows/zlib, libpng/libpng/projects/cbuilder5/libpngstat.bpr +109 -0
- data/windows/zlib, libpng/libpng/projects/cbuilder5/zlib.readme.txt +14 -0
- data/windows/zlib, libpng/libpng/projects/netware.txt +6 -0
- data/windows/zlib, libpng/libpng/projects/visualc6/README.txt +57 -0
- data/windows/zlib, libpng/libpng/projects/visualc6/libpng.dsp +472 -0
- data/windows/zlib, libpng/libpng/projects/visualc6/libpng.dsw +59 -0
- data/windows/zlib, libpng/libpng/projects/visualc6/pngtest.dsp +314 -0
- data/windows/zlib, libpng/libpng/projects/visualc71/PRJ0041.mak +21 -0
- data/windows/zlib, libpng/libpng/projects/visualc71/README.txt +57 -0
- data/windows/zlib, libpng/libpng/projects/visualc71/README_zlib.txt +44 -0
- data/windows/zlib, libpng/libpng/projects/visualc71/libpng.sln +88 -0
- data/windows/zlib, libpng/libpng/projects/visualc71/libpng.vcproj +702 -0
- data/windows/zlib, libpng/libpng/projects/visualc71/pngtest.vcproj +459 -0
- data/windows/zlib, libpng/libpng/projects/visualc71/zlib.vcproj +670 -0
- data/windows/zlib, libpng/libpng/projects/wince.txt +6 -0
- data/windows/zlib, libpng/libpng/scripts/CMakeLists.txt +210 -0
- data/windows/zlib, libpng/libpng/scripts/SCOPTIONS.ppc +7 -0
- data/windows/zlib, libpng/libpng/scripts/descrip.mms +52 -0
- data/windows/zlib, libpng/libpng/scripts/libpng-config-body.in +96 -0
- data/windows/zlib, libpng/libpng/scripts/libpng-config-head.in +21 -0
- data/windows/zlib, libpng/libpng/scripts/libpng-config.in +124 -0
- data/windows/zlib, libpng/libpng/scripts/libpng.icc +44 -0
- data/windows/zlib, libpng/libpng/scripts/libpng.pc-configure.in +10 -0
- data/windows/zlib, libpng/libpng/scripts/libpng.pc.in +10 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.32sunu +254 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.64sunu +254 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.acorn +51 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.aix +113 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.amiga +48 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.atari +51 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.bc32 +152 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.beos +226 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.bor +162 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.cygwin +299 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.darwin +234 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.dec +214 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.dj2 +55 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.elf +275 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.freebsd +48 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.gcc +79 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.gcmmx +271 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.hp64 +235 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.hpgcc +245 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.hpux +232 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.ibmc +71 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.intel +102 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.knr +99 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.linux +249 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.mingw +289 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.mips +83 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.msc +86 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.ne12bsd +45 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.netbsd +45 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.nommx +252 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.openbsd +73 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.os2 +69 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.sco +229 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.sggcc +242 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.sgi +245 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.so9 +251 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.solaris +249 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.solaris-x86 +248 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.std +92 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.sunos +97 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.tc3 +89 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.vcawin32 +99 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.vcwin32 +99 -0
- data/windows/zlib, libpng/libpng/scripts/makefile.watcom +109 -0
- data/windows/zlib, libpng/libpng/scripts/makevms.com +144 -0
- data/windows/zlib, libpng/libpng/scripts/pngos2.def +257 -0
- data/windows/zlib, libpng/libpng/scripts/pngw32.def +238 -0
- data/windows/zlib, libpng/libpng/scripts/pngw32.rc +112 -0
- data/windows/zlib, libpng/libpng/scripts/smakefile.ppc +30 -0
- data/windows/zlib, libpng/zlib/ChangeLog +855 -0
- data/windows/zlib, libpng/zlib/FAQ +339 -0
- data/windows/zlib, libpng/zlib/INDEX +51 -0
- data/windows/zlib, libpng/zlib/Makefile +154 -0
- data/windows/zlib, libpng/zlib/Makefile.in +154 -0
- data/windows/zlib, libpng/zlib/README +125 -0
- data/windows/zlib, libpng/zlib/adler32.c +149 -0
- data/windows/zlib, libpng/zlib/algorithm.txt +209 -0
- data/windows/zlib, libpng/zlib/amiga/Makefile.pup +66 -0
- data/windows/zlib, libpng/zlib/amiga/Makefile.sas +65 -0
- data/windows/zlib, libpng/zlib/as400/bndsrc +132 -0
- data/windows/zlib, libpng/zlib/as400/compile.clp +123 -0
- data/windows/zlib, libpng/zlib/as400/readme.txt +111 -0
- data/windows/zlib, libpng/zlib/as400/zlib.inc +331 -0
- data/windows/zlib, libpng/zlib/compress.c +79 -0
- data/windows/zlib, libpng/zlib/configure +459 -0
- data/windows/zlib, libpng/zlib/contrib/README.contrib +71 -0
- data/windows/zlib, libpng/zlib/contrib/ada/buffer_demo.adb +106 -0
- data/windows/zlib, libpng/zlib/contrib/ada/mtest.adb +156 -0
- data/windows/zlib, libpng/zlib/contrib/ada/read.adb +156 -0
- data/windows/zlib, libpng/zlib/contrib/ada/readme.txt +65 -0
- data/windows/zlib, libpng/zlib/contrib/ada/test.adb +463 -0
- data/windows/zlib, libpng/zlib/contrib/ada/zlib-streams.adb +225 -0
- data/windows/zlib, libpng/zlib/contrib/ada/zlib-streams.ads +114 -0
- data/windows/zlib, libpng/zlib/contrib/ada/zlib-thin.adb +141 -0
- data/windows/zlib, libpng/zlib/contrib/ada/zlib-thin.ads +450 -0
- data/windows/zlib, libpng/zlib/contrib/ada/zlib.adb +701 -0
- data/windows/zlib, libpng/zlib/contrib/ada/zlib.ads +328 -0
- data/windows/zlib, libpng/zlib/contrib/ada/zlib.gpr +20 -0
- data/windows/zlib, libpng/zlib/contrib/asm586/README.586 +43 -0
- data/windows/zlib, libpng/zlib/contrib/asm586/match.S +364 -0
- data/windows/zlib, libpng/zlib/contrib/asm686/README.686 +34 -0
- data/windows/zlib, libpng/zlib/contrib/asm686/match.S +329 -0
- data/windows/zlib, libpng/zlib/contrib/blast/Makefile +8 -0
- data/windows/zlib, libpng/zlib/contrib/blast/README +4 -0
- data/windows/zlib, libpng/zlib/contrib/blast/blast.c +444 -0
- data/windows/zlib, libpng/zlib/contrib/blast/blast.h +71 -0
- data/windows/zlib, libpng/zlib/contrib/blast/test.pk +0 -0
- data/windows/zlib, libpng/zlib/contrib/blast/test.txt +1 -0
- data/windows/zlib, libpng/zlib/contrib/delphi/ZLib.pas +557 -0
- data/windows/zlib, libpng/zlib/contrib/delphi/ZLibConst.pas +11 -0
- data/windows/zlib, libpng/zlib/contrib/delphi/readme.txt +76 -0
- data/windows/zlib, libpng/zlib/contrib/delphi/zlibd32.mak +93 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib.build +33 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib.chm +0 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib.sln +21 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib/AssemblyInfo.cs +58 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib/ChecksumImpl.cs +202 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib/CircularBuffer.cs +83 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib/CodecBase.cs +198 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib/Deflater.cs +106 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib/DotZLib.cs +288 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib/DotZLib.csproj +141 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib/GZipStream.cs +301 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib/Inflater.cs +105 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/DotZLib/UnitTests.cs +274 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/LICENSE_1_0.txt +23 -0
- data/windows/zlib, libpng/zlib/contrib/dotzlib/readme.txt +58 -0
- data/windows/zlib, libpng/zlib/contrib/infback9/README +1 -0
- data/windows/zlib, libpng/zlib/contrib/infback9/infback9.c +608 -0
- data/windows/zlib, libpng/zlib/contrib/infback9/infback9.h +37 -0
- data/windows/zlib, libpng/zlib/contrib/infback9/inffix9.h +107 -0
- data/windows/zlib, libpng/zlib/contrib/infback9/inflate9.h +47 -0
- data/windows/zlib, libpng/zlib/contrib/infback9/inftree9.c +323 -0
- data/windows/zlib, libpng/zlib/contrib/infback9/inftree9.h +55 -0
- data/windows/zlib, libpng/zlib/contrib/inflate86/inffas86.c +1157 -0
- data/windows/zlib, libpng/zlib/contrib/inflate86/inffast.S +1368 -0
- data/windows/zlib, libpng/zlib/contrib/iostream/test.cpp +24 -0
- data/windows/zlib, libpng/zlib/contrib/iostream/zfstream.cpp +329 -0
- data/windows/zlib, libpng/zlib/contrib/iostream/zfstream.h +128 -0
- data/windows/zlib, libpng/zlib/contrib/iostream2/zstream.h +307 -0
- data/windows/zlib, libpng/zlib/contrib/iostream2/zstream_test.cpp +25 -0
- data/windows/zlib, libpng/zlib/contrib/iostream3/README +35 -0
- data/windows/zlib, libpng/zlib/contrib/iostream3/TODO +17 -0
- data/windows/zlib, libpng/zlib/contrib/iostream3/test.cc +50 -0
- data/windows/zlib, libpng/zlib/contrib/iostream3/zfstream.cc +479 -0
- data/windows/zlib, libpng/zlib/contrib/iostream3/zfstream.h +466 -0
- data/windows/zlib, libpng/zlib/contrib/masm686/match.asm +413 -0
- data/windows/zlib, libpng/zlib/contrib/masmx64/bld_ml64.bat +2 -0
- data/windows/zlib, libpng/zlib/contrib/masmx64/gvmat64.asm +513 -0
- data/windows/zlib, libpng/zlib/contrib/masmx64/gvmat64.obj +0 -0
- data/windows/zlib, libpng/zlib/contrib/masmx64/inffas8664.c +186 -0
- data/windows/zlib, libpng/zlib/contrib/masmx64/inffasx64.asm +392 -0
- data/windows/zlib, libpng/zlib/contrib/masmx64/inffasx64.obj +0 -0
- data/windows/zlib, libpng/zlib/contrib/masmx64/readme.txt +28 -0
- data/windows/zlib, libpng/zlib/contrib/masmx86/bld_ml32.bat +2 -0
- data/windows/zlib, libpng/zlib/contrib/masmx86/gvmat32.asm +972 -0
- data/windows/zlib, libpng/zlib/contrib/masmx86/gvmat32.obj +0 -0
- data/windows/zlib, libpng/zlib/contrib/masmx86/gvmat32c.c +62 -0
- data/windows/zlib, libpng/zlib/contrib/masmx86/inffas32.asm +1083 -0
- data/windows/zlib, libpng/zlib/contrib/masmx86/inffas32.obj +0 -0
- data/windows/zlib, libpng/zlib/contrib/masmx86/mkasm.bat +3 -0
- data/windows/zlib, libpng/zlib/contrib/masmx86/readme.txt +21 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/ChangeLogUnzip +67 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/Makefile +25 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/crypt.h +132 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/ioapi.c +177 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/ioapi.h +75 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/iowin32.c +270 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/iowin32.h +21 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/miniunz.c +585 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/minizip.c +420 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/mztools.c +281 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/mztools.h +31 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/unzip.c +1598 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/unzip.h +354 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/zip.c +1219 -0
- data/windows/zlib, libpng/zlib/contrib/minizip/zip.h +235 -0
- data/windows/zlib, libpng/zlib/contrib/pascal/example.pas +599 -0
- data/windows/zlib, libpng/zlib/contrib/pascal/readme.txt +76 -0
- data/windows/zlib, libpng/zlib/contrib/pascal/zlibd32.mak +93 -0
- data/windows/zlib, libpng/zlib/contrib/pascal/zlibpas.pas +236 -0
- data/windows/zlib, libpng/zlib/contrib/puff/Makefile +8 -0
- data/windows/zlib, libpng/zlib/contrib/puff/README +63 -0
- data/windows/zlib, libpng/zlib/contrib/puff/puff.c +837 -0
- data/windows/zlib, libpng/zlib/contrib/puff/puff.h +31 -0
- data/windows/zlib, libpng/zlib/contrib/puff/zeros.raw +0 -0
- data/windows/zlib, libpng/zlib/contrib/testzlib/testzlib.c +275 -0
- data/windows/zlib, libpng/zlib/contrib/testzlib/testzlib.txt +10 -0
- data/windows/zlib, libpng/zlib/contrib/untgz/Makefile +14 -0
- data/windows/zlib, libpng/zlib/contrib/untgz/Makefile.msc +17 -0
- data/windows/zlib, libpng/zlib/contrib/untgz/untgz.c +674 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/readme.txt +73 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc7/miniunz.vcproj +126 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc7/minizip.vcproj +126 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc7/testzlib.vcproj +126 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc7/zlib.rc +32 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc7/zlibstat.vcproj +246 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc7/zlibvc.def +92 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc7/zlibvc.sln +78 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc7/zlibvc.vcproj +445 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc8/miniunz.vcproj +566 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc8/minizip.vcproj +563 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc8/testzlib.vcproj +948 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc8/testzlibdll.vcproj +567 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc8/zlib.rc +32 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc8/zlibstat.vcproj +870 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc8/zlibvc.def +92 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc8/zlibvc.sln +144 -0
- data/windows/zlib, libpng/zlib/contrib/vstudio/vc8/zlibvc.vcproj +1219 -0
- data/windows/zlib, libpng/zlib/crc32.c +423 -0
- data/windows/zlib, libpng/zlib/crc32.h +441 -0
- data/windows/zlib, libpng/zlib/deflate.c +1736 -0
- data/windows/zlib, libpng/zlib/deflate.h +331 -0
- data/windows/zlib, libpng/zlib/example.c +565 -0
- data/windows/zlib, libpng/zlib/examples/README.examples +42 -0
- data/windows/zlib, libpng/zlib/examples/fitblk.c +233 -0
- data/windows/zlib, libpng/zlib/examples/gun.c +693 -0
- data/windows/zlib, libpng/zlib/examples/gzappend.c +500 -0
- data/windows/zlib, libpng/zlib/examples/gzjoin.c +448 -0
- data/windows/zlib, libpng/zlib/examples/gzlog.c +413 -0
- data/windows/zlib, libpng/zlib/examples/gzlog.h +58 -0
- data/windows/zlib, libpng/zlib/examples/zlib_how.html +523 -0
- data/windows/zlib, libpng/zlib/examples/zpipe.c +191 -0
- data/windows/zlib, libpng/zlib/examples/zran.c +404 -0
- data/windows/zlib, libpng/zlib/gzio.c +1026 -0
- data/windows/zlib, libpng/zlib/infback.c +623 -0
- data/windows/zlib, libpng/zlib/inffast.c +318 -0
- data/windows/zlib, libpng/zlib/inffast.h +11 -0
- data/windows/zlib, libpng/zlib/inffixed.h +94 -0
- data/windows/zlib, libpng/zlib/inflate.c +1368 -0
- data/windows/zlib, libpng/zlib/inflate.h +115 -0
- data/windows/zlib, libpng/zlib/inftrees.c +329 -0
- data/windows/zlib, libpng/zlib/inftrees.h +55 -0
- data/windows/zlib, libpng/zlib/make_vms.com +461 -0
- data/windows/zlib, libpng/zlib/minigzip.c +322 -0
- data/windows/zlib, libpng/zlib/msdos/Makefile.bor +109 -0
- data/windows/zlib, libpng/zlib/msdos/Makefile.dj2 +104 -0
- data/windows/zlib, libpng/zlib/msdos/Makefile.emx +69 -0
- data/windows/zlib, libpng/zlib/msdos/Makefile.msc +106 -0
- data/windows/zlib, libpng/zlib/msdos/Makefile.tc +94 -0
- data/windows/zlib, libpng/zlib/old/Makefile.riscos +151 -0
- data/windows/zlib, libpng/zlib/old/README +3 -0
- data/windows/zlib, libpng/zlib/old/descrip.mms +48 -0
- data/windows/zlib, libpng/zlib/old/os2/Makefile.os2 +136 -0
- data/windows/zlib, libpng/zlib/old/os2/zlib.def +51 -0
- data/windows/zlib, libpng/zlib/old/visual-basic.txt +160 -0
- data/windows/zlib, libpng/zlib/old/zlib.html +971 -0
- data/windows/zlib, libpng/zlib/projects/README.projects +41 -0
- data/windows/zlib, libpng/zlib/projects/visualc6/README.txt +73 -0
- data/windows/zlib, libpng/zlib/projects/visualc6/example.dsp +278 -0
- data/windows/zlib, libpng/zlib/projects/visualc6/minigzip.dsp +278 -0
- data/windows/zlib, libpng/zlib/projects/visualc6/zlib.dsp +609 -0
- data/windows/zlib, libpng/zlib/projects/visualc6/zlib.dsw +59 -0
- data/windows/zlib, libpng/zlib/qnx/package.qpg +141 -0
- data/windows/zlib, libpng/zlib/trees.c +1219 -0
- data/windows/zlib, libpng/zlib/trees.h +128 -0
- data/windows/zlib, libpng/zlib/uncompr.c +61 -0
- data/windows/zlib, libpng/zlib/win32/DLL_FAQ.txt +397 -0
- data/windows/zlib, libpng/zlib/win32/Makefile.bor +107 -0
- data/windows/zlib, libpng/zlib/win32/Makefile.emx +69 -0
- data/windows/zlib, libpng/zlib/win32/Makefile.gcc +141 -0
- data/windows/zlib, libpng/zlib/win32/Makefile.msc +126 -0
- data/windows/zlib, libpng/zlib/win32/VisualC.txt +3 -0
- data/windows/zlib, libpng/zlib/win32/zlib.def +60 -0
- data/windows/zlib, libpng/zlib/win32/zlib1.rc +39 -0
- data/windows/zlib, libpng/zlib/zconf.h +332 -0
- data/windows/zlib, libpng/zlib/zconf.in.h +332 -0
- data/windows/zlib, libpng/zlib/zlib.3 +159 -0
- data/windows/zlib, libpng/zlib/zlib.h +1357 -0
- data/windows/zlib, libpng/zlib/zutil.c +318 -0
- data/windows/zlib, libpng/zlib/zutil.h +269 -0
- metadata +669 -216
@@ -0,0 +1 @@
|
|
1
|
+
/* pnggvrd.c was removed from libpng-1.2.20. */
|
@@ -0,0 +1,234 @@
|
|
1
|
+
|
2
|
+
/* pngwio.c - functions for data output
|
3
|
+
*
|
4
|
+
* Last changed in libpng 1.2.13 November 13, 2006
|
5
|
+
* For conditions of distribution and use, see copyright notice in png.h
|
6
|
+
* Copyright (c) 1998-2006 Glenn Randers-Pehrson
|
7
|
+
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
8
|
+
* (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
|
9
|
+
*
|
10
|
+
* This file provides a location for all output. Users who need
|
11
|
+
* special handling are expected to write functions that have the same
|
12
|
+
* arguments as these and perform similar functions, but that possibly
|
13
|
+
* use different output methods. Note that you shouldn't change these
|
14
|
+
* functions, but rather write replacement functions and then change
|
15
|
+
* them at run time with png_set_write_fn(...).
|
16
|
+
*/
|
17
|
+
|
18
|
+
#define PNG_INTERNAL
|
19
|
+
#include "png.h"
|
20
|
+
#ifdef PNG_WRITE_SUPPORTED
|
21
|
+
|
22
|
+
/* Write the data to whatever output you are using. The default routine
|
23
|
+
writes to a file pointer. Note that this routine sometimes gets called
|
24
|
+
with very small lengths, so you should implement some kind of simple
|
25
|
+
buffering if you are using unbuffered writes. This should never be asked
|
26
|
+
to write more than 64K on a 16 bit machine. */
|
27
|
+
|
28
|
+
void /* PRIVATE */
|
29
|
+
png_write_data(png_structp png_ptr, png_bytep data, png_size_t length)
|
30
|
+
{
|
31
|
+
if (png_ptr->write_data_fn != NULL )
|
32
|
+
(*(png_ptr->write_data_fn))(png_ptr, data, length);
|
33
|
+
else
|
34
|
+
png_error(png_ptr, "Call to NULL write function");
|
35
|
+
}
|
36
|
+
|
37
|
+
#if !defined(PNG_NO_STDIO)
|
38
|
+
/* This is the function that does the actual writing of data. If you are
|
39
|
+
not writing to a standard C stream, you should create a replacement
|
40
|
+
write_data function and use it at run time with png_set_write_fn(), rather
|
41
|
+
than changing the library. */
|
42
|
+
#ifndef USE_FAR_KEYWORD
|
43
|
+
void PNGAPI
|
44
|
+
png_default_write_data(png_structp png_ptr, png_bytep data, png_size_t length)
|
45
|
+
{
|
46
|
+
png_uint_32 check;
|
47
|
+
|
48
|
+
if(png_ptr == NULL) return;
|
49
|
+
#if defined(_WIN32_WCE)
|
50
|
+
if ( !WriteFile((HANDLE)(png_ptr->io_ptr), data, length, &check, NULL) )
|
51
|
+
check = 0;
|
52
|
+
#else
|
53
|
+
check = fwrite(data, 1, length, (png_FILE_p)(png_ptr->io_ptr));
|
54
|
+
#endif
|
55
|
+
if (check != length)
|
56
|
+
png_error(png_ptr, "Write Error");
|
57
|
+
}
|
58
|
+
#else
|
59
|
+
/* this is the model-independent version. Since the standard I/O library
|
60
|
+
can't handle far buffers in the medium and small models, we have to copy
|
61
|
+
the data.
|
62
|
+
*/
|
63
|
+
|
64
|
+
#define NEAR_BUF_SIZE 1024
|
65
|
+
#define MIN(a,b) (a <= b ? a : b)
|
66
|
+
|
67
|
+
void PNGAPI
|
68
|
+
png_default_write_data(png_structp png_ptr, png_bytep data, png_size_t length)
|
69
|
+
{
|
70
|
+
png_uint_32 check;
|
71
|
+
png_byte *near_data; /* Needs to be "png_byte *" instead of "png_bytep" */
|
72
|
+
png_FILE_p io_ptr;
|
73
|
+
|
74
|
+
if(png_ptr == NULL) return;
|
75
|
+
/* Check if data really is near. If so, use usual code. */
|
76
|
+
near_data = (png_byte *)CVT_PTR_NOCHECK(data);
|
77
|
+
io_ptr = (png_FILE_p)CVT_PTR(png_ptr->io_ptr);
|
78
|
+
if ((png_bytep)near_data == data)
|
79
|
+
{
|
80
|
+
#if defined(_WIN32_WCE)
|
81
|
+
if ( !WriteFile(io_ptr, near_data, length, &check, NULL) )
|
82
|
+
check = 0;
|
83
|
+
#else
|
84
|
+
check = fwrite(near_data, 1, length, io_ptr);
|
85
|
+
#endif
|
86
|
+
}
|
87
|
+
else
|
88
|
+
{
|
89
|
+
png_byte buf[NEAR_BUF_SIZE];
|
90
|
+
png_size_t written, remaining, err;
|
91
|
+
check = 0;
|
92
|
+
remaining = length;
|
93
|
+
do
|
94
|
+
{
|
95
|
+
written = MIN(NEAR_BUF_SIZE, remaining);
|
96
|
+
png_memcpy(buf, data, written); /* copy far buffer to near buffer */
|
97
|
+
#if defined(_WIN32_WCE)
|
98
|
+
if ( !WriteFile(io_ptr, buf, written, &err, NULL) )
|
99
|
+
err = 0;
|
100
|
+
#else
|
101
|
+
err = fwrite(buf, 1, written, io_ptr);
|
102
|
+
#endif
|
103
|
+
if (err != written)
|
104
|
+
break;
|
105
|
+
else
|
106
|
+
check += err;
|
107
|
+
data += written;
|
108
|
+
remaining -= written;
|
109
|
+
}
|
110
|
+
while (remaining != 0);
|
111
|
+
}
|
112
|
+
if (check != length)
|
113
|
+
png_error(png_ptr, "Write Error");
|
114
|
+
}
|
115
|
+
|
116
|
+
#endif
|
117
|
+
#endif
|
118
|
+
|
119
|
+
/* This function is called to output any data pending writing (normally
|
120
|
+
to disk). After png_flush is called, there should be no data pending
|
121
|
+
writing in any buffers. */
|
122
|
+
#if defined(PNG_WRITE_FLUSH_SUPPORTED)
|
123
|
+
void /* PRIVATE */
|
124
|
+
png_flush(png_structp png_ptr)
|
125
|
+
{
|
126
|
+
if (png_ptr->output_flush_fn != NULL)
|
127
|
+
(*(png_ptr->output_flush_fn))(png_ptr);
|
128
|
+
}
|
129
|
+
|
130
|
+
#if !defined(PNG_NO_STDIO)
|
131
|
+
void PNGAPI
|
132
|
+
png_default_flush(png_structp png_ptr)
|
133
|
+
{
|
134
|
+
#if !defined(_WIN32_WCE)
|
135
|
+
png_FILE_p io_ptr;
|
136
|
+
#endif
|
137
|
+
if(png_ptr == NULL) return;
|
138
|
+
#if !defined(_WIN32_WCE)
|
139
|
+
io_ptr = (png_FILE_p)CVT_PTR((png_ptr->io_ptr));
|
140
|
+
if (io_ptr != NULL)
|
141
|
+
fflush(io_ptr);
|
142
|
+
#endif
|
143
|
+
}
|
144
|
+
#endif
|
145
|
+
#endif
|
146
|
+
|
147
|
+
/* This function allows the application to supply new output functions for
|
148
|
+
libpng if standard C streams aren't being used.
|
149
|
+
|
150
|
+
This function takes as its arguments:
|
151
|
+
png_ptr - pointer to a png output data structure
|
152
|
+
io_ptr - pointer to user supplied structure containing info about
|
153
|
+
the output functions. May be NULL.
|
154
|
+
write_data_fn - pointer to a new output function that takes as its
|
155
|
+
arguments a pointer to a png_struct, a pointer to
|
156
|
+
data to be written, and a 32-bit unsigned int that is
|
157
|
+
the number of bytes to be written. The new write
|
158
|
+
function should call png_error(png_ptr, "Error msg")
|
159
|
+
to exit and output any fatal error messages.
|
160
|
+
flush_data_fn - pointer to a new flush function that takes as its
|
161
|
+
arguments a pointer to a png_struct. After a call to
|
162
|
+
the flush function, there should be no data in any buffers
|
163
|
+
or pending transmission. If the output method doesn't do
|
164
|
+
any buffering of ouput, a function prototype must still be
|
165
|
+
supplied although it doesn't have to do anything. If
|
166
|
+
PNG_WRITE_FLUSH_SUPPORTED is not defined at libpng compile
|
167
|
+
time, output_flush_fn will be ignored, although it must be
|
168
|
+
supplied for compatibility. */
|
169
|
+
void PNGAPI
|
170
|
+
png_set_write_fn(png_structp png_ptr, png_voidp io_ptr,
|
171
|
+
png_rw_ptr write_data_fn, png_flush_ptr output_flush_fn)
|
172
|
+
{
|
173
|
+
if(png_ptr == NULL) return;
|
174
|
+
png_ptr->io_ptr = io_ptr;
|
175
|
+
|
176
|
+
#if !defined(PNG_NO_STDIO)
|
177
|
+
if (write_data_fn != NULL)
|
178
|
+
png_ptr->write_data_fn = write_data_fn;
|
179
|
+
else
|
180
|
+
png_ptr->write_data_fn = png_default_write_data;
|
181
|
+
#else
|
182
|
+
png_ptr->write_data_fn = write_data_fn;
|
183
|
+
#endif
|
184
|
+
|
185
|
+
#if defined(PNG_WRITE_FLUSH_SUPPORTED)
|
186
|
+
#if !defined(PNG_NO_STDIO)
|
187
|
+
if (output_flush_fn != NULL)
|
188
|
+
png_ptr->output_flush_fn = output_flush_fn;
|
189
|
+
else
|
190
|
+
png_ptr->output_flush_fn = png_default_flush;
|
191
|
+
#else
|
192
|
+
png_ptr->output_flush_fn = output_flush_fn;
|
193
|
+
#endif
|
194
|
+
#endif /* PNG_WRITE_FLUSH_SUPPORTED */
|
195
|
+
|
196
|
+
/* It is an error to read while writing a png file */
|
197
|
+
if (png_ptr->read_data_fn != NULL)
|
198
|
+
{
|
199
|
+
png_ptr->read_data_fn = NULL;
|
200
|
+
png_warning(png_ptr,
|
201
|
+
"Attempted to set both read_data_fn and write_data_fn in");
|
202
|
+
png_warning(png_ptr,
|
203
|
+
"the same structure. Resetting read_data_fn to NULL.");
|
204
|
+
}
|
205
|
+
}
|
206
|
+
|
207
|
+
#if defined(USE_FAR_KEYWORD)
|
208
|
+
#if defined(_MSC_VER)
|
209
|
+
void *png_far_to_near(png_structp png_ptr,png_voidp ptr, int check)
|
210
|
+
{
|
211
|
+
void *near_ptr;
|
212
|
+
void FAR *far_ptr;
|
213
|
+
FP_OFF(near_ptr) = FP_OFF(ptr);
|
214
|
+
far_ptr = (void FAR *)near_ptr;
|
215
|
+
if(check != 0)
|
216
|
+
if(FP_SEG(ptr) != FP_SEG(far_ptr))
|
217
|
+
png_error(png_ptr,"segment lost in conversion");
|
218
|
+
return(near_ptr);
|
219
|
+
}
|
220
|
+
# else
|
221
|
+
void *png_far_to_near(png_structp png_ptr,png_voidp ptr, int check)
|
222
|
+
{
|
223
|
+
void *near_ptr;
|
224
|
+
void FAR *far_ptr;
|
225
|
+
near_ptr = (void FAR *)ptr;
|
226
|
+
far_ptr = (void FAR *)near_ptr;
|
227
|
+
if(check != 0)
|
228
|
+
if(far_ptr != ptr)
|
229
|
+
png_error(png_ptr,"segment lost in conversion");
|
230
|
+
return(near_ptr);
|
231
|
+
}
|
232
|
+
# endif
|
233
|
+
# endif
|
234
|
+
#endif /* PNG_WRITE_SUPPORTED */
|
@@ -0,0 +1,1532 @@
|
|
1
|
+
|
2
|
+
/* pngwrite.c - general routines to write a PNG file
|
3
|
+
*
|
4
|
+
* Last changed in libpng 1.2.27 [April 29, 2008]
|
5
|
+
* For conditions of distribution and use, see copyright notice in png.h
|
6
|
+
* Copyright (c) 1998-2008 Glenn Randers-Pehrson
|
7
|
+
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
8
|
+
* (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
|
9
|
+
*/
|
10
|
+
|
11
|
+
/* get internal access to png.h */
|
12
|
+
#define PNG_INTERNAL
|
13
|
+
#include "png.h"
|
14
|
+
#ifdef PNG_WRITE_SUPPORTED
|
15
|
+
|
16
|
+
/* Writes all the PNG information. This is the suggested way to use the
|
17
|
+
* library. If you have a new chunk to add, make a function to write it,
|
18
|
+
* and put it in the correct location here. If you want the chunk written
|
19
|
+
* after the image data, put it in png_write_end(). I strongly encourage
|
20
|
+
* you to supply a PNG_INFO_ flag, and check info_ptr->valid before writing
|
21
|
+
* the chunk, as that will keep the code from breaking if you want to just
|
22
|
+
* write a plain PNG file. If you have long comments, I suggest writing
|
23
|
+
* them in png_write_end(), and compressing them.
|
24
|
+
*/
|
25
|
+
void PNGAPI
|
26
|
+
png_write_info_before_PLTE(png_structp png_ptr, png_infop info_ptr)
|
27
|
+
{
|
28
|
+
png_debug(1, "in png_write_info_before_PLTE\n");
|
29
|
+
if (png_ptr == NULL || info_ptr == NULL)
|
30
|
+
return;
|
31
|
+
if (!(png_ptr->mode & PNG_WROTE_INFO_BEFORE_PLTE))
|
32
|
+
{
|
33
|
+
png_write_sig(png_ptr); /* write PNG signature */
|
34
|
+
#if defined(PNG_MNG_FEATURES_SUPPORTED)
|
35
|
+
if((png_ptr->mode&PNG_HAVE_PNG_SIGNATURE)&&(png_ptr->mng_features_permitted))
|
36
|
+
{
|
37
|
+
png_warning(png_ptr,"MNG features are not allowed in a PNG datastream");
|
38
|
+
png_ptr->mng_features_permitted=0;
|
39
|
+
}
|
40
|
+
#endif
|
41
|
+
/* write IHDR information. */
|
42
|
+
png_write_IHDR(png_ptr, info_ptr->width, info_ptr->height,
|
43
|
+
info_ptr->bit_depth, info_ptr->color_type, info_ptr->compression_type,
|
44
|
+
info_ptr->filter_type,
|
45
|
+
#if defined(PNG_WRITE_INTERLACING_SUPPORTED)
|
46
|
+
info_ptr->interlace_type);
|
47
|
+
#else
|
48
|
+
0);
|
49
|
+
#endif
|
50
|
+
/* the rest of these check to see if the valid field has the appropriate
|
51
|
+
flag set, and if it does, writes the chunk. */
|
52
|
+
#if defined(PNG_WRITE_gAMA_SUPPORTED)
|
53
|
+
if (info_ptr->valid & PNG_INFO_gAMA)
|
54
|
+
{
|
55
|
+
# ifdef PNG_FLOATING_POINT_SUPPORTED
|
56
|
+
png_write_gAMA(png_ptr, info_ptr->gamma);
|
57
|
+
#else
|
58
|
+
#ifdef PNG_FIXED_POINT_SUPPORTED
|
59
|
+
png_write_gAMA_fixed(png_ptr, info_ptr->int_gamma);
|
60
|
+
# endif
|
61
|
+
#endif
|
62
|
+
}
|
63
|
+
#endif
|
64
|
+
#if defined(PNG_WRITE_sRGB_SUPPORTED)
|
65
|
+
if (info_ptr->valid & PNG_INFO_sRGB)
|
66
|
+
png_write_sRGB(png_ptr, (int)info_ptr->srgb_intent);
|
67
|
+
#endif
|
68
|
+
#if defined(PNG_WRITE_iCCP_SUPPORTED)
|
69
|
+
if (info_ptr->valid & PNG_INFO_iCCP)
|
70
|
+
png_write_iCCP(png_ptr, info_ptr->iccp_name, PNG_COMPRESSION_TYPE_BASE,
|
71
|
+
info_ptr->iccp_profile, (int)info_ptr->iccp_proflen);
|
72
|
+
#endif
|
73
|
+
#if defined(PNG_WRITE_sBIT_SUPPORTED)
|
74
|
+
if (info_ptr->valid & PNG_INFO_sBIT)
|
75
|
+
png_write_sBIT(png_ptr, &(info_ptr->sig_bit), info_ptr->color_type);
|
76
|
+
#endif
|
77
|
+
#if defined(PNG_WRITE_cHRM_SUPPORTED)
|
78
|
+
if (info_ptr->valid & PNG_INFO_cHRM)
|
79
|
+
{
|
80
|
+
#ifdef PNG_FLOATING_POINT_SUPPORTED
|
81
|
+
png_write_cHRM(png_ptr,
|
82
|
+
info_ptr->x_white, info_ptr->y_white,
|
83
|
+
info_ptr->x_red, info_ptr->y_red,
|
84
|
+
info_ptr->x_green, info_ptr->y_green,
|
85
|
+
info_ptr->x_blue, info_ptr->y_blue);
|
86
|
+
#else
|
87
|
+
# ifdef PNG_FIXED_POINT_SUPPORTED
|
88
|
+
png_write_cHRM_fixed(png_ptr,
|
89
|
+
info_ptr->int_x_white, info_ptr->int_y_white,
|
90
|
+
info_ptr->int_x_red, info_ptr->int_y_red,
|
91
|
+
info_ptr->int_x_green, info_ptr->int_y_green,
|
92
|
+
info_ptr->int_x_blue, info_ptr->int_y_blue);
|
93
|
+
# endif
|
94
|
+
#endif
|
95
|
+
}
|
96
|
+
#endif
|
97
|
+
#if defined(PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED)
|
98
|
+
if (info_ptr->unknown_chunks_num)
|
99
|
+
{
|
100
|
+
png_unknown_chunk *up;
|
101
|
+
|
102
|
+
png_debug(5, "writing extra chunks\n");
|
103
|
+
|
104
|
+
for (up = info_ptr->unknown_chunks;
|
105
|
+
up < info_ptr->unknown_chunks + info_ptr->unknown_chunks_num;
|
106
|
+
up++)
|
107
|
+
{
|
108
|
+
int keep=png_handle_as_unknown(png_ptr, up->name);
|
109
|
+
if (keep != PNG_HANDLE_CHUNK_NEVER &&
|
110
|
+
up->location && !(up->location & PNG_HAVE_PLTE) &&
|
111
|
+
!(up->location & PNG_HAVE_IDAT) &&
|
112
|
+
((up->name[3] & 0x20) || keep == PNG_HANDLE_CHUNK_ALWAYS ||
|
113
|
+
(png_ptr->flags & PNG_FLAG_KEEP_UNSAFE_CHUNKS)))
|
114
|
+
{
|
115
|
+
if (up->size == 0)
|
116
|
+
png_warning(png_ptr, "Writing zero-length unknown chunk");
|
117
|
+
png_write_chunk(png_ptr, up->name, up->data, up->size);
|
118
|
+
}
|
119
|
+
}
|
120
|
+
}
|
121
|
+
#endif
|
122
|
+
png_ptr->mode |= PNG_WROTE_INFO_BEFORE_PLTE;
|
123
|
+
}
|
124
|
+
}
|
125
|
+
|
126
|
+
void PNGAPI
|
127
|
+
png_write_info(png_structp png_ptr, png_infop info_ptr)
|
128
|
+
{
|
129
|
+
#if defined(PNG_WRITE_TEXT_SUPPORTED) || defined(PNG_WRITE_sPLT_SUPPORTED)
|
130
|
+
int i;
|
131
|
+
#endif
|
132
|
+
|
133
|
+
png_debug(1, "in png_write_info\n");
|
134
|
+
|
135
|
+
if (png_ptr == NULL || info_ptr == NULL)
|
136
|
+
return;
|
137
|
+
|
138
|
+
png_write_info_before_PLTE(png_ptr, info_ptr);
|
139
|
+
|
140
|
+
if (info_ptr->valid & PNG_INFO_PLTE)
|
141
|
+
png_write_PLTE(png_ptr, info_ptr->palette,
|
142
|
+
(png_uint_32)info_ptr->num_palette);
|
143
|
+
else if (info_ptr->color_type == PNG_COLOR_TYPE_PALETTE)
|
144
|
+
png_error(png_ptr, "Valid palette required for paletted images");
|
145
|
+
|
146
|
+
#if defined(PNG_WRITE_tRNS_SUPPORTED)
|
147
|
+
if (info_ptr->valid & PNG_INFO_tRNS)
|
148
|
+
{
|
149
|
+
#if defined(PNG_WRITE_INVERT_ALPHA_SUPPORTED)
|
150
|
+
/* invert the alpha channel (in tRNS) */
|
151
|
+
if ((png_ptr->transformations & PNG_INVERT_ALPHA) &&
|
152
|
+
info_ptr->color_type == PNG_COLOR_TYPE_PALETTE)
|
153
|
+
{
|
154
|
+
int j;
|
155
|
+
for (j=0; j<(int)info_ptr->num_trans; j++)
|
156
|
+
info_ptr->trans[j] = (png_byte)(255 - info_ptr->trans[j]);
|
157
|
+
}
|
158
|
+
#endif
|
159
|
+
png_write_tRNS(png_ptr, info_ptr->trans, &(info_ptr->trans_values),
|
160
|
+
info_ptr->num_trans, info_ptr->color_type);
|
161
|
+
}
|
162
|
+
#endif
|
163
|
+
#if defined(PNG_WRITE_bKGD_SUPPORTED)
|
164
|
+
if (info_ptr->valid & PNG_INFO_bKGD)
|
165
|
+
png_write_bKGD(png_ptr, &(info_ptr->background), info_ptr->color_type);
|
166
|
+
#endif
|
167
|
+
#if defined(PNG_WRITE_hIST_SUPPORTED)
|
168
|
+
if (info_ptr->valid & PNG_INFO_hIST)
|
169
|
+
png_write_hIST(png_ptr, info_ptr->hist, info_ptr->num_palette);
|
170
|
+
#endif
|
171
|
+
#if defined(PNG_WRITE_oFFs_SUPPORTED)
|
172
|
+
if (info_ptr->valid & PNG_INFO_oFFs)
|
173
|
+
png_write_oFFs(png_ptr, info_ptr->x_offset, info_ptr->y_offset,
|
174
|
+
info_ptr->offset_unit_type);
|
175
|
+
#endif
|
176
|
+
#if defined(PNG_WRITE_pCAL_SUPPORTED)
|
177
|
+
if (info_ptr->valid & PNG_INFO_pCAL)
|
178
|
+
png_write_pCAL(png_ptr, info_ptr->pcal_purpose, info_ptr->pcal_X0,
|
179
|
+
info_ptr->pcal_X1, info_ptr->pcal_type, info_ptr->pcal_nparams,
|
180
|
+
info_ptr->pcal_units, info_ptr->pcal_params);
|
181
|
+
#endif
|
182
|
+
#if defined(PNG_WRITE_sCAL_SUPPORTED)
|
183
|
+
if (info_ptr->valid & PNG_INFO_sCAL)
|
184
|
+
#if defined(PNG_FLOATING_POINT_SUPPORTED) && !defined(PNG_NO_STDIO)
|
185
|
+
png_write_sCAL(png_ptr, (int)info_ptr->scal_unit,
|
186
|
+
info_ptr->scal_pixel_width, info_ptr->scal_pixel_height);
|
187
|
+
#else
|
188
|
+
#ifdef PNG_FIXED_POINT_SUPPORTED
|
189
|
+
png_write_sCAL_s(png_ptr, (int)info_ptr->scal_unit,
|
190
|
+
info_ptr->scal_s_width, info_ptr->scal_s_height);
|
191
|
+
#else
|
192
|
+
png_warning(png_ptr,
|
193
|
+
"png_write_sCAL not supported; sCAL chunk not written.");
|
194
|
+
#endif
|
195
|
+
#endif
|
196
|
+
#endif
|
197
|
+
#if defined(PNG_WRITE_pHYs_SUPPORTED)
|
198
|
+
if (info_ptr->valid & PNG_INFO_pHYs)
|
199
|
+
png_write_pHYs(png_ptr, info_ptr->x_pixels_per_unit,
|
200
|
+
info_ptr->y_pixels_per_unit, info_ptr->phys_unit_type);
|
201
|
+
#endif
|
202
|
+
#if defined(PNG_WRITE_tIME_SUPPORTED)
|
203
|
+
if (info_ptr->valid & PNG_INFO_tIME)
|
204
|
+
{
|
205
|
+
png_write_tIME(png_ptr, &(info_ptr->mod_time));
|
206
|
+
png_ptr->mode |= PNG_WROTE_tIME;
|
207
|
+
}
|
208
|
+
#endif
|
209
|
+
#if defined(PNG_WRITE_sPLT_SUPPORTED)
|
210
|
+
if (info_ptr->valid & PNG_INFO_sPLT)
|
211
|
+
for (i = 0; i < (int)info_ptr->splt_palettes_num; i++)
|
212
|
+
png_write_sPLT(png_ptr, info_ptr->splt_palettes + i);
|
213
|
+
#endif
|
214
|
+
#if defined(PNG_WRITE_TEXT_SUPPORTED)
|
215
|
+
/* Check to see if we need to write text chunks */
|
216
|
+
for (i = 0; i < info_ptr->num_text; i++)
|
217
|
+
{
|
218
|
+
png_debug2(2, "Writing header text chunk %d, type %d\n", i,
|
219
|
+
info_ptr->text[i].compression);
|
220
|
+
/* an internationalized chunk? */
|
221
|
+
if (info_ptr->text[i].compression > 0)
|
222
|
+
{
|
223
|
+
#if defined(PNG_WRITE_iTXt_SUPPORTED)
|
224
|
+
/* write international chunk */
|
225
|
+
png_write_iTXt(png_ptr,
|
226
|
+
info_ptr->text[i].compression,
|
227
|
+
info_ptr->text[i].key,
|
228
|
+
info_ptr->text[i].lang,
|
229
|
+
info_ptr->text[i].lang_key,
|
230
|
+
info_ptr->text[i].text);
|
231
|
+
#else
|
232
|
+
png_warning(png_ptr, "Unable to write international text");
|
233
|
+
#endif
|
234
|
+
/* Mark this chunk as written */
|
235
|
+
info_ptr->text[i].compression = PNG_TEXT_COMPRESSION_NONE_WR;
|
236
|
+
}
|
237
|
+
/* If we want a compressed text chunk */
|
238
|
+
else if (info_ptr->text[i].compression == PNG_TEXT_COMPRESSION_zTXt)
|
239
|
+
{
|
240
|
+
#if defined(PNG_WRITE_zTXt_SUPPORTED)
|
241
|
+
/* write compressed chunk */
|
242
|
+
png_write_zTXt(png_ptr, info_ptr->text[i].key,
|
243
|
+
info_ptr->text[i].text, 0,
|
244
|
+
info_ptr->text[i].compression);
|
245
|
+
#else
|
246
|
+
png_warning(png_ptr, "Unable to write compressed text");
|
247
|
+
#endif
|
248
|
+
/* Mark this chunk as written */
|
249
|
+
info_ptr->text[i].compression = PNG_TEXT_COMPRESSION_zTXt_WR;
|
250
|
+
}
|
251
|
+
else if (info_ptr->text[i].compression == PNG_TEXT_COMPRESSION_NONE)
|
252
|
+
{
|
253
|
+
#if defined(PNG_WRITE_tEXt_SUPPORTED)
|
254
|
+
/* write uncompressed chunk */
|
255
|
+
png_write_tEXt(png_ptr, info_ptr->text[i].key,
|
256
|
+
info_ptr->text[i].text,
|
257
|
+
0);
|
258
|
+
#else
|
259
|
+
png_warning(png_ptr, "Unable to write uncompressed text");
|
260
|
+
#endif
|
261
|
+
/* Mark this chunk as written */
|
262
|
+
info_ptr->text[i].compression = PNG_TEXT_COMPRESSION_NONE_WR;
|
263
|
+
}
|
264
|
+
}
|
265
|
+
#endif
|
266
|
+
#if defined(PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED)
|
267
|
+
if (info_ptr->unknown_chunks_num)
|
268
|
+
{
|
269
|
+
png_unknown_chunk *up;
|
270
|
+
|
271
|
+
png_debug(5, "writing extra chunks\n");
|
272
|
+
|
273
|
+
for (up = info_ptr->unknown_chunks;
|
274
|
+
up < info_ptr->unknown_chunks + info_ptr->unknown_chunks_num;
|
275
|
+
up++)
|
276
|
+
{
|
277
|
+
int keep=png_handle_as_unknown(png_ptr, up->name);
|
278
|
+
if (keep != PNG_HANDLE_CHUNK_NEVER &&
|
279
|
+
up->location && (up->location & PNG_HAVE_PLTE) &&
|
280
|
+
!(up->location & PNG_HAVE_IDAT) &&
|
281
|
+
((up->name[3] & 0x20) || keep == PNG_HANDLE_CHUNK_ALWAYS ||
|
282
|
+
(png_ptr->flags & PNG_FLAG_KEEP_UNSAFE_CHUNKS)))
|
283
|
+
{
|
284
|
+
png_write_chunk(png_ptr, up->name, up->data, up->size);
|
285
|
+
}
|
286
|
+
}
|
287
|
+
}
|
288
|
+
#endif
|
289
|
+
}
|
290
|
+
|
291
|
+
/* Writes the end of the PNG file. If you don't want to write comments or
|
292
|
+
* time information, you can pass NULL for info. If you already wrote these
|
293
|
+
* in png_write_info(), do not write them again here. If you have long
|
294
|
+
* comments, I suggest writing them here, and compressing them.
|
295
|
+
*/
|
296
|
+
void PNGAPI
|
297
|
+
png_write_end(png_structp png_ptr, png_infop info_ptr)
|
298
|
+
{
|
299
|
+
png_debug(1, "in png_write_end\n");
|
300
|
+
if (png_ptr == NULL)
|
301
|
+
return;
|
302
|
+
if (!(png_ptr->mode & PNG_HAVE_IDAT))
|
303
|
+
png_error(png_ptr, "No IDATs written into file");
|
304
|
+
|
305
|
+
/* see if user wants us to write information chunks */
|
306
|
+
if (info_ptr != NULL)
|
307
|
+
{
|
308
|
+
#if defined(PNG_WRITE_TEXT_SUPPORTED)
|
309
|
+
int i; /* local index variable */
|
310
|
+
#endif
|
311
|
+
#if defined(PNG_WRITE_tIME_SUPPORTED)
|
312
|
+
/* check to see if user has supplied a time chunk */
|
313
|
+
if ((info_ptr->valid & PNG_INFO_tIME) &&
|
314
|
+
!(png_ptr->mode & PNG_WROTE_tIME))
|
315
|
+
png_write_tIME(png_ptr, &(info_ptr->mod_time));
|
316
|
+
#endif
|
317
|
+
#if defined(PNG_WRITE_TEXT_SUPPORTED)
|
318
|
+
/* loop through comment chunks */
|
319
|
+
for (i = 0; i < info_ptr->num_text; i++)
|
320
|
+
{
|
321
|
+
png_debug2(2, "Writing trailer text chunk %d, type %d\n", i,
|
322
|
+
info_ptr->text[i].compression);
|
323
|
+
/* an internationalized chunk? */
|
324
|
+
if (info_ptr->text[i].compression > 0)
|
325
|
+
{
|
326
|
+
#if defined(PNG_WRITE_iTXt_SUPPORTED)
|
327
|
+
/* write international chunk */
|
328
|
+
png_write_iTXt(png_ptr,
|
329
|
+
info_ptr->text[i].compression,
|
330
|
+
info_ptr->text[i].key,
|
331
|
+
info_ptr->text[i].lang,
|
332
|
+
info_ptr->text[i].lang_key,
|
333
|
+
info_ptr->text[i].text);
|
334
|
+
#else
|
335
|
+
png_warning(png_ptr, "Unable to write international text");
|
336
|
+
#endif
|
337
|
+
/* Mark this chunk as written */
|
338
|
+
info_ptr->text[i].compression = PNG_TEXT_COMPRESSION_NONE_WR;
|
339
|
+
}
|
340
|
+
else if (info_ptr->text[i].compression >= PNG_TEXT_COMPRESSION_zTXt)
|
341
|
+
{
|
342
|
+
#if defined(PNG_WRITE_zTXt_SUPPORTED)
|
343
|
+
/* write compressed chunk */
|
344
|
+
png_write_zTXt(png_ptr, info_ptr->text[i].key,
|
345
|
+
info_ptr->text[i].text, 0,
|
346
|
+
info_ptr->text[i].compression);
|
347
|
+
#else
|
348
|
+
png_warning(png_ptr, "Unable to write compressed text");
|
349
|
+
#endif
|
350
|
+
/* Mark this chunk as written */
|
351
|
+
info_ptr->text[i].compression = PNG_TEXT_COMPRESSION_zTXt_WR;
|
352
|
+
}
|
353
|
+
else if (info_ptr->text[i].compression == PNG_TEXT_COMPRESSION_NONE)
|
354
|
+
{
|
355
|
+
#if defined(PNG_WRITE_tEXt_SUPPORTED)
|
356
|
+
/* write uncompressed chunk */
|
357
|
+
png_write_tEXt(png_ptr, info_ptr->text[i].key,
|
358
|
+
info_ptr->text[i].text, 0);
|
359
|
+
#else
|
360
|
+
png_warning(png_ptr, "Unable to write uncompressed text");
|
361
|
+
#endif
|
362
|
+
|
363
|
+
/* Mark this chunk as written */
|
364
|
+
info_ptr->text[i].compression = PNG_TEXT_COMPRESSION_NONE_WR;
|
365
|
+
}
|
366
|
+
}
|
367
|
+
#endif
|
368
|
+
#if defined(PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED)
|
369
|
+
if (info_ptr->unknown_chunks_num)
|
370
|
+
{
|
371
|
+
png_unknown_chunk *up;
|
372
|
+
|
373
|
+
png_debug(5, "writing extra chunks\n");
|
374
|
+
|
375
|
+
for (up = info_ptr->unknown_chunks;
|
376
|
+
up < info_ptr->unknown_chunks + info_ptr->unknown_chunks_num;
|
377
|
+
up++)
|
378
|
+
{
|
379
|
+
int keep=png_handle_as_unknown(png_ptr, up->name);
|
380
|
+
if (keep != PNG_HANDLE_CHUNK_NEVER &&
|
381
|
+
up->location && (up->location & PNG_AFTER_IDAT) &&
|
382
|
+
((up->name[3] & 0x20) || keep == PNG_HANDLE_CHUNK_ALWAYS ||
|
383
|
+
(png_ptr->flags & PNG_FLAG_KEEP_UNSAFE_CHUNKS)))
|
384
|
+
{
|
385
|
+
png_write_chunk(png_ptr, up->name, up->data, up->size);
|
386
|
+
}
|
387
|
+
}
|
388
|
+
}
|
389
|
+
#endif
|
390
|
+
}
|
391
|
+
|
392
|
+
png_ptr->mode |= PNG_AFTER_IDAT;
|
393
|
+
|
394
|
+
/* write end of PNG file */
|
395
|
+
png_write_IEND(png_ptr);
|
396
|
+
}
|
397
|
+
|
398
|
+
#if defined(PNG_WRITE_tIME_SUPPORTED)
|
399
|
+
#if !defined(_WIN32_WCE)
|
400
|
+
/* "time.h" functions are not supported on WindowsCE */
|
401
|
+
void PNGAPI
|
402
|
+
png_convert_from_struct_tm(png_timep ptime, struct tm FAR * ttime)
|
403
|
+
{
|
404
|
+
png_debug(1, "in png_convert_from_struct_tm\n");
|
405
|
+
ptime->year = (png_uint_16)(1900 + ttime->tm_year);
|
406
|
+
ptime->month = (png_byte)(ttime->tm_mon + 1);
|
407
|
+
ptime->day = (png_byte)ttime->tm_mday;
|
408
|
+
ptime->hour = (png_byte)ttime->tm_hour;
|
409
|
+
ptime->minute = (png_byte)ttime->tm_min;
|
410
|
+
ptime->second = (png_byte)ttime->tm_sec;
|
411
|
+
}
|
412
|
+
|
413
|
+
void PNGAPI
|
414
|
+
png_convert_from_time_t(png_timep ptime, time_t ttime)
|
415
|
+
{
|
416
|
+
struct tm *tbuf;
|
417
|
+
|
418
|
+
png_debug(1, "in png_convert_from_time_t\n");
|
419
|
+
tbuf = gmtime(&ttime);
|
420
|
+
png_convert_from_struct_tm(ptime, tbuf);
|
421
|
+
}
|
422
|
+
#endif
|
423
|
+
#endif
|
424
|
+
|
425
|
+
/* Initialize png_ptr structure, and allocate any memory needed */
|
426
|
+
png_structp PNGAPI
|
427
|
+
png_create_write_struct(png_const_charp user_png_ver, png_voidp error_ptr,
|
428
|
+
png_error_ptr error_fn, png_error_ptr warn_fn)
|
429
|
+
{
|
430
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
431
|
+
return (png_create_write_struct_2(user_png_ver, error_ptr, error_fn,
|
432
|
+
warn_fn, png_voidp_NULL, png_malloc_ptr_NULL, png_free_ptr_NULL));
|
433
|
+
}
|
434
|
+
|
435
|
+
/* Alternate initialize png_ptr structure, and allocate any memory needed */
|
436
|
+
png_structp PNGAPI
|
437
|
+
png_create_write_struct_2(png_const_charp user_png_ver, png_voidp error_ptr,
|
438
|
+
png_error_ptr error_fn, png_error_ptr warn_fn, png_voidp mem_ptr,
|
439
|
+
png_malloc_ptr malloc_fn, png_free_ptr free_fn)
|
440
|
+
{
|
441
|
+
#endif /* PNG_USER_MEM_SUPPORTED */
|
442
|
+
png_structp png_ptr;
|
443
|
+
#ifdef PNG_SETJMP_SUPPORTED
|
444
|
+
#ifdef USE_FAR_KEYWORD
|
445
|
+
jmp_buf jmpbuf;
|
446
|
+
#endif
|
447
|
+
#endif
|
448
|
+
int i;
|
449
|
+
png_debug(1, "in png_create_write_struct\n");
|
450
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
451
|
+
png_ptr = (png_structp)png_create_struct_2(PNG_STRUCT_PNG,
|
452
|
+
(png_malloc_ptr)malloc_fn, (png_voidp)mem_ptr);
|
453
|
+
#else
|
454
|
+
png_ptr = (png_structp)png_create_struct(PNG_STRUCT_PNG);
|
455
|
+
#endif /* PNG_USER_MEM_SUPPORTED */
|
456
|
+
if (png_ptr == NULL)
|
457
|
+
return (NULL);
|
458
|
+
|
459
|
+
/* added at libpng-1.2.6 */
|
460
|
+
#ifdef PNG_SET_USER_LIMITS_SUPPORTED
|
461
|
+
png_ptr->user_width_max=PNG_USER_WIDTH_MAX;
|
462
|
+
png_ptr->user_height_max=PNG_USER_HEIGHT_MAX;
|
463
|
+
#endif
|
464
|
+
|
465
|
+
#ifdef PNG_SETJMP_SUPPORTED
|
466
|
+
#ifdef USE_FAR_KEYWORD
|
467
|
+
if (setjmp(jmpbuf))
|
468
|
+
#else
|
469
|
+
if (setjmp(png_ptr->jmpbuf))
|
470
|
+
#endif
|
471
|
+
{
|
472
|
+
png_free(png_ptr, png_ptr->zbuf);
|
473
|
+
png_ptr->zbuf=NULL;
|
474
|
+
png_destroy_struct(png_ptr);
|
475
|
+
return (NULL);
|
476
|
+
}
|
477
|
+
#ifdef USE_FAR_KEYWORD
|
478
|
+
png_memcpy(png_ptr->jmpbuf,jmpbuf,png_sizeof(jmp_buf));
|
479
|
+
#endif
|
480
|
+
#endif
|
481
|
+
|
482
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
483
|
+
png_set_mem_fn(png_ptr, mem_ptr, malloc_fn, free_fn);
|
484
|
+
#endif /* PNG_USER_MEM_SUPPORTED */
|
485
|
+
png_set_error_fn(png_ptr, error_ptr, error_fn, warn_fn);
|
486
|
+
|
487
|
+
if(user_png_ver)
|
488
|
+
{
|
489
|
+
i=0;
|
490
|
+
do
|
491
|
+
{
|
492
|
+
if(user_png_ver[i] != png_libpng_ver[i])
|
493
|
+
png_ptr->flags |= PNG_FLAG_LIBRARY_MISMATCH;
|
494
|
+
} while (png_libpng_ver[i++]);
|
495
|
+
}
|
496
|
+
|
497
|
+
if (png_ptr->flags & PNG_FLAG_LIBRARY_MISMATCH)
|
498
|
+
{
|
499
|
+
/* Libpng 0.90 and later are binary incompatible with libpng 0.89, so
|
500
|
+
* we must recompile any applications that use any older library version.
|
501
|
+
* For versions after libpng 1.0, we will be compatible, so we need
|
502
|
+
* only check the first digit.
|
503
|
+
*/
|
504
|
+
if (user_png_ver == NULL || user_png_ver[0] != png_libpng_ver[0] ||
|
505
|
+
(user_png_ver[0] == '1' && user_png_ver[2] != png_libpng_ver[2]) ||
|
506
|
+
(user_png_ver[0] == '0' && user_png_ver[2] < '9'))
|
507
|
+
{
|
508
|
+
#if !defined(PNG_NO_STDIO) && !defined(_WIN32_WCE)
|
509
|
+
char msg[80];
|
510
|
+
if (user_png_ver)
|
511
|
+
{
|
512
|
+
png_snprintf(msg, 80,
|
513
|
+
"Application was compiled with png.h from libpng-%.20s",
|
514
|
+
user_png_ver);
|
515
|
+
png_warning(png_ptr, msg);
|
516
|
+
}
|
517
|
+
png_snprintf(msg, 80,
|
518
|
+
"Application is running with png.c from libpng-%.20s",
|
519
|
+
png_libpng_ver);
|
520
|
+
png_warning(png_ptr, msg);
|
521
|
+
#endif
|
522
|
+
#ifdef PNG_ERROR_NUMBERS_SUPPORTED
|
523
|
+
png_ptr->flags=0;
|
524
|
+
#endif
|
525
|
+
png_error(png_ptr,
|
526
|
+
"Incompatible libpng version in application and library");
|
527
|
+
}
|
528
|
+
}
|
529
|
+
|
530
|
+
/* initialize zbuf - compression buffer */
|
531
|
+
png_ptr->zbuf_size = PNG_ZBUF_SIZE;
|
532
|
+
png_ptr->zbuf = (png_bytep)png_malloc(png_ptr,
|
533
|
+
(png_uint_32)png_ptr->zbuf_size);
|
534
|
+
|
535
|
+
png_set_write_fn(png_ptr, png_voidp_NULL, png_rw_ptr_NULL,
|
536
|
+
png_flush_ptr_NULL);
|
537
|
+
|
538
|
+
#if defined(PNG_WRITE_WEIGHTED_FILTER_SUPPORTED)
|
539
|
+
png_set_filter_heuristics(png_ptr, PNG_FILTER_HEURISTIC_DEFAULT,
|
540
|
+
1, png_doublep_NULL, png_doublep_NULL);
|
541
|
+
#endif
|
542
|
+
|
543
|
+
#ifdef PNG_SETJMP_SUPPORTED
|
544
|
+
/* Applications that neglect to set up their own setjmp() and then encounter
|
545
|
+
a png_error() will longjmp here. Since the jmpbuf is then meaningless we
|
546
|
+
abort instead of returning. */
|
547
|
+
#ifdef USE_FAR_KEYWORD
|
548
|
+
if (setjmp(jmpbuf))
|
549
|
+
PNG_ABORT();
|
550
|
+
png_memcpy(png_ptr->jmpbuf,jmpbuf,png_sizeof(jmp_buf));
|
551
|
+
#else
|
552
|
+
if (setjmp(png_ptr->jmpbuf))
|
553
|
+
PNG_ABORT();
|
554
|
+
#endif
|
555
|
+
#endif
|
556
|
+
return (png_ptr);
|
557
|
+
}
|
558
|
+
|
559
|
+
/* Initialize png_ptr structure, and allocate any memory needed */
|
560
|
+
#if defined(PNG_1_0_X) || defined(PNG_1_2_X)
|
561
|
+
/* Deprecated. */
|
562
|
+
#undef png_write_init
|
563
|
+
void PNGAPI
|
564
|
+
png_write_init(png_structp png_ptr)
|
565
|
+
{
|
566
|
+
/* We only come here via pre-1.0.7-compiled applications */
|
567
|
+
png_write_init_2(png_ptr, "1.0.6 or earlier", 0, 0);
|
568
|
+
}
|
569
|
+
|
570
|
+
void PNGAPI
|
571
|
+
png_write_init_2(png_structp png_ptr, png_const_charp user_png_ver,
|
572
|
+
png_size_t png_struct_size, png_size_t png_info_size)
|
573
|
+
{
|
574
|
+
/* We only come here via pre-1.0.12-compiled applications */
|
575
|
+
if(png_ptr == NULL) return;
|
576
|
+
#if !defined(PNG_NO_STDIO) && !defined(_WIN32_WCE)
|
577
|
+
if(png_sizeof(png_struct) > png_struct_size ||
|
578
|
+
png_sizeof(png_info) > png_info_size)
|
579
|
+
{
|
580
|
+
char msg[80];
|
581
|
+
png_ptr->warning_fn=NULL;
|
582
|
+
if (user_png_ver)
|
583
|
+
{
|
584
|
+
png_snprintf(msg, 80,
|
585
|
+
"Application was compiled with png.h from libpng-%.20s",
|
586
|
+
user_png_ver);
|
587
|
+
png_warning(png_ptr, msg);
|
588
|
+
}
|
589
|
+
png_snprintf(msg, 80,
|
590
|
+
"Application is running with png.c from libpng-%.20s",
|
591
|
+
png_libpng_ver);
|
592
|
+
png_warning(png_ptr, msg);
|
593
|
+
}
|
594
|
+
#endif
|
595
|
+
if(png_sizeof(png_struct) > png_struct_size)
|
596
|
+
{
|
597
|
+
png_ptr->error_fn=NULL;
|
598
|
+
#ifdef PNG_ERROR_NUMBERS_SUPPORTED
|
599
|
+
png_ptr->flags=0;
|
600
|
+
#endif
|
601
|
+
png_error(png_ptr,
|
602
|
+
"The png struct allocated by the application for writing is too small.");
|
603
|
+
}
|
604
|
+
if(png_sizeof(png_info) > png_info_size)
|
605
|
+
{
|
606
|
+
png_ptr->error_fn=NULL;
|
607
|
+
#ifdef PNG_ERROR_NUMBERS_SUPPORTED
|
608
|
+
png_ptr->flags=0;
|
609
|
+
#endif
|
610
|
+
png_error(png_ptr,
|
611
|
+
"The info struct allocated by the application for writing is too small.");
|
612
|
+
}
|
613
|
+
png_write_init_3(&png_ptr, user_png_ver, png_struct_size);
|
614
|
+
}
|
615
|
+
#endif /* PNG_1_0_X || PNG_1_2_X */
|
616
|
+
|
617
|
+
|
618
|
+
void PNGAPI
|
619
|
+
png_write_init_3(png_structpp ptr_ptr, png_const_charp user_png_ver,
|
620
|
+
png_size_t png_struct_size)
|
621
|
+
{
|
622
|
+
png_structp png_ptr=*ptr_ptr;
|
623
|
+
#ifdef PNG_SETJMP_SUPPORTED
|
624
|
+
jmp_buf tmp_jmp; /* to save current jump buffer */
|
625
|
+
#endif
|
626
|
+
|
627
|
+
int i = 0;
|
628
|
+
|
629
|
+
if (png_ptr == NULL)
|
630
|
+
return;
|
631
|
+
|
632
|
+
do
|
633
|
+
{
|
634
|
+
if (user_png_ver[i] != png_libpng_ver[i])
|
635
|
+
{
|
636
|
+
#ifdef PNG_LEGACY_SUPPORTED
|
637
|
+
png_ptr->flags |= PNG_FLAG_LIBRARY_MISMATCH;
|
638
|
+
#else
|
639
|
+
png_ptr->warning_fn=NULL;
|
640
|
+
png_warning(png_ptr,
|
641
|
+
"Application uses deprecated png_write_init() and should be recompiled.");
|
642
|
+
break;
|
643
|
+
#endif
|
644
|
+
}
|
645
|
+
} while (png_libpng_ver[i++]);
|
646
|
+
|
647
|
+
png_debug(1, "in png_write_init_3\n");
|
648
|
+
|
649
|
+
#ifdef PNG_SETJMP_SUPPORTED
|
650
|
+
/* save jump buffer and error functions */
|
651
|
+
png_memcpy(tmp_jmp, png_ptr->jmpbuf, png_sizeof (jmp_buf));
|
652
|
+
#endif
|
653
|
+
|
654
|
+
if (png_sizeof(png_struct) > png_struct_size)
|
655
|
+
{
|
656
|
+
png_destroy_struct(png_ptr);
|
657
|
+
png_ptr = (png_structp)png_create_struct(PNG_STRUCT_PNG);
|
658
|
+
*ptr_ptr = png_ptr;
|
659
|
+
}
|
660
|
+
|
661
|
+
/* reset all variables to 0 */
|
662
|
+
png_memset(png_ptr, 0, png_sizeof (png_struct));
|
663
|
+
|
664
|
+
/* added at libpng-1.2.6 */
|
665
|
+
#ifdef PNG_SET_USER_LIMITS_SUPPORTED
|
666
|
+
png_ptr->user_width_max=PNG_USER_WIDTH_MAX;
|
667
|
+
png_ptr->user_height_max=PNG_USER_HEIGHT_MAX;
|
668
|
+
#endif
|
669
|
+
|
670
|
+
#ifdef PNG_SETJMP_SUPPORTED
|
671
|
+
/* restore jump buffer */
|
672
|
+
png_memcpy(png_ptr->jmpbuf, tmp_jmp, png_sizeof (jmp_buf));
|
673
|
+
#endif
|
674
|
+
|
675
|
+
png_set_write_fn(png_ptr, png_voidp_NULL, png_rw_ptr_NULL,
|
676
|
+
png_flush_ptr_NULL);
|
677
|
+
|
678
|
+
/* initialize zbuf - compression buffer */
|
679
|
+
png_ptr->zbuf_size = PNG_ZBUF_SIZE;
|
680
|
+
png_ptr->zbuf = (png_bytep)png_malloc(png_ptr,
|
681
|
+
(png_uint_32)png_ptr->zbuf_size);
|
682
|
+
|
683
|
+
#if defined(PNG_WRITE_WEIGHTED_FILTER_SUPPORTED)
|
684
|
+
png_set_filter_heuristics(png_ptr, PNG_FILTER_HEURISTIC_DEFAULT,
|
685
|
+
1, png_doublep_NULL, png_doublep_NULL);
|
686
|
+
#endif
|
687
|
+
}
|
688
|
+
|
689
|
+
/* Write a few rows of image data. If the image is interlaced,
|
690
|
+
* either you will have to write the 7 sub images, or, if you
|
691
|
+
* have called png_set_interlace_handling(), you will have to
|
692
|
+
* "write" the image seven times.
|
693
|
+
*/
|
694
|
+
void PNGAPI
|
695
|
+
png_write_rows(png_structp png_ptr, png_bytepp row,
|
696
|
+
png_uint_32 num_rows)
|
697
|
+
{
|
698
|
+
png_uint_32 i; /* row counter */
|
699
|
+
png_bytepp rp; /* row pointer */
|
700
|
+
|
701
|
+
png_debug(1, "in png_write_rows\n");
|
702
|
+
|
703
|
+
if (png_ptr == NULL)
|
704
|
+
return;
|
705
|
+
|
706
|
+
/* loop through the rows */
|
707
|
+
for (i = 0, rp = row; i < num_rows; i++, rp++)
|
708
|
+
{
|
709
|
+
png_write_row(png_ptr, *rp);
|
710
|
+
}
|
711
|
+
}
|
712
|
+
|
713
|
+
/* Write the image. You only need to call this function once, even
|
714
|
+
* if you are writing an interlaced image.
|
715
|
+
*/
|
716
|
+
void PNGAPI
|
717
|
+
png_write_image(png_structp png_ptr, png_bytepp image)
|
718
|
+
{
|
719
|
+
png_uint_32 i; /* row index */
|
720
|
+
int pass, num_pass; /* pass variables */
|
721
|
+
png_bytepp rp; /* points to current row */
|
722
|
+
|
723
|
+
if (png_ptr == NULL)
|
724
|
+
return;
|
725
|
+
|
726
|
+
png_debug(1, "in png_write_image\n");
|
727
|
+
#if defined(PNG_WRITE_INTERLACING_SUPPORTED)
|
728
|
+
/* intialize interlace handling. If image is not interlaced,
|
729
|
+
this will set pass to 1 */
|
730
|
+
num_pass = png_set_interlace_handling(png_ptr);
|
731
|
+
#else
|
732
|
+
num_pass = 1;
|
733
|
+
#endif
|
734
|
+
/* loop through passes */
|
735
|
+
for (pass = 0; pass < num_pass; pass++)
|
736
|
+
{
|
737
|
+
/* loop through image */
|
738
|
+
for (i = 0, rp = image; i < png_ptr->height; i++, rp++)
|
739
|
+
{
|
740
|
+
png_write_row(png_ptr, *rp);
|
741
|
+
}
|
742
|
+
}
|
743
|
+
}
|
744
|
+
|
745
|
+
/* called by user to write a row of image data */
|
746
|
+
void PNGAPI
|
747
|
+
png_write_row(png_structp png_ptr, png_bytep row)
|
748
|
+
{
|
749
|
+
if (png_ptr == NULL)
|
750
|
+
return;
|
751
|
+
png_debug2(1, "in png_write_row (row %ld, pass %d)\n",
|
752
|
+
png_ptr->row_number, png_ptr->pass);
|
753
|
+
|
754
|
+
/* initialize transformations and other stuff if first time */
|
755
|
+
if (png_ptr->row_number == 0 && png_ptr->pass == 0)
|
756
|
+
{
|
757
|
+
/* make sure we wrote the header info */
|
758
|
+
if (!(png_ptr->mode & PNG_WROTE_INFO_BEFORE_PLTE))
|
759
|
+
png_error(png_ptr,
|
760
|
+
"png_write_info was never called before png_write_row.");
|
761
|
+
|
762
|
+
/* check for transforms that have been set but were defined out */
|
763
|
+
#if !defined(PNG_WRITE_INVERT_SUPPORTED) && defined(PNG_READ_INVERT_SUPPORTED)
|
764
|
+
if (png_ptr->transformations & PNG_INVERT_MONO)
|
765
|
+
png_warning(png_ptr, "PNG_WRITE_INVERT_SUPPORTED is not defined.");
|
766
|
+
#endif
|
767
|
+
#if !defined(PNG_WRITE_FILLER_SUPPORTED) && defined(PNG_READ_FILLER_SUPPORTED)
|
768
|
+
if (png_ptr->transformations & PNG_FILLER)
|
769
|
+
png_warning(png_ptr, "PNG_WRITE_FILLER_SUPPORTED is not defined.");
|
770
|
+
#endif
|
771
|
+
#if !defined(PNG_WRITE_PACKSWAP_SUPPORTED) && defined(PNG_READ_PACKSWAP_SUPPORTED)
|
772
|
+
if (png_ptr->transformations & PNG_PACKSWAP)
|
773
|
+
png_warning(png_ptr, "PNG_WRITE_PACKSWAP_SUPPORTED is not defined.");
|
774
|
+
#endif
|
775
|
+
#if !defined(PNG_WRITE_PACK_SUPPORTED) && defined(PNG_READ_PACK_SUPPORTED)
|
776
|
+
if (png_ptr->transformations & PNG_PACK)
|
777
|
+
png_warning(png_ptr, "PNG_WRITE_PACK_SUPPORTED is not defined.");
|
778
|
+
#endif
|
779
|
+
#if !defined(PNG_WRITE_SHIFT_SUPPORTED) && defined(PNG_READ_SHIFT_SUPPORTED)
|
780
|
+
if (png_ptr->transformations & PNG_SHIFT)
|
781
|
+
png_warning(png_ptr, "PNG_WRITE_SHIFT_SUPPORTED is not defined.");
|
782
|
+
#endif
|
783
|
+
#if !defined(PNG_WRITE_BGR_SUPPORTED) && defined(PNG_READ_BGR_SUPPORTED)
|
784
|
+
if (png_ptr->transformations & PNG_BGR)
|
785
|
+
png_warning(png_ptr, "PNG_WRITE_BGR_SUPPORTED is not defined.");
|
786
|
+
#endif
|
787
|
+
#if !defined(PNG_WRITE_SWAP_SUPPORTED) && defined(PNG_READ_SWAP_SUPPORTED)
|
788
|
+
if (png_ptr->transformations & PNG_SWAP_BYTES)
|
789
|
+
png_warning(png_ptr, "PNG_WRITE_SWAP_SUPPORTED is not defined.");
|
790
|
+
#endif
|
791
|
+
|
792
|
+
png_write_start_row(png_ptr);
|
793
|
+
}
|
794
|
+
|
795
|
+
#if defined(PNG_WRITE_INTERLACING_SUPPORTED)
|
796
|
+
/* if interlaced and not interested in row, return */
|
797
|
+
if (png_ptr->interlaced && (png_ptr->transformations & PNG_INTERLACE))
|
798
|
+
{
|
799
|
+
switch (png_ptr->pass)
|
800
|
+
{
|
801
|
+
case 0:
|
802
|
+
if (png_ptr->row_number & 0x07)
|
803
|
+
{
|
804
|
+
png_write_finish_row(png_ptr);
|
805
|
+
return;
|
806
|
+
}
|
807
|
+
break;
|
808
|
+
case 1:
|
809
|
+
if ((png_ptr->row_number & 0x07) || png_ptr->width < 5)
|
810
|
+
{
|
811
|
+
png_write_finish_row(png_ptr);
|
812
|
+
return;
|
813
|
+
}
|
814
|
+
break;
|
815
|
+
case 2:
|
816
|
+
if ((png_ptr->row_number & 0x07) != 4)
|
817
|
+
{
|
818
|
+
png_write_finish_row(png_ptr);
|
819
|
+
return;
|
820
|
+
}
|
821
|
+
break;
|
822
|
+
case 3:
|
823
|
+
if ((png_ptr->row_number & 0x03) || png_ptr->width < 3)
|
824
|
+
{
|
825
|
+
png_write_finish_row(png_ptr);
|
826
|
+
return;
|
827
|
+
}
|
828
|
+
break;
|
829
|
+
case 4:
|
830
|
+
if ((png_ptr->row_number & 0x03) != 2)
|
831
|
+
{
|
832
|
+
png_write_finish_row(png_ptr);
|
833
|
+
return;
|
834
|
+
}
|
835
|
+
break;
|
836
|
+
case 5:
|
837
|
+
if ((png_ptr->row_number & 0x01) || png_ptr->width < 2)
|
838
|
+
{
|
839
|
+
png_write_finish_row(png_ptr);
|
840
|
+
return;
|
841
|
+
}
|
842
|
+
break;
|
843
|
+
case 6:
|
844
|
+
if (!(png_ptr->row_number & 0x01))
|
845
|
+
{
|
846
|
+
png_write_finish_row(png_ptr);
|
847
|
+
return;
|
848
|
+
}
|
849
|
+
break;
|
850
|
+
}
|
851
|
+
}
|
852
|
+
#endif
|
853
|
+
|
854
|
+
/* set up row info for transformations */
|
855
|
+
png_ptr->row_info.color_type = png_ptr->color_type;
|
856
|
+
png_ptr->row_info.width = png_ptr->usr_width;
|
857
|
+
png_ptr->row_info.channels = png_ptr->usr_channels;
|
858
|
+
png_ptr->row_info.bit_depth = png_ptr->usr_bit_depth;
|
859
|
+
png_ptr->row_info.pixel_depth = (png_byte)(png_ptr->row_info.bit_depth *
|
860
|
+
png_ptr->row_info.channels);
|
861
|
+
|
862
|
+
png_ptr->row_info.rowbytes = PNG_ROWBYTES(png_ptr->row_info.pixel_depth,
|
863
|
+
png_ptr->row_info.width);
|
864
|
+
|
865
|
+
png_debug1(3, "row_info->color_type = %d\n", png_ptr->row_info.color_type);
|
866
|
+
png_debug1(3, "row_info->width = %lu\n", png_ptr->row_info.width);
|
867
|
+
png_debug1(3, "row_info->channels = %d\n", png_ptr->row_info.channels);
|
868
|
+
png_debug1(3, "row_info->bit_depth = %d\n", png_ptr->row_info.bit_depth);
|
869
|
+
png_debug1(3, "row_info->pixel_depth = %d\n", png_ptr->row_info.pixel_depth);
|
870
|
+
png_debug1(3, "row_info->rowbytes = %lu\n", png_ptr->row_info.rowbytes);
|
871
|
+
|
872
|
+
/* Copy user's row into buffer, leaving room for filter byte. */
|
873
|
+
png_memcpy_check(png_ptr, png_ptr->row_buf + 1, row,
|
874
|
+
png_ptr->row_info.rowbytes);
|
875
|
+
|
876
|
+
#if defined(PNG_WRITE_INTERLACING_SUPPORTED)
|
877
|
+
/* handle interlacing */
|
878
|
+
if (png_ptr->interlaced && png_ptr->pass < 6 &&
|
879
|
+
(png_ptr->transformations & PNG_INTERLACE))
|
880
|
+
{
|
881
|
+
png_do_write_interlace(&(png_ptr->row_info),
|
882
|
+
png_ptr->row_buf + 1, png_ptr->pass);
|
883
|
+
/* this should always get caught above, but still ... */
|
884
|
+
if (!(png_ptr->row_info.width))
|
885
|
+
{
|
886
|
+
png_write_finish_row(png_ptr);
|
887
|
+
return;
|
888
|
+
}
|
889
|
+
}
|
890
|
+
#endif
|
891
|
+
|
892
|
+
/* handle other transformations */
|
893
|
+
if (png_ptr->transformations)
|
894
|
+
png_do_write_transformations(png_ptr);
|
895
|
+
|
896
|
+
#if defined(PNG_MNG_FEATURES_SUPPORTED)
|
897
|
+
/* Write filter_method 64 (intrapixel differencing) only if
|
898
|
+
* 1. Libpng was compiled with PNG_MNG_FEATURES_SUPPORTED and
|
899
|
+
* 2. Libpng did not write a PNG signature (this filter_method is only
|
900
|
+
* used in PNG datastreams that are embedded in MNG datastreams) and
|
901
|
+
* 3. The application called png_permit_mng_features with a mask that
|
902
|
+
* included PNG_FLAG_MNG_FILTER_64 and
|
903
|
+
* 4. The filter_method is 64 and
|
904
|
+
* 5. The color_type is RGB or RGBA
|
905
|
+
*/
|
906
|
+
if((png_ptr->mng_features_permitted & PNG_FLAG_MNG_FILTER_64) &&
|
907
|
+
(png_ptr->filter_type == PNG_INTRAPIXEL_DIFFERENCING))
|
908
|
+
{
|
909
|
+
/* Intrapixel differencing */
|
910
|
+
png_do_write_intrapixel(&(png_ptr->row_info), png_ptr->row_buf + 1);
|
911
|
+
}
|
912
|
+
#endif
|
913
|
+
|
914
|
+
/* Find a filter if necessary, filter the row and write it out. */
|
915
|
+
png_write_find_filter(png_ptr, &(png_ptr->row_info));
|
916
|
+
|
917
|
+
if (png_ptr->write_row_fn != NULL)
|
918
|
+
(*(png_ptr->write_row_fn))(png_ptr, png_ptr->row_number, png_ptr->pass);
|
919
|
+
}
|
920
|
+
|
921
|
+
#if defined(PNG_WRITE_FLUSH_SUPPORTED)
|
922
|
+
/* Set the automatic flush interval or 0 to turn flushing off */
|
923
|
+
void PNGAPI
|
924
|
+
png_set_flush(png_structp png_ptr, int nrows)
|
925
|
+
{
|
926
|
+
png_debug(1, "in png_set_flush\n");
|
927
|
+
if (png_ptr == NULL)
|
928
|
+
return;
|
929
|
+
png_ptr->flush_dist = (nrows < 0 ? 0 : nrows);
|
930
|
+
}
|
931
|
+
|
932
|
+
/* flush the current output buffers now */
|
933
|
+
void PNGAPI
|
934
|
+
png_write_flush(png_structp png_ptr)
|
935
|
+
{
|
936
|
+
int wrote_IDAT;
|
937
|
+
|
938
|
+
png_debug(1, "in png_write_flush\n");
|
939
|
+
if (png_ptr == NULL)
|
940
|
+
return;
|
941
|
+
/* We have already written out all of the data */
|
942
|
+
if (png_ptr->row_number >= png_ptr->num_rows)
|
943
|
+
return;
|
944
|
+
|
945
|
+
do
|
946
|
+
{
|
947
|
+
int ret;
|
948
|
+
|
949
|
+
/* compress the data */
|
950
|
+
ret = deflate(&png_ptr->zstream, Z_SYNC_FLUSH);
|
951
|
+
wrote_IDAT = 0;
|
952
|
+
|
953
|
+
/* check for compression errors */
|
954
|
+
if (ret != Z_OK)
|
955
|
+
{
|
956
|
+
if (png_ptr->zstream.msg != NULL)
|
957
|
+
png_error(png_ptr, png_ptr->zstream.msg);
|
958
|
+
else
|
959
|
+
png_error(png_ptr, "zlib error");
|
960
|
+
}
|
961
|
+
|
962
|
+
if (!(png_ptr->zstream.avail_out))
|
963
|
+
{
|
964
|
+
/* write the IDAT and reset the zlib output buffer */
|
965
|
+
png_write_IDAT(png_ptr, png_ptr->zbuf,
|
966
|
+
png_ptr->zbuf_size);
|
967
|
+
png_ptr->zstream.next_out = png_ptr->zbuf;
|
968
|
+
png_ptr->zstream.avail_out = (uInt)png_ptr->zbuf_size;
|
969
|
+
wrote_IDAT = 1;
|
970
|
+
}
|
971
|
+
} while(wrote_IDAT == 1);
|
972
|
+
|
973
|
+
/* If there is any data left to be output, write it into a new IDAT */
|
974
|
+
if (png_ptr->zbuf_size != png_ptr->zstream.avail_out)
|
975
|
+
{
|
976
|
+
/* write the IDAT and reset the zlib output buffer */
|
977
|
+
png_write_IDAT(png_ptr, png_ptr->zbuf,
|
978
|
+
png_ptr->zbuf_size - png_ptr->zstream.avail_out);
|
979
|
+
png_ptr->zstream.next_out = png_ptr->zbuf;
|
980
|
+
png_ptr->zstream.avail_out = (uInt)png_ptr->zbuf_size;
|
981
|
+
}
|
982
|
+
png_ptr->flush_rows = 0;
|
983
|
+
png_flush(png_ptr);
|
984
|
+
}
|
985
|
+
#endif /* PNG_WRITE_FLUSH_SUPPORTED */
|
986
|
+
|
987
|
+
/* free all memory used by the write */
|
988
|
+
void PNGAPI
|
989
|
+
png_destroy_write_struct(png_structpp png_ptr_ptr, png_infopp info_ptr_ptr)
|
990
|
+
{
|
991
|
+
png_structp png_ptr = NULL;
|
992
|
+
png_infop info_ptr = NULL;
|
993
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
994
|
+
png_free_ptr free_fn = NULL;
|
995
|
+
png_voidp mem_ptr = NULL;
|
996
|
+
#endif
|
997
|
+
|
998
|
+
png_debug(1, "in png_destroy_write_struct\n");
|
999
|
+
if (png_ptr_ptr != NULL)
|
1000
|
+
{
|
1001
|
+
png_ptr = *png_ptr_ptr;
|
1002
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
1003
|
+
free_fn = png_ptr->free_fn;
|
1004
|
+
mem_ptr = png_ptr->mem_ptr;
|
1005
|
+
#endif
|
1006
|
+
}
|
1007
|
+
|
1008
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
1009
|
+
if (png_ptr != NULL)
|
1010
|
+
{
|
1011
|
+
free_fn = png_ptr->free_fn;
|
1012
|
+
mem_ptr = png_ptr->mem_ptr;
|
1013
|
+
}
|
1014
|
+
#endif
|
1015
|
+
|
1016
|
+
if (info_ptr_ptr != NULL)
|
1017
|
+
info_ptr = *info_ptr_ptr;
|
1018
|
+
|
1019
|
+
if (info_ptr != NULL)
|
1020
|
+
{
|
1021
|
+
if (png_ptr != NULL)
|
1022
|
+
{
|
1023
|
+
png_free_data(png_ptr, info_ptr, PNG_FREE_ALL, -1);
|
1024
|
+
|
1025
|
+
#if defined(PNG_UNKNOWN_CHUNKS_SUPPORTED)
|
1026
|
+
if (png_ptr->num_chunk_list)
|
1027
|
+
{
|
1028
|
+
png_free(png_ptr, png_ptr->chunk_list);
|
1029
|
+
png_ptr->chunk_list=NULL;
|
1030
|
+
png_ptr->num_chunk_list=0;
|
1031
|
+
}
|
1032
|
+
#endif
|
1033
|
+
}
|
1034
|
+
|
1035
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
1036
|
+
png_destroy_struct_2((png_voidp)info_ptr, (png_free_ptr)free_fn,
|
1037
|
+
(png_voidp)mem_ptr);
|
1038
|
+
#else
|
1039
|
+
png_destroy_struct((png_voidp)info_ptr);
|
1040
|
+
#endif
|
1041
|
+
*info_ptr_ptr = NULL;
|
1042
|
+
}
|
1043
|
+
|
1044
|
+
if (png_ptr != NULL)
|
1045
|
+
{
|
1046
|
+
png_write_destroy(png_ptr);
|
1047
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
1048
|
+
png_destroy_struct_2((png_voidp)png_ptr, (png_free_ptr)free_fn,
|
1049
|
+
(png_voidp)mem_ptr);
|
1050
|
+
#else
|
1051
|
+
png_destroy_struct((png_voidp)png_ptr);
|
1052
|
+
#endif
|
1053
|
+
*png_ptr_ptr = NULL;
|
1054
|
+
}
|
1055
|
+
}
|
1056
|
+
|
1057
|
+
|
1058
|
+
/* Free any memory used in png_ptr struct (old method) */
|
1059
|
+
void /* PRIVATE */
|
1060
|
+
png_write_destroy(png_structp png_ptr)
|
1061
|
+
{
|
1062
|
+
#ifdef PNG_SETJMP_SUPPORTED
|
1063
|
+
jmp_buf tmp_jmp; /* save jump buffer */
|
1064
|
+
#endif
|
1065
|
+
png_error_ptr error_fn;
|
1066
|
+
png_error_ptr warning_fn;
|
1067
|
+
png_voidp error_ptr;
|
1068
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
1069
|
+
png_free_ptr free_fn;
|
1070
|
+
#endif
|
1071
|
+
|
1072
|
+
png_debug(1, "in png_write_destroy\n");
|
1073
|
+
/* free any memory zlib uses */
|
1074
|
+
deflateEnd(&png_ptr->zstream);
|
1075
|
+
|
1076
|
+
/* free our memory. png_free checks NULL for us. */
|
1077
|
+
png_free(png_ptr, png_ptr->zbuf);
|
1078
|
+
png_free(png_ptr, png_ptr->row_buf);
|
1079
|
+
#ifndef PNG_NO_WRITE_FILTERING
|
1080
|
+
png_free(png_ptr, png_ptr->prev_row);
|
1081
|
+
png_free(png_ptr, png_ptr->sub_row);
|
1082
|
+
png_free(png_ptr, png_ptr->up_row);
|
1083
|
+
png_free(png_ptr, png_ptr->avg_row);
|
1084
|
+
png_free(png_ptr, png_ptr->paeth_row);
|
1085
|
+
#endif
|
1086
|
+
|
1087
|
+
#if defined(PNG_TIME_RFC1123_SUPPORTED)
|
1088
|
+
png_free(png_ptr, png_ptr->time_buffer);
|
1089
|
+
#endif
|
1090
|
+
|
1091
|
+
#if defined(PNG_WRITE_WEIGHTED_FILTER_SUPPORTED)
|
1092
|
+
png_free(png_ptr, png_ptr->prev_filters);
|
1093
|
+
png_free(png_ptr, png_ptr->filter_weights);
|
1094
|
+
png_free(png_ptr, png_ptr->inv_filter_weights);
|
1095
|
+
png_free(png_ptr, png_ptr->filter_costs);
|
1096
|
+
png_free(png_ptr, png_ptr->inv_filter_costs);
|
1097
|
+
#endif
|
1098
|
+
|
1099
|
+
#ifdef PNG_SETJMP_SUPPORTED
|
1100
|
+
/* reset structure */
|
1101
|
+
png_memcpy(tmp_jmp, png_ptr->jmpbuf, png_sizeof (jmp_buf));
|
1102
|
+
#endif
|
1103
|
+
|
1104
|
+
error_fn = png_ptr->error_fn;
|
1105
|
+
warning_fn = png_ptr->warning_fn;
|
1106
|
+
error_ptr = png_ptr->error_ptr;
|
1107
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
1108
|
+
free_fn = png_ptr->free_fn;
|
1109
|
+
#endif
|
1110
|
+
|
1111
|
+
png_memset(png_ptr, 0, png_sizeof (png_struct));
|
1112
|
+
|
1113
|
+
png_ptr->error_fn = error_fn;
|
1114
|
+
png_ptr->warning_fn = warning_fn;
|
1115
|
+
png_ptr->error_ptr = error_ptr;
|
1116
|
+
#ifdef PNG_USER_MEM_SUPPORTED
|
1117
|
+
png_ptr->free_fn = free_fn;
|
1118
|
+
#endif
|
1119
|
+
|
1120
|
+
#ifdef PNG_SETJMP_SUPPORTED
|
1121
|
+
png_memcpy(png_ptr->jmpbuf, tmp_jmp, png_sizeof (jmp_buf));
|
1122
|
+
#endif
|
1123
|
+
}
|
1124
|
+
|
1125
|
+
/* Allow the application to select one or more row filters to use. */
|
1126
|
+
void PNGAPI
|
1127
|
+
png_set_filter(png_structp png_ptr, int method, int filters)
|
1128
|
+
{
|
1129
|
+
png_debug(1, "in png_set_filter\n");
|
1130
|
+
if (png_ptr == NULL)
|
1131
|
+
return;
|
1132
|
+
#if defined(PNG_MNG_FEATURES_SUPPORTED)
|
1133
|
+
if((png_ptr->mng_features_permitted & PNG_FLAG_MNG_FILTER_64) &&
|
1134
|
+
(method == PNG_INTRAPIXEL_DIFFERENCING))
|
1135
|
+
method = PNG_FILTER_TYPE_BASE;
|
1136
|
+
#endif
|
1137
|
+
if (method == PNG_FILTER_TYPE_BASE)
|
1138
|
+
{
|
1139
|
+
switch (filters & (PNG_ALL_FILTERS | 0x07))
|
1140
|
+
{
|
1141
|
+
#ifndef PNG_NO_WRITE_FILTER
|
1142
|
+
case 5:
|
1143
|
+
case 6:
|
1144
|
+
case 7: png_warning(png_ptr, "Unknown row filter for method 0");
|
1145
|
+
#endif /* PNG_NO_WRITE_FILTER */
|
1146
|
+
case PNG_FILTER_VALUE_NONE:
|
1147
|
+
png_ptr->do_filter=PNG_FILTER_NONE; break;
|
1148
|
+
#ifndef PNG_NO_WRITE_FILTER
|
1149
|
+
case PNG_FILTER_VALUE_SUB:
|
1150
|
+
png_ptr->do_filter=PNG_FILTER_SUB; break;
|
1151
|
+
case PNG_FILTER_VALUE_UP:
|
1152
|
+
png_ptr->do_filter=PNG_FILTER_UP; break;
|
1153
|
+
case PNG_FILTER_VALUE_AVG:
|
1154
|
+
png_ptr->do_filter=PNG_FILTER_AVG; break;
|
1155
|
+
case PNG_FILTER_VALUE_PAETH:
|
1156
|
+
png_ptr->do_filter=PNG_FILTER_PAETH; break;
|
1157
|
+
default: png_ptr->do_filter = (png_byte)filters; break;
|
1158
|
+
#else
|
1159
|
+
default: png_warning(png_ptr, "Unknown row filter for method 0");
|
1160
|
+
#endif /* PNG_NO_WRITE_FILTER */
|
1161
|
+
}
|
1162
|
+
|
1163
|
+
/* If we have allocated the row_buf, this means we have already started
|
1164
|
+
* with the image and we should have allocated all of the filter buffers
|
1165
|
+
* that have been selected. If prev_row isn't already allocated, then
|
1166
|
+
* it is too late to start using the filters that need it, since we
|
1167
|
+
* will be missing the data in the previous row. If an application
|
1168
|
+
* wants to start and stop using particular filters during compression,
|
1169
|
+
* it should start out with all of the filters, and then add and
|
1170
|
+
* remove them after the start of compression.
|
1171
|
+
*/
|
1172
|
+
if (png_ptr->row_buf != NULL)
|
1173
|
+
{
|
1174
|
+
#ifndef PNG_NO_WRITE_FILTER
|
1175
|
+
if ((png_ptr->do_filter & PNG_FILTER_SUB) && png_ptr->sub_row == NULL)
|
1176
|
+
{
|
1177
|
+
png_ptr->sub_row = (png_bytep)png_malloc(png_ptr,
|
1178
|
+
(png_ptr->rowbytes + 1));
|
1179
|
+
png_ptr->sub_row[0] = PNG_FILTER_VALUE_SUB;
|
1180
|
+
}
|
1181
|
+
|
1182
|
+
if ((png_ptr->do_filter & PNG_FILTER_UP) && png_ptr->up_row == NULL)
|
1183
|
+
{
|
1184
|
+
if (png_ptr->prev_row == NULL)
|
1185
|
+
{
|
1186
|
+
png_warning(png_ptr, "Can't add Up filter after starting");
|
1187
|
+
png_ptr->do_filter &= ~PNG_FILTER_UP;
|
1188
|
+
}
|
1189
|
+
else
|
1190
|
+
{
|
1191
|
+
png_ptr->up_row = (png_bytep)png_malloc(png_ptr,
|
1192
|
+
(png_ptr->rowbytes + 1));
|
1193
|
+
png_ptr->up_row[0] = PNG_FILTER_VALUE_UP;
|
1194
|
+
}
|
1195
|
+
}
|
1196
|
+
|
1197
|
+
if ((png_ptr->do_filter & PNG_FILTER_AVG) && png_ptr->avg_row == NULL)
|
1198
|
+
{
|
1199
|
+
if (png_ptr->prev_row == NULL)
|
1200
|
+
{
|
1201
|
+
png_warning(png_ptr, "Can't add Average filter after starting");
|
1202
|
+
png_ptr->do_filter &= ~PNG_FILTER_AVG;
|
1203
|
+
}
|
1204
|
+
else
|
1205
|
+
{
|
1206
|
+
png_ptr->avg_row = (png_bytep)png_malloc(png_ptr,
|
1207
|
+
(png_ptr->rowbytes + 1));
|
1208
|
+
png_ptr->avg_row[0] = PNG_FILTER_VALUE_AVG;
|
1209
|
+
}
|
1210
|
+
}
|
1211
|
+
|
1212
|
+
if ((png_ptr->do_filter & PNG_FILTER_PAETH) &&
|
1213
|
+
png_ptr->paeth_row == NULL)
|
1214
|
+
{
|
1215
|
+
if (png_ptr->prev_row == NULL)
|
1216
|
+
{
|
1217
|
+
png_warning(png_ptr, "Can't add Paeth filter after starting");
|
1218
|
+
png_ptr->do_filter &= (png_byte)(~PNG_FILTER_PAETH);
|
1219
|
+
}
|
1220
|
+
else
|
1221
|
+
{
|
1222
|
+
png_ptr->paeth_row = (png_bytep)png_malloc(png_ptr,
|
1223
|
+
(png_ptr->rowbytes + 1));
|
1224
|
+
png_ptr->paeth_row[0] = PNG_FILTER_VALUE_PAETH;
|
1225
|
+
}
|
1226
|
+
}
|
1227
|
+
|
1228
|
+
if (png_ptr->do_filter == PNG_NO_FILTERS)
|
1229
|
+
#endif /* PNG_NO_WRITE_FILTER */
|
1230
|
+
png_ptr->do_filter = PNG_FILTER_NONE;
|
1231
|
+
}
|
1232
|
+
}
|
1233
|
+
else
|
1234
|
+
png_error(png_ptr, "Unknown custom filter method");
|
1235
|
+
}
|
1236
|
+
|
1237
|
+
/* This allows us to influence the way in which libpng chooses the "best"
|
1238
|
+
* filter for the current scanline. While the "minimum-sum-of-absolute-
|
1239
|
+
* differences metric is relatively fast and effective, there is some
|
1240
|
+
* question as to whether it can be improved upon by trying to keep the
|
1241
|
+
* filtered data going to zlib more consistent, hopefully resulting in
|
1242
|
+
* better compression.
|
1243
|
+
*/
|
1244
|
+
#if defined(PNG_WRITE_WEIGHTED_FILTER_SUPPORTED) /* GRR 970116 */
|
1245
|
+
void PNGAPI
|
1246
|
+
png_set_filter_heuristics(png_structp png_ptr, int heuristic_method,
|
1247
|
+
int num_weights, png_doublep filter_weights,
|
1248
|
+
png_doublep filter_costs)
|
1249
|
+
{
|
1250
|
+
int i;
|
1251
|
+
|
1252
|
+
png_debug(1, "in png_set_filter_heuristics\n");
|
1253
|
+
if (png_ptr == NULL)
|
1254
|
+
return;
|
1255
|
+
if (heuristic_method >= PNG_FILTER_HEURISTIC_LAST)
|
1256
|
+
{
|
1257
|
+
png_warning(png_ptr, "Unknown filter heuristic method");
|
1258
|
+
return;
|
1259
|
+
}
|
1260
|
+
|
1261
|
+
if (heuristic_method == PNG_FILTER_HEURISTIC_DEFAULT)
|
1262
|
+
{
|
1263
|
+
heuristic_method = PNG_FILTER_HEURISTIC_UNWEIGHTED;
|
1264
|
+
}
|
1265
|
+
|
1266
|
+
if (num_weights < 0 || filter_weights == NULL ||
|
1267
|
+
heuristic_method == PNG_FILTER_HEURISTIC_UNWEIGHTED)
|
1268
|
+
{
|
1269
|
+
num_weights = 0;
|
1270
|
+
}
|
1271
|
+
|
1272
|
+
png_ptr->num_prev_filters = (png_byte)num_weights;
|
1273
|
+
png_ptr->heuristic_method = (png_byte)heuristic_method;
|
1274
|
+
|
1275
|
+
if (num_weights > 0)
|
1276
|
+
{
|
1277
|
+
if (png_ptr->prev_filters == NULL)
|
1278
|
+
{
|
1279
|
+
png_ptr->prev_filters = (png_bytep)png_malloc(png_ptr,
|
1280
|
+
(png_uint_32)(png_sizeof(png_byte) * num_weights));
|
1281
|
+
|
1282
|
+
/* To make sure that the weighting starts out fairly */
|
1283
|
+
for (i = 0; i < num_weights; i++)
|
1284
|
+
{
|
1285
|
+
png_ptr->prev_filters[i] = 255;
|
1286
|
+
}
|
1287
|
+
}
|
1288
|
+
|
1289
|
+
if (png_ptr->filter_weights == NULL)
|
1290
|
+
{
|
1291
|
+
png_ptr->filter_weights = (png_uint_16p)png_malloc(png_ptr,
|
1292
|
+
(png_uint_32)(png_sizeof(png_uint_16) * num_weights));
|
1293
|
+
|
1294
|
+
png_ptr->inv_filter_weights = (png_uint_16p)png_malloc(png_ptr,
|
1295
|
+
(png_uint_32)(png_sizeof(png_uint_16) * num_weights));
|
1296
|
+
for (i = 0; i < num_weights; i++)
|
1297
|
+
{
|
1298
|
+
png_ptr->inv_filter_weights[i] =
|
1299
|
+
png_ptr->filter_weights[i] = PNG_WEIGHT_FACTOR;
|
1300
|
+
}
|
1301
|
+
}
|
1302
|
+
|
1303
|
+
for (i = 0; i < num_weights; i++)
|
1304
|
+
{
|
1305
|
+
if (filter_weights[i] < 0.0)
|
1306
|
+
{
|
1307
|
+
png_ptr->inv_filter_weights[i] =
|
1308
|
+
png_ptr->filter_weights[i] = PNG_WEIGHT_FACTOR;
|
1309
|
+
}
|
1310
|
+
else
|
1311
|
+
{
|
1312
|
+
png_ptr->inv_filter_weights[i] =
|
1313
|
+
(png_uint_16)((double)PNG_WEIGHT_FACTOR*filter_weights[i]+0.5);
|
1314
|
+
png_ptr->filter_weights[i] =
|
1315
|
+
(png_uint_16)((double)PNG_WEIGHT_FACTOR/filter_weights[i]+0.5);
|
1316
|
+
}
|
1317
|
+
}
|
1318
|
+
}
|
1319
|
+
|
1320
|
+
/* If, in the future, there are other filter methods, this would
|
1321
|
+
* need to be based on png_ptr->filter.
|
1322
|
+
*/
|
1323
|
+
if (png_ptr->filter_costs == NULL)
|
1324
|
+
{
|
1325
|
+
png_ptr->filter_costs = (png_uint_16p)png_malloc(png_ptr,
|
1326
|
+
(png_uint_32)(png_sizeof(png_uint_16) * PNG_FILTER_VALUE_LAST));
|
1327
|
+
|
1328
|
+
png_ptr->inv_filter_costs = (png_uint_16p)png_malloc(png_ptr,
|
1329
|
+
(png_uint_32)(png_sizeof(png_uint_16) * PNG_FILTER_VALUE_LAST));
|
1330
|
+
|
1331
|
+
for (i = 0; i < PNG_FILTER_VALUE_LAST; i++)
|
1332
|
+
{
|
1333
|
+
png_ptr->inv_filter_costs[i] =
|
1334
|
+
png_ptr->filter_costs[i] = PNG_COST_FACTOR;
|
1335
|
+
}
|
1336
|
+
}
|
1337
|
+
|
1338
|
+
/* Here is where we set the relative costs of the different filters. We
|
1339
|
+
* should take the desired compression level into account when setting
|
1340
|
+
* the costs, so that Paeth, for instance, has a high relative cost at low
|
1341
|
+
* compression levels, while it has a lower relative cost at higher
|
1342
|
+
* compression settings. The filter types are in order of increasing
|
1343
|
+
* relative cost, so it would be possible to do this with an algorithm.
|
1344
|
+
*/
|
1345
|
+
for (i = 0; i < PNG_FILTER_VALUE_LAST; i++)
|
1346
|
+
{
|
1347
|
+
if (filter_costs == NULL || filter_costs[i] < 0.0)
|
1348
|
+
{
|
1349
|
+
png_ptr->inv_filter_costs[i] =
|
1350
|
+
png_ptr->filter_costs[i] = PNG_COST_FACTOR;
|
1351
|
+
}
|
1352
|
+
else if (filter_costs[i] >= 1.0)
|
1353
|
+
{
|
1354
|
+
png_ptr->inv_filter_costs[i] =
|
1355
|
+
(png_uint_16)((double)PNG_COST_FACTOR / filter_costs[i] + 0.5);
|
1356
|
+
png_ptr->filter_costs[i] =
|
1357
|
+
(png_uint_16)((double)PNG_COST_FACTOR * filter_costs[i] + 0.5);
|
1358
|
+
}
|
1359
|
+
}
|
1360
|
+
}
|
1361
|
+
#endif /* PNG_WRITE_WEIGHTED_FILTER_SUPPORTED */
|
1362
|
+
|
1363
|
+
void PNGAPI
|
1364
|
+
png_set_compression_level(png_structp png_ptr, int level)
|
1365
|
+
{
|
1366
|
+
png_debug(1, "in png_set_compression_level\n");
|
1367
|
+
if (png_ptr == NULL)
|
1368
|
+
return;
|
1369
|
+
png_ptr->flags |= PNG_FLAG_ZLIB_CUSTOM_LEVEL;
|
1370
|
+
png_ptr->zlib_level = level;
|
1371
|
+
}
|
1372
|
+
|
1373
|
+
void PNGAPI
|
1374
|
+
png_set_compression_mem_level(png_structp png_ptr, int mem_level)
|
1375
|
+
{
|
1376
|
+
png_debug(1, "in png_set_compression_mem_level\n");
|
1377
|
+
if (png_ptr == NULL)
|
1378
|
+
return;
|
1379
|
+
png_ptr->flags |= PNG_FLAG_ZLIB_CUSTOM_MEM_LEVEL;
|
1380
|
+
png_ptr->zlib_mem_level = mem_level;
|
1381
|
+
}
|
1382
|
+
|
1383
|
+
void PNGAPI
|
1384
|
+
png_set_compression_strategy(png_structp png_ptr, int strategy)
|
1385
|
+
{
|
1386
|
+
png_debug(1, "in png_set_compression_strategy\n");
|
1387
|
+
if (png_ptr == NULL)
|
1388
|
+
return;
|
1389
|
+
png_ptr->flags |= PNG_FLAG_ZLIB_CUSTOM_STRATEGY;
|
1390
|
+
png_ptr->zlib_strategy = strategy;
|
1391
|
+
}
|
1392
|
+
|
1393
|
+
void PNGAPI
|
1394
|
+
png_set_compression_window_bits(png_structp png_ptr, int window_bits)
|
1395
|
+
{
|
1396
|
+
if (png_ptr == NULL)
|
1397
|
+
return;
|
1398
|
+
if (window_bits > 15)
|
1399
|
+
png_warning(png_ptr, "Only compression windows <= 32k supported by PNG");
|
1400
|
+
else if (window_bits < 8)
|
1401
|
+
png_warning(png_ptr, "Only compression windows >= 256 supported by PNG");
|
1402
|
+
#ifndef WBITS_8_OK
|
1403
|
+
/* avoid libpng bug with 256-byte windows */
|
1404
|
+
if (window_bits == 8)
|
1405
|
+
{
|
1406
|
+
png_warning(png_ptr, "Compression window is being reset to 512");
|
1407
|
+
window_bits=9;
|
1408
|
+
}
|
1409
|
+
#endif
|
1410
|
+
png_ptr->flags |= PNG_FLAG_ZLIB_CUSTOM_WINDOW_BITS;
|
1411
|
+
png_ptr->zlib_window_bits = window_bits;
|
1412
|
+
}
|
1413
|
+
|
1414
|
+
void PNGAPI
|
1415
|
+
png_set_compression_method(png_structp png_ptr, int method)
|
1416
|
+
{
|
1417
|
+
png_debug(1, "in png_set_compression_method\n");
|
1418
|
+
if (png_ptr == NULL)
|
1419
|
+
return;
|
1420
|
+
if (method != 8)
|
1421
|
+
png_warning(png_ptr, "Only compression method 8 is supported by PNG");
|
1422
|
+
png_ptr->flags |= PNG_FLAG_ZLIB_CUSTOM_METHOD;
|
1423
|
+
png_ptr->zlib_method = method;
|
1424
|
+
}
|
1425
|
+
|
1426
|
+
void PNGAPI
|
1427
|
+
png_set_write_status_fn(png_structp png_ptr, png_write_status_ptr write_row_fn)
|
1428
|
+
{
|
1429
|
+
if (png_ptr == NULL)
|
1430
|
+
return;
|
1431
|
+
png_ptr->write_row_fn = write_row_fn;
|
1432
|
+
}
|
1433
|
+
|
1434
|
+
#if defined(PNG_WRITE_USER_TRANSFORM_SUPPORTED)
|
1435
|
+
void PNGAPI
|
1436
|
+
png_set_write_user_transform_fn(png_structp png_ptr, png_user_transform_ptr
|
1437
|
+
write_user_transform_fn)
|
1438
|
+
{
|
1439
|
+
png_debug(1, "in png_set_write_user_transform_fn\n");
|
1440
|
+
if (png_ptr == NULL)
|
1441
|
+
return;
|
1442
|
+
png_ptr->transformations |= PNG_USER_TRANSFORM;
|
1443
|
+
png_ptr->write_user_transform_fn = write_user_transform_fn;
|
1444
|
+
}
|
1445
|
+
#endif
|
1446
|
+
|
1447
|
+
|
1448
|
+
#if defined(PNG_INFO_IMAGE_SUPPORTED)
|
1449
|
+
void PNGAPI
|
1450
|
+
png_write_png(png_structp png_ptr, png_infop info_ptr,
|
1451
|
+
int transforms, voidp params)
|
1452
|
+
{
|
1453
|
+
if (png_ptr == NULL || info_ptr == NULL)
|
1454
|
+
return;
|
1455
|
+
#if defined(PNG_WRITE_INVERT_ALPHA_SUPPORTED)
|
1456
|
+
/* invert the alpha channel from opacity to transparency */
|
1457
|
+
if (transforms & PNG_TRANSFORM_INVERT_ALPHA)
|
1458
|
+
png_set_invert_alpha(png_ptr);
|
1459
|
+
#endif
|
1460
|
+
|
1461
|
+
/* Write the file header information. */
|
1462
|
+
png_write_info(png_ptr, info_ptr);
|
1463
|
+
|
1464
|
+
/* ------ these transformations don't touch the info structure ------- */
|
1465
|
+
|
1466
|
+
#if defined(PNG_WRITE_INVERT_SUPPORTED)
|
1467
|
+
/* invert monochrome pixels */
|
1468
|
+
if (transforms & PNG_TRANSFORM_INVERT_MONO)
|
1469
|
+
png_set_invert_mono(png_ptr);
|
1470
|
+
#endif
|
1471
|
+
|
1472
|
+
#if defined(PNG_WRITE_SHIFT_SUPPORTED)
|
1473
|
+
/* Shift the pixels up to a legal bit depth and fill in
|
1474
|
+
* as appropriate to correctly scale the image.
|
1475
|
+
*/
|
1476
|
+
if ((transforms & PNG_TRANSFORM_SHIFT)
|
1477
|
+
&& (info_ptr->valid & PNG_INFO_sBIT))
|
1478
|
+
png_set_shift(png_ptr, &info_ptr->sig_bit);
|
1479
|
+
#endif
|
1480
|
+
|
1481
|
+
#if defined(PNG_WRITE_PACK_SUPPORTED)
|
1482
|
+
/* pack pixels into bytes */
|
1483
|
+
if (transforms & PNG_TRANSFORM_PACKING)
|
1484
|
+
png_set_packing(png_ptr);
|
1485
|
+
#endif
|
1486
|
+
|
1487
|
+
#if defined(PNG_WRITE_SWAP_ALPHA_SUPPORTED)
|
1488
|
+
/* swap location of alpha bytes from ARGB to RGBA */
|
1489
|
+
if (transforms & PNG_TRANSFORM_SWAP_ALPHA)
|
1490
|
+
png_set_swap_alpha(png_ptr);
|
1491
|
+
#endif
|
1492
|
+
|
1493
|
+
#if defined(PNG_WRITE_FILLER_SUPPORTED)
|
1494
|
+
/* Get rid of filler (OR ALPHA) bytes, pack XRGB/RGBX/ARGB/RGBA into
|
1495
|
+
* RGB (4 channels -> 3 channels). The second parameter is not used.
|
1496
|
+
*/
|
1497
|
+
if (transforms & PNG_TRANSFORM_STRIP_FILLER)
|
1498
|
+
png_set_filler(png_ptr, 0, PNG_FILLER_BEFORE);
|
1499
|
+
#endif
|
1500
|
+
|
1501
|
+
#if defined(PNG_WRITE_BGR_SUPPORTED)
|
1502
|
+
/* flip BGR pixels to RGB */
|
1503
|
+
if (transforms & PNG_TRANSFORM_BGR)
|
1504
|
+
png_set_bgr(png_ptr);
|
1505
|
+
#endif
|
1506
|
+
|
1507
|
+
#if defined(PNG_WRITE_SWAP_SUPPORTED)
|
1508
|
+
/* swap bytes of 16-bit files to most significant byte first */
|
1509
|
+
if (transforms & PNG_TRANSFORM_SWAP_ENDIAN)
|
1510
|
+
png_set_swap(png_ptr);
|
1511
|
+
#endif
|
1512
|
+
|
1513
|
+
#if defined(PNG_WRITE_PACKSWAP_SUPPORTED)
|
1514
|
+
/* swap bits of 1, 2, 4 bit packed pixel formats */
|
1515
|
+
if (transforms & PNG_TRANSFORM_PACKSWAP)
|
1516
|
+
png_set_packswap(png_ptr);
|
1517
|
+
#endif
|
1518
|
+
|
1519
|
+
/* ----------------------- end of transformations ------------------- */
|
1520
|
+
|
1521
|
+
/* write the bits */
|
1522
|
+
if (info_ptr->valid & PNG_INFO_IDAT)
|
1523
|
+
png_write_image(png_ptr, info_ptr->row_pointers);
|
1524
|
+
|
1525
|
+
/* It is REQUIRED to call this to finish writing the rest of the file */
|
1526
|
+
png_write_end(png_ptr, info_ptr);
|
1527
|
+
|
1528
|
+
transforms = transforms; /* quiet compiler warnings */
|
1529
|
+
params = params;
|
1530
|
+
}
|
1531
|
+
#endif
|
1532
|
+
#endif /* PNG_WRITE_SUPPORTED */
|