add fuzz corpus
@ -2,6 +2,7 @@
|
|||||||
- fix a deadlock with --vips-leak [DarthSim]
|
- fix a deadlock with --vips-leak [DarthSim]
|
||||||
- better gifload behaviour for DISPOSAL_UNSPECIFIED [DarthSim]
|
- better gifload behaviour for DISPOSAL_UNSPECIFIED [DarthSim]
|
||||||
- ban ppm max_value < 0
|
- ban ppm max_value < 0
|
||||||
|
- add fuzz corpus to dist
|
||||||
|
|
||||||
20/6/19 started 8.9.1
|
20/6/19 started 8.9.1
|
||||||
- don't use the new source loaders for new_from_file or new_from_buffer, it
|
- don't use the new source loaders for new_from_file or new_from_buffer, it
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
<para>
|
<para>
|
||||||
This page tries to explain what the different strategies are and when each is used. If you are running into unexpected memory, disc or CPU use, this might be helpful. <literal>vips_image_new_from_file()</literal> has the official documentation.
|
This page tries to explain what the different strategies are and when each is used. If you are running into unexpected memory, disc or CPU use, this might be helpful. <literal>vips_image_new_from_file()</literal> has the official documentation.
|
||||||
</para>
|
</para>
|
||||||
<refsect3 id="direct-access">
|
<section xml:id="direct-access">
|
||||||
<title>Direct access</title>
|
<title>Direct access</title>
|
||||||
<para>
|
<para>
|
||||||
This is the fastest and simplest one. The file is mapped directly into the process’s address space and can be read with ordinary pointer access. Small files are completely mapped; large files are mapped in a series of small windows that are shared and which scroll about as pixels are read. Files which are accessed like this can be read by many threads at once, making them especially quick. They also interact well with the computer’s operating system: your OS will use spare memory to cache recently used chunks of the file.
|
This is the fastest and simplest one. The file is mapped directly into the process’s address space and can be read with ordinary pointer access. Small files are completely mapped; large files are mapped in a series of small windows that are shared and which scroll about as pixels are read. Files which are accessed like this can be read by many threads at once, making them especially quick. They also interact well with the computer’s operating system: your OS will use spare memory to cache recently used chunks of the file.
|
||||||
@ -25,10 +25,10 @@
|
|||||||
For this to be possible, the file format needs to be a simple dump of a memory array. libvips supports direct access for vips, 8-bit binary ppm/pbm/pnm, analyse and raw.
|
For this to be possible, the file format needs to be a simple dump of a memory array. libvips supports direct access for vips, 8-bit binary ppm/pbm/pnm, analyse and raw.
|
||||||
</para>
|
</para>
|
||||||
<para>
|
<para>
|
||||||
libvips has a special direct write mode where pixels can be written directly to the file image. This is used for the <ulink url="libvips-draw.html">draw operators</ulink>.
|
libvips has a special direct write mode where pixels can be written directly to the file image. This is used for the <link xlink:href="libvips-draw.html">draw operators</link>.
|
||||||
</para>
|
</para>
|
||||||
</refsect3>
|
</section>
|
||||||
<refsect3 id="random-access-via-load-library">
|
<section xml:id="random-access-via-load-library">
|
||||||
<title>Random access via load library</title>
|
<title>Random access via load library</title>
|
||||||
<para>
|
<para>
|
||||||
Some image file formats have libraries which allow true random access to image pixels. For example, libtiff lets you read any tile out of a tiled tiff image very quickly. Because the libraries allow true random access, libvips can simply hook the image load library up to the input of the operation pipeline.
|
Some image file formats have libraries which allow true random access to image pixels. For example, libtiff lets you read any tile out of a tiled tiff image very quickly. Because the libraries allow true random access, libvips can simply hook the image load library up to the input of the operation pipeline.
|
||||||
@ -39,8 +39,8 @@
|
|||||||
<para>
|
<para>
|
||||||
libvips can load tiled tiff, tiled OpenEXR, FITS and OpenSlide images in this manner.
|
libvips can load tiled tiff, tiled OpenEXR, FITS and OpenSlide images in this manner.
|
||||||
</para>
|
</para>
|
||||||
</refsect3>
|
</section>
|
||||||
<refsect3 id="full-decompression">
|
<section xml:id="full-decompression">
|
||||||
<title>Full decompression</title>
|
<title>Full decompression</title>
|
||||||
<para>
|
<para>
|
||||||
Many image load libraries do not support random access. In order to use images of this type as inputs to pipelines, libvips has to convert them to a random access format first.
|
Many image load libraries do not support random access. In order to use images of this type as inputs to pipelines, libvips has to convert them to a random access format first.
|
||||||
@ -54,8 +54,8 @@
|
|||||||
<para>
|
<para>
|
||||||
This is the slowest and most memory-hungry way to read files, but it’s unavoidable for many file formats. Unless you can use the next one!
|
This is the slowest and most memory-hungry way to read files, but it’s unavoidable for many file formats. Unless you can use the next one!
|
||||||
</para>
|
</para>
|
||||||
</refsect3>
|
</section>
|
||||||
<refsect3 id="sequential-access">
|
<section xml:id="sequential-access">
|
||||||
<title>Sequential access</title>
|
<title>Sequential access</title>
|
||||||
<para>
|
<para>
|
||||||
This a fairly recent addition to libvips and is a hybrid of the previous two.
|
This a fairly recent addition to libvips and is a hybrid of the previous two.
|
||||||
@ -90,7 +90,7 @@ $ vips shrink fred.png jim.png 10 10
|
|||||||
<para>
|
<para>
|
||||||
This is done automatically in command-line operation. In programs, you need to set <literal>access</literal> to #VIPS_ACCESS_SEQUENTIAL in calls to functions like vips_image_new_from_file().
|
This is done automatically in command-line operation. In programs, you need to set <literal>access</literal> to #VIPS_ACCESS_SEQUENTIAL in calls to functions like vips_image_new_from_file().
|
||||||
</para>
|
</para>
|
||||||
</refsect3>
|
</section>
|
||||||
|
|
||||||
|
|
||||||
</refentry>
|
</refentry>
|
||||||
|
@ -21,7 +21,7 @@ $filename = "image.jpg";
|
|||||||
$image = Vips\Image::thumbnail($filename, 200, ["height" => 200]);
|
$image = Vips\Image::thumbnail($filename, 200, ["height" => 200]);
|
||||||
$image->writeToFile("my-thumbnail.jpg");
|
$image->writeToFile("my-thumbnail.jpg");
|
||||||
</programlisting>
|
</programlisting>
|
||||||
<refsect3 id="libvips-options">
|
<section xml:id="libvips-options">
|
||||||
<title>libvips options</title>
|
<title>libvips options</title>
|
||||||
<para>
|
<para>
|
||||||
<literal>vipsthumbnail</literal> supports the usual range of vips command-line options. A few of them are useful:
|
<literal>vipsthumbnail</literal> supports the usual range of vips command-line options. A few of them are useful:
|
||||||
@ -38,8 +38,8 @@ $image->writeToFile("my-thumbnail.jpg");
|
|||||||
<para>
|
<para>
|
||||||
<literal>--vips-info</literal> shows a higher level view of the operations that <literal>vipsthumbnail</literal> is running.
|
<literal>--vips-info</literal> shows a higher level view of the operations that <literal>vipsthumbnail</literal> is running.
|
||||||
</para>
|
</para>
|
||||||
</refsect3>
|
</section>
|
||||||
<refsect3 id="looping">
|
<section xml:id="looping">
|
||||||
<title>Looping</title>
|
<title>Looping</title>
|
||||||
<para>
|
<para>
|
||||||
<literal>vipsthumbnail</literal> can process many images in one command. For example:
|
<literal>vipsthumbnail</literal> can process many images in one command. For example:
|
||||||
@ -56,8 +56,8 @@ $ vipsthumbnail *.jpg
|
|||||||
<programlisting>
|
<programlisting>
|
||||||
$ parallel vipsthumbnail ::: *.jpg
|
$ parallel vipsthumbnail ::: *.jpg
|
||||||
</programlisting>
|
</programlisting>
|
||||||
</refsect3>
|
</section>
|
||||||
<refsect3 id="thumbnail-size">
|
<section xml:id="thumbnail-size">
|
||||||
<title>Thumbnail size</title>
|
<title>Thumbnail size</title>
|
||||||
<para>
|
<para>
|
||||||
You can set the bounding box of the generated thumbnail with the <literal>--size</literal> option. For example:
|
You can set the bounding box of the generated thumbnail with the <literal>--size</literal> option. For example:
|
||||||
@ -80,8 +80,8 @@ $ vipsthumbnail shark.jpg --size 200x
|
|||||||
<para>
|
<para>
|
||||||
You can append <literal>!</literal> to force a resize to the exact target size, breaking the aspect ratio.
|
You can append <literal>!</literal> to force a resize to the exact target size, breaking the aspect ratio.
|
||||||
</para>
|
</para>
|
||||||
</refsect3>
|
</section>
|
||||||
<refsect3 id="cropping">
|
<section xml:id="cropping">
|
||||||
<title>Cropping</title>
|
<title>Cropping</title>
|
||||||
<para>
|
<para>
|
||||||
<literal>vipsthumbnail</literal> normally shrinks images to fit within the box set by <literal>--size</literal>. You can use the <literal>--smartcrop</literal> option to crop to fill the box instead. Excess pixels are trimmed away using the strategy you set. For example:
|
<literal>vipsthumbnail</literal> normally shrinks images to fit within the box set by <literal>--size</literal>. You can use the <literal>--smartcrop</literal> option to crop to fill the box instead. Excess pixels are trimmed away using the strategy you set. For example:
|
||||||
@ -92,30 +92,28 @@ $ vipsthumbnail owl.jpg --smartcrop attention -s 128
|
|||||||
<para>
|
<para>
|
||||||
Where <literal>owl.jpg</literal> is an off-centre composition:
|
Where <literal>owl.jpg</literal> is an off-centre composition:
|
||||||
</para>
|
</para>
|
||||||
<figure>
|
<para>
|
||||||
<mediaobject>
|
<inlinemediaobject>
|
||||||
<imageobject>
|
<imageobject>
|
||||||
<imagedata fileref="owl.jpg" />
|
<imagedata fileref="owl.jpg" />
|
||||||
</imageobject>
|
</imageobject>
|
||||||
<textobject><phrase></phrase></textobject>
|
</inlinemediaobject>
|
||||||
</mediaobject>
|
</para>
|
||||||
</figure>
|
|
||||||
<para>
|
<para>
|
||||||
Gives this result:
|
Gives this result:
|
||||||
</para>
|
</para>
|
||||||
<figure>
|
<para>
|
||||||
<mediaobject>
|
<inlinemediaobject>
|
||||||
<imageobject>
|
<imageobject>
|
||||||
<imagedata fileref="tn_owl.jpg" />
|
<imagedata fileref="tn_owl.jpg" />
|
||||||
</imageobject>
|
</imageobject>
|
||||||
<textobject><phrase></phrase></textobject>
|
</inlinemediaobject>
|
||||||
</mediaobject>
|
</para>
|
||||||
</figure>
|
|
||||||
<para>
|
<para>
|
||||||
First it shrinks the image to get the vertical axis to 128 pixels, then crops down to 128 pixels across using the <literal>attention</literal> strategy. This one searches the image for features which might catch a human eye, see <literal>vips_smartcrop()</literal> for details.
|
First it shrinks the image to get the vertical axis to 128 pixels, then crops down to 128 pixels across using the <literal>attention</literal> strategy. This one searches the image for features which might catch a human eye, see <literal>vips_smartcrop()</literal> for details.
|
||||||
</para>
|
</para>
|
||||||
</refsect3>
|
</section>
|
||||||
<refsect3 id="linear-light">
|
<section xml:id="linear-light">
|
||||||
<title>Linear light</title>
|
<title>Linear light</title>
|
||||||
<para>
|
<para>
|
||||||
Shrinking images involves combining many pixels into one. Arithmetic averaging really ought to be in terms of the number of photons, but (for historical reasons) the values stored in image files are usually related to the voltage that should be applied to the electron gun in a CRT display.
|
Shrinking images involves combining many pixels into one. Arithmetic averaging really ought to be in terms of the number of photons, but (for historical reasons) the values stored in image files are usually related to the voltage that should be applied to the electron gun in a CRT display.
|
||||||
@ -142,8 +140,8 @@ real 0m4.660s
|
|||||||
user 0m4.640s
|
user 0m4.640s
|
||||||
sys 0m0.016s
|
sys 0m0.016s
|
||||||
</programlisting>
|
</programlisting>
|
||||||
</refsect3>
|
</section>
|
||||||
<refsect3 id="output-directory">
|
<section xml:id="output-directory">
|
||||||
<title>Output directory</title>
|
<title>Output directory</title>
|
||||||
<para>
|
<para>
|
||||||
You set the thumbnail write parameters with the <literal>-o</literal> option. This is a pattern which the input filename is pasted into to produce the output filename. For example:
|
You set the thumbnail write parameters with the <literal>-o</literal> option. This is a pattern which the input filename is pasted into to produce the output filename. For example:
|
||||||
@ -172,8 +170,8 @@ $ vipsthumbnail fred.jpg ../jim.tif -o mythumbs/tn_%s.jpg
|
|||||||
<para>
|
<para>
|
||||||
Now both input files will have thumbnails written to a subdirectory of their current directory.
|
Now both input files will have thumbnails written to a subdirectory of their current directory.
|
||||||
</para>
|
</para>
|
||||||
</refsect3>
|
</section>
|
||||||
<refsect3 id="output-format-and-options">
|
<section xml:id="output-format-and-options">
|
||||||
<title>Output format and options</title>
|
<title>Output format and options</title>
|
||||||
<para>
|
<para>
|
||||||
You can use <literal>-o</literal> to specify the thumbnail image format too. For example:
|
You can use <literal>-o</literal> to specify the thumbnail image format too. For example:
|
||||||
@ -247,8 +245,8 @@ $ vipsthumbnail 42-32157534.jpg -o x.jpg[optimize_coding,strip]
|
|||||||
$ ls -l x.jpg
|
$ ls -l x.jpg
|
||||||
-rw-r–r– 1 john john 3600 Nov 12 21:27 x.jpg
|
-rw-r–r– 1 john john 3600 Nov 12 21:27 x.jpg
|
||||||
</programlisting>
|
</programlisting>
|
||||||
</refsect3>
|
</section>
|
||||||
<refsect3 id="colour-management">
|
<section xml:id="colour-management">
|
||||||
<title>Colour management</title>
|
<title>Colour management</title>
|
||||||
<para>
|
<para>
|
||||||
<literal>vipsthumbnail</literal> will optionally put images through LittleCMS for you. You can use this to move all thumbnails to the same colour space. All web browsers assume that images without an ICC profile are in sRGB colourspace, so if you move your thumbnails to sRGB, you can strip all the embedded profiles. This can save several kb per thumbnail.
|
<literal>vipsthumbnail</literal> will optionally put images through LittleCMS for you. You can use this to move all thumbnails to the same colour space. All web browsers assume that images without an ICC profile are in sRGB colourspace, so if you move your thumbnails to sRGB, you can strip all the embedded profiles. This can save several kb per thumbnail.
|
||||||
@ -265,12 +263,15 @@ $ ls -l tn_shark.jpg
|
|||||||
Now encode with sRGB and delete any embedded profile:
|
Now encode with sRGB and delete any embedded profile:
|
||||||
</para>
|
</para>
|
||||||
<programlisting>
|
<programlisting>
|
||||||
$ vipsthumbnail shark.jpg --eprofile /usr/share/color/icc/sRGB.icc --delete
|
$ vipsthumbnail shark.jpg --eprofile srgb --delete
|
||||||
$ ls -l tn_shark.jpg
|
$ ls -l tn_shark.jpg
|
||||||
-rw-r–r– 1 john john 4229 Nov 9 14:33 tn_shark.jpg
|
-rw-r–r– 1 john john 4229 Nov 9 14:33 tn_shark.jpg
|
||||||
</programlisting>
|
</programlisting>
|
||||||
<para>
|
<para>
|
||||||
It’ll look identical to a user, but be almost half the size.
|
(You can use the filename of any RGB profile. The magic string <literal>srgb</literal> selects a high-quality sRGB profile that’s built into libvips.)
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
<literal>tn_shark.jpg</literal> will look identical to a user, but it’s almost half the size.
|
||||||
</para>
|
</para>
|
||||||
<para>
|
<para>
|
||||||
You can also specify a fallback input profile to use if the image has no embedded one. This can often happen with CMYK images, producing an error message like:
|
You can also specify a fallback input profile to use if the image has no embedded one. This can often happen with CMYK images, producing an error message like:
|
||||||
@ -284,28 +285,13 @@ vips_colourspace: no known route from 'cmyk' to 'srgb'
|
|||||||
If you supply a CMYK profile, it will be able to convert the image, for example:
|
If you supply a CMYK profile, it will be able to convert the image, for example:
|
||||||
</para>
|
</para>
|
||||||
<programlisting>
|
<programlisting>
|
||||||
$ vipsthumbnail kgdev.jpg --iprofile /usr/share/color/icc/colord/FOGRA28L_webcoated.icc
|
$ vipsthumbnail kgdev.jpg --iprofile cmyk
|
||||||
</programlisting>
|
</programlisting>
|
||||||
<para>
|
<para>
|
||||||
I’ve had good results with this profile:
|
(As before, the magic string <literal>cmyk</literal> selects a high-quality CMYK profile that’s built into libvips, but you can use any CMYK profile you like.)
|
||||||
</para>
|
</para>
|
||||||
<para>
|
</section>
|
||||||
https://github.com/libvips/nip2/blob/master/share/nip2/data/cmyk.icm
|
<section xml:id="final-suggestion">
|
||||||
</para>
|
|
||||||
<para>
|
|
||||||
It makes nice-looking images from most CMYK files, and is completely free.
|
|
||||||
</para>
|
|
||||||
</refsect3>
|
|
||||||
<refsect3 id="auto-rotate">
|
|
||||||
<title>Auto-rotate</title>
|
|
||||||
<para>
|
|
||||||
Many JPEG files have a hint set in the header giving the image orientation. If you strip out the metadata, this hint will be lost, and the image will appear to be rotated.
|
|
||||||
</para>
|
|
||||||
<para>
|
|
||||||
If you use the <literal>--rotate</literal> option, <literal>vipsthumbnail</literal> examines the image header and if there’s an orientation tag, applies and removes it.
|
|
||||||
</para>
|
|
||||||
</refsect3>
|
|
||||||
<refsect3 id="final-suggestion">
|
|
||||||
<title>Final suggestion</title>
|
<title>Final suggestion</title>
|
||||||
<para>
|
<para>
|
||||||
Putting all this together, I suggest this as a sensible set of options:
|
Putting all this together, I suggest this as a sensible set of options:
|
||||||
@ -314,10 +300,9 @@ $ vipsthumbnail kgdev.jpg --iprofile /usr/share/color/icc/colord/FOGRA28L_webcoa
|
|||||||
$ vipsthumbnail fred.jpg \
|
$ vipsthumbnail fred.jpg \
|
||||||
--size 128 \
|
--size 128 \
|
||||||
-o tn_%s.jpg[optimize_coding,strip] \
|
-o tn_%s.jpg[optimize_coding,strip] \
|
||||||
--eprofile /usr/share/color/icc/sRGB.icc \
|
--eprofile srgb
|
||||||
--rotate
|
|
||||||
</programlisting>
|
</programlisting>
|
||||||
</refsect3>
|
</section>
|
||||||
|
|
||||||
|
|
||||||
</refentry>
|
</refentry>
|
||||||
|
@ -25,4 +25,6 @@ libstandaloneengine_a_SOURCES = StandaloneFuzzTargetMain.c
|
|||||||
check_PROGRAMS = $(FUZZPROGS)
|
check_PROGRAMS = $(FUZZPROGS)
|
||||||
noinst_LIBRARIES = $(FUZZLIBS)
|
noinst_LIBRARIES = $(FUZZLIBS)
|
||||||
|
|
||||||
EXTRA_DIST = $(TESTS)
|
EXTRA_DIST = \
|
||||||
|
$(TESTS) \
|
||||||
|
common_fuzzer_corpus
|
||||||
|
Before Width: | Height: | Size: 44 B After Width: | Height: | Size: 44 B |
Before Width: | Height: | Size: 289 B After Width: | Height: | Size: 289 B |
Before Width: | Height: | Size: 71 B After Width: | Height: | Size: 71 B |
Before Width: | Height: | Size: 166 B After Width: | Height: | Size: 166 B |
Before Width: | Height: | Size: 97 B After Width: | Height: | Size: 97 B |