1
0
mirror of https://github.com/paboyle/Grid.git synced 2024-11-16 02:35:36 +00:00
Grid/lib/serialisation/TextIO.h

128 lines
3.5 KiB
C
Raw Normal View History

/*************************************************************************************
Grid physics library, www.github.com/paboyle/Grid
Source file: ./lib/serialisation/TextIO.h
Copyright (C) 2015
Author: Antonin Portelli <antonin.portelli@me.com>
Author: Peter Boyle <paboyle@ph.ed.ac.uk>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
See the full license in the file "LICENSE" in the top level distribution directory
*************************************************************************************/
/* END LEGAL */
2015-08-20 23:04:38 +01:00
#ifndef GRID_SERIALISATION_TEXT_READER_H
#define GRID_SERIALISATION_TEXT_READER_H
#include <iostream>
#include <iomanip>
#include <fstream>
#include <sstream>
#include <math.h>
#include <vector>
#include <cassert>
2015-11-16 18:14:37 +00:00
namespace Grid
{
class TextWriter: public Writer<TextWriter>
{
2015-11-16 18:14:37 +00:00
public:
TextWriter(const std::string &fileName);
virtual ~TextWriter(void) = default;
void push(const std::string &s);
void pop(void);
template <typename U>
void writeDefault(const std::string &s, const U &x);
2015-11-16 18:14:37 +00:00
template <typename U>
void writeDefault(const std::string &s, const std::vector<U> &x);
2015-11-16 18:14:37 +00:00
private:
void indent(void);
private:
std::ofstream file_;
int level_{0};
};
2015-11-16 18:14:37 +00:00
class TextReader: public Reader<TextReader>
{
public:
TextReader(const std::string &fileName);
virtual ~TextReader(void) = default;
bool push(const std::string &s);
2015-11-16 18:14:37 +00:00
void pop(void);
template <typename U>
void readDefault(const std::string &s, U &output);
template <typename U>
void readDefault(const std::string &s, std::vector<U> &output);
private:
void checkIndent(void);
private:
std::ifstream file_;
int level_{0};
};
// Writer template implementation ////////////////////////////////////////////
template <typename U>
void TextWriter::writeDefault(const std::string &s, const U &x)
2015-11-16 18:14:37 +00:00
{
2015-08-20 23:04:38 +01:00
indent();
file_ << std::boolalpha << x << std::endl;
}
2015-11-16 18:14:37 +00:00
template <typename U>
void TextWriter::writeDefault(const std::string &s, const std::vector<U> &x)
2015-11-16 18:14:37 +00:00
{
uint64_t sz = x.size();
2015-11-16 18:14:37 +00:00
write(s, sz);
for (uint64_t i = 0; i < sz; ++i)
{
write(s, x[i]);
2015-08-20 23:04:38 +01:00
}
}
2015-11-16 18:14:37 +00:00
// Reader template implementation ////////////////////////////////////////////
template <typename U>
void TextReader::readDefault(const std::string &s, U &output)
{
std::string buf;
2015-08-20 23:04:38 +01:00
2015-11-16 18:14:37 +00:00
readDefault(s, buf);
fromString(output, buf);
}
2015-11-16 18:14:37 +00:00
template <>
void TextReader::readDefault(const std::string &s, std::string &output);
2015-11-16 18:14:37 +00:00
template <typename U>
void TextReader::readDefault(const std::string &s, std::vector<U> &output)
{
2015-11-16 18:14:37 +00:00
uint64_t sz;
read("", sz);
output.resize(sz);
for (uint64_t i = 0; i < sz; ++i)
{
read("", output[i]);
}
}
}
2015-11-16 18:14:37 +00:00
#endif