[ 1846595 ] 2pack do not set the start node in a workflow after import

- Added proper defer endElement processing handling.
This commit is contained in:
Heng Sin Low 2007-12-18 16:06:53 +00:00
parent a2191ada06
commit 3ca8cdd94a
6 changed files with 27 additions and 25 deletions

View File

@ -43,6 +43,8 @@ public class Element {
//skip this node
public boolean skip = false;
public boolean deferEnd = false;
/**
* @param uri
* @param localName

View File

@ -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.");

View File

@ -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);
}
}

View File

@ -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;
}

View File

@ -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;
}

View File

@ -52,6 +52,7 @@ public class WorkflowNodeNextConditionElementHandler extends
workflowName);
if (workflowId <= 0) {
element.defer = true;
element.unresolved = "AD_Workflow: " + workflowName;
return;
}