mirror of
				https://github.com/paboyle/Grid.git
				synced 2025-11-04 05:54:32 +00:00 
			
		
		
		
	Fixing JSON error for complex numbers
This commit is contained in:
		@@ -40,10 +40,8 @@ JSONWriter::~JSONWriter(void)
 | 
			
		||||
  delete_comma();
 | 
			
		||||
  ss_ << "}";  
 | 
			
		||||
 | 
			
		||||
  cout  << ss_.str() << endl;
 | 
			
		||||
  // write prettified JSON to file
 | 
			
		||||
  std::ofstream os(fileName_);
 | 
			
		||||
  std::cout << "Writing on file" << std::endl;
 | 
			
		||||
  os << std::setw(2) << json::parse(ss_.str()) << std::endl;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -96,7 +94,7 @@ JSONReader::JSONReader(const string &fileName)
 | 
			
		||||
 | 
			
		||||
  // test
 | 
			
		||||
  // serialize to standard output
 | 
			
		||||
  std::cout << "JSONReader::JSONReader : " << jobject_ << endl; 
 | 
			
		||||
  //std::cout << "JSONReader::JSONReader : " << jobject_ << endl; 
 | 
			
		||||
  jcur_ = jobject_;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -114,7 +112,7 @@ bool JSONReader::push(const string &s)
 | 
			
		||||
      std::cout << "out of range: " << e.what() << '\n';
 | 
			
		||||
      return false;
 | 
			
		||||
    }
 | 
			
		||||
    cout << "JSONReader::push : " << s << " : "<< jcur_ << endl;
 | 
			
		||||
    //cout << "JSONReader::push : " << s << " : "<< jcur_ << endl;
 | 
			
		||||
  }
 | 
			
		||||
  else
 | 
			
		||||
  {
 | 
			
		||||
@@ -135,7 +133,7 @@ void JSONReader::pop(void)
 | 
			
		||||
  else
 | 
			
		||||
    do_pop.pop_back();
 | 
			
		||||
 | 
			
		||||
  cout << "JSONReader::pop : " << jcur_ << endl;
 | 
			
		||||
  //cout << "JSONReader::pop : " << jcur_ << endl;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool JSONReader::nextElement(const std::string &s)
 | 
			
		||||
@@ -158,14 +156,14 @@ bool JSONReader::nextElement(const std::string &s)
 | 
			
		||||
template <>
 | 
			
		||||
void JSONReader::readDefault(const string &s, string &output)
 | 
			
		||||
{
 | 
			
		||||
  cout << "JSONReader::readDefault(string) : " << s<< " " << jcur_ << endl;
 | 
			
		||||
  //cout << "JSONReader::readDefault(string) : " << s<< " " << jcur_ << endl;
 | 
			
		||||
  if (s.size()){
 | 
			
		||||
    std::cout << "String: "<< jcur_[s] << std::endl;
 | 
			
		||||
    //std::cout << "String: "<< jcur_[s] << std::endl;
 | 
			
		||||
    output = jcur_[s];
 | 
			
		||||
  }
 | 
			
		||||
  else
 | 
			
		||||
  {
 | 
			
		||||
    std::cout << "String: "<< jcur_ << std::endl;
 | 
			
		||||
    //std::cout << "String: "<< jcur_ << std::endl;
 | 
			
		||||
    output = jcur_;    
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -106,7 +106,7 @@ namespace Grid
 | 
			
		||||
  template <typename U>
 | 
			
		||||
  void JSONWriter::writeDefault(const std::string &s, const U &x)
 | 
			
		||||
  {
 | 
			
		||||
    std::cout << "JSONReader::writeDefault(U) : " << s <<  std::endl;
 | 
			
		||||
    //std::cout << "JSONReader::writeDefault(U) : " << s <<  std::endl;
 | 
			
		||||
    std::ostringstream os;
 | 
			
		||||
    os << std::boolalpha << x;
 | 
			
		||||
    if (s.size())
 | 
			
		||||
@@ -118,7 +118,7 @@ namespace Grid
 | 
			
		||||
  template <typename U>
 | 
			
		||||
  void JSONWriter::writeDefault(const std::string &s, const std::complex<U> &x)
 | 
			
		||||
  {
 | 
			
		||||
    std::cout << "JSONReader::writeDefault(complex) : " << s <<  std::endl;
 | 
			
		||||
    //std::cout << "JSONReader::writeDefault(complex) : " << s <<  std::endl;
 | 
			
		||||
    std::ostringstream os;
 | 
			
		||||
    os << "["<< std::boolalpha << x.real() << ", " << x.imag() << "]";
 | 
			
		||||
    if (s.size())
 | 
			
		||||
@@ -130,7 +130,7 @@ namespace Grid
 | 
			
		||||
  template <typename U>
 | 
			
		||||
  void JSONWriter::writeDefault(const std::string &s, const std::vector<U> &x)
 | 
			
		||||
  {
 | 
			
		||||
    std::cout << "JSONReader::writeDefault(vec U) : " << s <<  std::endl;
 | 
			
		||||
    //std::cout << "JSONReader::writeDefault(vec U) : " << s <<  std::endl;
 | 
			
		||||
 | 
			
		||||
    if (s.size())
 | 
			
		||||
      ss_ << " \""<<s<<"\" : [";
 | 
			
		||||
@@ -146,7 +146,7 @@ namespace Grid
 | 
			
		||||
 | 
			
		||||
  template<std::size_t N>
 | 
			
		||||
  void JSONWriter::writeDefault(const std::string &s, const char(&x)[N]){
 | 
			
		||||
    std::cout << "JSONReader::writeDefault(char U) : " << s <<  std::endl;
 | 
			
		||||
    //std::cout << "JSONReader::writeDefault(char U) : " << s <<  std::endl;
 | 
			
		||||
 | 
			
		||||
    if (s.size())
 | 
			
		||||
    ss_ << "\""<< s << "\" : \"" << x << "\" ," ;
 | 
			
		||||
@@ -158,15 +158,15 @@ namespace Grid
 | 
			
		||||
  template <typename U>
 | 
			
		||||
  void JSONReader::readDefault(const std::string &s, U &output)
 | 
			
		||||
  {
 | 
			
		||||
    std::cout << "JSONReader::readDefault(U) : " << s << "  :  "<< jcur_ << std::endl;
 | 
			
		||||
    //std::cout << "JSONReader::readDefault(U) : " << s << "  :  "<< jcur_ << std::endl;
 | 
			
		||||
 | 
			
		||||
    if (s.size()){
 | 
			
		||||
      std::cout << "String: "<< jcur_[s] << std::endl;
 | 
			
		||||
      //std::cout << "String: "<< jcur_[s] << std::endl;
 | 
			
		||||
      output = jcur_[s];
 | 
			
		||||
    }
 | 
			
		||||
    else
 | 
			
		||||
    {
 | 
			
		||||
      std::cout << "String: "<< jcur_ << std::endl;
 | 
			
		||||
      //std::cout << "String: "<< jcur_ << std::endl;
 | 
			
		||||
      output = jcur_;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@@ -177,7 +177,7 @@ namespace Grid
 | 
			
		||||
  void JSONReader::readDefault(const std::string &s, std::complex<U> &output)
 | 
			
		||||
  {
 | 
			
		||||
    U tmp1, tmp2;
 | 
			
		||||
    std::cout << "JSONReader::readDefault( complex U) : " << s << "  :  "<< jcur_ << std::endl;
 | 
			
		||||
    //std::cout << "JSONReader::readDefault( complex U) : " << s << "  :  "<< jcur_ << std::endl;
 | 
			
		||||
    json j = jcur_;
 | 
			
		||||
    json::iterator it = j.begin();
 | 
			
		||||
    jcur_ = *it;
 | 
			
		||||
@@ -197,14 +197,14 @@ namespace Grid
 | 
			
		||||
  {
 | 
			
		||||
    std::string    buf;
 | 
			
		||||
    unsigned int   i = 0;
 | 
			
		||||
    std::cout << "JSONReader::readDefault(vec) : " << jcur_ << std::endl;
 | 
			
		||||
    //std::cout << "JSONReader::readDefault(vec) : " << jcur_ << std::endl;
 | 
			
		||||
    if (s.size())
 | 
			
		||||
      push(s);
 | 
			
		||||
 | 
			
		||||
    json j = jcur_;
 | 
			
		||||
    for (json::iterator it = j.begin(); it != j.end(); ++it) {
 | 
			
		||||
      jcur_ = *it;
 | 
			
		||||
      std::cout << "Value: " << it.value() << "\n";
 | 
			
		||||
      //std::cout << "Value: " << it.value() << "\n";
 | 
			
		||||
      output.resize(i + 1);
 | 
			
		||||
      read("", output[i++]);
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user