Skip to content

Commit

Permalink
Skip certain restore elements during parsing
Browse files Browse the repository at this point in the history
  • Loading branch information
avazirna committed Jul 27, 2023
1 parent b8ce32e commit f84f11f
Showing 1 changed file with 11 additions and 3 deletions.
14 changes: 11 additions & 3 deletions src/main/java/org/commcare/data/xml/DataModelPullParser.java
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
import java.io.IOException;
import java.io.InputStream;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Vector;

/**
Expand All @@ -28,31 +29,33 @@ public class DataModelPullParser extends ElementParser<Boolean> {
private final InputStream is;
private final String requiredRootEnvelope = null;
private final CommCareOTARestoreListener rListener;
private List<String> blocksToSkipParsing;

public DataModelPullParser(InputStream is, TransactionParserFactory factory) throws InvalidStructureException, IOException {
this(is, factory, false);
}

public DataModelPullParser(InputStream is, TransactionParserFactory factory, CommCareOTARestoreListener rl) throws InvalidStructureException, IOException {
this(is, factory, false, false, rl);
this(is, factory, false, false, rl, null);
}

public DataModelPullParser(InputStream is, TransactionParserFactory factory, boolean deep) throws InvalidStructureException, IOException {
this(is, factory, false, deep);
}

public DataModelPullParser(InputStream is, TransactionParserFactory factory, boolean failfast, boolean deep) throws InvalidStructureException, IOException {
this(is, factory, failfast, deep, null);
this(is, factory, failfast, deep, null, null);
}

public DataModelPullParser(InputStream is, TransactionParserFactory factory, boolean failfast, boolean deep, CommCareOTARestoreListener rListener) throws InvalidStructureException, IOException {
public DataModelPullParser(InputStream is, TransactionParserFactory factory, boolean failfast, boolean deep, CommCareOTARestoreListener rListener, List<String> blocksToSkipParsing) throws InvalidStructureException, IOException {
super(ElementParser.instantiateParser(is));
this.is = is;
this.failfast = failfast;
this.factory = factory;
errors = new Vector<>();
this.deep = deep;
this.rListener = rListener;
this.blocksToSkipParsing = blocksToSkipParsing;
}

@Override
Expand Down Expand Up @@ -126,6 +129,11 @@ private void parseBlock(String root, LinkedHashSet<TransactionParser> parsers) t
continue;
}

if (blocksToSkipParsing != null && blocksToSkipParsing.equals(name)) {
this.skipBlock(name);
continue;
}

TransactionParser transaction = factory.getParser(parser);
if (transaction == null) {
if (deep) {
Expand Down

0 comments on commit f84f11f

Please sign in to comment.