/*
dumpTask.java
Runnable class to do a journal sync. Issued by the GanymedeScheduler
Created: 20 May 2004
Module By: Jonathan Abbey, jonabbey@arlut.utexas.edu
-----------------------------------------------------------------------
Ganymede Directory Management System
Copyright (C) 1996-2014
The University of Texas at Austin
Contact information
Web site: http://www.arlut.utexas.edu/gash2
Author Email: ganymede_author@arlut.utexas.edu
Email mailing list: ganymede@arlut.utexas.edu
US Mail:
Computer Science Division
Applied Research Laboratories
The University of Texas at Austin
PO Box 8029, Austin TX 78713-8029
Telephone: (512) 835-3200
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, see <http://www.gnu.org/licenses/>.
*/
package arlut.csd.ganymede.server;
import java.io.IOException;
import arlut.csd.Util.TranslationService;
/*------------------------------------------------------------------------------
class
dumpTask
------------------------------------------------------------------------------*/
/**
* <p>Runnable class to do a journal sync. Issued by the
* {@link arlut.csd.ganymede.server.GanymedeScheduler GanymedeScheduler}.</p>
*/
class dumpTask implements Runnable {
static TranslationService ts = TranslationService.getTranslationService("arlut.csd.ganymede.server.dumpTask");
public dumpTask()
{
}
public void run()
{
boolean started = false;
boolean completed = false;
boolean gotSemaphore = false;
/* -- */
try
{
if (Ganymede.db.journal.isClean())
{
Ganymede.debug(ts.l("deferring"));
return;
}
String error = GanymedeServer.lSemaphore.increment();
if (error != null)
{
Ganymede.debug(ts.l("semaphore_disabled", error));
return;
}
else
{
gotSemaphore = true;
}
started = true;
Ganymede.debug(ts.l("running", Integer.valueOf(Ganymede.db.journal.getTransactionsInJournal())));
try
{
Ganymede.db.dump(Ganymede.dbFilename, true, false);
}
catch (IOException ex)
{
Ganymede.debug(ts.l("dump_error", ex.getMessage()));
}
catch (InterruptedException ex)
{
Ganymede.debug(ts.l("dump_interrupted_error", ex.getMessage()));
}
completed = true;
}
finally
{
// we'll go through here if our task was stopped
// note that the DBStore dump code will handle
// thread death ok.
if (started && !completed)
{
Ganymede.debug(ts.l("forced_stop"));
}
if (gotSemaphore)
{
GanymedeServer.lSemaphore.decrement();
}
Ganymede.debug(ts.l("completed"));
}
}
}