File: test_text_reader.cpp

package info (click to toggle)
libgtextutils 0.6.2-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 1,680 kB
  • sloc: sh: 10,041; cpp: 947; ansic: 415; makefile: 69
file content (73 lines) | stat: -rw-r--r-- 2,337 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
   Gordon's Text-Utilities Library
   Copyright (C) 2009 Assaf Gordon (gordon@cshl.edu)

   This program is free software: you can redistribute it and/or modify
   it under the terms of the GNU Affero 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 Affero General Public License for more details.

   You should have received a copy of the GNU Affero General Public License
   along with this program.  If not, see <http://www.gnu.org/licenses/>
*/
#include <err.h>
#include <iostream>
#include <string>

#include <gtextutils/stream_wrapper.h>
#include <gtextutils/text_line_reader.h>

#include "tests_assertion.h"

/*
 * Testing the TextLineReader class
 *
 * Read four lines from a known file,
 * using different methods
 */

using namespace std;

int main()
{
	InputStreamWrapper input("test.txt");
	TextLineReader reader ( input.stream() );

	string line ;

	ASSERT ( reader.next_line() );
	line = reader.line_string() ; //first line - with explicit method to get the string
	ASSERT( line == "first line" ) ;

	ASSERT ( reader.next_line() );
	line = reader ; //second line - with implicit conversion to std::string
	ASSERT( line == "second line" ) ;

	ASSERT ( reader.next_line() );
	istream &is1 ( reader.line_stream() ); //third line - with explicit method to get the istream
	is1 >> line ; // read each word from the line
	ASSERT( line == "third" ) ;
	is1 >> line ;
	ASSERT ( line == "line" ) ;
	is1 >> line ; // read past the end of the line - this should fail (and not read the next word from the next line, as it would have happened with a normal istream;
	ASSERT ( ! is1 ) ;

	ASSERT ( reader.next_line() );
	istream &is2 ( reader ) ; // fourth line - with implicit conversion to std::istream
	is2 >> line ;
	ASSERT( line == "fourth" ) ;
	is2 >> line ;
	ASSERT( line == "line" ) ;
	is1 >> line ; // read past the end of the line - this should fail (and not read the next word from the next line
	ASSERT ( !is2 ) ;


	//read past the end of the file - make sure it fails.
	ASSERT ( !reader.next_line() ) ;
	return 0;
}