/** * Alipay.com Inc. * Copyright (c) 2004-2012 All Rights Reserved. */ package com.alipay.zdal.parser.sql.parser; import java.util.HashMap; import java.util.Map; /** * * @author ���� * @version $Id: Keywords.java, v 0.1 2012-11-17 ����3:53:24 Exp $ */ public class Keywords { private final Map<String, Token> keywords; public final static Keywords DEFAULT_KEYWORDS; static { Map<String, Token> map = new HashMap<String, Token>(); map.put("ALL", Token.ALL); map.put("ALTER", Token.ALTER); map.put("AND", Token.AND); map.put("ANY", Token.ANY); map.put("AS", Token.AS); map.put("ASC", Token.ASC); map.put("BETWEEN", Token.BETWEEN); map.put("BY", Token.BY); map.put("CASE", Token.CASE); map.put("CAST", Token.CAST); map.put("CHECK", Token.CHECK); map.put("CONSTRAINT", Token.CONSTRAINT); map.put("CREATE", Token.CREATE); map.put("DATABASE", Token.DATABASE); map.put("DEFAULT", Token.DEFAULT); map.put("DELETE", Token.DELETE); map.put("DESC", Token.DESC); map.put("DISTINCT", Token.DISTINCT); map.put("DROP", Token.DROP); map.put("ELSE", Token.ELSE); map.put("END", Token.END); map.put("ESCAPE", Token.ESCAPE); map.put("EXISTS", Token.EXISTS); map.put("FOR", Token.FOR); map.put("FOREIGN", Token.FOREIGN); map.put("FROM", Token.FROM); map.put("FULL", Token.FULL); map.put("GROUP", Token.GROUP); map.put("HAVING", Token.HAVING); map.put("IN", Token.IN); map.put("INDEX", Token.INDEX); map.put("INNER", Token.INNER); map.put("INSERT", Token.INSERT); map.put("INTERSECT", Token.INTERSECT); map.put("INTERVAL", Token.INTERVAL); map.put("INTO", Token.INTO); map.put("IS", Token.IS); map.put("JOIN", Token.JOIN); map.put("KEY", Token.KEY); map.put("LEFT", Token.LEFT); map.put("LIKE", Token.LIKE); map.put("LOCK", Token.LOCK); map.put("MINUS", Token.MINUS); map.put("NEW", Token.NEW); map.put("NOT", Token.NOT); map.put("NULL", Token.NULL); map.put("ON", Token.ON); map.put("OR", Token.OR); map.put("ORDER", Token.ORDER); map.put("OUTER", Token.OUTER); map.put("PRIMARY", Token.PRIMARY); map.put("REFERENCES", Token.REFERENCES); map.put("RIGHT", Token.RIGHT); map.put("SCHEMA", Token.SCHEMA); map.put("SELECT", Token.SELECT); map.put("SET", Token.SET); map.put("SOME", Token.SOME); map.put("TABLE", Token.TABLE); map.put("THEN", Token.THEN); map.put("TRUNCATE", Token.TRUNCATE); map.put("UNION", Token.UNION); map.put("UNIQUE", Token.UNIQUE); map.put("UPDATE", Token.UPDATE); map.put("VALUES", Token.VALUES); map.put("VIEW", Token.VIEW); map.put("WHEN", Token.WHEN); map.put("WHERE", Token.WHERE); map.put("XOR", Token.XOR); map.put("RR", Token.RR); map.put("RS", Token.RS); map.put("UR", Token.UR); DEFAULT_KEYWORDS = new Keywords(map); } public boolean containsValue(Token token) { return this.keywords.containsValue(token); } public Keywords(Map<String, Token> keywords) { this.keywords = keywords; } public Token getKeyword(String key) { key = key.toUpperCase(); return keywords.get(key); } public Map<String, Token> getKeywords() { return keywords; } }