public class org.apache.activemq.transaction.XATransaction extends org.apache.activemq.transaction.Transaction
{
private static final org.slf4j.Logger LOG;
private final org.apache.activemq.store.TransactionStore transactionStore;
private final org.apache.activemq.command.XATransactionId xid;
private final org.apache.activemq.broker.TransactionBroker broker;
private final org.apache.activemq.command.ConnectionId connectionId;
public void <init>(org.apache.activemq.store.TransactionStore, org.apache.activemq.command.XATransactionId, org.apache.activemq.broker.TransactionBroker, org.apache.activemq.command.ConnectionId)
{
org.slf4j.Logger v, v;
org.apache.activemq.command.ConnectionId v;
org.apache.activemq.transaction.XATransaction v;
org.apache.activemq.command.XATransactionId v;
java.lang.String v;
org.apache.activemq.store.TransactionStore v;
org.apache.activemq.broker.TransactionBroker v;
boolean v;
v := @this: org.apache.activemq.transaction.XATransaction;
v := @parameter: org.apache.activemq.store.TransactionStore;
v := @parameter: org.apache.activemq.command.XATransactionId;
v := @parameter: org.apache.activemq.broker.TransactionBroker;
v := @parameter: org.apache.activemq.command.ConnectionId;
specialinvoke v.<org.apache.activemq.transaction.Transaction: void <init>()>();
v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.store.TransactionStore transactionStore> = v;
v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.XATransactionId xid> = v;
v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.broker.TransactionBroker broker> = v;
v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.ConnectionId connectionId> = v;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.XATransactionId)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("XA Transaction new/begin : \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
return;
}
public void commit(boolean) throws javax.transaction.xa.XAException, java.io.IOException
{
org.slf4j.Logger v, v;
java.util.concurrent.FutureTask v, v, v;
byte v;
org.apache.activemq.transaction.XATransaction v;
org.apache.activemq.command.XATransactionId v;
java.lang.String v;
org.apache.activemq.command.TransactionId v, v;
boolean v, v;
v := @this: org.apache.activemq.transaction.XATransaction;
v := @parameter: boolean;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.XATransactionId xid>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (boolean,org.apache.activemq.command.XATransactionId)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("XA Transaction commit onePhase:\u, xid: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: byte getState()>();
tableswitch(v)
{
case 0: goto label;
case 1: goto label;
case 2: goto label;
default: goto label;
};
label:
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void checkForPreparedState(boolean)>(v);
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void setStateFinished()>();
goto label;
label:
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void checkForPreparedState(boolean)>(v);
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void doPrePrepare()>();
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void setStateFinished()>();
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.TransactionId getTransactionId()>();
v = v.<org.apache.activemq.transaction.XATransaction: java.util.concurrent.FutureTask preCommitTask>;
v = v.<org.apache.activemq.transaction.XATransaction: java.util.concurrent.FutureTask postCommitTask>;
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void storeCommit(org.apache.activemq.command.TransactionId,boolean,java.lang.Runnable,java.lang.Runnable)>(v, 0, v, v);
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.TransactionId getTransactionId()>();
v = v.<org.apache.activemq.transaction.XATransaction: java.util.concurrent.FutureTask postCommitTask>;
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void storeCommit(org.apache.activemq.command.TransactionId,boolean,java.lang.Runnable,java.lang.Runnable)>(v, 1, null, v);
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void setStateFinished()>();
goto label;
label:
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void illegalStateTransition(java.lang.String)>("commit");
label:
return;
}
private void storeCommit(org.apache.activemq.command.TransactionId, boolean, java.lang.Runnable, java.lang.Runnable) throws javax.transaction.xa.XAException, java.io.IOException
{
java.lang.Throwable v, v;
java.util.concurrent.FutureTask v, v, v;
java.lang.Runnable v, v;
java.lang.String v, v, v, v, v, v;
org.apache.activemq.store.TransactionStore v;
org.apache.activemq.command.TransactionId v, v;
boolean v;
org.slf4j.Logger v;
org.apache.activemq.transaction.XATransaction v;
javax.transaction.xa.XAException v, v;
v := @this: org.apache.activemq.transaction.XATransaction;
v := @parameter: org.apache.activemq.command.TransactionId;
v := @parameter: boolean;
v := @parameter: java.lang.Runnable;
v := @parameter: java.lang.Runnable;
label:
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.store.TransactionStore transactionStore>;
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.TransactionId getTransactionId()>();
v = v.<org.apache.activemq.transaction.XATransaction: java.util.concurrent.FutureTask preCommitTask>;
v = v.<org.apache.activemq.transaction.XATransaction: java.util.concurrent.FutureTask postCommitTask>;
interfaceinvoke v.<org.apache.activemq.store.TransactionStore: void commit(org.apache.activemq.command.TransactionId,boolean,java.lang.Runnable,java.lang.Runnable)>(v, v, v, v);
v = v.<org.apache.activemq.transaction.XATransaction: java.util.concurrent.FutureTask postCommitTask>;
virtualinvoke v.<org.apache.activemq.transaction.XATransaction: void waitPostCommitDone(java.util.concurrent.FutureTask)>(v);
label:
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.TransactionId)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Store COMMIT FAILED: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("STORE COMMIT FAILED: \u0001");
v = staticinvoke <org.apache.activemq.transaction.XATransaction: javax.transaction.xa.XAException newXAException(java.lang.String,int)>(v, 4);
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void doPostRollback()>();
goto label;
label:
virtualinvoke v.<org.apache.activemq.transaction.XATransaction: void rollback()>();
v = staticinvoke <org.apache.activemq.transaction.XATransaction: javax.transaction.xa.XAException newXAException(java.lang.String,int)>("STORE COMMIT FAILED: Transaction rolled back", 101);
label:
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("STORE COMMIT FAILED: \u. Rolled failed:\u0001");
v = staticinvoke <org.apache.activemq.transaction.XATransaction: javax.transaction.xa.XAException newXAException(java.lang.String,int)>(v, 103);
label:
virtualinvoke v.<javax.transaction.xa.XAException: java.lang.Throwable initCause(java.lang.Throwable)>(v);
throw v;
label:
return;
catch javax.transaction.xa.XAException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void illegalStateTransition(java.lang.String) throws javax.transaction.xa.XAException
{
org.apache.activemq.transaction.XATransaction v;
int v;
javax.transaction.xa.XAException v;
java.lang.String v, v;
v := @this: org.apache.activemq.transaction.XATransaction;
v := @parameter: java.lang.String;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Cannot call \u now.");
v = (int) -6;
v = staticinvoke <org.apache.activemq.transaction.XATransaction: javax.transaction.xa.XAException newXAException(java.lang.String,int)>(v, v);
throw v;
}
private void checkForPreparedState(boolean) throws javax.transaction.xa.XAException
{
org.apache.activemq.transaction.XATransaction v;
int v;
javax.transaction.xa.XAException v;
boolean v;
v := @this: org.apache.activemq.transaction.XATransaction;
v := @parameter: boolean;
if v != 0 goto label;
v = (int) -6;
v = staticinvoke <org.apache.activemq.transaction.XATransaction: javax.transaction.xa.XAException newXAException(java.lang.String,int)>("Cannot do 2 phase commit if the transaction has not been prepared", v);
throw v;
label:
return;
}
private void doPrePrepare() throws javax.transaction.xa.XAException, java.io.IOException
{
java.lang.Throwable v;
org.slf4j.Logger v;
org.apache.activemq.transaction.XATransaction v;
javax.transaction.xa.XAException v, v;
v := @this: org.apache.activemq.transaction.XATransaction;
label:
virtualinvoke v.<org.apache.activemq.transaction.XATransaction: void prePrepare()>();
label:
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("PRE-PREPARE FAILED: ", v);
virtualinvoke v.<org.apache.activemq.transaction.XATransaction: void rollback()>();
v = staticinvoke <org.apache.activemq.transaction.XATransaction: javax.transaction.xa.XAException newXAException(java.lang.String,int)>("PRE-PREPARE FAILED: Transaction rolled back", 104);
virtualinvoke v.<javax.transaction.xa.XAException: java.lang.Throwable initCause(java.lang.Throwable)>(v);
throw v;
label:
return;
catch javax.transaction.xa.XAException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void rollback() throws javax.transaction.xa.XAException, java.io.IOException
{
byte v, v;
org.apache.activemq.command.XATransactionId v;
java.lang.String v, v;
org.apache.activemq.store.TransactionStore v, v, v;
org.apache.activemq.command.TransactionId v, v, v;
boolean v;
org.slf4j.Logger v, v;
org.apache.activemq.transaction.XATransaction v;
javax.transaction.xa.XAException v;
v := @this: org.apache.activemq.transaction.XATransaction;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.XATransactionId xid>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.XATransactionId)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("XA Transaction rollback: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: byte getState()>();
tableswitch(v)
{
case 0: goto label;
case 1: goto label;
case 2: goto label;
case 3: goto label;
default: goto label;
};
label:
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void setStateFinished()>();
goto label;
label:
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void setStateFinished()>();
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.store.TransactionStore transactionStore>;
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.TransactionId getTransactionId()>();
interfaceinvoke v.<org.apache.activemq.store.TransactionStore: void rollback(org.apache.activemq.command.TransactionId)>(v);
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void doPostRollback()>();
goto label;
label:
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void setStateFinished()>();
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.store.TransactionStore transactionStore>;
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.TransactionId getTransactionId()>();
interfaceinvoke v.<org.apache.activemq.store.TransactionStore: void rollback(org.apache.activemq.command.TransactionId)>(v);
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void doPostRollback()>();
goto label;
label:
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.store.TransactionStore transactionStore>;
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.TransactionId getTransactionId()>();
interfaceinvoke v.<org.apache.activemq.store.TransactionStore: void rollback(org.apache.activemq.command.TransactionId)>(v);
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void doPostRollback()>();
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: byte getState()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (byte)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Invalid state: \u0001");
v = staticinvoke <org.apache.activemq.transaction.XATransaction: javax.transaction.xa.XAException newXAException(java.lang.String,int)>(v, 105);
throw v;
label:
return;
}
private void doPostRollback() throws javax.transaction.xa.XAException
{
java.lang.Throwable v;
org.slf4j.Logger v;
org.apache.activemq.transaction.XATransaction v;
int v;
javax.transaction.xa.XAException v;
v := @this: org.apache.activemq.transaction.XATransaction;
label:
virtualinvoke v.<org.apache.activemq.transaction.XATransaction: void fireAfterRollback()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("POST ROLLBACK FAILED: ", v);
v = (int) -3;
v = staticinvoke <org.apache.activemq.transaction.XATransaction: javax.transaction.xa.XAException newXAException(java.lang.String,int)>("POST ROLLBACK FAILED", v);
virtualinvoke v.<javax.transaction.xa.XAException: java.lang.Throwable initCause(java.lang.Throwable)>(v);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public int prepare() throws javax.transaction.xa.XAException, java.io.IOException
{
org.slf4j.Logger v, v;
java.util.concurrent.FutureTask v;
byte v;
org.apache.activemq.transaction.XATransaction v;
org.apache.activemq.command.XATransactionId v;
java.lang.String v;
org.apache.activemq.store.TransactionStore v;
org.apache.activemq.command.TransactionId v;
boolean v;
v := @this: org.apache.activemq.transaction.XATransaction;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.XATransactionId xid>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.XATransactionId)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("XA Transaction prepare: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: byte getState()>();
lookupswitch(v)
{
case 0: goto label;
case 1: goto label;
default: goto label;
};
label:
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void setStateFinished()>();
return 3;
label:
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void doPrePrepare()>();
virtualinvoke v.<org.apache.activemq.transaction.XATransaction: void setState(byte)>(2);
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.store.TransactionStore transactionStore>;
v = virtualinvoke v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.TransactionId getTransactionId()>();
interfaceinvoke v.<org.apache.activemq.store.TransactionStore: void prepare(org.apache.activemq.command.TransactionId)>(v);
v = v.<org.apache.activemq.transaction.XATransaction: java.util.concurrent.FutureTask preCommitTask>;
virtualinvoke v.<java.util.concurrent.FutureTask: void run()>();
return 0;
label:
specialinvoke v.<org.apache.activemq.transaction.XATransaction: void illegalStateTransition(java.lang.String)>("prepare");
return 3;
}
private void setStateFinished()
{
org.apache.activemq.command.XATransactionId v;
org.apache.activemq.transaction.XATransaction v;
org.apache.activemq.broker.TransactionBroker v;
v := @this: org.apache.activemq.transaction.XATransaction;
virtualinvoke v.<org.apache.activemq.transaction.XATransaction: void setState(byte)>(3);
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.broker.TransactionBroker broker>;
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.XATransactionId xid>;
virtualinvoke v.<org.apache.activemq.broker.TransactionBroker: void removeTransaction(org.apache.activemq.command.XATransactionId)>(v);
return;
}
public org.apache.activemq.command.ConnectionId getConnectionId()
{
org.apache.activemq.transaction.XATransaction v;
org.apache.activemq.command.ConnectionId v;
v := @this: org.apache.activemq.transaction.XATransaction;
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.ConnectionId connectionId>;
return v;
}
public org.apache.activemq.command.TransactionId getTransactionId()
{
org.apache.activemq.command.XATransactionId v;
org.apache.activemq.transaction.XATransaction v;
v := @this: org.apache.activemq.transaction.XATransaction;
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.XATransactionId xid>;
return v;
}
public org.slf4j.Logger getLog()
{
org.slf4j.Logger v;
org.apache.activemq.transaction.XATransaction v;
v := @this: org.apache.activemq.transaction.XATransaction;
v = <org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG>;
return v;
}
public org.apache.activemq.command.XATransactionId getXid()
{
org.apache.activemq.command.XATransactionId v;
org.apache.activemq.transaction.XATransaction v;
v := @this: org.apache.activemq.transaction.XATransaction;
v = v.<org.apache.activemq.transaction.XATransaction: org.apache.activemq.command.XATransactionId xid>;
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/transaction/XATransaction;");
<org.apache.activemq.transaction.XATransaction: org.slf4j.Logger LOG> = v;
return;
}
}