Blame cxx/ismpq.cc

Packit 15dc08
/* operator>> -- C++-style input of mpq_t.
Packit 15dc08
Packit 15dc08
Copyright 2003 Free Software Foundation, Inc.
Packit 15dc08
Packit 15dc08
This file is part of the GNU MP Library.
Packit 15dc08
Packit 15dc08
The GNU MP Library is free software; you can redistribute it and/or modify
Packit 15dc08
it under the terms of either:
Packit 15dc08
Packit 15dc08
  * the GNU Lesser General Public License as published by the Free
Packit 15dc08
    Software Foundation; either version 3 of the License, or (at your
Packit 15dc08
    option) any later version.
Packit 15dc08
Packit 15dc08
or
Packit 15dc08
Packit 15dc08
  * the GNU General Public License as published by the Free Software
Packit 15dc08
    Foundation; either version 2 of the License, or (at your option) any
Packit 15dc08
    later version.
Packit 15dc08
Packit 15dc08
or both in parallel, as here.
Packit 15dc08
Packit 15dc08
The GNU MP Library is distributed in the hope that it will be useful, but
Packit 15dc08
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
Packit 15dc08
or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
Packit 15dc08
for more details.
Packit 15dc08
Packit 15dc08
You should have received copies of the GNU General Public License and the
Packit 15dc08
GNU Lesser General Public License along with the GNU MP Library.  If not,
Packit 15dc08
see https://www.gnu.org/licenses/.  */
Packit 15dc08
Packit 15dc08
#include <cctype>
Packit 15dc08
#include <iostream>
Packit 15dc08
#include <string>
Packit 15dc08
#include "gmp.h"
Packit 15dc08
#include "gmp-impl.h"
Packit 15dc08
Packit 15dc08
using namespace std;
Packit 15dc08
Packit 15dc08
Packit 15dc08
istream &
Packit 15dc08
operator>> (istream &i, mpq_ptr q)
Packit 15dc08
{
Packit 15dc08
  if (! (i >> mpq_numref(q)))
Packit 15dc08
    return i;
Packit 15dc08
Packit 15dc08
  char  c = 0;
Packit 15dc08
  i.get(c); // start reading
Packit 15dc08
Packit 15dc08
  if (c == '/')
Packit 15dc08
    {
Packit 15dc08
      // skip slash, read denominator
Packit 15dc08
      i.get(c);
Packit 15dc08
      return __gmpz_operator_in_nowhite (i, mpq_denref(q), c);
Packit 15dc08
    }
Packit 15dc08
  else
Packit 15dc08
    {
Packit 15dc08
      // no denominator, set 1
Packit 15dc08
      q->_mp_den._mp_size = 1;
Packit 15dc08
      q->_mp_den._mp_d[0] = 1;
Packit 15dc08
      if (i.good())
Packit 15dc08
        i.putback(c);
Packit 15dc08
      else if (i.eof())
Packit 15dc08
        i.clear(ios::eofbit);
Packit 15dc08
    }
Packit 15dc08
Packit 15dc08
  return i;
Packit 15dc08
}