001: package workbench.gui.editor;
002:
003: /*
004: * Token.java - Generic token
005: * Copyright (C) 1998, 1999 Slava Pestov
006: *
007: * You may use and modify this package for any purpose. Redistribution is
008: * permitted, in both source and binary form, provided that this notice
009: * remains intact in all source distributions of this package.
010: */
011:
012: /**
013: * A linked list of tokens. Each token has three fields - a token
014: * identifier, which is a byte value that can be looked up in the
015: * array returned by <code>SyntaxDocument.getColors()</code>
016: * to get a color value, a length value which is the length of the
017: * token in the text, and a pointer to the next token in the list.
018: *
019: * @author Slava Pestov
020: * @version $Id: Token.java,v 1.2 2007/12/17 20:41:20 thomas Exp $
021: */
022: public class Token {
023: /**
024: * Normal text token id. This should be used to mark
025: * normal text.
026: */
027: public static final byte NULL = 0;
028:
029: /**
030: * Comment 1 token id. This can be used to mark a comment.
031: */
032: public static final byte COMMENT1 = 1;
033:
034: /**
035: * Comment 2 token id. This can be used to mark a comment.
036: */
037: public static final byte COMMENT2 = 2;
038:
039: /**
040: * Literal 1 token id. This can be used to mark a string
041: * literal (eg, C mode uses this to mark "..." literals)
042: */
043: public static final byte LITERAL1 = 3;
044:
045: /**
046: * Literal 2 token id. This can be used to mark an object
047: * literal (eg, Java mode uses this to mark true, false, etc)
048: */
049: public static final byte LITERAL2 = 4;
050:
051: /**
052: * Label token id. This can be used to mark labels
053: * (eg, C mode uses this to mark ...: sequences)
054: */
055: public static final byte LABEL = 5;
056:
057: /**
058: * Keyword 1 token id. This can be used to mark a
059: * keyword. This should be used for general language
060: * constructs.
061: */
062: public static final byte KEYWORD1 = 6;
063:
064: /**
065: * Keyword 2 token id. This can be used to mark a
066: * keyword. This should be used for preprocessor
067: * commands, or variables.
068: */
069: public static final byte KEYWORD2 = 7;
070:
071: /**
072: * Keyword 3 token id. This can be used to mark a
073: * keyword. This should be used for data types.
074: */
075: public static final byte KEYWORD3 = 8;
076:
077: /**
078: * Operator token id. This can be used to mark an
079: * operator. (eg, SQL mode marks +, -, etc with this
080: * token type)
081: */
082: public static final byte OPERATOR = 9;
083:
084: /**
085: * Invalid token id. This can be used to mark invalid
086: * or incomplete tokens, so the user can easily spot
087: * syntax errors.
088: */
089: public static final byte INVALID = 10;
090:
091: /**
092: * The total number of defined token ids.
093: */
094: public static final byte ID_COUNT = 11;
095:
096: /**
097: * The first id that can be used for internal state
098: * in a token marker.
099: */
100: public static final byte INTERNAL_FIRST = 100;
101:
102: /**
103: * The last id that can be used for internal state
104: * in a token marker.
105: */
106: public static final byte INTERNAL_LAST = 126;
107:
108: /**
109: * The token type, that along with a length of 0
110: * marks the end of the token list.
111: */
112: //public static final byte END = 127;
113: private char pendingChar = 0;
114:
115: /**
116: * The length of this token.
117: */
118: public int length;
119:
120: /**
121: * The id of this token.
122: */
123: public byte id;
124:
125: /**
126: * The next token in the linked list.
127: */
128: public Token next;
129:
130: /**
131: * Creates a new token.
132: * @param length The length of the token
133: * @param id The id of the token
134: */
135: public Token(int length, byte id) {
136: this .length = length;
137: this .id = id;
138: }
139:
140: public boolean isLiteral() {
141: return isLiteral(this .id);
142: }
143:
144: public boolean isMultiline() {
145: return this .pendingChar != 0;
146: }
147:
148: public void setPendingLiteralChar(char c) {
149: this .pendingChar = c;
150: }
151:
152: public char getPendingLiteralChar() {
153: return this .pendingChar;
154: }
155:
156: public static boolean isLiteral(int tokenId) {
157: return (tokenId == LITERAL1 || tokenId == LITERAL2);
158: }
159:
160: public String typeString() {
161: return typeString(this .id);
162: }
163:
164: public static String typeString(int id) {
165: String type = "NULL";
166: switch (id) {
167: case COMMENT1:
168: type = "C1";
169: break;
170: case COMMENT2:
171: type = "C2";
172: break;
173: case LITERAL1:
174: type = "L1";
175: break;
176: case LITERAL2:
177: type = "L2";
178: break;
179: case KEYWORD1:
180: type = "K1";
181: break;
182: case KEYWORD2:
183: type = "K2";
184: break;
185: case KEYWORD3:
186: type = "K3";
187: break;
188: case OPERATOR:
189: type = "OP";
190: break;
191: case NULL:
192: type = "NL";
193: break;
194: // case END:
195: // type = "EN";
196: // break;
197: default:
198: type = "OT";
199: break;
200: }
201: return type;
202: }
203:
204: /**
205: * Returns a string representation of this token.
206: */
207: public String toString() {
208: return "[type=" + typeString() + ",length=" + length + "]";
209: }
210: }
|