aboutsummaryrefslogtreecommitdiffstats
path: root/src/exiv2wrapper.cpp
diff options
context:
space:
mode:
authorOlivier Tilloy <olivier@tilloy.net>2010-01-21 20:10:45 +0100
committerOlivier Tilloy <olivier@tilloy.net>2010-01-21 20:10:45 +0100
commit2a5a7a4eee4ccb4eed8999f7cd4635d85d6c9dcd (patch)
tree70ffea8b5b9242f7e2c0fcdef60d089ce7083502 /src/exiv2wrapper.cpp
parent8e5e6e590687a1cfb5be7da367ac9dd7501260ca (diff)
downloadpyexiv2-2a5a7a4eee4ccb4eed8999f7cd4635d85d6c9dcd.tar.gz
Updated error codes translation to the errors defined in libexiv2 0.19.
Diffstat (limited to 'src/exiv2wrapper.cpp')
-rw-r--r--src/exiv2wrapper.cpp230
1 files changed, 206 insertions, 24 deletions
diff --git a/src/exiv2wrapper.cpp b/src/exiv2wrapper.cpp
index a8f328a..08864a0 100644
--- a/src/exiv2wrapper.cpp
+++ b/src/exiv2wrapper.cpp
@@ -730,7 +730,6 @@ void Preview::writeToFile(const std::string& path) const
}
-// TODO: update the errors code to reflect changes from src/error.cpp in libexiv2
void translateExiv2Error(Exiv2::Error const& error)
{
// Use the Python 'C' API to set up an exception object
@@ -741,57 +740,239 @@ void translateExiv2Error(Exiv2::Error const& error)
// defined by Exiv2 (file 'src/error.cpp') are changed
switch (error.code())
{
- case -2:
- case -1:
- case 1:
+ // Exiv2 error codes
case 2:
+ // {path}: Call to `{function}' failed: {strerror}
+ // May be raised when reading a file
PyErr_SetString(PyExc_RuntimeError, message);
break;
case 3:
+ // This does not look like a {image type} image
+ // May be raised by readMetadata()
+ PyErr_SetString(PyExc_IOError, message);
+ break;
+ case 4:
+ // Invalid dataset name `{dataset name}'
+ // May be raised when instantiating an IptcKey from a string
+ PyErr_SetString(PyExc_KeyError, message);
+ break;
+ case 5:
+ // Invalid record name `{record name}'
+ // May be raised when instantiating an IptcKey from a string
+ PyErr_SetString(PyExc_KeyError, message);
+ break;
+ case 6:
+ // Invalid key `{key}'
+ // May be raised when instantiating an ExifKey, an IptcKey or an
+ // XmpKey from a string
+ PyErr_SetString(PyExc_KeyError, message);
+ break;
+ case 7:
+ // Invalid tag name or ifdId `{tag name}', ifdId {ifdId}
+ // May be raised when instantiating an ExifKey from a string
+ PyErr_SetString(PyExc_KeyError, message);
+ break;
+ case 8:
+ // Value not set
+ // May be raised when calling value() on a datum
+ PyErr_SetString(PyExc_ValueError, message);
+ break;
case 9:
+ // {path}: Failed to open the data source: {strerror}
+ // May be raised by readMetadata()
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 10:
+ // {path}: Failed to open file ({mode}): {strerror}
+ // May be raised by writeMetadata()
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 11:
+ // {path}: The file contains data of an unknown image type
+ // May be raised when opening an image
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 12:
+ // The memory contains data of an unknown image type
+ // May be raised when instantiating an image from a data buffer
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 13:
+ // Image type {image type} is not supported
+ // May be raised when creating a new image
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 14:
+ // Failed to read image data
+ // May be raised by readMetadata()
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 15:
+ // This does not look like a JPEG image
+ // May be raised by readMetadata()
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 17:
+ // {old path}: Failed to rename file to {new path}: {strerror}
+ // May be raised by writeMetadata()
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 18:
+ // {path}: Transfer failed: {strerror}
+ // May be raised by writeMetadata()
+ PyErr_SetString(PyExc_IOError, message);
+ break;
+ case 19:
+ // Memory transfer failed: {strerror}
+ // May be raised by writeMetadata()
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 20:
- case 21:
- case 23:
- case 31:
- case 32:
- case 33:
- case 36:
- case 37:
+ // Failed to read input data
+ // May be raised by writeMetadata()
PyErr_SetString(PyExc_IOError, message);
break;
- case 4:
- case 5:
- case 6:
- case 7:
- PyErr_SetString(PyExc_IndexError, message);
+ case 21:
+ // Failed to write image
+ // May be raised by writeMetadata()
+ PyErr_SetString(PyExc_IOError, message);
break;
- case 8:
case 22:
- case 24:
- case 25:
+ // Input data does not contain a valid image
+ // May be raised by writeMetadata()
+ PyErr_SetString(PyExc_IOError, message);
+ break;
+ case 23:
+ // Invalid ifdId {ifdId}
+ // May be raised when instantiating an ExifKey from a tag and
+ // IFD item string
+ PyErr_SetString(PyExc_KeyError, message);
+ break;
case 26:
+ // Offset out of range
+ // May be raised by writeMetadata() (TIFF)
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 27:
+ // Unsupported data area offset type
+ // May be raised by writeMetadata() (TIFF)
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 28:
+ // Invalid charset: `{charset name}'
+ // May be raised when instantiating a CommentValue from a string
+ PyErr_SetString(PyExc_ValueError, message);
+ break;
case 29:
+ // Unsupported date format
+ // May be raised when instantiating a DateValue from a string
+ PyErr_SetString(PyExc_ValueError, message);
+ break;
case 30:
- case 34:
+ // Unsupported time format
+ // May be raised when instantiating a TimeValue from a string
PyErr_SetString(PyExc_ValueError, message);
break;
- case 16:
- case 19:
+ case 31:
+ // Writing to {image format} images is not supported
+ // May be raised by writeMetadata() for certain image types
+ PyErr_SetString(PyExc_IOError, message);
+ break;
+ case 32:
+ // Setting {metadata type} in {image format} images is not supported
+ // May be raised when setting certain types of metadata for certain
+ // image types that don't support them
+ PyErr_SetString(PyExc_ValueError, message);
+ break;
+ case 33:
+ // This does not look like a CRW image
+ // May be raised by readMetadata() (CRW)
+ PyErr_SetString(PyExc_IOError, message);
+ break;
case 35:
- PyErr_SetString(PyExc_MemoryError, message);
+ // No namespace info available for XMP prefix `{prefix}'
+ // May be raised when retrieving property info for an XmpKey
+ PyErr_SetString(PyExc_KeyError, message);
+ break;
+ case 36:
+ // No prefix registered for namespace `{namespace}', needed for
+ // property path `{property path}'
+ // May be raised by readMetadata() when reading the XMP data
+ PyErr_SetString(PyExc_KeyError, message);
+ break;
+ case 37:
+ // Size of {type of metadata} JPEG segment is larger than
+ // 65535 bytes
+ // May be raised by writeMetadata() (JPEG)
+ PyErr_SetString(PyExc_ValueError, message);
+ break;
+ case 38:
+ // Unhandled Xmpdatum {key} of type {value type}
+ // May be raised by readMetadata() when reading the XMP data
+ PyErr_SetString(PyExc_TypeError, message);
+ break;
+ case 39:
+ // Unhandled XMP node {key} with opt={XMP Toolkit option flags}
+ // May be raised by readMetadata() when reading the XMP data
+ PyErr_SetString(PyExc_TypeError, message);
+ break;
+ case 40:
+ // XMP Toolkit error {error id}: {error message}
+ // May be raised by readMetadata() when reading the XMP data
+ PyErr_SetString(PyExc_RuntimeError, message);
+ break;
+ case 41:
+ // Failed to decode Lang Alt property {property path}
+ // with opt={XMP Toolkit option flags}
+ // May be raised by readMetadata() when reading the XMP data
+ PyErr_SetString(PyExc_ValueError, message);
+ break;
+ case 42:
+ // Failed to decode Lang Alt qualifier {qualifier path}
+ // with opt={XMP Toolkit option flags}
+ // May be raised by readMetadata() when reading the XMP data
+ PyErr_SetString(PyExc_ValueError, message);
+ break;
+ case 43:
+ // Failed to encode Lang Alt property {key}
+ // May be raised by writeMetadata()
+ PyErr_SetString(PyExc_ValueError, message);
+ break;
+ case 44:
+ // Failed to determine property name from path {property path},
+ // namespace {namespace}
+ // May be raised by readMetadata() when reading the XMP data
+ PyErr_SetString(PyExc_KeyError, message);
+ break;
+ case 45:
+ // Schema namespace {namespace} is not registered with
+ // the XMP Toolkit
+ // May be raised by readMetadata() when reading the XMP data
+ PyErr_SetString(PyExc_ValueError, message);
+ break;
+ case 46:
+ // No namespace registered for prefix `{prefix}'
+ // May be raised when instantiating an XmpKey from a string
+ PyErr_SetString(PyExc_KeyError, message);
+ break;
+ case 47:
+ // Aliases are not supported. Please send this XMP packet
+ // to ahuggel@gmx.net `{namespace}', `{property path}', `{value}'
+ // May be raised by readMetadata() when reading the XMP data
+ PyErr_SetString(PyExc_ValueError, message);
+ break;
+ case 48:
+ // Invalid XmpText type `{type}'
+ // May be raised when instantiating an XmpTextValue from a string
+ PyErr_SetString(PyExc_TypeError, message);
+ break;
+ case 49:
+ // TIFF directory {TIFF directory name} has too many entries
+ // May be raised by writeMetadata() (TIFF)
+ PyErr_SetString(PyExc_IOError, message);
break;
- // custom error codes
+ // Custom error codes
case METADATA_NOT_READ:
PyErr_SetString(PyExc_IOError, "Image metadata has not been read yet");
break;
@@ -802,6 +983,7 @@ void translateExiv2Error(Exiv2::Error const& error)
PyErr_SetString(PyExc_KeyError, "Tag not set");
break;
+ // Default handler
default:
PyErr_SetString(PyExc_RuntimeError, message);
}