diff --git a/src/mol-model/structure/structure/structure.ts b/src/mol-model/structure/structure/structure.ts index 0d262041252f50b998b7465ce7625921028560c0..317ea029f1593ae17ff62f7cc3e60222c786f7b5 100644 --- a/src/mol-model/structure/structure/structure.ts +++ b/src/mol-model/structure/structure/structure.ts @@ -44,6 +44,7 @@ namespace Structure { } export interface Builder { + add(unit: Unit, atoms: OrderedSet): void, addUnit(unit: Unit): void, addAtoms(unitId: number, atoms: OrderedSet): void, getStructure(): Structure, @@ -55,6 +56,7 @@ namespace Structure { private atoms = Object.create(null); atomCount = 0; + add(unit: Unit, atoms: OrderedSet) { this.addUnit(unit); this.addAtoms(unit.id, atoms); } addUnit(unit: Unit) { this.units[unit.id] = unit; } addAtoms(unitId: number, atoms: OrderedSet) { this.atoms[unitId] = atoms; this.atomCount += OrderedSet.size(atoms); } getStructure(): Structure { return this.atomCount > 0 ? Structure.create(this.units, AtomSet.create(this.atoms)) : Empty; } diff --git a/src/mol-model/structure/structure/symmetry.ts b/src/mol-model/structure/structure/symmetry.ts index 2a4ef8c37c4f3a24b67391554806f2efd4489964..fa1ca3ab1749e4d88b8a6742c04885be94f9e639 100644 --- a/src/mol-model/structure/structure/symmetry.ts +++ b/src/mol-model/structure/structure/symmetry.ts @@ -23,12 +23,9 @@ function buildAssemblyImpl(structure: Structure, name: string) { const assembly = ModelSymmetry.findAssembly(models[0], name); if (!assembly) throw new Error(`Assembly '${name}' is not defined.`); - const { operatorGroups } = assembly; + const assembler = Structure.Builder(); - const assemblyUnits = Object.create(null); - const assemblyAtoms = Object.create(null); - - for (const g of operatorGroups) { + for (const g of assembly.operatorGroups) { const selection = g.selector(structure); if (Selection.structureCount(selection) === 0) continue; const { units, atoms } = Selection.union(selection); @@ -37,15 +34,11 @@ function buildAssemblyImpl(structure: Structure, name: string) { for (const oper of g.operators) { for (let uI = 0, _uI = unitIds.length; uI < _uI; uI++) { - const unitId = unitIds[uI]; - const unit = units[unitId]; - - const newUnit = Unit.create(unit.model, oper); - assemblyUnits[newUnit.id] = newUnit; - assemblyAtoms[newUnit.id] = AtomSet.unitGetByIndex(atoms, uI); + const unit = units[unitIds[uI]]; + assembler.add(Unit.create(unit.model, oper), AtomSet.unitGetByIndex(atoms, uI)); } } } - return Structure.create(assemblyUnits, AtomSet.create(assemblyAtoms)); + return assembler.getStructure(); } \ No newline at end of file diff --git a/src/mol-ql/TODO b/src/mol-ql/TODO new file mode 100644 index 0000000000000000000000000000000000000000..e2a008501f360e80518129bb74699afacf9f8a3d --- /dev/null +++ b/src/mol-ql/TODO @@ -0,0 +1,2 @@ +- Have the ability to define schemas for output. + Define properties for each pattern/whatever that could be exported as CIF/CSV/JSON. \ No newline at end of file