2019-08-07 16:49:16 +02:00
[](https://gitter.im/libspng/community?utm_source=badge& utm_medium=badge& utm_campaign=pr-badge)
2021-01-28 21:46:13 +01:00
[](https://opencollective.com/libspng)
2019-08-15 20:17:38 +02:00
[](https://oss-fuzz-build-logs.storage.googleapis.com/index.html#libspng )
2019-07-17 14:06:49 +02:00
[](https://scan.coverity.com/projects/randy408-libspng)
2020-09-08 21:48:14 +02:00
[](https://libspng.org/download)
2019-07-17 14:06:49 +02:00
2019-08-07 16:49:16 +02:00
# libspng
2018-03-28 14:38:53 +00:00
2021-02-08 16:17:51 +01:00
lib**spng** (**s**imple **png** ) is a C library for reading and writing Portable Network Graphics (PNG)
2018-03-28 14:38:53 +00:00
format files with a focus on security and ease of use.
2018-05-21 20:05:01 +00:00
libspng is an alternative to libpng, the projects are separate and the APIs are
not compatible.
2019-08-07 16:49:16 +02:00
## Motivation
2018-11-28 17:54:50 +02:00
2020-05-13 09:53:32 +02:00
The goal is to provide a fast PNG library with a simpler API than [libpng ](https://github.com/glennrp/libpng/blob/libpng16/png.h ),
it outperforms the reference implementation in common use cases.
2018-11-28 17:54:50 +02:00
2019-08-07 16:49:16 +02:00
## Performance
2018-11-28 17:54:50 +02:00
2019-08-07 16:49:16 +02:00

2018-11-28 17:54:50 +02:00
2019-08-07 16:49:16 +02:00
## Features
2018-09-03 18:42:39 +03:00
2021-07-29 15:00:42 +02:00
| Feature | spng | libpng | stb_image | lodepng |
2020-06-07 12:03:13 +02:00
|--------------------------------------|---------|--------------------|-----------|---------|
| Decode from stream | ✅ | ✅ | ✅ | ❌ |
| Gamma correction | ✅ | ✅ | ❌ | ❌ |
| No known security bugs< sup > [1]< / sup > | ✅ | ✅ | ❌ | ✅ |
| Progressive image read | ✅ | ✅ | ❌ | ❌ |
| Parses all standard chunks | ✅ | ✅ | ❌ | ❌ |
| Doesn't require zlib< sup > [2]< / sup > | ✅ | ❌ | ✅ | ✅ |
2021-07-27 16:55:26 +02:00
| Encoding | ✅ | ✅ | ✅ | ✅ |
2020-06-07 12:03:13 +02:00
| Animated PNG | Planned | ✅< sup > [3]< / sup > | ❌ | ❌ |
2020-05-26 17:30:28 +02:00
2020-06-07 12:03:13 +02:00
< sup > [1]</ sup > The project is fuzz tested on [OSS-Fuzz ](https://github.com/google/oss-fuzz ) and vulnerabilities are fixed before they become public.
2018-10-31 20:07:07 +02:00
2020-06-07 12:03:13 +02:00
< sup > [2]</ sup > Building with miniz is [supported ](docs/build.md#miniz ).
2019-08-14 12:04:51 +02:00
2020-06-07 12:03:13 +02:00
< sup > [3]< / sup > With a 3rd party patch
2019-02-20 22:13:04 +01:00
2021-01-28 21:31:26 +01:00
## Getting spng
2018-09-03 18:42:39 +03:00
2019-08-07 16:49:16 +02:00
Download the [latest release ](https://libspng.org/download ) and include `spng.c/spng.h` in your project,
2021-03-02 06:37:55 +01:00
you can also build with CMake or Meson, refer to the [documentation ](docs/build.md ) for details.
2018-09-03 18:42:39 +03:00
2019-08-07 16:49:16 +02:00
## Usage
2018-09-03 18:42:39 +03:00
2019-08-07 16:49:16 +02:00
```c
2020-08-07 15:46:04 +02:00
#include <spng.h>
2021-07-27 16:55:26 +02:00
/* Create a decoder context */
2019-08-07 16:49:16 +02:00
spng_ctx *ctx = spng_ctx_new(0);
2018-10-31 20:07:07 +02:00
2019-08-07 16:49:16 +02:00
/* Set an input buffer */
spng_set_png_buffer(ctx, buf, buf_size);
2018-03-28 14:38:53 +00:00
2019-08-07 16:49:16 +02:00
/* Determine output image size */
spng_decoded_image_size(ctx, SPNG_FMT_RGBA8, &out_size);
/* Decode to 8-bit RGBA */
spng_decode_image(ctx, out, out_size, SPNG_FMT_RGBA8, 0);
/* Free context memory */
spng_ctx_free(ctx);
2021-07-27 16:55:26 +02:00
/* Creating an encoder context requires a flag */
spng_ctx *enc = spng_ctx_new(SPNG_CTX_ENCODER);
2021-09-25 19:21:19 +02:00
/* Encode to internal buffer managed by the library */
spng_set_option(enc, SPNG_ENCODE_TO_BUFFER, 1);
2021-07-27 16:55:26 +02:00
/* Specify image dimensions, PNG format */
struct spng_ihdr ihdr =
{
.width = width,
2022-04-21 23:00:00 +02:00
.height = height,
2021-07-27 16:55:26 +02:00
.bit_depth = 8,
.color_type = SPNG_COLOR_TYPE_TRUECOLOR_ALPHA
};
/* Image will be encoded according to ihdr.color_type, .bit_depth */
spng_set_ihdr(enc, &ihdr);
/* SPNG_FMT_PNG is a special value that matches the format in ihdr,
SPNG_ENCODE_FINALIZE will finalize the PNG with the end-of-file marker */
spng_encode_image(enc, image, image_size, SPNG_FMT_PNG, SPNG_ENCODE_FINALIZE);
/* PNG is written to an internal buffer by default */
void *png = spng_get_png_buffer(enc, & png_size, &error);
/* User owns the buffer after a successful call */
free(png);
/* Free context memory */
spng_ctx_free(enc);
2019-08-07 16:49:16 +02:00
```
2020-11-21 19:33:18 +01:00
See [example.c ](examples/example.c ).
2019-08-07 16:49:16 +02:00
## License
Code is licensed under the BSD 2-clause "Simplified" License.
2019-01-10 10:59:33 +02:00
2019-08-07 16:49:16 +02:00
The project contains optimizations and test images from libpng, these are licensed under the
[PNG Reference Library License version 2 ](http://www.libpng.org/pub/png/src/libpng-LICENSE.txt ).
2018-03-28 14:38:53 +00:00
2019-08-07 16:49:16 +02:00
## Security & Testing
2018-03-28 14:38:53 +00:00
2019-08-07 16:49:16 +02:00
Code is written according to the rules of the
2018-11-28 17:54:50 +02:00
[CERT C Coding Standard ](https://wiki.sei.cmu.edu/confluence/display/c/SEI+CERT+C+Coding+Standard ).
2019-01-10 10:59:33 +02:00
All integer arithmetic is checked for overflow and all error conditions are handled gracefully.
2019-08-07 16:49:16 +02:00
The library is continuously fuzzed by [OSS-Fuzz ](https://github.com/google/oss-fuzz ),
2020-06-30 17:05:00 +02:00
code is also scanned with Clang Static Analyzer, Coverity Scan and PVS-Studio.
2018-03-28 14:38:53 +00:00
2020-07-13 18:26:43 +02:00
The test suite consists of over 1000 test cases,
2019-08-07 16:49:16 +02:00
175 [test images ](http://www.schaik.com/pngsuite/ ) are decoded with all possible
2020-07-13 18:26:43 +02:00
output format and flag combinations and compared against libpng for [correctness ](tests/README.md#Correctness ).
2018-05-21 12:57:56 +00:00
2019-08-07 16:49:16 +02:00
## Versioning
2018-05-21 12:57:56 +00:00
2020-04-18 16:32:12 +02:00
Releases follow the [semantic versioning ](https://semver.org/ ) scheme with additional guarantees:
2018-11-05 12:34:54 +02:00
2019-08-07 16:49:16 +02:00
* Releases from 0.4.0 to 0.8.x are stable
2020-04-18 16:32:12 +02:00
* If 1.0.0 will introduce breaking changes then 0.8.x will be maintained as a separate stable branch
2019-03-11 16:17:21 +01:00
2020-04-18 16:32:12 +02:00
Currently 1.0.0 is planned to be [compatible ](https://github.com/randy408/libspng/issues/3 ).
2018-03-28 14:38:53 +00:00
2019-08-07 16:49:16 +02:00
## Documentation
2018-03-28 14:38:53 +00:00
2019-08-07 16:49:16 +02:00
Online documentation is available at [libspng.org/docs ](https://libspng.org/docs ).
2019-03-11 16:17:21 +01:00
2019-08-07 16:49:16 +02:00
## Known Issues
2018-09-03 18:42:39 +03:00
2020-06-09 21:08:49 +02:00
* Decoding to `SPNG_FMT_G8` , `SPNG_FMT_GA8` and `SPNG_FMT_GA16` output formats is not supported
for all PNG color type and bit depth combinations, see documentation for details.
* Gamma correction is not implemented for `SPNG_FMT_PNG` , `SPNG_FMT_G8` , `SPNG_FMT_GA8`
and `SPNG_FMT_GA16` output formats.
2021-01-28 21:31:26 +01:00
## Supporting spng
2021-01-28 21:46:13 +01:00
You can sponsor development through [OpenCollective ](https://opencollective.com/libspng/ ), funds will be used for maintenance and further development according to the [roadmap ](https://github.com/randy408/libspng/milestones ).
2021-01-28 21:31:26 +01:00
2021-01-28 21:46:13 +01:00
### OpenCollective backers
2021-01-28 21:31:26 +01:00
#### Individuals
< a href = "https://opencollective.com/libspng" > < img src = "https://opencollective.com/libspng/backers.svg?width=890" > < / a >
#### Organizations
Support this project with your organization. Your logo will show up here with a link to your website. [[Contribute ](https://opencollective.com/libspng/contribute )]
< a href = "https://opencollective.com/libspng/sponsor/0/website" > < img src = "https://opencollective.com/libspng/sponsor/0/avatar.svg" > < / a >
< a href = "https://opencollective.com/libspng/sponsor/1/website" > < img src = "https://opencollective.com/libspng/sponsor/1/avatar.svg" > < / a >
< a href = "https://opencollective.com/libspng/sponsor/2/website" > < img src = "https://opencollective.com/libspng/sponsor/2/avatar.svg" > < / a >
< a href = "https://opencollective.com/libspng/sponsor/3/website" > < img src = "https://opencollective.com/libspng/sponsor/3/avatar.svg" > < / a >
< a href = "https://opencollective.com/libspng/sponsor/4/website" > < img src = "https://opencollective.com/libspng/sponsor/4/avatar.svg" > < / a >
< a href = "https://opencollective.com/libspng/sponsor/5/website" > < img src = "https://opencollective.com/libspng/sponsor/5/avatar.svg" > < / a >
< a href = "https://opencollective.com/l i bspng/sponsor/6/website" >< img src = "https://opencollective.com/libspng/sponsor/6/avatar.svg" ></ a >
< a href = "https://opencollective.com/libspng/sponsor/7/website" > < img src = "https://opencollective.com/libspng/sponsor/7/avatar.svg" > < / a >
< a href = "https://opencollective.com/libspng/sponsor/8/website" > < img src = "https://opencollective.com/libspng/sponsor/8/avatar.svg" > < / a >
< a href = "https://opencollective.com/libspng/sponsor/9/website" > < img src = "https://opencollective.com/libspng/sponsor/9/avatar.svg" > < / a >