Pteros  2.0
Molecular modeling library for human beings!
gro_file.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 <fstream>
34 #include "pteros/core/file_handler.h"
35 
36 namespace pteros {
37 
39 class GroFile: public FileHandler {
40 public:
41  // High-level API
42  GroFile(std::string& fname): FileHandler(fname) {}
43  virtual void open(char open_mode);
44  virtual void close();
45 
46  virtual FileContent get_content_type() const {
47  return FileContent()
48  .atoms(true)
49  .coord(true);
50  }
51 
52 protected:
53 
54  std::fstream f;
55 
56  virtual bool do_read(System *sys, Frame *frame, const FileContent& what);
57  virtual void do_write(const Selection &sel, const FileContent& what);
58 };
59 
60 }
61 
62 
63 
64 
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::GroFile
Reader for GRO files. It doesn't use VMD plugins because it doesn't support writing.
Definition: gro_file.h:39
pteros::System
The system of atoms.
Definition: system.h:93
pteros::Frame
Definition of single trajectory frame.
Definition: system.h:51
pteros::GroFile::open
virtual void open(char open_mode)
Opens a file with given access mode. Need to be defined by derived classes.
Definition: gro_file.cpp:39
pteros::GroFile::get_content_type
virtual FileContent get_content_type() const
Reports content of this file type.
Definition: gro_file.h:46