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

📄 perltokenmarker.java

📁 jedit中独立出来的语法高亮组件
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/* * PerlTokenMarker.java - Perl token marker * Copyright (C) 1998, 1999 Slava Pestov * * You may use and modify this package for any purpose. Redistribution is * permitted, in both source and binary form, provided that this notice * remains intact in all source distributions of this package. */package org.syntax.jedit.tokenmarker;import org.syntax.jedit.*;import javax.swing.text.Segment;/** * Perl token marker. * * @author Slava Pestov * @version $Id: PerlTokenMarker.java,v 1.11 1999/12/13 03:40:30 sp Exp $ */public class PerlTokenMarker extends TokenMarker{	// public members	public static final byte S_ONE = Token.INTERNAL_FIRST;	public static final byte S_TWO = (byte)(Token.INTERNAL_FIRST + 1);	public static final byte S_END = (byte)(Token.INTERNAL_FIRST + 2);	public PerlTokenMarker()	{		this(getKeywords());	}	public PerlTokenMarker(KeywordMap keywords)	{		this.keywords = keywords;	}	public byte markTokensImpl(byte _token, Segment line, int lineIndex)	{		char[] array = line.array;		int offset = line.offset;		token = _token;		lastOffset = offset;		lastKeyword = offset;		matchChar = '\0';		matchCharBracket = false;		matchSpacesAllowed = false;		int length = line.count + offset;		if(token == Token.LITERAL1 && lineIndex != 0			&& lineInfo[lineIndex - 1].obj != null)		{			String str = (String)lineInfo[lineIndex - 1].obj;			if(str != null && str.length() == line.count				&& SyntaxUtilities.regionMatches(false,line,				offset,str))			{				addToken(line.count,token);				return Token.NULL;			}			else			{				addToken(line.count,token);				lineInfo[lineIndex].obj = str;				return token;			}		}		boolean backslash = false;loop:		for(int i = offset; i < length; i++)		{			int i1 = (i+1);			char c = array[i];			if(c == '\\')			{				backslash = !backslash;				continue;			}			switch(token)			{			case Token.NULL:				switch(c)				{				case '#':					if(doKeyword(line,i,c))						break;					if(backslash)						backslash = false;					else					{						addToken(i - lastOffset,token);						addToken(length - i,Token.COMMENT1);						lastOffset = lastKeyword = length;						break loop;					}					break;				case '=':					backslash = false;					if(i == offset)					{						token = Token.COMMENT2;						addToken(length - i,token);						lastOffset = lastKeyword = length;						break loop;					}					else						doKeyword(line,i,c);					break;				case '$': case '&': case '%': case '@':					backslash = false;					if(doKeyword(line,i,c))						break;					if(length - i > 1)					{						if(c == '&' && (array[i1] == '&'							|| Character.isWhitespace(							array[i1])))							i++;						else						{							addToken(i - lastOffset,token);							lastOffset = lastKeyword = i;							token = Token.KEYWORD2;						}					}					break;				case '"':					if(doKeyword(line,i,c))						break;					if(backslash)						backslash = false;					else					{						addToken(i - lastOffset,token);						token = Token.LITERAL1;						lineInfo[lineIndex].obj = null;						lastOffset = lastKeyword = i;					}					break;				case '\'':					if(backslash)						backslash = false;					else					{						int oldLastKeyword = lastKeyword;						if(doKeyword(line,i,c))							break;						if(i != oldLastKeyword)							break;						addToken(i - lastOffset,token);						token = Token.LITERAL2;						lastOffset = lastKeyword = i;					}					break;				case '`':					if(doKeyword(line,i,c))						break;					if(backslash)						backslash = false;					else					{						addToken(i - lastOffset,token);						token = Token.OPERATOR;						lastOffset = lastKeyword = i;					}					break;				case '<':					if(doKeyword(line,i,c))						break;					if(backslash)						backslash = false;					else					{						if(length - i > 2 && array[i1] == '<'							&& !Character.isWhitespace(array[i+2]))						{							addToken(i - lastOffset,token);							lastOffset = lastKeyword = i;							token = Token.LITERAL1;							int len = length - (i+2);							if(array[length - 1] == ';')								len--;							lineInfo[lineIndex].obj =								createReadinString(array,i + 2,len);						}					}					break;				case ':':					backslash = false;					if(doKeyword(line,i,c))						break;					// Doesn't pick up all labels,					// but at least doesn't mess up					// XXX::YYY					if(lastKeyword != 0)						break;					addToken(i1 - lastOffset,Token.LABEL);					lastOffset = lastKeyword = i1;					break;				case '-':					backslash = false;					if(doKeyword(line,i,c))						break;					if(i != lastKeyword || length - i <= 1)						break;					switch(array[i1])					{					case 'r': case 'w': case 'x':					case 'o': case 'R': case 'W':					case 'X': case 'O': case 'e':					case 'z': case 's': case 'f':					case 'd': case 'l': case 'p':					case 'S': case 'b': case 'c':					case 't': case 'u': case 'g':					case 'k': case 'T': case 'B':					case 'M': case 'A': case 'C':						addToken(i - lastOffset,token);						addToken(2,Token.KEYWORD3);						lastOffset = lastKeyword = i+2;						i++;					}					break;				case '/': case '?':					if(doKeyword(line,i,c))						break;					if(length - i > 1)					{						backslash = false;						char ch = array[i1];						if(Character.isWhitespace(ch))							break;						matchChar = c;						matchSpacesAllowed = false;						addToken(i - lastOffset,token);						token = S_ONE;						lastOffset = lastKeyword = i;					}					break;				default:					backslash = false;					if(!Character.isLetterOrDigit(c)						&& c != '_')						doKeyword(line,i,c);					break;				}				break;			case Token.KEYWORD2:				backslash = false;				// This test checks for an end-of-variable				// condition				if(!Character.isLetterOrDigit(c) && c != '_'					&& c != '#' && c != '\'' && c != ':'					&& c != '&')				{					// If this is the first character					// of the variable name ($'aaa)					// ignore it					if(i != offset && array[i-1] == '$')					{						addToken(i1 - lastOffset,token);						lastOffset = lastKeyword = i1;					}					// Otherwise, end of variable...					else					{						addToken(i - lastOffset,token);						lastOffset = lastKeyword = i;						// Wind back so that stuff						// like $hello$fred is picked						// up						i--;						token = Token.NULL;					}				}				break;			case S_ONE: case S_TWO:				if(backslash)					backslash = false;				else				{					if(matchChar == '\0')					{						if(Character.isWhitespace(matchChar)							&& !matchSpacesAllowed)							break;						else							matchChar = c;					}					else					{						switch(matchChar)						{						case '(':							matchChar = ')';							matchCharBracket = true;							break;						case '[':							matchChar = ']';							matchCharBracket = true;							break;						case '{':							matchChar = '}';							matchCharBracket = true;							break;						case '<':							matchChar = '>';							matchCharBracket = true;							break;						default:							matchCharBracket = false;							break;						}						if(c != matchChar)							break;						if(token == S_TWO)						{							token = S_ONE;							if(matchCharBracket)								matchChar = '\0';						}						else						{							token = S_END;							addToken(i1 - lastOffset,								Token.LITERAL2);							lastOffset = lastKeyword = i1;						}					}				}				break;			case S_END:				backslash = false;				if(!Character.isLetterOrDigit(c)					&& c != '_')					doKeyword(line,i,c);				break;			case Token.COMMENT2:				backslash = false;				if(i == offset)				{					addToken(line.count,token);					if(length - i > 3 && SyntaxUtilities						.regionMatches(false,line,offset,"=cut"))						token = Token.NULL;					lastOffset = lastKeyword = length;					break loop;				}				break;			case Token.LITERAL1:				if(backslash)					backslash = false;				/* else if(c == '$')					backslash = true; */				else if(c == '"')				{					addToken(i1 - lastOffset,token);

⌨️ 快捷键说明

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