/usr/include/OpenImageIO/imagecache.h is in libopenimageio-dev 1.7.17~dfsg0-1ubuntu2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 | /*
Copyright 2008 Larry Gritz and the other authors and contributors.
All Rights Reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are
met:
* Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
* Neither the name of the software's owners nor the names of its
contributors may be used to endorse or promote products derived from
this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
(This is the Modified BSD License)
*/
/// \file
/// An API for accessing images via a system that
/// automatically manages a cache of resident image data.
#ifndef OPENIMAGEIO_IMAGECACHE_H
#define OPENIMAGEIO_IMAGECACHE_H
#include "OpenImageIO/ustring.h"
#include "OpenImageIO/imageio.h"
OIIO_NAMESPACE_BEGIN
struct ROI;
namespace pvt {
// Forward declaration
class ImageCacheImpl;
class ImageCacheFile;
class ImageCachePerThreadInfo;
};
/// Define an API to an abstract class that manages image files,
/// caches of open file handles as well as tiles of pixels so that truly
/// huge amounts of image data may be accessed by an application with low
/// memory footprint.
class OIIO_API ImageCache {
public:
/// Create a ImageCache and return a pointer. This should only be
/// freed by passing it to ImageCache::destroy()!
///
/// If shared==true, it's intended to be shared with other like-minded
/// owners in the same process who also ask for a shared cache. If
/// false, a private image cache will be created.
static ImageCache *create (bool shared=true);
/// Destroy a ImageCache that was created using ImageCache::create().
/// The variety that takes a 'teardown' parameter, when set to true,
/// will fully destroy even a "shared" ImageCache.
static void destroy (ImageCache * x);
static void destroy (ImageCache * x, bool teardown);
ImageCache (void) { }
virtual ~ImageCache () { }
OIIO_DEPRECATED("clear() was never implemented. Don't bother calling it. [1.7]")
virtual void clear () { }
/// Set an attribute controlling the image cache. Return true
/// if the name and type were recognized and the attrib was set.
/// Documented attributes:
/// int max_open_files : maximum number of file handles held open
/// float max_memory_MB : maximum tile cache size, in MB
/// string searchpath : colon-separated search path for images
/// string plugin_searchpath : colon-separated search path for plugins
/// int autotile : if >0, tile size to emulate for non-tiled images
/// int autoscanline : autotile using full width tiles
/// int automip : if nonzero, emulate mipmap on the fly
/// int accept_untiled : if nonzero, accept untiled images, but
/// if zero, reject untiled images (default=1)
/// int accept_unmipped : if nonzero, accept unmipped images (def=1)
/// int statistics:level : verbosity of statistics auto-printed.
/// int forcefloat : if nonzero, convert all to float.
/// int failure_retries : number of times to retry a read before fail.
/// int deduplicate : if nonzero, detect duplicate textures (default=1)
/// string substitute_image : uses the named image in place of all
/// texture and image references.
/// int unassociatedalpha : if nonzero, keep unassociated alpha images
/// int max_errors_per_file : Limits how many errors to issue for
/// issue for each (default: 100)
///
virtual bool attribute (string_view name, TypeDesc type,
const void *val) = 0;
// Shortcuts for common types
virtual bool attribute (string_view name, int val) = 0;
virtual bool attribute (string_view name, float val) = 0;
virtual bool attribute (string_view name, double val) = 0;
virtual bool attribute (string_view name, string_view val) = 0;
/// Get the named attribute, store it in *val. All of the attributes
/// that may be set with the attribute() call may also be queried with
/// getattribute().
///
/// Additionally, there are some read-only attributes that can be
/// queried with getattribute():
/// int total_files : the total number of unique files referenced by
/// calls to the ImageCache.
/// string[] all_filenames : an array that will be filled with the
/// list of the names of all files referenced by calls to
/// the ImageCache. (The array is of ustrings or char*'s.)
/// stat:* : a variety of statistics (see full docs for details).
///
virtual bool getattribute (string_view name, TypeDesc type,
void *val) const = 0;
// Shortcuts for common types
virtual bool getattribute (string_view name, int &val) const = 0;
virtual bool getattribute (string_view name, float &val) const = 0;
virtual bool getattribute (string_view name, double &val) const = 0;
virtual bool getattribute (string_view name, char **val) const = 0;
virtual bool getattribute (string_view name, std::string &val) const = 0;
/// Define an opaque data type that allows us to have a pointer
/// to certain per-thread information that the ImageCache maintains.
/// Any given one of these should NEVER be shared between running
/// threads.
typedef pvt::ImageCachePerThreadInfo Perthread;
/// Retrieve a Perthread, unique to the calling thread. This is a
/// thread-specific pointer that will always return the Perthread for a
/// thread, which will also be automatically destroyed when the thread
/// terminates.
///
/// Applications that want to manage their own Perthread pointers (with
/// create_thread_info and destroy_thread_info) should still call this,
/// but passing in their managed pointer. If the passed-in thread_info
/// is not NULL, it won't create a new one or retrieve a TSP, but it
/// will do other necessary housekeeping on the Perthread information.
virtual Perthread * get_perthread_info (Perthread *thread_info = NULL) = 0;
/// Create a new Perthread. It is the caller's responsibility to
/// eventually destroy it using destroy_thread_info().
virtual Perthread * create_thread_info () = 0;
/// Destroy a Perthread that was allocated by create_thread_info().
virtual void destroy_thread_info (Perthread *thread_info) = 0;
/// Define an opaque data type that allows us to have a handle to an
/// image (already having its name resolved) but without exposing
/// any internals.
typedef pvt::ImageCacheFile ImageHandle;
/// Retrieve an opaque handle for fast image lookups. The opaque
/// pointer thread_info is thread-specific information returned by
/// get_perthread_info(). Return NULL if something has gone
/// horribly wrong.
virtual ImageHandle * get_image_handle (ustring filename,
Perthread *thread_info=NULL) = 0;
/// Return true if the image handle (previously returned by
/// get_image_handle()) is a valid image that can be subsequently read.
virtual bool good (ImageHandle *file) = 0;
/// Given possibly-relative 'filename', resolve it using the search
/// path rules and return the full resolved filename.
virtual std::string resolve_filename (const std::string &filename) const=0;
/// Get information about the named image. Return true if found
/// and the data has been put in *data. Return false if the image
/// doesn't exist, doesn't have the requested data, if the data
/// doesn't match the type requested. or some other failure.
virtual bool get_image_info (ustring filename, int subimage, int miplevel,
ustring dataname, TypeDesc datatype, void *data) = 0;
virtual bool get_image_info (ImageHandle *file, Perthread *thread_info,
int subimage, int miplevel,
ustring dataname, TypeDesc datatype, void *data) = 0;
/// Get the ImageSpec associated with the named image (the first
/// subimage & miplevel by default, or as set by 'subimage' and
/// 'miplevel'). If the file is found and is an image format that
/// can be read, store a copy of its specification in spec and
/// return true. Return false if the file was not found or could
/// not be opened as an image file by any available ImageIO plugin.
virtual bool get_imagespec (ustring filename, ImageSpec &spec,
int subimage=0, int miplevel=0,
bool native=false) = 0;
virtual bool get_imagespec (ImageHandle *file, Perthread *thread_info,
ImageSpec &spec,
int subimage=0, int miplevel=0,
bool native=false) = 0;
/// Return a pointer to an ImageSpec associated with the named image
/// (the first subimage & miplevel by default, or as set by
/// 'subimage' and 'miplevel') if the file is found and is an image
/// format that can be read, otherwise return NULL.
///
/// This method is much more efficient than get_imagespec(), since
/// it just returns a pointer to the spec held internally by the
/// ImageCache (rather than copying the spec to the user's memory).
/// However, the caller must beware that the pointer is only valid
/// as long as nobody (even other threads) calls invalidate() on the
/// file, or invalidate_all(), or destroys the ImageCache.
virtual const ImageSpec *imagespec (ustring filename, int subimage=0,
int miplevel=0, bool native=false) = 0;
virtual const ImageSpec *imagespec (ImageHandle *file,
Perthread *thread_info,
int subimage=0, int miplevel=0,
bool native=false) = 0;
/// Retrieve the rectangle of pixels spanning [xbegin..xend) X
/// [ybegin..yend) X [zbegin..zend), with "exclusive end" a la STL,
/// specified as integer pixel coordinates in the designated
/// subimage & miplevel, storing the pixel values beginning at the
/// address specified by result. The pixel values will be converted
/// to the type specified by format. It is up to the caller to
/// ensure that result points to an area of memory big enough to
/// accommodate the requested rectangle (taking into consideration
/// its dimensions, number of channels, and data format). Requested
/// pixels outside the valid pixel data region will be filled in
/// with 0 values.
///
/// Return true if the file is found and could be opened by an
/// available ImageIO plugin, otherwise return false.
virtual bool get_pixels (ustring filename, int subimage, int miplevel,
int xbegin, int xend, int ybegin, int yend,
int zbegin, int zend,
TypeDesc format, void *result) = 0;
virtual bool get_pixels (ImageHandle *file, Perthread *thread_info,
int subimage, int miplevel,
int xbegin, int xend, int ybegin, int yend,
int zbegin, int zend,
TypeDesc format, void *result) = 0;
/// Retrieve the rectangle of pixels spanning [xbegin..xend) X
/// [ybegin..yend) X [zbegin..zend), channels [chbegin..chend),
/// with "exclusive end" a la STL, specified as integer pixel
/// coordinates in the designated subimage & miplevel, storing the
/// pixel values beginning at the address specified by result and
/// with the given x, y, and z strides (in bytes). The pixel values
/// will be converted to the type specified by format. If the
/// strides are set to AutoStride, they will be automatically
/// computed assuming a contiguous data layout. It is up to the
/// caller to ensure that result points to an area of memory big
/// enough to accommodate the requested rectangle (taking into
/// consideration its dimensions, number of channels, and data
/// format). Requested pixels outside the valid pixel data region
/// will be filled in with 0 values. The optional cache_chbegin and
/// cache_chend hint as to which range of channels should be cached
/// (which by default will be all channels of the file).
///
/// Return true if the file is found and could be opened by an
/// available ImageIO plugin, otherwise return false.
virtual bool get_pixels (ustring filename,
int subimage, int miplevel, int xbegin, int xend,
int ybegin, int yend, int zbegin, int zend,
int chbegin, int chend, TypeDesc format, void *result,
stride_t xstride=AutoStride, stride_t ystride=AutoStride,
stride_t zstride=AutoStride,
int cache_chbegin = 0, int cache_chend = -1) = 0;
virtual bool get_pixels (ImageHandle *file, Perthread *thread_info,
int subimage, int miplevel, int xbegin, int xend,
int ybegin, int yend, int zbegin, int zend,
int chbegin, int chend, TypeDesc format, void *result,
stride_t xstride=AutoStride, stride_t ystride=AutoStride,
stride_t zstride=AutoStride,
int cache_chbegin = 0, int cache_chend = -1) = 0;
/// Define an opaque data type that allows us to have a pointer
/// to a tile but without exposing any internals.
class Tile;
/// Find a tile given by an image filename, subimage & miplevel, channel
/// range, and pixel coordinates. An opaque pointer to the tile will be
/// returned, or NULL if no such file (or tile within the file) exists
/// or can be read. The tile will not be purged from the cache until
/// after release_tile() is called on the tile pointer the same number
/// of times that get_tile() was called (refcnt). This is thread-safe!
/// If chend < chbegin, it will retrieve a tile containing all channels
/// in the file.
virtual Tile * get_tile (ustring filename, int subimage, int miplevel,
int x, int y, int z,
int chbegin = 0, int chend = -1) = 0;
virtual Tile * get_tile (ImageHandle *file, Perthread *thread_info,
int subimage, int miplevel,
int x, int y, int z,
int chbegin = 0, int chend = -1) = 0;
/// After finishing with a tile, release_tile will allow it to
/// once again be purged from the tile cache if required.
virtual void release_tile (Tile *tile) const = 0;
/// Retrieve the data type of the pixels stored in the tile, which may
/// be different than the type of the pixels in the disk file.
virtual TypeDesc tile_format (const Tile *tile) const = 0;
/// Retrieve the ROI describing the pixels and channels stored in the
/// tile.
virtual ROI tile_roi (const Tile *tile) const = 0;
/// For a tile retrived by get_tile(), return a pointer to the
/// pixel data itself, and also store in 'format' the data type that
/// the pixels are internally stored in (which may be different than
/// the data type of the pixels in the disk file).
virtual const void * tile_pixels (Tile *tile, TypeDesc &format) const = 0;
/// The add_file() call causes a file to be opened or added to the
/// cache. There is no reason to use this method unless you are
/// supplying a custom creator, or configuration, or both.
///
/// If creator is not NULL, it points to an ImageInput::Creator that
/// will be used rather than the default ImageInput::create(), thus
/// instead of reading from disk, creates and uses a custom ImageInput
/// to generate the image. The 'creator' is a factory that creates the
/// custom ImageInput and will be called like this:
/// ImageInput *in = creator();
/// Once created, the ImageCache owns the ImageInput and is responsible
/// for destroying it when done. Custom ImageInputs allow "procedural"
/// images, among other things. Also, this is the method you use to set
/// up a "writeable" ImageCache images (perhaps with a type of
/// ImageInput that's just a stub that does as little as possible).
///
/// If config is not NULL, it points to an ImageSpec with configuration
/// options/hints that will be passed to the underlying
/// ImageInput::open() call. Thus, this can be used to ensure that the
/// ImageCache opens a call with special configuration options.
///
/// This call (including any custom creator or configuration hints) will
/// have no effect if there's already an image by the same name in the
/// cache. Custom creators or configurations only "work" the FIRST time
/// a particular filename is referenced in the lifetime of the
/// ImageCache.
virtual bool add_file (ustring filename, ImageInput::Creator creator=NULL,
const ImageSpec *config=NULL) = 0;
/// Preemptively add a tile corresponding to the named image, at the
/// given subimage, MIP level, and channel range. The tile added is the
/// one whose corner is (x,y,z), and buffer points to the pixels (in the
/// given format, with supplied strides) which will be copied and
/// inserted into the cache and made available for future lookups.
/// If chend < chbegin, it will add a tile containing the full set of
/// channels for the image.
virtual bool add_tile (ustring filename, int subimage, int miplevel,
int x, int y, int z, int chbegin, int chend,
TypeDesc format, const void *buffer,
stride_t xstride=AutoStride, stride_t ystride=AutoStride,
stride_t zstride=AutoStride) = 0;
OIIO_DEPRECATED("Use the version of add_tile with channel range. [1.6]")
virtual bool add_tile (ustring filename, int subimage, int miplevel,
int x, int y, int z, TypeDesc format, const void *buffer,
stride_t xstride=AutoStride, stride_t ystride=AutoStride,
stride_t zstride=AutoStride) {
return add_tile (filename, subimage, miplevel, x, y, z, 0, -1,
format, buffer, xstride, ystride, zstride);
}
/// If any of the API routines returned false indicating an error,
/// this routine will return the error string (and clear any error
/// flags). If no error has occurred since the last time geterror()
/// was called, it will return an empty string.
virtual std::string geterror () const = 0;
/// Return the statistics output as a huge string.
///
virtual std::string getstats (int level=1) const = 0;
/// Reset most statistics to be as they were with a fresh
/// ImageCache. Caveat emptor: this does not flush the cache itelf,
/// so the resulting statistics from the next set of texture
/// requests will not match the number of tile reads, etc., that
/// would have resulted from a new ImageCache.
virtual void reset_stats () = 0;
/// Invalidate any loaded tiles or open file handles associated with
/// the filename, so that any subsequent queries will be forced to
/// re-open the file or re-load any tiles (even those that were
/// previously loaded and would ordinarily be reused). A client
/// might do this if, for example, they are aware that an image
/// being held in the cache has been updated on disk. This is safe
/// to do even if other procedures are currently holding
/// reference-counted tile pointers from the named image, but those
/// procedures will not get updated pixels until they release the
/// tiles they are holding.
virtual void invalidate (ustring filename) = 0;
/// Invalidate all loaded tiles and open file handles. This is safe
/// to do even if other procedures are currently holding
/// reference-counted tile pointers from the named image, but those
/// procedures will not get updated pixels until they release the
/// tiles they are holding. If force is true, everything will be
/// invalidated, no matter how wasteful it is, but if force is
/// false, in actuality files will only be invalidated if their
/// modification times have been changed since they were first
/// opened.
virtual void invalidate_all (bool force=false) = 0;
private:
// Make delete private and unimplemented in order to prevent apps
// from calling it. Instead, they should call ImageCache::destroy().
void operator delete (void * /*todel*/) { }
};
OIIO_NAMESPACE_END
#endif // OPENIMAGEIO_IMAGECACHE_H
|