DO NOT MERGE) ExifInterface: Make saveAttributes throw an exception before change am: 659275dc30
am: 8d3e6bd3ef
Change-Id: I83f7733039ee73407aa5d7f3848ad1074e9dfb03
This commit is contained in:
@ -1034,6 +1034,7 @@ public class ExifInterface {
|
|||||||
private int mThumbnailOffset;
|
private int mThumbnailOffset;
|
||||||
private int mThumbnailLength;
|
private int mThumbnailLength;
|
||||||
private byte[] mThumbnailBytes;
|
private byte[] mThumbnailBytes;
|
||||||
|
private boolean mIsSupportedFile;
|
||||||
|
|
||||||
// Pattern to check non zero timestamp
|
// Pattern to check non zero timestamp
|
||||||
private static final Pattern sNonZeroTimePattern = Pattern.compile(".*[1-9].*");
|
private static final Pattern sNonZeroTimePattern = Pattern.compile(".*[1-9].*");
|
||||||
@ -1332,9 +1333,11 @@ public class ExifInterface {
|
|||||||
try {
|
try {
|
||||||
InputStream in = new FileInputStream(mFilename);
|
InputStream in = new FileInputStream(mFilename);
|
||||||
getJpegAttributes(in);
|
getJpegAttributes(in);
|
||||||
|
mIsSupportedFile = true;
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
// Ignore exceptions in order to keep the compatibility with the old versions of
|
// Ignore exceptions in order to keep the compatibility with the old versions of
|
||||||
// ExifInterface.
|
// ExifInterface.
|
||||||
|
mIsSupportedFile = false;
|
||||||
Log.w(TAG, "Invalid image.", e);
|
Log.w(TAG, "Invalid image.", e);
|
||||||
} finally {
|
} finally {
|
||||||
addDefaultValuesForCompatibility();
|
addDefaultValuesForCompatibility();
|
||||||
@ -1363,6 +1366,10 @@ public class ExifInterface {
|
|||||||
* and make a single call rather than multiple calls for each attribute.
|
* and make a single call rather than multiple calls for each attribute.
|
||||||
*/
|
*/
|
||||||
public void saveAttributes() throws IOException {
|
public void saveAttributes() throws IOException {
|
||||||
|
if (!mIsSupportedFile) {
|
||||||
|
throw new UnsupportedOperationException(
|
||||||
|
"ExifInterface only supports saving attributes on JPEG formats.");
|
||||||
|
}
|
||||||
// Keep the thumbnail in memory
|
// Keep the thumbnail in memory
|
||||||
mThumbnailBytes = getThumbnail();
|
mThumbnailBytes = getThumbnail();
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user