OpenStructure
build-dev-doc
stage
include
ost
mol
bond_table.hh
Go to the documentation of this file.
1
//------------------------------------------------------------------------------
2
// This file is part of the OpenStructure project <www.openstructure.org>
3
//
4
// Copyright (C) 2008-2020 by the OpenStructure authors
5
//
6
// This library is free software; you can redistribute it and/or modify it under
7
// the terms of the GNU Lesser General Public License as published by the Free
8
// Software Foundation; either version 3.0 of the License, or (at your option)
9
// any later version.
10
// This library is distributed in the hope that it will be useful, but WITHOUT
11
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12
// FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
13
// details.
14
//
15
// You should have received a copy of the GNU Lesser General Public License
16
// along with this library; if not, write to the Free Software Foundation, Inc.,
17
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
18
//------------------------------------------------------------------------------
19
#ifndef OST_BOND_TABLE_HH
20
#define OST_BOND_TABLE_HH
21
22
#include <map>
23
24
#include <
ost/mol/impl/connector_impl_fw.hh
>
25
#include <
ost/mol/bond_handle.hh
>
26
27
namespace
ost
{
namespace
mol {
28
29
template
<
typename
ATOM>
30
struct
BondTableEntry
{
31
BondTableEntry
(
const
BondHandle
& b,
const
ATOM& atom)
32
:
bond
(b) {
33
atoms
[0]=atom;
34
}
35
BondHandle
bond
;
36
ATOM
atoms
[2];
37
bool
IsComplete
()
const
{
38
return
atoms
[1].IsValid();
39
}
40
};
41
42
template
<
typename
ATOM>
43
struct
BondTable
{
44
typedef
BondTableEntry<ATOM>
EntryType
;
45
typedef
typename
std::map<impl::ConnectorImpl*, EntryType>
MapType
;
46
MapType
bonds
;
47
void
Update
(
const
BondHandle
& bond,
const
ATOM& a) {
48
if
(!bond.
IsValid
())
return
;
49
typename
MapType::iterator i=
bonds
.find(bond.
Impl
().get());
50
if
(i!=
bonds
.end()) {
51
i->second.atoms[1]=a;
52
}
else
{
53
bonds
.insert(std::make_pair(bond.
Impl
().get(),
EntryType
(bond, a)));
54
}
55
}
56
57
};
58
59
}}
60
#endif
bond_handle.hh
ost::mol::BondHandle
chemical bond
Definition:
bond_handle.hh:35
ost::mol::BondHandle::Impl
const impl::ConnectorImplP & Impl() const
Definition:
bond_handle.hh:105
ost::mol::BondHandle::IsValid
bool IsValid() const
check validity of handle
connector_impl_fw.hh
ost
Definition:
base.dox:1
ost::mol::BondTableEntry
Definition:
bond_table.hh:30
ost::mol::BondTableEntry::IsComplete
bool IsComplete() const
Definition:
bond_table.hh:37
ost::mol::BondTableEntry::atoms
ATOM atoms[2]
Definition:
bond_table.hh:36
ost::mol::BondTableEntry::bond
BondHandle bond
Definition:
bond_table.hh:35
ost::mol::BondTableEntry::BondTableEntry
BondTableEntry(const BondHandle &b, const ATOM &atom)
Definition:
bond_table.hh:31
ost::mol::BondTable
Definition:
bond_table.hh:43
ost::mol::BondTable::EntryType
BondTableEntry< ATOM > EntryType
Definition:
bond_table.hh:44
ost::mol::BondTable::bonds
MapType bonds
Definition:
bond_table.hh:46
ost::mol::BondTable::Update
void Update(const BondHandle &bond, const ATOM &a)
Definition:
bond_table.hh:47
ost::mol::BondTable::MapType
std::map< impl::ConnectorImpl *, EntryType > MapType
Definition:
bond_table.hh:45
Generated by
1.9.1