Pteros
2.0
Molecular modeling library for human beings!
babel_wrapper.h
1
/*
2
* This file is a part of
3
*
4
* ============================================
5
* ### Pteros molecular modeling library ###
6
* ============================================
7
*
8
* https://github.com/yesint/pteros
9
*
10
* (C) 2009-2021, Semen Yesylevskyy
11
*
12
* All works, which use Pteros, should cite the following papers:
13
*
14
* 1. Semen O. Yesylevskyy, "Pteros 2.0: Evolution of the fast parallel
15
* molecular analysis library for C++ and python",
16
* Journal of Computational Chemistry, 2015, 36(19), 1480–1488.
17
* doi: 10.1002/jcc.23943.
18
*
19
* 2. Semen O. Yesylevskyy, "Pteros: Fast and easy to use open-source C++
20
* library for molecular analysis",
21
* Journal of Computational Chemistry, 2012, 33(19), 1632–1636.
22
* doi: 10.1002/jcc.22989.
23
*
24
* This is free software distributed under Artistic License:
25
* http://www.opensource.org/licenses/artistic-license-2.0.php
26
*
27
*/
28
29
30
#pragma once
31
32
#include <string>
33
#include "pteros/core/system.h"
34
#include "pteros/core/selection.h"
35
#include "pteros/core/file_handler.h"
36
37
#include <openbabel/obconversion.h>
38
#include <openbabel/mol.h>
39
40
namespace
pteros {
41
43
class
BabelWrapper
:
public
FileHandler
{
44
public
:
45
// High-level API
46
BabelWrapper
(std::string& fname);
47
virtual
void
open
(
char
open_mode);
48
virtual
void
close();
49
50
protected
:
51
OpenBabel::OBConversion conv;
52
OpenBabel::OBMol mol;
53
54
// Tells if the format need bonds to be present
55
virtual
bool
need_bonds() = 0;
56
57
virtual
bool
do_read(
System
*sys,
Frame
*frame,
const
FileContent& what);
58
virtual
void
do_write(
const
Selection
&sel,
const
FileContent& what);
59
};
60
61
}
62
63
64
65
66
pteros::Selection
Selection class.
Definition:
selection.h:65
pteros::FileHandler
Generic API for reading and writing any molecule file formats.
Definition:
file_handler.h:74
pteros::BabelWrapper::open
virtual void open(char open_mode)
Opens a file with given access mode. Need to be defined by derived classes.
Definition:
babel_wrapper.cpp:49
pteros::System
The system of atoms.
Definition:
system.h:93
pteros::BabelWrapper
Generic API for reading and writing any molecule file formats.
Definition:
babel_wrapper.h:43
pteros::Frame
Definition of single trajectory frame.
Definition:
system.h:51
src
core
io
babel_wrapper.h
Generated on Sat Jul 9 2022 15:59:59 for Pteros by
1.8.17