⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 t_undoable.java

📁 derby database source code.good for you.
💻 JAVA
字号:
/*   Derby - Class org.apache.derbyTesting.unitTests.store.T_DaemonService   Copyright 1997, 2005 The Apache Software Foundation or its licensors, as applicable.   Licensed under the Apache License, Version 2.0 (the "License");   you may not use this file except in compliance with the License.   You may obtain a copy of the License at      http://www.apache.org/licenses/LICENSE-2.0   Unless required by applicable law or agreed to in writing, software   distributed under the License is distributed on an "AS IS" BASIS,   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   See the License for the specific language governing permissions and   limitations under the License. */package org.apache.derbyTesting.unitTests.store;import org.apache.derbyTesting.unitTests.harness.T_Fail;import org.apache.derby.iapi.store.raw.*;import org.apache.derby.iapi.services.sanity.SanityManager;import org.apache.derby.iapi.services.io.FormatIdUtil;import org.apache.derby.iapi.services.io.Formatable;import org.apache.derby.iapi.services.io.StoredFormatIds;import org.apache.derby.iapi.error.StandardException;import org.apache.derby.iapi.store.raw.log.LogInstant;import org.apache.derby.iapi.util.ByteArray;import org.apache.derby.iapi.services.io.DynamicByteArrayOutputStream;import java.io.IOException;import java.io.IOException;import java.io.InputStream;import java.io.ObjectInput;import java.io.ObjectOutput;import java.io.StreamCorruptedException;import java.util.Vector;import java.io.OutputStream;import java.io.InputStream;import org.apache.derby.iapi.services.io.LimitObjectInput;//// Tracing can be done like so (commented out)//import org.apache.derbyTesting.unitTests.util.MsgTrace;public class T_Undoableimplements Undoable{	static final int REMOVE_NONE  = 0;	static final int REMOVE_ME    = 1;	static final int REMOVE_TO_ME = 2;	protected ByteArray preparedLog;	protected DynamicByteArrayOutputStream logBuffer;	GlobalTransactionId tid = null;	int tranSeq = -1;	int recordSeq = -1;	int removeWhat = REMOVE_NONE;	int LWMTranSeq = 0;	boolean rollBack = true;	int lastRecord = -1;	boolean lastTransaction = false;	int optionalDataLen;	boolean verbose;	// no-arg constructor, required by Formatable 	public T_Undoable() { super(); }	T_Undoable(GlobalTransactionId tid, int tranSeq, int recordSeq,			   int removeWhat, int LWMTranSeq,			   boolean rollBack, int lastRecord, boolean lastTransaction,			   int optionalDataLen,boolean verbose)		 throws T_Fail	{//MsgTrace.traceString("{{{tu.new");		T_Fail.T_ASSERT((removeWhat >= REMOVE_NONE) &&							 (removeWhat <= REMOVE_TO_ME));		T_Fail.T_ASSERT(rollBack == (recordSeq < 0));		T_Fail.T_ASSERT(rollBack == (tranSeq < 0));		this.tid = tid;		this.tranSeq = tranSeq;		this.recordSeq = recordSeq;		this.removeWhat = removeWhat;		this.LWMTranSeq = LWMTranSeq;		this.rollBack = rollBack;		this.lastRecord = lastRecord;		this.lastTransaction = lastTransaction;		this.optionalDataLen = optionalDataLen;		this.verbose = verbose;				try {			writeOptionalDataToBuffer();		} catch (IOException ioe) {			throw T_Fail.exceptionFail(ioe);		} catch (StandardException se) {			throw T_Fail.exceptionFail(se);		}//MsgTrace.traceString("}}}tu.new");	}		private void writeOptionalDataToBuffer()		throws StandardException, IOException	{		if (logBuffer == null) {			// YYZ: need to revisit this.  Do we really want to allocate this much for a buffer every time?			logBuffer = new DynamicByteArrayOutputStream(1024); // init size 1K		} else {			logBuffer.reset();		}		int optionalDataStart = logBuffer.getPosition();		if (SanityManager.DEBUG) {			SanityManager.ASSERT(optionalDataStart == 0,				"Buffer for writing the optional data should start at position 0");		}//MsgTrace.traceString("{{{tu.writeOpetionalData");		if (optionalDataLen > 0)		{			byte[] buf = new byte[optionalDataLen];			for (int ix=0;ix <optionalDataLen;ix++)				buf[ix] = (byte)ix;			logBuffer.write(buf);		}//MsgTrace.traceString("}}}tu.writeOpetionalData");		int optionalDataLength = logBuffer.getPosition() - optionalDataStart;				if (SanityManager.DEBUG) {			if (optionalDataLength != logBuffer.getUsed())				SanityManager.THROWASSERT("wrong optional data length, optionalDataLength = "					+ optionalDataLength + ", logBuffer.getUsed() = " + logBuffer.getUsed());		}		// set the position to the beginning of the buffer		logBuffer.setPosition(optionalDataStart);		this.preparedLog = new ByteArray (logBuffer.getByteArray(), optionalDataStart,			optionalDataLength);	}		/*	  Loggable methods	  */	public void doMe(Transaction xact, LogInstant instant,					 LimitObjectInput in)	{		if (verbose)			System.out.println("Loggable.doMe("+toString()+")");		return;	}	/*		methods to support prepared log		the following two methods should not be called during recover	*/	public ByteArray getPreparedLog()	{		return this.preparedLog;	}	public boolean needsRedo(Transaction xact) {return false;}	public void releaseResource(Transaction xact) {return;}	public int group () { return Loggable.RAWSTORE ; };	/*	  Undoable methods.	 */	public Compensation generateUndo(Transaction xact, LimitObjectInput in)		 throws StandardException, IOException	{//MsgTrace.traceString("+++tu.generateUndo");		return new T_Compensation();	}	/*	  Formatable methods	  */	/**	 @exception IOException	thrown on error	 */	public void writeExternal(ObjectOutput out)	throws IOException	{//MsgTrace.traceString("{{{tu.writeExternal");		if (SanityManager.DEBUG)		{			SanityManager.ASSERT((removeWhat >= REMOVE_NONE) &&								 (removeWhat <= REMOVE_TO_ME));			SanityManager.ASSERT(rollBack == (recordSeq < 0));			SanityManager.ASSERT(rollBack == (tranSeq < 0));		}		out.writeObject(tid);		out.writeInt(tranSeq);		out.writeInt(recordSeq);		out.writeInt(removeWhat);		out.writeInt(LWMTranSeq);		out.writeBoolean(rollBack);		out.writeInt(lastRecord);		out.writeBoolean(lastTransaction);		out.writeInt(optionalDataLen);//MsgTrace.traceString("}}}tu.writeExternal");	}	public void readExternal(ObjectInput in) 	throws IOException,ClassNotFoundException	{//MsgTrace.traceString("{{{tu.readExternal");		try		{			tid = (GlobalTransactionId)in.readObject();			tranSeq = in.readInt();			recordSeq = in.readInt();			removeWhat = in.readInt();			LWMTranSeq = in.readInt();			rollBack = in.readBoolean();			lastRecord = in.readInt();			lastTransaction = in.readBoolean();			optionalDataLen = in.readInt();		}		catch ( ClassCastException exception ) {//MsgTrace.traceString("{{{tu.readExternal---exception");			throw new StreamCorruptedException();		}//MsgTrace.traceString("}}}tu.readExternal");	}	public int getTypeFormatId()	{		return StoredFormatIds.SERIALIZABLE_FORMAT_ID;	}	/*	  Object methods.	  */	public String toString()	{	    String traceTid = "tid: null";		if (tid !=null) traceTid = "tid: "+tid;		String traceRemoveWhat;		switch (removeWhat)		{		case  REMOVE_NONE:			traceRemoveWhat = "REMOVE_NONE";			break;		case  REMOVE_ME:			traceRemoveWhat = "REMOVE_ME";			break;		case  REMOVE_TO_ME:			traceRemoveWhat = "REMOVE_TO_ME";			break;		default:			traceRemoveWhat = "removeWhat: invalidValue";			break;		}		return			traceTid+" "+			"tranSeq: "+tranSeq+" "+			"recordSeq: "+recordSeq+" "+			traceRemoveWhat+" "+			"LWMTranSeq: "+LWMTranSeq+" "+			"rollback: "+rollBack+" "+			"lastRecord: "+lastRecord+" "+			"optionalDataLen: "+optionalDataLen+" "+			"lastTransaction: "+lastTransaction;	}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -