mirror of
https://github.com/eclipse-cdt/cdt
synced 2025-07-04 15:45:25 +02:00
performance fix - when dealing with spirit stuff
This commit is contained in:
parent
c40400de72
commit
7deaf70d13
1 changed files with 38 additions and 0 deletions
|
@ -21,6 +21,8 @@ import java.io.IOException;
|
|||
import java.io.InterruptedIOException;
|
||||
import java.net.Socket;
|
||||
import java.net.SocketException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Stack;
|
||||
|
||||
import org.eclipse.dstore.core.model.DE;
|
||||
|
@ -524,6 +526,42 @@ public class XMLparser
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (parent != null && parent.getNestedSize() > 0 && _dataStore.isVirtual())
|
||||
{
|
||||
// end of children of parent
|
||||
// find all spirits that match non-spirits
|
||||
List toDelete = new ArrayList();
|
||||
for (int s= 0; s < parent.getNestedSize(); s++)
|
||||
{
|
||||
DataElement element = parent.get(s);
|
||||
if (element.isSpirit())
|
||||
{
|
||||
String name = element.getName();
|
||||
String value = element.getValue();
|
||||
|
||||
// delete this element if there's another one with the same name and value
|
||||
for (int n = 0; n < parent.getNestedSize(); n++)
|
||||
{
|
||||
if (n != s)
|
||||
{
|
||||
DataElement compare = parent.get(n);
|
||||
String cname = compare.getName();
|
||||
String cvalue = compare.getValue();
|
||||
if (!compare.isSpirit() && cname.equals(name) && cvalue.equals(value))
|
||||
toDelete.add(compare);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// delete elements
|
||||
for (int d = 0; d < toDelete.size(); d++)
|
||||
{
|
||||
DataElement delement = (DataElement)toDelete.get(d);
|
||||
_dataStore.deleteObject(parent,delement);
|
||||
}
|
||||
}
|
||||
|
||||
_tagStack.pop();
|
||||
if (_tagStack.empty())
|
||||
|
|
Loading…
Add table
Reference in a new issue