⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tokenizertest.java

📁 这个是一个计算表达式的java包
💻 JAVA
字号:
/*
Created 19 Aug 2006 - Richard Morris
*/
package com.singularsys.jeptests;

import static org.junit.Assert.*;

import java.io.StringReader;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;

import com.singularsys.jep.Jep;
import com.singularsys.jep.JepComponent;
import com.singularsys.jep.NodeFactory;
import com.singularsys.jep.Operator;
import com.singularsys.jep.ParseException;
import com.singularsys.jep.PrintVisitor;
import com.singularsys.jep.VariableFactory;
import com.singularsys.jep.VariableTable;
import com.singularsys.jep.configurableparser.ConfigurableParser;
import com.singularsys.jep.configurableparser.Lookahead2Iterator;
import com.singularsys.jep.configurableparser.Tokenizer;
import com.singularsys.jep.configurableparser.tokens.CommentToken;
import com.singularsys.jep.configurableparser.tokens.IdentifierToken;
import com.singularsys.jep.configurableparser.tokens.NumberToken;
import com.singularsys.jep.configurableparser.tokens.OperatorToken;
import com.singularsys.jep.configurableparser.tokens.StringToken;
import com.singularsys.jep.configurableparser.tokens.Token;
import com.singularsys.jep.configurableparser.tokens.WhiteSpaceToken;
import com.singularsys.jep.functions.Logical;
import com.singularsys.jep.misc.ExtendedOperatorSet;
import com.singularsys.jep.standard.DoubleNumberFactory;
import com.singularsys.jep.standard.StandardEvaluator;
import com.singularsys.jep.standard.StandardFunctionTable;
import com.singularsys.jep.OperatorTable;
public class TokenizerTest {
	Jep jep;
	ConfigurableParser cp;
	
	public void checkIdentifier(Token expected,Token actual)
	{
		assertTrue("Token should be an identifier",actual instanceof IdentifierToken);
		assertEquals("Value for IndetifierToken does not match",expected.getSource(),actual.getSource());
	}
	public void checkNumber(Token expected,Token actual)
	{
		assertTrue("Token should be an identifier",actual instanceof NumberToken);
		assertEquals("Value for NumberToken does not match",expected.getSource(),actual.getSource());
	}
	public void checkString(Token expected,Token actual)
	{
		assertTrue("Token should be an identifier",actual instanceof StringToken);
		assertEquals("Value for StringToken does not match",expected.getSource(),actual.getSource());
	}
	public void checkComment(Token expected,Token actual)
	{
		assertTrue("Token should be an identifier",actual instanceof CommentToken);
		assertEquals("Value for StringToken does not match",expected.getSource(),actual.getSource());
	}
	public void checkWhiteSpace(Token expected,Token actual)
	{
		assertTrue("Token should be an identifier",actual instanceof WhiteSpaceToken);
		assertEquals("Value for StringToken does not match",expected.getSource(),actual.getSource());
	}
	public void checkOperator(Token expected,Token actual)
	{
		assertTrue("Token should be an identifier",actual instanceof OperatorToken);
		OperatorToken expOpTok = (OperatorToken) expected;
		OperatorToken actualOpTok = (OperatorToken) actual;
		assertEquals("Binary ops don't match",expOpTok.getBinaryOp(),actualOpTok.getBinaryOp());
		assertEquals("Binary ops don't match",expOpTok.getPrefixOp(),actualOpTok.getPrefixOp());
		assertEquals("Binary ops don't match",expOpTok.getSuffixOp(),actualOpTok.getSuffixOp());
		assertEquals("Binary ops don't match",expOpTok.getTernaryOp(),actualOpTok.getTernaryOp());
	}

	public void check(List<Token> tokens,List<Token> expected)
	{
		if(tokens.size() != expected.size())
			fail("Length of token sequence "+tokens.size()+" does not match expected size "+expected.size());
		for(int i=0;i<tokens.size();++i) {
			Token test = tokens.get(i);
			Token expect = expected.get(i);
			if(expect instanceof IdentifierToken)
				checkIdentifier(expect,test);
			else if(expect instanceof NumberToken)
				checkNumber(expect,test);
			else if(expect instanceof StringToken)
				checkString(expect,test);
			else if(expect instanceof OperatorToken)
				checkOperator(expect,test);
			else if(expect instanceof CommentToken)
				checkComment(expect,test);
			else if(expect instanceof WhiteSpaceToken)
				checkWhiteSpace(expect,test);
			else
				fail("Unknown token type");
		}
			
	}
	
	public void check(List<Token> tokens,Object[] expected) throws ParseException
	{
		List<Token> fullExpected = new ArrayList<Token>();
		for(Object obj:expected) {
			if(obj instanceof String)
			{
				List<Token> toks = cp.scan(new StringReader((String) obj));
				if(toks.size()!=1)
					fail("Each string in expected should be an individual token");
				fullExpected.add(toks.get(0));
			}
			else if(obj instanceof Operator)
			{
				Token t = new OperatorToken(Collections.singletonList((Operator) obj));
				fullExpected.add(t);
			}
		}
		check(tokens,fullExpected);
	}
	
	public void check(String str,String[] expected) throws ParseException
	{
		check(scan(str),expected);
	}
	@BeforeClass
	public static void setUpBeforeClass() throws Exception {
	}

	@AfterClass
	public static void tearDownAfterClass() throws Exception {
	}

	@Before
	public void setUp() throws Exception {
		jep = new Jep(new JepComponent[]{
				new DoubleNumberFactory(),
				new VariableFactory(),
				new NodeFactory(),
				new StandardFunctionTable(),
				new VariableTable(),
				new ExtendedOperatorSet(),
				new ConfigurableParser(),
				new StandardEvaluator(),
				new PrintVisitor()
		});
		cp = (ConfigurableParser) jep.getParser();
//		tk = cp.getTk();
	}

	@After
	public void tearDown() throws Exception {
	}

	List<Token> scan(String s) throws ParseException {
		return cp.scan(new StringReader(s));
	}
	
	/** Tests individual tokens */
	@Test
	public final void testTokens() throws ParseException {
		List<Token> tokens = scan("a");
		check(tokens,Collections.singletonList((Token) new IdentifierToken("a")));
		tokens = scan("\"aaa\"");
		check(tokens,Collections.singletonList((Token) new StringToken("\"aaa\"","aaa",'"')));
//		tokens = scan("'aaa'");
//		check(tokens,Collections.singletonList((Token) new StringToken("'aaa'","aaa",'\'')));
		tokens = scan("1");
		check(tokens,Collections.singletonList((Token) new NumberToken("1",jep.getNumberFactory())));
		tokens = scan("1.2");
		check(tokens,Collections.singletonList((Token) new NumberToken("1.2",jep.getNumberFactory())));
		tokens = scan("1.");
		check(tokens,Collections.singletonList((Token) new NumberToken("1.",jep.getNumberFactory())));
		tokens = scan(".2");
		check(tokens,Collections.singletonList((Token) new NumberToken(".2",jep.getNumberFactory())));
		tokens = scan("//aa a");
		check(tokens,Collections.singletonList((Token) new CommentToken("//aa a")));
		tokens = scan("/*aa a*/");
		check(tokens,Collections.singletonList((Token) new CommentToken("/*aa a*/")));
		tokens = scan("#aa a");
		check(tokens,Collections.singletonList((Token) new CommentToken("#aa a")));
		tokens = scan("*");
		check(tokens,Collections.singletonList((Token) new OperatorToken(
				Collections.singletonList(jep.getOperatorTable().getOperator(OperatorTable.OP_MULTIPLY)))));

	}

	@Test
	public  final void testScan() throws ParseException {
		check("a!=b",new String[]{"a","!=","b"});
		check("a&&b",new String[]{"a","&&","b"});
		check("a<=b",new String[]{"a","<=","b"});
		check("a==b",new String[]{"a","==","b"});
		check("a>=b",new String[]{"a",">=","b"});
		check("a^^b",new String[]{"a","^^","b"});
		check("a||b",new String[]{"a","||","b"});
		check("a!b",new String[]{"a","!","b"});
		check("a%b",new String[]{"a","%","b"});
		check("a*b",new String[]{"a","*","b"});
		check("a+b",new String[]{"a","+","b"});
		check("a-b",new String[]{"a","-","b"});
		check("a.b",new String[]{"a",".","b"});
		check("a/b",new String[]{"a","/","b"});
		check("a<b",new String[]{"a","<","b"});
		check("a=b",new String[]{"a","=","b"});
		check("a>b",new String[]{"a",">","b"});
		check("a^b",new String[]{"a","^","b"});
		check("-a",new String[]{"-","a"});
		check("+a",new String[]{"+","a"});
		check("!a",new String[]{"!","a"});
		check("a%",new String[]{"a","%"});
		check(" a",new String[]{" ","a"});
		check("a b",new String[]{"a"," ","b"});
		check("a ",new String[]{"a"," "});
		check("a-1",new String[]{"a","-","1"});
		check("-1",new String[]{"-","1"});
		check("a/*zzz*/b",new String[]{"a","/*zzz*/","b"});
	}
	@Test
	public final void testRemoveWhitespace() throws ParseException {
		Operator binaryminus = jep.getOperatorTable().getOperator(OperatorTable.OP_SUBTRACT); 
		Operator unaryminus = jep.getOperatorTable().getOperator(OperatorTable.OP_NEGATE); 
		Operator binarymul = jep.getOperatorTable().getOperator(OperatorTable.OP_MULTIPLY); 
	}

	@Test
	public final void testScanOps() throws ParseException {
		Operator binaryminus = jep.getOperatorTable().getOperator(OperatorTable.OP_SUBTRACT); 
		Operator unaryminus = jep.getOperatorTable().getOperator(OperatorTable.OP_NEGATE); 
		Operator binarymul = jep.getOperatorTable().getOperator(OperatorTable.OP_MULTIPLY); 
//		check(tk.scanOperatorFix(tk.scan("a-b")), new Object[]{"a",binaryminus,"b"});
//		check(tk.scanOperatorFix(tk.scan("-b")), new Object[]{unaryminus,"b"});
//		check(tk.scanOperatorFix(tk.scan("a*-b")), new Object[]{"a","*",unaryminus,"b"});
	}

	@Test
	public final void testIt() {
		List<Integer> list = new ArrayList<Integer>();
		list.add(1);
		list.add(2);
		list.add(3);
		list.add(4);
		list.add(5);
		Lookahead2Iterator<Integer> myIt = new Lookahead2Iterator<Integer>(list);
		assertNotNull(myIt.peekNext());
		assertEquals(new Integer(1),myIt.peekNext());
		assertEquals(new Integer(1),myIt.peekNext());
		myIt.consume();
		assertEquals(new Integer(2),myIt.peekNext());
		assertEquals(new Integer(2),myIt.peekNext());
		myIt.consume();
		assertEquals(new Integer(3),myIt.peekNext());
		assertEquals(new Integer(3),myIt.peekNext());
		myIt.consume();
		assertEquals(new Integer(4),myIt.peekNext());
		assertEquals(new Integer(4),myIt.peekNext());
		assertNotNull(myIt.peekNext());
		myIt.consume();
		assertEquals(new Integer(5),myIt.peekNext());
		assertEquals(new Integer(5),myIt.peekNext());
		assertNotNull(myIt.peekNext());
		myIt.consume();
		assertNull(myIt.peekNext());
	}

	@Test
	public void testMultiLineComments() throws Exception {
		String comment = "/* y + \n" +
			" a b\n" +
			" c */";
		String s = "x+" + comment + "d";
		List<Token> tokens = cp.scan(new StringReader(s));
		System.out.print(Tokenizer.toString(tokens));
		assertTrue(tokens.get(0) instanceof IdentifierToken);
		assertEquals(tokens.get(0).getSource(),"x");
		assertTrue(tokens.get(1) instanceof OperatorToken);
		assertEquals(tokens.get(1).getSource(),"+");
		assertTrue(tokens.get(2) instanceof CommentToken);
		assertEquals(tokens.get(2).getSource(),comment);
		assertTrue(tokens.get(3) instanceof IdentifierToken);
		assertEquals(tokens.get(3).getSource(),"d");
	}

	@Test
	public void testMultiLineWhiteSpace() throws Exception {
		String s = "x+y+\nz";
		List<Token> tokens = cp.scan(new StringReader(s));
		System.out.print(Tokenizer.toString(tokens));
		assertTrue(tokens.get(0) instanceof IdentifierToken);
		assertEquals(tokens.get(0).getSource(),"x");
		assertTrue(tokens.get(1) instanceof OperatorToken);
		assertEquals(tokens.get(1).getSource(),"+");
		assertTrue(tokens.get(2) instanceof IdentifierToken);
		assertEquals(tokens.get(2).getSource(),"y");
		assertTrue(tokens.get(3) instanceof OperatorToken);
		assertEquals(tokens.get(3).getSource(),"+");
		assertTrue(tokens.get(4) instanceof WhiteSpaceToken);
		assertEquals(tokens.get(4).getSource(),"\n");
		assertTrue(tokens.get(5) instanceof IdentifierToken);
		assertEquals(tokens.get(5).getSource(),"z");
	}

	@Test
	public void testSemiColon() throws Exception {
		String s = "1;2;3;\n" +
			"4;5;";
		List<Token> tokens = cp.scan(new StringReader(s));
		assertTrue(tokens.get(0) instanceof NumberToken);
		assertEquals("1",tokens.get(0).getSource());
		assertTrue(tokens.size()==1);

		tokens = cp.scan();
		assertTrue(tokens.get(0) instanceof NumberToken);
		assertEquals("2",tokens.get(0).getSource());
		assertTrue(tokens.size()==1);

		tokens = cp.scan();
		assertTrue(tokens.get(0) instanceof NumberToken);
		assertEquals("3",tokens.get(0).getSource());
		assertTrue(tokens.size()==1);

		tokens = cp.scan();
		assertTrue(tokens.get(0) instanceof WhiteSpaceToken);
		assertEquals("\n",tokens.get(0).getSource());
		assertTrue(tokens.get(1) instanceof NumberToken);
		assertEquals("4",tokens.get(1).getSource());
		assertTrue(tokens.size()==2);

		tokens = cp.scan();
		assertTrue(tokens.get(0) instanceof NumberToken);
		assertEquals("5",tokens.get(0).getSource());
		assertTrue(tokens.size()==1);
		
		tokens = cp.scan();
		assertTrue(tokens.size()==0);
	}
	
	@Test
	public void testSemiColon2() throws Exception {
		String s = "1;2;x+\n" +
			"y;5;";
		List<Token> tokens = cp.scan(new StringReader(s));
		assertTrue(tokens.get(0) instanceof NumberToken);
		assertEquals("1",tokens.get(0).getSource());
		assertTrue(tokens.size()==1);

		tokens = cp.scan();
		assertTrue(tokens.get(0) instanceof NumberToken);
		assertEquals("2",tokens.get(0).getSource());
		assertTrue(tokens.size()==1);

		tokens = cp.scan();
		assertTrue(tokens.get(0) instanceof IdentifierToken);
		assertEquals("x",tokens.get(0).getSource());
		assertTrue(tokens.get(1) instanceof OperatorToken);
		assertEquals("+",tokens.get(1).getSource());
		assertTrue(tokens.get(2) instanceof WhiteSpaceToken);
		assertEquals("\n",tokens.get(2).getSource());
		assertTrue(tokens.get(3) instanceof IdentifierToken);
		assertEquals("y",tokens.get(3).getSource());
		assertTrue(tokens.size()==4);

		tokens = cp.scan();
		assertTrue(tokens.get(0) instanceof NumberToken);
		assertEquals("5",tokens.get(0).getSource());
		assertTrue(tokens.size()==1);
		
		tokens = cp.scan();
		assertTrue(tokens.size()==0);
	}

	public void testExtended() throws Exception
	{
		List<Token> tokens = cp.scan(new StringReader("5!"));
	}
	
	/**
	 * Tests operators with alphabet characters, such as the "AND" operator
	 * @throws Exception
	 */
	@Test
	public void alphabeticOpsTest() throws Exception {
		// alter operator table
		OperatorTable ot = jep.getOperatorTable();
		Operator andOp = new Operator("AND", new Logical(0), Operator.BINARY+Operator.LEFT+Operator.ASSOCIATIVE);
		ot.addOperator(OperatorTable.OP_AND, andOp, ot.getAnd());
		// informs the parser and other components about the new operator
		jep.reinitializeComponents();

		List<Token> tokens = cp.scan(new StringReader("1AND1"));
		printTokenList(tokens);
		check(tokens, new Object[]{"1", andOp, "1"});
		
	}
	
	public void printTokenList(List<Token> tokens) {
		for (Token t:tokens) {
			System.out.print(t.toString() + ", ");
		}
	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -