Package de.uplanet.util.transaction
Class DirectDirectoryTransaction
- java.lang.Object
-
- de.uplanet.util.transaction.DirectDirectoryTransaction
-
- All Implemented Interfaces:
ITwoPhaseIOTransaction,ITwoPhaseTransaction
public final class DirectDirectoryTransaction extends Object
The IO operation may be done before requestCommit is called, on a call of the process method. Without a process() call the IO Operation is done by the requestCommit call.
-
-
Constructor Summary
Constructors Constructor Description DirectDirectoryTransaction(File p_dirDst, File p_dirSrc)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidcommit()Commit the transaction.FilegetBackup()FilegetDestinationDirectory()Get the destination directory.ThrowablegetLastError()FilegetSourceDirectory()Get the source directory.booleanhasBackup()booleanprocess()booleanrequestCommit()Request a file system transaction.booleanrollback()Try to rollback the directory transaction.StringtoString()
-
-
-
Constructor Detail
-
DirectDirectoryTransaction
public DirectDirectoryTransaction(File p_dirDst, File p_dirSrc) throws IOException
- Parameters:
p_dirDst-p_dirSrc-- Throws:
IOException
-
-
Method Detail
-
requestCommit
public boolean requestCommit()
Description copied from interface:ITwoPhaseTransactionRequest a file system transaction.When this method returns
trueit has sucessfully moved the source file to it's new location, and has successfully created a backup copy of the destination file, if it existed before.- Specified by:
requestCommitin interfaceITwoPhaseTransaction
-
process
public boolean process()
-
getDestinationDirectory
public final File getDestinationDirectory()
Get the destination directory.- Returns:
- The value
p_dirDstthat was passed to the contructor.
-
getSourceDirectory
public final File getSourceDirectory()
Get the source directory.- Returns:
- The value
p_dirSrcthat was passed to the contructor.
-
hasBackup
public final boolean hasBackup()
- Specified by:
hasBackupin interfaceITwoPhaseIOTransaction- Returns:
trueif the transaction has left a backup directory, orfalseotherwise (e.g. if the destination directory did not exist before the transaction).
-
getBackup
public File getBackup()
- Specified by:
getBackupin interfaceITwoPhaseIOTransaction- Returns:
- The backup directory that was left by the transaction, or
nullif none was created (e.g. if the destination directory did not exist before the transaction).
-
commit
public final void commit()
Description copied from interface:ITwoPhaseTransactionCommit the transaction.- Specified by:
commitin interfaceITwoPhaseTransaction
-
rollback
public boolean rollback()
Try to rollback the directory transaction.- Specified by:
rollbackin interfaceITwoPhaseTransaction- Returns:
trueif the rollback was successful, orfalseotherwise. In the latter caseITwoPhaseTransaction.getLastError()may give additional information about why the rollback failed, and a backup directory may exist then.
-
getLastError
public final Throwable getLastError()
- Specified by:
getLastErrorin interfaceITwoPhaseTransaction- Returns:
- The last exception that was caugth during the transaction,
or
nullif no error occurred;
-
-