summaryrefslogtreecommitdiffstats
path: root/drm
diff options
context:
space:
mode:
authorJeff Sharkey <jsharkey@android.com>2012-12-17 17:03:11 -0800
committerJeff Sharkey <jsharkey@android.com>2012-12-17 17:04:16 -0800
commit7ccc90955fad0701b6b14c813a2850ee4149c5a2 (patch)
tree739a3713dfef5518ed642f8602593fd8b772b28a /drm
parentf67c8a9685e0f20d5ffb9de95f6d1ce47f052141 (diff)
downloadframeworks_base-7ccc90955fad0701b6b14c813a2850ee4149c5a2.zip
frameworks_base-7ccc90955fad0701b6b14c813a2850ee4149c5a2.tar.gz
frameworks_base-7ccc90955fad0701b6b14c813a2850ee4149c5a2.tar.bz2
Move stream creation outside of DrmOutputStream.
More closely matches the object ownership pattern used by other stream APIs. Callers must now explicitly finish(). Also fixes write(int) bug by switching to Streams API. Change-Id: I64f9c5887ef02496b1ce4e97ce6af5dad93b4be2
Diffstat (limited to 'drm')
-rw-r--r--drm/java/android/drm/DrmOutputStream.java67
1 files changed, 34 insertions, 33 deletions
diff --git a/drm/java/android/drm/DrmOutputStream.java b/drm/java/android/drm/DrmOutputStream.java
index 2e1b756..87677b8 100644
--- a/drm/java/android/drm/DrmOutputStream.java
+++ b/drm/java/android/drm/DrmOutputStream.java
@@ -17,8 +17,10 @@
package android.drm;
import static android.drm.DrmConvertedStatus.STATUS_OK;
+import static android.drm.DrmManagerClient.INVALID_SESSION;
+
+import android.util.Log;
-import java.io.File;
import java.io.FilterOutputStream;
import java.io.IOException;
import java.io.OutputStream;
@@ -26,8 +28,7 @@ import java.io.RandomAccessFile;
import java.net.UnknownServiceException;
import java.util.Arrays;
-import libcore.io.IoUtils;
-import libcore.util.SneakyThrow;
+import libcore.io.Streams;
/**
* Stream that applies a {@link DrmManagerClient} transformation to data before
@@ -36,45 +37,45 @@ import libcore.util.SneakyThrow;
* @hide
*/
public class DrmOutputStream extends OutputStream {
+ private static final String TAG = "DrmOutputStream";
private final DrmManagerClient mClient;
+ private final RandomAccessFile mFile;
- private int mSessionId;
- private RandomAccessFile mOutput;
+ private int mSessionId = INVALID_SESSION;
- public DrmOutputStream(DrmManagerClient client, File file, String mimeType) throws IOException {
+ /**
+ * @param file Opened with "rw" mode.
+ */
+ public DrmOutputStream(DrmManagerClient client, RandomAccessFile file, String mimeType)
+ throws IOException {
mClient = client;
- mOutput = new RandomAccessFile(file, "rw");
-
- try {
- mSessionId = mClient.openConvertSession(mimeType);
- if (mSessionId == DrmManagerClient.INVALID_SESSION) {
- throw new UnknownServiceException("Failed to open DRM session for " + mimeType);
- }
- } catch (Throwable thrown) {
- IoUtils.closeQuietly(mOutput);
- SneakyThrow.sneakyThrow(thrown);
+ mFile = file;
+
+ mSessionId = mClient.openConvertSession(mimeType);
+ if (mSessionId == INVALID_SESSION) {
+ throw new UnknownServiceException("Failed to open DRM session for " + mimeType);
+ }
+ }
+
+ public void finish() throws IOException {
+ final DrmConvertedStatus status = mClient.closeConvertSession(mSessionId);
+ if (status.statusCode == STATUS_OK) {
+ mFile.seek(status.offset);
+ mFile.write(status.convertedData);
+ mSessionId = INVALID_SESSION;
+ } else {
+ throw new IOException("Unexpected DRM status: " + status.statusCode);
}
}
@Override
public void close() throws IOException {
- try {
- final DrmConvertedStatus status = mClient.closeConvertSession(mSessionId);
- if (status.statusCode == STATUS_OK) {
- mOutput.seek(status.offset);
- mOutput.write(status.convertedData);
- } else {
- throw new IOException("Unexpected DRM status: " + status.statusCode);
- }
- } finally {
- try {
- mOutput.getFD().sync();
- } finally {
- mOutput.close();
- mOutput = null;
- }
+ if (mSessionId == INVALID_SESSION) {
+ Log.w(TAG, "Closing stream without finishing");
}
+
+ mFile.close();
}
@Override
@@ -91,7 +92,7 @@ public class DrmOutputStream extends OutputStream {
final DrmConvertedStatus status = mClient.convertData(mSessionId, exactBuffer);
if (status.statusCode == STATUS_OK) {
- mOutput.write(status.convertedData);
+ mFile.write(status.convertedData);
} else {
throw new IOException("Unexpected DRM status: " + status.statusCode);
}
@@ -99,6 +100,6 @@ public class DrmOutputStream extends OutputStream {
@Override
public void write(int oneByte) throws IOException {
- write(new byte[] { (byte) oneByte });
+ Streams.writeSingleByte(this, oneByte);
}
}