Source
/*
* ALMA - Atacama Large Millimeter Array
* (c) European Southern Observatory, 2002
* (c) Associated Universities Inc., 2002
* Copyright by ESO (in the framework of the ALMA collaboration),
* Copyright by AUI (in the framework of the ALMA collaboration),
* All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
* File Interval.cpp
*/
using namespace std;
namespace asdm {
Interval Interval::getInterval(StringTokenizer &t) {
int64_t value = Long::parseLong(t.nextToken());
return Interval (value);
}
bool Interval::isZero() const {
return value == 0L;
}
int64_t Interval::fromString(const string& s) {
return Long::parseLong(s);
}
string Interval::toString(int64_t x) {
return Long::toString(x);
}
void Interval::toBin(EndianOSStream& eoss) {
eoss.writeLongLong(value);
}
void Interval::toBin(vector<Interval> interval, EndianOSStream& eoss) {
eoss.writeInt((int) interval.size());
for (unsigned int i = 0; i < interval.size(); i++)
eoss.writeLongLong(interval.at(i).value);
}
void Interval::toBin(vector<vector<Interval> >interval, EndianOSStream& eoss) {
eoss.writeInt((int) interval.size());