- /* try MP3 now. */
- rememberingInputStream = new RememberingInputStream(rememberingInputStream.remembered());
- InputStream limitedInputStream = ByteStreams.limit(rememberingInputStream, 1048576);
- metadata = Mp3Identifier.identify(limitedInputStream);
- if (metadata.isPresent()) {
- return Optional.of(new IdentifyingInputStream(rememberingInputStream.remembered(), metadata.get()));
+ /* try Ogg Vorbis next. */
+ try {
+ rememberingInputStream = new RememberingInputStream(rememberingInputStream.remembered());
+ Optional<Metadata> metadata = OggVorbisIdentifier.identify(rememberingInputStream);
+ if (metadata.isPresent()) {
+ return Optional.of(new IdentifyingInputStream(rememberingInputStream.remembered(), metadata.get()));
+ }
+ } catch (EOFException eofe1) {
+ /* ignore. */
+ }
+
+ /* finally, try MP3. */
+ try {
+ rememberingInputStream = new RememberingInputStream(rememberingInputStream.remembered());
+ InputStream limitedInputStream = ByteStreams.limit(rememberingInputStream, 1048576);
+ Optional<Metadata> metadata = Mp3Identifier.identify(limitedInputStream);
+ if (metadata.isPresent()) {
+ return Optional.of(new IdentifyingInputStream(rememberingInputStream.remembered(), metadata.get()));
+ }
+ } catch (EOFException eofe1) {
+ /* ignore. */