CoreNEURON
|
Definition at line 32 of file nrn_filehandler.hpp.
#include <nrn_filehandler.hpp>
Public Types | |
enum | parse_action { read, seek } |
Defined flag values for parse_array() More... | |
Public Member Functions | |
FileHandler () | |
FileHandler (const std::string &filename) | |
void | open (const std::string &filename, std::ios::openmode mode=std::ios::in) |
Preserving chkpnt state, move to a new file. More... | |
bool | fail () const |
Is the file not open. More... | |
bool | eof () |
nothing more to read More... | |
int | checkpoint () const |
Query chkpnt state. More... | |
void | checkpoint (int c) |
Explicitly override chkpnt state. More... | |
void | record_checkpoint () |
Record current chkpnt state. More... | |
void | restore_checkpoint () |
Restored last recorded chkpnt state. More... | |
int | read_int () |
Parse a single integer entry. More... | |
void | read_mapping_count (int *gid, int *nsec, int *nseg, int *nseclist) |
Parse a neuron mapping count entries. More... | |
void | read_mapping_cell_count (int *count) |
Reads number of cells in parsing file. More... | |
template<typename T > | |
int | read_mapping_info (T *mapinfo) |
Parse a neuron section segment mapping. More... | |
template<typename T > | |
T * | parse_array (T *p, size_t count, parse_action flag) |
Generic parse function for an array of fixed length. More... | |
template<typename T > | |
T * | read_array (T *p, size_t count) |
Read an integer array of fixed length. More... | |
template<typename T > | |
T * | read_array (size_t count) |
Allocate and read an integer array of fixed length. More... | |
template<typename T > | |
std::vector< T > | read_vector (size_t count) |
void | close () |
Close currently open file. More... | |
template<typename T > | |
void | write_array (T *p, size_t nb_elements) |
Write an 1D array. More... | |
template<typename T > | |
void | write_array (T *p, size_t nb_elements, size_t line_width, size_t nb_lines, bool to_transpose=false) |
Write a padded array. More... | |
template<typename T > | |
FileHandler & | operator<< (const T &scalar) |
Static Public Member Functions | |
static bool | file_exist (const std::string &filename) |
Private Member Functions | |
void | read_checkpoint_assert () |
Read a checkpoint line, bump our chkpnt counter, and assert equality. More... | |
FileHandler (const FileHandler &)=delete | |
FileHandler & | operator= (const FileHandler &)=delete |
void | write_checkpoint () |
Private Attributes | |
std::fstream | F |
File stream associated with reader. More... | |
std::ios_base::openmode | current_mode |
File open mode (not stored in fstream) More... | |
int | chkpnt |
Current checkpoint number state. More... | |
int | stored_chkpnt |
last "remembered" checkpoint number state. More... | |
Defined flag values for parse_array()
Enumerator | |
---|---|
read | |
seek |
Definition at line 140 of file nrn_filehandler.hpp.
|
privatedelete |
|
inline |
Definition at line 50 of file nrn_filehandler.hpp.
|
explicit |
Definition at line 14 of file nrn_filehandler.cpp.
|
inline |
Query chkpnt state.
Definition at line 70 of file nrn_filehandler.hpp.
|
inline |
Explicitly override chkpnt state.
Definition at line 75 of file nrn_filehandler.hpp.
void coreneuron::FileHandler::close | ( | ) |
Close currently open file.
Definition at line 104 of file nrn_filehandler.cpp.
bool coreneuron::FileHandler::eof | ( | ) |
nothing more to read
Definition at line 45 of file nrn_filehandler.cpp.
|
inline |
Is the file not open.
Definition at line 60 of file nrn_filehandler.hpp.
|
static |
Definition at line 20 of file nrn_filehandler.cpp.
void coreneuron::FileHandler::open | ( | const std::string & | filename, |
std::ios::openmode | mode = std::ios::in |
||
) |
Preserving chkpnt state, move to a new file.
Definition at line 25 of file nrn_filehandler.cpp.
|
inline |
Definition at line 241 of file nrn_filehandler.hpp.
|
privatedelete |
|
inline |
Generic parse function for an array of fixed length.
T | the array element type: may be int or double . |
p | pointer to the target in memory for reading into. |
count | number of items of type T to parse. |
action | whether to validate and skip (seek ) or copy array into memory (read ). |
Error if count is non-zero, flag is read
, and the supplied pointer is
null.
Arrays are represented by a checkpoint line followed by the array items in increasing index order, in the native binary representation of the writing process.
Definition at line 159 of file nrn_filehandler.hpp.
|
inline |
Allocate and read an integer array of fixed length.
Definition at line 187 of file nrn_filehandler.hpp.
|
inline |
Read an integer array of fixed length.
Definition at line 181 of file nrn_filehandler.hpp.
|
private |
Read a checkpoint line, bump our chkpnt counter, and assert equality.
Checkpoint information is represented by a sequence "checkpt %d\n" where d is a scanf-compatible representation of the checkpoint integer.
Definition at line 85 of file nrn_filehandler.cpp.
int coreneuron::FileHandler::read_int | ( | ) |
Parse a single integer entry.
Single integer entries are represented by their standard (C locale) text representation, followed by a newline. Extraneous characters following the integer but preceding the newline are ignore.
Definition at line 57 of file nrn_filehandler.cpp.
void coreneuron::FileHandler::read_mapping_cell_count | ( | int * | count | ) |
Reads number of cells in parsing file.
Definition at line 81 of file nrn_filehandler.cpp.
void coreneuron::FileHandler::read_mapping_count | ( | int * | gid, |
int * | nsec, | ||
int * | nseg, | ||
int * | nseclist | ||
) |
Parse a neuron mapping count entries.
Reads neuron mapping info which is represented by gid, #sections, #segments, #section lists
mapping file has extra strings, ignore those
Definition at line 70 of file nrn_filehandler.cpp.
|
inline |
Parse a neuron section segment mapping.
Read count no of mappings for section to segment
Definition at line 113 of file nrn_filehandler.hpp.
|
inline |
Definition at line 192 of file nrn_filehandler.hpp.
|
inline |
Record current chkpnt state.
Definition at line 80 of file nrn_filehandler.hpp.
|
inline |
Restored last recorded chkpnt state.
Definition at line 85 of file nrn_filehandler.hpp.
|
inline |
Write an 1D array.
Definition at line 203 of file nrn_filehandler.hpp.
|
inline |
Write a padded array.
nb_elements is number of elements to write per line, line_width is full size of a line in nb elements
Definition at line 214 of file nrn_filehandler.hpp.
|
inlineprivate |
Definition at line 252 of file nrn_filehandler.hpp.
|
private |
Current checkpoint number state.
Definition at line 35 of file nrn_filehandler.hpp.
|
private |
File open mode (not stored in fstream)
Definition at line 34 of file nrn_filehandler.hpp.
|
private |
File stream associated with reader.
Definition at line 33 of file nrn_filehandler.hpp.
|
private |
last "remembered" checkpoint number state.
Definition at line 36 of file nrn_filehandler.hpp.