[ 1846595 ] 2pack do not set the start node in a workflow after import
- Added proper defer endElement processing handling.
This commit is contained in:
parent
a2191ada06
commit
3ca8cdd94a
|
@ -43,6 +43,8 @@ public class Element {
|
|||
//skip this node
|
||||
public boolean skip = false;
|
||||
|
||||
public boolean deferEnd = false;
|
||||
|
||||
/**
|
||||
* @param uri
|
||||
* @param localName
|
||||
|
|
|
@ -647,7 +647,7 @@ public class PackInHandler extends DefaultHandler {
|
|||
ElementHandler handler = handlers.get(elementValue);
|
||||
if (handler != null)
|
||||
handler.endElement(m_ctx, e);
|
||||
if (e.defer)
|
||||
if (e.defer || e.deferEnd)
|
||||
defer.add(new DeferEntry(e, false));
|
||||
else if (!e.skip) {
|
||||
if (log.isLoggable(Level.INFO))
|
||||
|
@ -673,25 +673,22 @@ public class PackInHandler extends DefaultHandler {
|
|||
do {
|
||||
int startSize = defer.size();
|
||||
List<DeferEntry> tmp = new ArrayList<DeferEntry>(defer);
|
||||
List<Element> startElements = new ArrayList<Element>();
|
||||
defer.clear();
|
||||
for (DeferEntry d : tmp) {
|
||||
if (d.startElement) {
|
||||
d.element.defer = false;
|
||||
d.element.unresolved = "";
|
||||
d.element.pass++;
|
||||
startElements.add(d.element);
|
||||
} else {
|
||||
if (d.element.defer && startElements.contains(d.element)) {
|
||||
defer.add(d);
|
||||
continue;
|
||||
} else {
|
||||
//only defer endElement
|
||||
d.element.defer = false;
|
||||
if (d.element.deferEnd) {
|
||||
d.element.deferEnd = false;
|
||||
d.element.unresolved = "";
|
||||
d.element.pass++;
|
||||
}
|
||||
}
|
||||
if (log.isLoggable(Level.INFO)) {
|
||||
log.info("Processeing Defer Element: " + d.element.getElementValue() + " - "
|
||||
+ d.element.attributes.getValue(0));
|
||||
}
|
||||
ElementHandler handler = handlers.get(d.element.getElementValue());
|
||||
if (handler != null) {
|
||||
if (d.startElement)
|
||||
|
@ -702,11 +699,15 @@ public class PackInHandler extends DefaultHandler {
|
|||
if (d.element.defer)
|
||||
defer.add(d);
|
||||
else if (!d.startElement) {
|
||||
if (d.element.deferEnd)
|
||||
defer.add(d);
|
||||
else {
|
||||
if (log.isLoggable(Level.INFO))
|
||||
log.info("Processed: " + d.element.getElementValue() + " - "
|
||||
log.info("Imported Defer Element: " + d.element.getElementValue() + " - "
|
||||
+ d.element.attributes.getValue(0));
|
||||
}
|
||||
}
|
||||
}
|
||||
int endSize = defer.size();
|
||||
if (startSize == endSize) break;
|
||||
} while (defer.size() > 0);
|
||||
|
@ -714,10 +715,10 @@ public class PackInHandler extends DefaultHandler {
|
|||
if (defer.size() > 0) {
|
||||
int count = 0;
|
||||
for (DeferEntry d : defer) {
|
||||
if (d.startElement) {
|
||||
if (!d.startElement) {
|
||||
count++;
|
||||
if (log.isLoggable(Level.INFO))
|
||||
log.info("Unresolved: " + d.element.getElementValue() + " - " + d.element.attributes.getValue(0) + ", " + d.element.unresolved);
|
||||
if (log.isLoggable(Level.SEVERE))
|
||||
log.severe("Unresolved: " + d.element.getElementValue() + " - " + d.element.attributes.getValue(0) + ", " + d.element.unresolved);
|
||||
}
|
||||
}
|
||||
throw new RuntimeException("Failed to resolve dependency for " + count + " elements.");
|
||||
|
|
|
@ -70,16 +70,13 @@ public class SQLStatementElementHandler extends AbstractElementHandler {
|
|||
// Postgres needs to commit DDL statements
|
||||
if (m_con != null && !m_con.getAutoCommit())
|
||||
m_con.commit();
|
||||
stmt.close();
|
||||
} finally {
|
||||
m_con.close();
|
||||
}
|
||||
}
|
||||
/* else if(DB.isSybase() == true && DBType.equals("Sybase")){
|
||||
pstmt.executeUpdate();
|
||||
log.info("Exceuted SQL Statement for Sybase");
|
||||
}
|
||||
*/ }
|
||||
catch (Exception e) {
|
||||
pstmt.close();
|
||||
} catch (Exception e) {
|
||||
log.log(Level.SEVERE,"SQLSatement", e);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -178,7 +178,7 @@ public class WorkflowElementHandler extends AbstractElementHandler {
|
|||
MWorkflow m_Workflow = new MWorkflow(ctx, element.recordId, getTrxName(ctx));
|
||||
int id = get_IDWithColumn(ctx, "AD_WF_Node", "Name", name);
|
||||
if (id <= 0) {
|
||||
element.defer = true;
|
||||
element.deferEnd = true;
|
||||
element.unresolved = "AD_WF_Node=" + name;
|
||||
return;
|
||||
}
|
||||
|
|
|
@ -50,6 +50,7 @@ public class WorkflowNodeElementHandler extends AbstractElementHandler {
|
|||
}
|
||||
if (element.parent != null && element.parent.getElementValue().equals("workflow")
|
||||
&& element.parent.defer) {
|
||||
element.unresolved = "Parent element mark as defer: " + atts.getValue("ADWorkflowNameID");
|
||||
element.defer = true;
|
||||
return;
|
||||
}
|
||||
|
|
|
@ -52,6 +52,7 @@ public class WorkflowNodeNextConditionElementHandler extends
|
|||
workflowName);
|
||||
if (workflowId <= 0) {
|
||||
element.defer = true;
|
||||
element.unresolved = "AD_Workflow: " + workflowName;
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue