#include "line.hpp"
// io/line.cpp - Input from files, line-by-line
//
// Copyright © 2014 Ben Longbons <b.r.longbons@gmail.com>
//
// This file is part of The Mana World (Athena server)
//
// 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 3 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, see <http://www.gnu.org/licenses/>.
#include "../strings/astring.hpp"
#include "../strings/zstring.hpp"
#include "cxxstdio.hpp"
#include "../poison.hpp"
namespace tmwa
{
namespace io
{
LineReader::LineReader(ZString name)
: filename(name), line(0), column(0), rf(name)
{}
LineReader::LineReader(ZString name, FD fd)
: filename(name), line(0), column(0), rf(fd)
{}
LineReader::LineReader(read_file_from_string, ZString name, XString content, int startline, FD fd)
: filename(name), line(startline-1), column(0), rf(from_string, content, fd)
{}
LineReader::LineReader(read_file_from_string, ZString name, LString content, int startline, FD fd)
: filename(name), line(startline-1), column(0), rf(from_string, content, fd)
{}
bool LineReader::read_line(Line& l)
{
AString text;
if (rf.getline(text))
{
l.text = text;
l.filename = filename;
l.line = ++line;
l.column = 0; // whole line
return true;
}
return false;
}
bool LineReader::is_open()
{
return rf.is_open();
}
LineCharReader::LineCharReader(ZString name)
: LineReader(name)
{
column = 1; // not 0, not whole line
if (rf.is_open())
adv();
if (!line)
column = 0;
}
// sigh, copy-paste
// in just a couple months I can drop support for gcc 4.6 though
LineCharReader::LineCharReader(ZString name, FD fd)
: LineReader(name, fd)
{
column = 1; // not 0, not whole line
if (rf.is_open())
adv();
if (!line)
column = 0;
}
LineCharReader::LineCharReader(read_file_from_string, ZString name, XString content, int startline, int startcol, FD fd)
: LineReader(from_string, name, content, 1, fd)
{
column = 1; // not 0, not whole line
if (rf.is_open())
adv();
if (!line)
column = 0;
else
{
line = startline;
column = startcol;
line_text = STRPRINTF("%*s"_fmt, static_cast<int>(column-1 + line_text.size()), line_text);
}
}
LineCharReader::LineCharReader(read_file_from_string, ZString name, LString content, int startline, int startcol, FD fd)
: LineReader(from_string, name, content, 1, fd)
{
column = 1; // not 0, not whole line
if (rf.is_open())
adv();
if (!line)
column = 0;
else
{
line = startline;
column = startcol;
line_text = STRPRINTF("%*s"_fmt, static_cast<int>(column-1 + line_text.size()), line_text);
}
}
bool LineCharReader::get(LineChar& c)
{
if (!column)
return false;
c.text = line_text;
c.filename = filename;
c.line = line;
c.column = column;
return true;
}
void LineCharReader::adv()
{
if (column - 1 == line_text.size())
{
Line tmp;
if (!read_line(tmp))
{
// eof
column = 0;
return;
}
line_text = tmp.text;
column = 1;
}
else
column++;
}
bool LineCharReader::is_open()
{
return line != 0;
}
} // namespace io
} // namespace tmwa