/*
* eXist Open Source Native XML Database
* Copyright (C) 2001-2015 The eXist Project
*
* http://exist-db.org
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software Foundation
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
package org.exist.storage.dom;
import java.nio.ByteBuffer;
import org.exist.storage.DBBroker;
import org.exist.storage.NativeBroker;
import org.exist.storage.journal.AbstractLoggable;
import org.exist.storage.journal.LogException;
import org.exist.storage.journal.Loggable;
import org.exist.storage.txn.Txn;
/**
* @author wolf
*/
public class SplitPageLoggable extends AbstractLoggable implements Loggable {
protected long pageNum;
protected int splitOffset;
protected byte[] oldData;
protected int oldLen;
private DOMFile domDb = null;
public SplitPageLoggable(final Txn transaction, final long pageNum, final int splitOffset, final byte[] oldData,
final int oldLen) {
super(DOMFile.LOG_SPLIT_PAGE, transaction.getId());
this.pageNum = pageNum;
this.splitOffset = splitOffset;
this.oldData = oldData;
this.oldLen = oldLen;
}
public SplitPageLoggable(final DBBroker broker, final long transactId) {
super(DOMFile.LOG_SPLIT_PAGE, transactId);
this.domDb = ((NativeBroker) broker).getDOMFile();
}
@Override
public void write(final ByteBuffer out) {
out.putInt((int) pageNum);
out.putInt(splitOffset);
out.putShort((short) oldLen);
out.put(oldData, 0, oldLen);
}
@Override
public void read(final ByteBuffer in) {
pageNum = in.getInt();
splitOffset = in.getInt();
oldLen = in.getShort();
oldData = new byte[domDb.getFileHeader().getWorkSize()];
in.get(oldData, 0, oldLen);
}
@Override
public int getLogSize() {
return 10 + oldLen;
}
@Override
public void redo() throws LogException {
domDb.redoSplitPage(this);
}
@Override
public void undo() throws LogException {
domDb.undoSplitPage(this);
}
@Override
public String dump() {
return super.dump() + " - page split: " + pageNum + " at offset: " + splitOffset;
}
}