for (AnalyzedData ad : as.getDataSetReadOnly()) {
if (tr == null) {
tr = rt.beginTransaction();
}
Matrix m = ad.getMatrixData();
PhyloTree t = ad.getTreeData();
if (m != null) {
System.err.println(" Repatriating matrix " + m.getId()
+ " to study " + s.getId() + " submission " + sub.getId());
if (m.getStudy() != s) {
String nexusFileName = m.getNexusFileName();
Map<String,String> nexusMap = m.getStudy().getNexusFiles();
String nexusFile = nexusMap.remove(nexusFileName);
s.getNexusFiles().put(nexusFileName, nexusFile);
m.setStudy(s);
}
if (! ms.contains(m)) {
Submission oldSub = sh.findByMatrix(m);
if (oldSub != null) {