1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
|
/*
* Selector data types
*
* (c) 2016 Schrodinger, Inc.
*/
#pragma once
#include "os_std.h"
#include "pymol/memory.h"
#include "AtomIterators.h"
#include <string>
#include <unordered_map>
#include <vector>
#define cNDummyModels 2
#define cNDummyAtoms 2
struct TableRec {
int model;
int atom;
int index;
float f1;
};
struct SelectionInfoRec {
SelectorID_t ID = 0;
std::string name;
ObjectMolecule* theOneObject = nullptr;
int theOneAtom = -1;
bool justOneObject() const { return theOneObject != nullptr; }
bool justOneAtom() const { return justOneObject() && theOneAtom >= 0; }
SelectionInfoRec() = default;
SelectionInfoRec(SelectorID_t id, std::string name_)
: ID(id)
, name(std::move(name_))
{
}
};
struct MemberType {
SelectorID_t selection;
int tag; /* must not be zero since it is also used as a boolean test for membership */
SelectorMemberOffset_t next;
};
struct CSelectorManager
{
std::vector<MemberType> Member;
SelectorMemberOffset_t FreeMember = 0;
std::vector<SelectionInfoRec> Info;
SelectorID_t NSelection = 0;
std::unordered_map<std::string, int> Key;
CSelectorManager();
};
struct CSelector {
PyMOLGlobals* G = nullptr;
CSelectorManager* mgr = nullptr;
std::vector<ObjectMolecule*> Obj;
std::vector<TableRec> Table;
pymol::cache_ptr<ObjectMolecule> Origin;
pymol::cache_ptr<ObjectMolecule> Center;
int NCSet = 0; // Seems to hold the largest NCSet in Obj
bool SeleBaseOffsetsValid = false;
CSelector(PyMOLGlobals* G, CSelectorManager* mgr);
CSelector(const CSelector&) = default;
CSelector& operator=(const CSelector&) = default;
CSelector(CSelector&&) = default;
CSelector& operator=(CSelector&&) = default;
~CSelector();
};
/**
* Iterator over the selector table. If `SelectorUpdateTable(G,
* cSelectorUpdateTableAllStates, -1)` was called, this would be all atoms.
*
* Does NOT provide coord or coordset access
*
* @pre Selector table is up-to-date
*/
class SelectorAtomIterator : public AbstractAtomIterator
{
CSelector* selector;
public:
int a; //!< index in selector table
SelectorAtomIterator(CSelector* I)
: selector(I)
{
reset();
}
void reset() override { a = cNDummyAtoms - 1; }
bool next() override;
};
|