package istlab.KisoJikken.Test; //package org.fife.ui.rsyntaxtextarea.modes; import java.io.*; import javax.swing.text.Segment; import org.fife.ui.rsyntaxtextarea.*; import java.io.InputStreamReader; %% // 生成するクラスの名前 %public %class WordTestTokenMaker %extends AbstractJFlexCTokenMaker %unicode %type org.fife.ui.rsyntaxtextarea.Token %{ /* フィールドやメソッドはここに書く */ /* public static void main(String[] args) throws IOException { new Lexer0(new InputStreamReader(System.in)).yylex(); } */ public WordTestTokenMaker(){ } /** * Always returns <code>TokenTypes.NULL</code>, as there are no multiline * tokens in properties files. * * @param text The line of tokens to examine. * @param initialTokenType The token type to start with (i.e., the value * of <code>getLastTokenTypeOnLine</code> for the line before * <code>text</code>). * @return <code>TokenTypes.NULL</code>. */ public int getLastTokenTypeOnLine(Segment text, int initialTokenType) { return TokenTypes.NULL; } /** * Adds the token specified to the current linked list of tokens. * * @param tokenType The token's type. * @see #addToken(int, int, int) */ private void addHyperlinkToken(int start, int end, int tokenType) { int so = start + offsetShift; addToken(zzBuffer, start,end, tokenType, so, true); } /** * Adds the token specified to the current linked list of tokens. * * @param tokenType The token's type. */ private void addToken(int tokenType) { addToken(zzStartRead, zzMarkedPos-1, tokenType); } /** * Adds the token specified to the current linked list of tokens. * * @param tokenType The token's type. * @param link Whether this token is a hyperlink. */ private void addToken(int tokenType, boolean link) { int so = zzStartRead + offsetShift; super.addToken(zzBuffer, zzStartRead,zzMarkedPos-1, tokenType, so, link); zzStartRead = zzMarkedPos; } /** * Adds the token specified to the current linked list of tokens. * * @param tokenType The token's type. * @see #addHyperlinkToken(int, int, int) */ private void addToken(int start, int end, int tokenType) { int so = start + offsetShift; addToken(zzBuffer, start,end, tokenType, so, false); } /** * Adds the token specified to the current linked list of tokens. * * @param array The character array. * @param start The starting offset in the array. * @param end The ending offset in the array. * @param tokenType The token's type. * @param startOffset The offset in the document at which this token * occurs. * @param hyperlink Whether this token is a hyperlink. */ @Override public void addToken(char[] array, int start, int end, int tokenType, int startOffset, boolean hyperlink) { super.addToken(array, start,end, tokenType, startOffset, hyperlink); zzStartRead = zzMarkedPos; } /** * Returns the text to place at the beginning and end of a * line to "comment" it in a this programming language. * * @return <code>null</code>, as there are no comments in plain text. */ @Override public String[] getLineCommentStartAndEnd(int languageIndex) { return new String[] { "//", null }; } /** * Always returns <tt>false</tt>, as you never want "mark occurrences" * working in plain text files. * * @param type The token type. * @return Whether tokens of this type should have "mark occurrences" * enabled. */ @Override public boolean getMarkOccurrencesOfTokenType(int type) { return false; } /** * Returns the first token in the linked list of tokens generated * from <code>text</code>. This method must be implemented by * subclasses so they can correctly implement syntax highlighting. * * @param text The text from which to get tokens. * @param initialTokenType The token type we should start with. * @param startOffset The offset into the document at which * <code>text</code> starts. * @return The first <code>Token</code> in a linked list representing * the syntax highlighted text. */ public Token getTokenList(Segment text, int initialTokenType, int startOffset) { resetTokenList(); this.offsetShift = -text.offset + startOffset; // Start off in the proper state. s = text; try { yyreset(zzReader); yybegin(YYINITIAL); return yylex(); } catch (IOException ioe) { ioe.printStackTrace(); return new TokenImpl(); } } /** * Refills the input buffer. * * @return <code>true</code> if EOF was reached, otherwise * <code>false</code>. */ private boolean zzRefill() { return zzCurrentPos>=s.offset+s.count; } /** * Resets the scanner to read from a new input stream. * Does not close the old reader. * * All internal variables are reset, the old input stream * <b>cannot</b> be reused (internal buffer is discarded and lost). * Lexical state is set to <tt>YY_INITIAL</tt>. * * @param reader the new input stream */ public final void yyreset(java.io.Reader reader) { // 's' has been updated. zzBuffer = s.array; /* * We replaced the line below with the two below it because zzRefill * no longer "refills" the buffer (since the way we do it, it's always * "full" the first time through, since it points to the segment's * array). So, we assign zzEndRead here. */ //zzStartRead = zzEndRead = s.offset; zzStartRead = s.offset; zzEndRead = zzStartRead + s.count - 1; zzCurrentPos = zzMarkedPos = s.offset; zzLexicalState = YYINITIAL; zzReader = reader; // zzAtBOL = true; zzAtEOF = false; } %} LineTerminator = ([\n]) %% <YYINITIAL> { /* ここに動作記述を書く。*/ /* yytext()はマッチした文字列を返すメソッド */ [hH]ello { addToken(TokenTypes.COMMENT_EOL, false); } . { System.out.print(yytext()); addToken(TokenTypes.IDENTIFIER, false); } /* その他の文字はそのまま出力 */ {LineTerminator}| <<EOF>> { addNullToken(); return firstToken; } }