*/
package mircoders.media;
-import java.io.StringReader;
-
import mir.entity.Entity;
import mir.log.LoggerWrapper;
import mir.media.MediaExc;
import mir.media.MediaFailure;
import mir.media.MediaHandler;
-import mir.misc.FileUtil;
import mir.misc.StringUtil;
+import mir.util.IORoutines;
+
+import java.io.File;
+import java.io.FileOutputStream;
/**
* Please note: this media handler produces
*
* @see mir.media.MediaHandler
* @author mh <mh@nadir.org>
- * @version $Id: MediaHandlerMp3.java,v 1.15.2.6 2005/02/10 16:22:23 rhindes Exp $
+ * @version $Id: MediaHandlerMp3.java,v 1.15.2.7 2005/08/21 17:09:23 zapata Exp $
*/
-public class MediaHandlerMp3 extends MediaHandlerAudio implements MediaHandler
-{
-
+public class MediaHandlerMp3 extends MediaHandlerAudio implements MediaHandler {
public MediaHandlerMp3() {
logger = new LoggerWrapper("Media.Audio.Mp3");
}
+ /**
+ * {@inheritDoc}
+ */
public void produce(Entity ent, Entity mediaTypeEnt) throws MediaExc, MediaFailure {
-
- // first check if the file exists
super.produce(ent, mediaTypeEnt);
String baseName = ent.getId();
String playlistFile = baseName + ".pls";
try {
- //write the "meta" files
- //first the .m3u since it only contains one line
- FileUtil.write(getStoragePath() + "/" + datePath + "/" + mpegURLFile,
- new StringReader(mp3Pointer), "US-ASCII");
- //now the .pls file
- FileUtil.write(getStoragePath() + "/" + datePath + "/" + playlistFile,
- new StringReader(mp3Pointer), "US-ASCII");
+ IORoutines.writeStream(mp3Pointer, "us-ascii",
+ new FileOutputStream(new File(getBaseStoragePath() + "/" + datePath + "/" + mpegURLFile)));
+
+ IORoutines.writeStream(mp3Pointer, "us-ascii",
+ new FileOutputStream(new File(getBaseStoragePath() + "/" + datePath + "/" + playlistFile)));
}
catch (Throwable e) {
- logger.error("MediaHandlerMp3.produce: " + e.toString());
+ logger.error("MediaHandlerMp3.execute: " + e.toString());
throw new MediaFailure(e);
}