An Object containing nested boolean values representing the available input and output formats/methods.
console.log(sharp.format);Returns Object
An Object containing the version numbers of libvips and its dependencies.
console.log(sharp.versions);Gets or, when options are provided, sets the limits of libvips' operation cache. Existing entries in the cache will be trimmed after any change in limits. This method always returns cache statistics, useful for determining how much working memory is required for a particular task.
options(Object | Boolean) Object with the following attributes, or Boolean where true uses default cache settings and false removes all caching (optional, defaulttrue)
const stats = sharp.cache();sharp.cache( { items: 200 } );
sharp.cache( { files: 0 } );
sharp.cache(false);Returns Object
Gets or, when a concurrency is provided, sets
the number of threads libvips' should create to process each image.
The default value is the number of CPU cores.
A value of 0 will reset to this default.
The maximum number of images that can be processed in parallel
is limited by libuv's UV_THREADPOOL_SIZE environment variable.
This method always returns the current concurrency.
concurrencyNumber?
const threads = sharp.concurrency(); // 4
sharp.concurrency(2); // 2
sharp.concurrency(0); // 4Returns Number concurrency
An EventEmitter that emits a change event when a task is either:
- queued, waiting for libuv to provide a worker thread
- complete
sharp.queue.on('change', function(queueLength) {
console.log('Queue contains ' + queueLength + ' task(s)');
});Provides access to internal task counters.
- queue is the number of tasks this module has queued waiting for libuv to provide a worker thread from its pool.
- process is the number of resize tasks currently being processed.
const counters = sharp.counters(); // { queue: 2, process: 4 }Returns Object
Get and set use of SIMD vector unit instructions. Requires libvips to have been compiled with liborc support.
Improves the performance of resize, blur and sharpen operations
by taking advantage of the SIMD vector unit of the CPU, e.g. Intel SSE and ARM NEON.
simdBoolean (optional, defaulttrue)
const simd = sharp.simd();
// simd is `true` if the runtime use of liborc is currently enabledconst simd = sharp.simd(false);
// prevent libvips from using liborc at runtimeReturns Boolean