/* * eXist Open Source Native XML Database * Copyright (C) 2001-04 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., 675 Mass Ave, Cambridge, MA 02139, USA. * * $Id$ */ 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(Txn transaction, long pageNum, int splitOffset, byte[] oldData, int oldLen) { super(DOMFile.LOG_SPLIT_PAGE, transaction.getId()); this.pageNum = pageNum; this.splitOffset = splitOffset; this.oldData = oldData; this.oldLen = oldLen; } /** * * * @param broker * @param transactId */ public SplitPageLoggable(DBBroker broker, long transactId) { super(DOMFile.LOG_SPLIT_PAGE, transactId); this.domDb = ((NativeBroker)broker).getDOMFile(); } /* (non-Javadoc) * @see org.exist.storage.log.Loggable#write(java.nio.ByteBuffer) */ public void write(ByteBuffer out) { out.putInt((int) pageNum); out.putInt(splitOffset); out.putShort((short) oldLen); out.put(oldData, 0, oldLen); } /* (non-Javadoc) * @see org.exist.storage.log.Loggable#read(java.nio.ByteBuffer) */ public void read(ByteBuffer in) { pageNum = in.getInt(); splitOffset = in.getInt(); oldLen = in.getShort(); oldData = new byte[domDb.getFileHeader().getWorkSize()]; in.get(oldData, 0, oldLen); } /* (non-Javadoc) * @see org.exist.storage.log.Loggable#getLogSize() */ public int getLogSize() { return 10 + oldLen; } public void redo() throws LogException { domDb.redoSplitPage(this); } public void undo() throws LogException { domDb.undoSplitPage(this); } public String dump() { return super.dump() + " - page split: " + pageNum + " at offset: " + splitOffset; } }