/*******************************************************************************
* Copyright (c) 2015 Jeff Martin.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the GNU Lesser General Public
* License v3.0 which accompanies this distribution, and is available at
* http://www.gnu.org/licenses/lgpl.html
*
* Contributors:
* Jeff Martin - initial API and implementation
******************************************************************************/
package cuchaz.enigma.analysis;
public class Token implements Comparable {
public int start;
public int end;
public String text;
public Token(int start, int end, String source) {
this.start = start;
this.end = end;
if (source != null) {
this.text = source.substring(start, end);
}
}
public int getRenameOffset(String to) {
int length = this.end - this.start;
return to.length() - length;
}
public String rename(String source, String to) {
int oldEnd = this.end;
this.text = to;
this.end = this.start + to.length();
return source.substring(0, this.start) + to + source.substring(oldEnd);
}
public Token move(int offset) {
Token token = new Token(this.start + offset, this.end + offset, null);
token.text = text;
return token;
}
public boolean contains(int pos) {
return pos >= start && pos <= end;
}
@Override
public int compareTo(Token other) {
return start - other.start;
}
@Override
public boolean equals(Object other) {
return other instanceof Token && equals((Token) other);
}
@Override
public int hashCode() {
return start * 37 + end;
}
public boolean equals(Token other) {
return start == other.start && end == other.end;
}
@Override
public String toString() {
return String.format("[%d,%d]", start, end);
}
}