/*
* TV-Browser
* Copyright (C) 04-2003 Martin Oberhauser (darras@users.sourceforge.net)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
* CVS information:
* $RCSfile$
* $Source$
* $Date: 2010-01-20 23:52:45 +0100 (Wed, 20 Jan 2010) $
* $Author: bananeweizen $
* $Revision: 6381 $
*/
package tvbrowserdataservice;
import java.io.File;
import java.io.InputStream;
import java.util.logging.Logger;
import tvbrowserdataservice.file.DayProgramFile;
import util.exc.TvBrowserException;
import util.io.DownloadHandler;
import util.io.DownloadJob;
/**
*
*
* @author Til Schneider, www.murfman.de
*/
public class DayProgramReceiveDH implements DownloadHandler {
private static final Logger mLog
= Logger.getLogger(DayProgramReceiveDH.class.getName());
private TvBrowserDataService mDataService;
private TvDataBaseUpdater mUpdater;
/**
* Creates a new DayProgramReceiveDH.
*
* @param dataService The dataservice of the data to receive.
* @param updater The TvDataBaseUpdater.
*/
public DayProgramReceiveDH(TvBrowserDataService dataService,
TvDataBaseUpdater updater)
{
mDataService = dataService;
mUpdater = updater;
}
public void handleDownload(DownloadJob job, InputStream stream)
throws TvBrowserException
{
mLog.fine("Receiving file " + job.getFileName());
File completeFile = new File(mDataService.getDataDir(), job.getFileName());
try {
DayProgramFile prog = new DayProgramFile();
prog.readFromStream(stream, job);
// When we are here then the loading succeed -> The file is OK.
// It is not a corrupt because it is currently being updated.
// Save the day program
prog.writeToFile(completeFile);
// Tell the database updater that this file needs an update
mUpdater.addUpdateJobForDayProgramFile(job.getFileName());
}
catch (Exception exc) {
throw new TvBrowserException(getClass(), "error.1",
"Saving dayprogram file failed: {0}", completeFile.getAbsolutePath(),
exc);
}
finally {
mDataService.checkCancelDownload();
}
}
public void handleFileNotFound(String fileName) throws TvBrowserException {
// There is no data for this day
mDataService.checkCancelDownload();
}
}