public class org.apache.camel.impl.DefaultUnitOfWork extends java.lang.Object implements org.apache.camel.spi.UnitOfWork, org.apache.camel.Service
{
private static final org.slf4j.Logger LOG;
private org.apache.camel.spi.UnitOfWork parent;
private java.lang.String id;
private org.apache.camel.CamelContext context;
private java.util.List synchronizations;
private org.apache.camel.Message originalInMessage;
private org.apache.camel.spi.TracedRouteNodes tracedRouteNodes;
private java.util.Set transactedBy;
private final java.util.Deque routeContextStack;
private java.util.Deque subUnitOfWorks;
private final transient org.slf4j.Logger log;
public void <init>(org.apache.camel.Exchange)
{
org.apache.camel.Exchange v;
org.slf4j.Logger v;
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
v = <org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger LOG>;
specialinvoke v.<org.apache.camel.impl.DefaultUnitOfWork: void <init>(org.apache.camel.Exchange,org.slf4j.Logger)>(v, v);
return;
}
protected void <init>(org.apache.camel.Exchange, org.slf4j.Logger)
{
org.apache.camel.Message v, v, v, v, v, v, v, v, v, v, v;
java.util.Date v;
java.util.Map v, v;
org.apache.camel.impl.DefaultTracedRouteNodes v;
boolean v, v, v, v, v, v;
org.apache.camel.impl.DefaultMessage v;
java.lang.Throwable v;
org.apache.camel.Exchange v;
java.lang.Boolean v, v, v, v, v;
java.lang.String v, v, v;
org.apache.camel.CamelContext v, v, v, v, v, v, v, v, v;
org.slf4j.Logger v, v, v, v;
org.apache.camel.impl.DefaultUnitOfWork v;
org.apache.camel.spi.InflightRepository v;
java.lang.Class v;
java.lang.Object v, v, v, v;
java.util.ArrayDeque v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.slf4j.Logger;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.ArrayDeque;
specialinvoke v.<java.util.ArrayDeque: void <init>()>();
v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque routeContextStack> = v;
v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log> = v;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("UnitOfWork created for ExchangeId: {} with {}", v, v);
label:
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.CamelContext getContext()>();
v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.CamelContext context> = v;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.CamelContext context>;
v = interfaceinvoke v.<org.apache.camel.CamelContext: java.lang.Boolean isTracing()>();
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.CamelContext context>;
v = interfaceinvoke v.<org.apache.camel.CamelContext: java.lang.Boolean isTracing()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
v = new org.apache.camel.impl.DefaultTracedRouteNodes;
specialinvoke v.<org.apache.camel.impl.DefaultTracedRouteNodes: void <init>()>();
v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.spi.TracedRouteNodes tracedRouteNodes> = v;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.CamelContext context>;
v = interfaceinvoke v.<org.apache.camel.CamelContext: java.lang.Boolean isAllowUseOriginalMessage()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.Message getIn()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("org.apache.camel.component.jms.JmsMessage");
if v == 0 goto label;
v = new org.apache.camel.impl.DefaultMessage;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.CamelContext context>;
specialinvoke v.<org.apache.camel.impl.DefaultMessage: void <init>(org.apache.camel.CamelContext)>(v);
v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.Message originalInMessage> = v;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.Message originalInMessage>;
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.Message getIn()>();
v = interfaceinvoke v.<org.apache.camel.Message: java.lang.Object getBody()>();
interfaceinvoke v.<org.apache.camel.Message: void setBody(java.lang.Object)>(v);
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.Message originalInMessage>;
v = interfaceinvoke v.<org.apache.camel.Message: java.util.Map getHeaders()>();
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.Message getIn()>();
v = interfaceinvoke v.<org.apache.camel.Message: java.util.Map getHeaders()>();
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
goto label;
label:
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.Message getIn()>();
v = interfaceinvoke v.<org.apache.camel.Message: org.apache.camel.Message copy()>();
v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.Message originalInMessage> = v;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.Message originalInMessage>;
v = v instanceof org.apache.camel.impl.MessageSupport;
if v == 0 goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.Message originalInMessage>;
virtualinvoke v.<org.apache.camel.impl.MessageSupport: void setExchange(org.apache.camel.Exchange)>(v);
label:
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Object getProperty(java.lang.String)>("CamelCreatedTimestamp");
if v != null goto label;
v = new java.util.Date;
specialinvoke v.<java.util.Date: void <init>()>();
interfaceinvoke v.<org.apache.camel.Exchange: void setProperty(java.lang.String,java.lang.Object)>("CamelCreatedTimestamp", v);
label:
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.CamelContext getContext()>();
v = interfaceinvoke v.<org.apache.camel.CamelContext: java.lang.Boolean isUseBreadcrumb()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.Message getIn()>();
v = interfaceinvoke v.<org.apache.camel.Message: java.lang.Object getHeader(java.lang.String,java.lang.Class)>("breadcrumbId", class "Ljava/lang/String;");
if v != null goto label;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.Message getIn()>();
interfaceinvoke v.<org.apache.camel.Message: void setHeader(java.lang.String,java.lang.Object)>("breadcrumbId", v);
label:
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Object getProperty(java.lang.String)>("CamelExternalRedelivered");
if v != null goto label;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Boolean isExternalRedelivered()>();
if v != null goto label;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(0);
label:
interfaceinvoke v.<org.apache.camel.Exchange: void setProperty(java.lang.String,java.lang.Object)>("CamelExternalRedelivered", v);
label:
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.CamelContext getContext()>();
staticinvoke <org.apache.camel.util.EventHelper: boolean notifyExchangeCreated(org.apache.camel.CamelContext,org.apache.camel.Exchange)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Exception occurred during event notification. This exception will be ignored.", v);
label:
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.CamelContext getContext()>();
if v == null goto label;
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.CamelContext getContext()>();
v = interfaceinvoke v.<org.apache.camel.CamelContext: org.apache.camel.spi.InflightRepository getInflightRepository()>();
interfaceinvoke v.<org.apache.camel.spi.InflightRepository: void add(org.apache.camel.Exchange)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
org.apache.camel.spi.UnitOfWork newInstance(org.apache.camel.Exchange)
{
org.apache.camel.Exchange v;
org.apache.camel.impl.DefaultUnitOfWork v, v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
v = new org.apache.camel.impl.DefaultUnitOfWork;
specialinvoke v.<org.apache.camel.impl.DefaultUnitOfWork: void <init>(org.apache.camel.Exchange)>(v);
return v;
}
public void setParentUnitOfWork(org.apache.camel.spi.UnitOfWork)
{
org.apache.camel.spi.UnitOfWork v;
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.spi.UnitOfWork;
v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.spi.UnitOfWork parent> = v;
return;
}
public org.apache.camel.spi.UnitOfWork createChildUnitOfWork(org.apache.camel.Exchange)
{
org.apache.camel.spi.UnitOfWork v;
org.apache.camel.Exchange v;
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
v = virtualinvoke v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.spi.UnitOfWork newInstance(org.apache.camel.Exchange)>(v);
interfaceinvoke v.<org.apache.camel.spi.UnitOfWork: void setParentUnitOfWork(org.apache.camel.spi.UnitOfWork)>(v);
return v;
}
public void start() throws java.lang.Exception
{
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v.<org.apache.camel.impl.DefaultUnitOfWork: java.lang.String id> = null;
return;
}
public void stop() throws java.lang.Exception
{
org.apache.camel.spi.TracedRouteNodes v, v;
org.apache.camel.impl.DefaultUnitOfWork v;
java.util.Set v, v;
java.util.Deque v, v, v;
java.util.List v, v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
interfaceinvoke v.<java.util.List: void clear()>();
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.spi.TracedRouteNodes tracedRouteNodes>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.spi.TracedRouteNodes tracedRouteNodes>;
interfaceinvoke v.<org.apache.camel.spi.TracedRouteNodes: void clear()>();
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Set transactedBy>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Set transactedBy>;
interfaceinvoke v.<java.util.Set: void clear()>();
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque routeContextStack>;
interfaceinvoke v.<java.util.Deque: void clear()>();
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque subUnitOfWorks>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque subUnitOfWorks>;
interfaceinvoke v.<java.util.Deque: void clear()>();
label:
v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.Message originalInMessage> = null;
v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.spi.UnitOfWork parent> = null;
v.<org.apache.camel.impl.DefaultUnitOfWork: java.lang.String id> = null;
return;
}
public synchronized void addSynchronization(org.apache.camel.spi.Synchronization)
{
java.util.List v, v;
org.slf4j.Logger v;
org.apache.camel.impl.DefaultUnitOfWork v;
org.apache.camel.spi.Synchronization v;
java.util.ArrayList v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.spi.Synchronization;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
if v != null goto label;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations> = v;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Adding synchronization {}", v);
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
return;
}
public synchronized void removeSynchronization(org.apache.camel.spi.Synchronization)
{
java.util.List v, v;
org.apache.camel.impl.DefaultUnitOfWork v;
org.apache.camel.spi.Synchronization v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.spi.Synchronization;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
label:
return;
}
public synchronized boolean containsSynchronization(org.apache.camel.spi.Synchronization)
{
java.util.List v, v;
org.apache.camel.impl.DefaultUnitOfWork v;
org.apache.camel.spi.Synchronization v;
boolean v, v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.spi.Synchronization;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public void handoverSynchronization(org.apache.camel.Exchange)
{
org.apache.camel.Exchange v;
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
virtualinvoke v.<org.apache.camel.impl.DefaultUnitOfWork: void handoverSynchronization(org.apache.camel.Exchange,java.util.function.Predicate)>(v, null);
return;
}
public void handoverSynchronization(org.apache.camel.Exchange, java.util.function.Predicate)
{
org.apache.camel.Exchange v;
boolean v, v, v, v, v;
org.slf4j.Logger v, v;
java.util.Iterator v;
java.util.function.Predicate v;
org.apache.camel.impl.DefaultUnitOfWork v;
java.util.List v, v, v;
java.lang.Object v;
org.apache.camel.spi.Synchronization v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: java.util.function.Predicate;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
label:
return;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = 1;
v = v instanceof org.apache.camel.spi.SynchronizationVetoable;
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.camel.spi.SynchronizationVetoable: boolean allowHandover()>();
label:
if v == 0 goto label;
if v == null goto label;
v = interfaceinvoke v.<java.util.function.Predicate: boolean test(java.lang.Object)>(v);
if v == 0 goto label;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Handover synchronization {} to: {}", v, v);
interfaceinvoke v.<org.apache.camel.Exchange: void addOnCompletion(org.apache.camel.spi.Synchronization)>(v);
interfaceinvoke v.<java.util.Iterator: void remove()>();
goto label;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Handover not allow for synchronization {}", v);
goto label;
label:
return;
}
public void done(org.apache.camel.Exchange)
{
java.lang.Throwable v, v;
org.apache.camel.Exchange v;
org.apache.camel.spi.SubUnitOfWorkCallback v;
java.lang.String v;
boolean v;
org.apache.camel.CamelContext v, v, v, v;
org.slf4j.Logger v, v, v, v;
org.apache.camel.impl.DefaultUnitOfWork v;
java.util.List v;
org.apache.camel.spi.InflightRepository v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("UnitOfWork done for ExchangeId: {} with {}", v, v);
v = interfaceinvoke v.<org.apache.camel.Exchange: boolean isFailed()>();
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
staticinvoke <org.apache.camel.util.UnitOfWorkHelper: void doneSynchronizations(org.apache.camel.Exchange,java.util.List,org.slf4j.Logger)>(v, v, v);
label:
v = virtualinvoke v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.spi.SubUnitOfWorkCallback getSubUnitOfWorkCallback()>();
if v == null goto label;
interfaceinvoke v.<org.apache.camel.spi.SubUnitOfWorkCallback: void onDone(org.apache.camel.Exchange)>(v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Exception occurred during savepoint onDone. This exception will be ignored.", v);
label:
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.CamelContext getContext()>();
if v == null goto label;
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.CamelContext getContext()>();
v = interfaceinvoke v.<org.apache.camel.CamelContext: org.apache.camel.spi.InflightRepository getInflightRepository()>();
interfaceinvoke v.<org.apache.camel.spi.InflightRepository: void remove(org.apache.camel.Exchange)>(v);
label:
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.CamelContext getContext()>();
staticinvoke <org.apache.camel.util.EventHelper: boolean notifyExchangeFailed(org.apache.camel.CamelContext,org.apache.camel.Exchange)>(v, v);
goto label;
label:
v = interfaceinvoke v.<org.apache.camel.Exchange: org.apache.camel.CamelContext getContext()>();
staticinvoke <org.apache.camel.util.EventHelper: boolean notifyExchangeDone(org.apache.camel.CamelContext,org.apache.camel.Exchange)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Exception occurred during event notification. This exception will be ignored.", v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void beforeRoute(org.apache.camel.Exchange, org.apache.camel.Route)
{
java.lang.Object[] v;
org.apache.camel.Route v;
org.slf4j.Logger v, v, v;
org.apache.camel.impl.DefaultUnitOfWork v;
org.apache.camel.Exchange v;
java.util.List v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.Route;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = newarray (java.lang.Object)[3];
v = interfaceinvoke v.<org.apache.camel.Route: java.lang.String getId()>();
v[0] = v;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
v[1] = v;
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object[])>("UnitOfWork beforeRoute: {} for ExchangeId: {} with {}", v);
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
staticinvoke <org.apache.camel.util.UnitOfWorkHelper: void beforeRouteSynchronizations(org.apache.camel.Route,org.apache.camel.Exchange,java.util.List,org.slf4j.Logger)>(v, v, v, v);
return;
}
public void afterRoute(org.apache.camel.Exchange, org.apache.camel.Route)
{
java.lang.Object[] v;
org.apache.camel.Route v;
org.slf4j.Logger v, v, v;
org.apache.camel.impl.DefaultUnitOfWork v;
org.apache.camel.Exchange v;
java.util.List v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.Route;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = newarray (java.lang.Object)[3];
v = interfaceinvoke v.<org.apache.camel.Route: java.lang.String getId()>();
v[0] = v;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
v[1] = v;
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object[])>("UnitOfWork afterRoute: {} for ExchangeId: {} with {}", v);
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.List synchronizations>;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
staticinvoke <org.apache.camel.util.UnitOfWorkHelper: void afterRouteSynchronizations(org.apache.camel.Route,org.apache.camel.Exchange,java.util.List,org.slf4j.Logger)>(v, v, v, v);
return;
}
public java.lang.String getId()
{
org.apache.camel.CamelContext v;
org.apache.camel.impl.DefaultUnitOfWork v;
java.lang.String v, v, v;
org.apache.camel.spi.UuidGenerator v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.lang.String id>;
if v != null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.CamelContext context>;
v = interfaceinvoke v.<org.apache.camel.CamelContext: org.apache.camel.spi.UuidGenerator getUuidGenerator()>();
v = interfaceinvoke v.<org.apache.camel.spi.UuidGenerator: java.lang.String generateUuid()>();
v.<org.apache.camel.impl.DefaultUnitOfWork: java.lang.String id> = v;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.lang.String id>;
return v;
}
public org.apache.camel.Message getOriginalInMessage()
{
java.lang.IllegalStateException v;
org.apache.camel.CamelContext v;
org.apache.camel.Message v, v;
org.apache.camel.impl.DefaultUnitOfWork v;
java.lang.Boolean v;
boolean v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.Message originalInMessage>;
if v != null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.CamelContext context>;
v = interfaceinvoke v.<org.apache.camel.CamelContext: java.lang.Boolean isAllowUseOriginalMessage()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v != 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("AllowUseOriginalMessage is disabled. Cannot access the original message.");
throw v;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.Message originalInMessage>;
return v;
}
public org.apache.camel.spi.TracedRouteNodes getTracedRouteNodes()
{
org.apache.camel.spi.TracedRouteNodes v;
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.spi.TracedRouteNodes tracedRouteNodes>;
return v;
}
public boolean isTransacted()
{
org.apache.camel.impl.DefaultUnitOfWork v;
java.util.Set v, v;
boolean v, v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Set transactedBy>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Set transactedBy>;
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public boolean isTransactedBy(java.lang.Object)
{
org.apache.camel.impl.DefaultUnitOfWork v;
java.util.Set v;
java.lang.Object v;
boolean v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: java.lang.Object;
v = specialinvoke v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Set getTransactedBy()>();
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
return v;
}
public void beginTransactedBy(java.lang.Object)
{
java.util.Set v;
java.lang.Object v;
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: java.lang.Object;
v = specialinvoke v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Set getTransactedBy()>();
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
return;
}
public void endTransactedBy(java.lang.Object)
{
java.util.Set v;
java.lang.Object v;
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: java.lang.Object;
v = specialinvoke v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Set getTransactedBy()>();
interfaceinvoke v.<java.util.Set: boolean remove(java.lang.Object)>(v);
return;
}
public org.apache.camel.spi.RouteContext getRouteContext()
{
java.lang.Object v;
java.util.Deque v;
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque routeContextStack>;
v = interfaceinvoke v.<java.util.Deque: java.lang.Object peek()>();
return v;
}
public void pushRouteContext(org.apache.camel.spi.RouteContext)
{
java.util.Deque v;
org.apache.camel.spi.RouteContext v;
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.spi.RouteContext;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque routeContextStack>;
interfaceinvoke v.<java.util.Deque: void push(java.lang.Object)>(v);
return;
}
public org.apache.camel.spi.RouteContext popRouteContext()
{
java.lang.Object v;
java.util.Deque v;
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque routeContextStack>;
v = interfaceinvoke v.<java.util.Deque: java.lang.Object pollFirst()>();
return v;
}
public org.apache.camel.AsyncCallback beforeProcess(org.apache.camel.Processor, org.apache.camel.Exchange, org.apache.camel.AsyncCallback)
{
org.apache.camel.Processor v;
org.apache.camel.impl.DefaultUnitOfWork v;
org.apache.camel.AsyncCallback v;
org.apache.camel.Exchange v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Processor;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.AsyncCallback;
return v;
}
public void afterProcess(org.apache.camel.Processor, org.apache.camel.Exchange, org.apache.camel.AsyncCallback, boolean)
{
org.apache.camel.Processor v;
org.apache.camel.impl.DefaultUnitOfWork v;
org.apache.camel.AsyncCallback v;
org.apache.camel.Exchange v;
boolean v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Processor;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.AsyncCallback;
v := @parameter: boolean;
return;
}
public void beginSubUnitOfWork(org.apache.camel.Exchange)
{
org.slf4j.Logger v, v;
org.apache.camel.impl.DefaultUnitOfWork v;
org.apache.camel.Exchange v;
java.util.Deque v, v;
org.apache.camel.impl.DefaultSubUnitOfWork v;
java.lang.String v;
java.util.ArrayDeque v;
boolean v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("beginSubUnitOfWork exchangeId: {}", v);
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque subUnitOfWorks>;
if v != null goto label;
v = new java.util.ArrayDeque;
specialinvoke v.<java.util.ArrayDeque: void <init>()>();
v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque subUnitOfWorks> = v;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque subUnitOfWorks>;
v = new org.apache.camel.impl.DefaultSubUnitOfWork;
specialinvoke v.<org.apache.camel.impl.DefaultSubUnitOfWork: void <init>()>();
interfaceinvoke v.<java.util.Deque: void push(java.lang.Object)>(v);
return;
}
public void endSubUnitOfWork(org.apache.camel.Exchange)
{
org.apache.camel.Exchange v;
java.util.Deque v, v, v;
java.lang.Integer v;
org.apache.camel.CamelUnitOfWorkException v;
int v, v;
java.lang.Boolean v, v;
java.lang.String v, v;
java.util.NoSuchElementException v;
boolean v, v, v, v;
org.slf4j.Logger v, v, v, v;
org.apache.camel.impl.DefaultUnitOfWork v;
java.util.List v;
java.lang.Object v, v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v := @parameter: org.apache.camel.Exchange;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("endSubUnitOfWork exchangeId: {}", v);
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque subUnitOfWorks>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque subUnitOfWorks>;
v = interfaceinvoke v.<java.util.Deque: boolean isEmpty()>();
if v == 0 goto label;
label:
return;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque subUnitOfWorks>;
v = interfaceinvoke v.<java.util.Deque: java.lang.Object pop()>();
label:
goto label;
label:
v := @caughtexception;
label:
if v == null goto label;
v = interfaceinvoke v.<org.apache.camel.spi.SubUnitOfWork: boolean isFailed()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.camel.spi.SubUnitOfWork: java.util.List getExceptions()>();
if v == null goto label;
v = interfaceinvoke v.<java.util.List: int size()>();
if v != 1 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
goto label;
label:
v = new org.apache.camel.CamelUnitOfWorkException;
specialinvoke v.<org.apache.camel.CamelUnitOfWorkException: void <init>(org.apache.camel.Exchange,java.util.List)>(v, v);
v = v;
label:
interfaceinvoke v.<org.apache.camel.Exchange: void setException(java.lang.Throwable)>(v);
label:
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(1);
interfaceinvoke v.<org.apache.camel.Exchange: void setProperty(java.lang.String,java.lang.Object)>("CamelRollbackOnly", v);
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(1);
interfaceinvoke v.<org.apache.camel.Exchange: void setProperty(java.lang.String,java.lang.Object)>("CamelUnitOfWorkExhausted", v);
interfaceinvoke v.<org.apache.camel.Exchange: void setProperty(java.lang.String,java.lang.Object)>("CamelErrorHandlerHandled", null);
interfaceinvoke v.<org.apache.camel.Exchange: void setProperty(java.lang.String,java.lang.Object)>("CamelFailureHandled", null);
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
if v == null goto label;
v = interfaceinvoke v.<java.util.List: int size()>();
goto label;
label:
v = 0;
label:
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("endSubUnitOfWork exchangeId: {} with {} caused exceptions.", v, v);
label:
return;
catch java.util.NoSuchElementException from label to label with label;
}
public org.apache.camel.spi.SubUnitOfWorkCallback getSubUnitOfWorkCallback()
{
org.apache.camel.impl.DefaultUnitOfWork v;
org.apache.camel.spi.SubUnitOfWorkCallback v;
org.apache.camel.spi.UnitOfWork v, v;
java.lang.Object v;
java.util.Deque v, v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.spi.UnitOfWork parent>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: org.apache.camel.spi.UnitOfWork parent>;
v = interfaceinvoke v.<org.apache.camel.spi.UnitOfWork: org.apache.camel.spi.SubUnitOfWorkCallback getSubUnitOfWorkCallback()>();
return v;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque subUnitOfWorks>;
if v == null goto label;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Deque subUnitOfWorks>;
v = interfaceinvoke v.<java.util.Deque: java.lang.Object peek()>();
goto label;
label:
v = null;
label:
return v;
}
private java.util.Set getTransactedBy()
{
org.apache.camel.impl.DefaultUnitOfWork v;
java.util.Set v, v;
java.util.LinkedHashSet v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Set transactedBy>;
if v != null goto label;
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>()>();
v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Set transactedBy> = v;
label:
v = v.<org.apache.camel.impl.DefaultUnitOfWork: java.util.Set transactedBy>;
return v;
}
public java.lang.String toString()
{
org.apache.camel.impl.DefaultUnitOfWork v;
v := @this: org.apache.camel.impl.DefaultUnitOfWork;
return "DefaultUnitOfWork";
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/camel/impl/DefaultUnitOfWork;");
<org.apache.camel.impl.DefaultUnitOfWork: org.slf4j.Logger LOG> = v;
return;
}
}