File: misc.java

package info (click to toggle)
mauve 20120103-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 28,504 kB
  • sloc: java: 250,155; sh: 2,834; xml: 208; makefile: 66
file content (73 lines) | stat: -rw-r--r-- 2,849 bytes parent folder | download | duplicates (5)
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
// Test of several methods of StreamTokenizer.

/*************************************************************************
/* 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 2 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, write to the Free Software Foundation
/* Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307 USA
/*************************************************************************/

// Tags: JDK1.1

package gnu.testlet.java.io.StreamTokenizer;

import java.io.*;
import gnu.testlet.Testlet;
import gnu.testlet.TestHarness;

public class misc implements Testlet
{
  public void test (TestHarness harness)
  {
	int tt;		// Token type

	StringReader sr = new StringReader("LineOne\nSecond/Line\n?Question?3.14\nAxyz");
	StreamTokenizer st = new StreamTokenizer(sr);
	st.eolIsSignificant(true);	// Pass EOLs as tokens
 	st.ordinaryChar('/');		// Remove 'comment' specialness of /
	st.lowerCaseMode(true);
	try {
		tt = st.nextToken();
		harness.check(st.lineno(), 1, "lineno()");
		harness.check(st.sval, "lineone", "lowerCaseMode()");
		tt = st.nextToken();  // Should be newline		
		harness.check(tt, StreamTokenizer.TT_EOL, "eolIsSignificant()");
		tt = st.nextToken();	// Parse 'Second'
		tt = st.nextToken();	// Parse '/'
		st.lowerCaseMode(false);
		tt = st.nextToken();	// Parse 'Line'; wouldn't happen if / were a comment char
		harness.check(st.sval, "Line", "ordinaryChar()");
		st.pushBack();
		tt = st.nextToken();
		harness.check(st.sval, "Line", "pushBack()");
		st.quoteChar('?');
		tt = st.nextToken();	// Parse EOL
		tt = st.nextToken();	// Get string quoted by ?
		harness.check(st.ttype, '?', "ttype field");
		harness.check(st.sval, "Question", "quoteChar()");
		st.parseNumbers();		// Get ready for the next one
		tt = st.nextToken();
		harness.check(tt, StreamTokenizer.TT_NUMBER, "TT_NUMBER");
		harness.check(st.nval > 3.1399 && st.nval < 3.1401, "parseNumbers()");
		harness.debug("'3.14' came out " + st.nval);
		st.ordinaryChars('A','C');	// Make A, B, and C their own special tokens
		tt = st.nextToken();	// Parse EOL
		harness.check(st.nextToken(), 'A', "ordinaryChars()");
		st.resetSyntax();		// Every character is its own token
		harness.check(st.nextToken(), 'x', "resetSyntax()");
	}
	catch (IOException e) {
		harness.debug (e);
		harness.fail ("Unexpected Exception caught");
	}
  }
}