diff --git a/starboard/android/apk/app/src/main/java/dev/cobalt/media/MediaCodecBridge.java b/starboard/android/apk/app/src/main/java/dev/cobalt/media/MediaCodecBridge.java index 6fa4e720b759..cbf1cbf068f7 100644 --- a/starboard/android/apk/app/src/main/java/dev/cobalt/media/MediaCodecBridge.java +++ b/starboard/android/apk/app/src/main/java/dev/cobalt/media/MediaCodecBridge.java @@ -752,10 +752,10 @@ public static void createVideoMediaCodecBridge( // outCreateMediaCodecBridgeResult.mErrorMessage is set inside configureVideo() on error. return; } - if (!bridge.start()) { + if (!bridge.start(outCreateMediaCodecBridgeResult)) { Log.e(TAG, "Failed to start video codec."); bridge.release(); - outCreateMediaCodecBridgeResult.mErrorMessage = "Failed to start video codec"; + // outCreateMediaCodecBridgeResult.mErrorMessage is set inside start() on error. return; } @@ -777,13 +777,21 @@ public void release() { mMediaCodec.set(null); } + public boolean start() { + return start(null); + } + @SuppressWarnings("unused") @UsedByNative - public boolean start() { + public boolean start(CreateMediaCodecBridgeResult outCreateMediaCodecBridgeResult) { try { mMediaCodec.get().start(); } catch (IllegalStateException | IllegalArgumentException e) { - Log.e(TAG, "Cannot start the media codec", e); + Log.e(TAG, "Failed to start the media codec", e); + if (outCreateMediaCodecBridgeResult != null) { + outCreateMediaCodecBridgeResult.mErrorMessage = + "Failed to start media codec " + e.toString(); + } return false; } return true;