All Downloads are FREE. Search and download functionalities are using the official Maven repository.

hudson.MarkupText Maven / Gradle / Ivy

package hudson;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * Mutable representation of string with HTML mark up.
 *
 * 

* This class is used to put mark up on plain text. * See * the test code for a typical usage and its result. * * @author Kohsuke Kawaguchi * @since 1.70 */ public class MarkupText extends AbstractMarkupText { private final String text; /** * Added mark up tags. */ private final List tags = new ArrayList(); /** * Represents one mark up inserted into text. */ private static final class Tag implements Comparable { private final int pos; private final String markup; public Tag(int pos, String markup) { this.pos = pos; this.markup = markup; } public int compareTo(Tag that) { return this.pos-that.pos; } } /** * Represents a substring of a {@link MarkupText}. */ public final class SubText extends AbstractMarkupText { private final int start,end; private final int[] groups; public SubText(Matcher m, int textOffset) { start = m.start() + textOffset; end = m.end() + textOffset; int cnt = m.groupCount(); groups = new int[cnt*2]; for( int i=0; i * Start/end tag text can contain special tokens "$0", "$1", ... * and they will be replaced by their {@link #group(int) group match}. * "\$" can be used to escape characters. */ public void surroundWith(String startTag, String endTag) { addMarkup(0,length(),replace(startTag),replace(endTag)); } /** * Works like {@link #surroundWith(String, String)} except * that the token replacement is not performed on parameters. */ public void surroundWithLiteral(String startTag, String endTag) { addMarkup(0,length(),startTag,endTag); } /** * Gets the start index of the captured group within {@link MarkupText#getText()}. * * @param groupIndex * 0 means the start of the whole subtext. 1, 2, ... are * groups captured by '(...)' in the regexp. */ public int start(int groupIndex) { if(groupIndex==0) return start; return groups[groupIndex*2-2]; } /** * Gets the start index of this subtext within {@link MarkupText#getText()}. */ public int start() { return start; } /** * Gets the end index of the captured group within {@link MarkupText#getText()}. */ public int end(int groupIndex) { if(groupIndex==0) return end; return groups[groupIndex*2-1]; } /** * Gets the end index of this subtext within {@link MarkupText#getText()}. */ public int end() { return end; } /** * Returns {@code getText().length()} */ public int length() { return end-start; } /** * Gets the text that represents the captured group. */ public String group(int groupIndex) { if(start(groupIndex)==-1) return null; return text.substring(start(groupIndex),end(groupIndex)); } /** * Replaces the group tokens like "$0", "$1", and etc with their actual matches. */ public String replace(String s) { StringBuffer buf = new StringBuffer(); for( int i=0; iendPos) throw new IndexOutOfBoundsException(); // when multiple tags are added to the same range, we want them to show up like // abc, not abc. Do this by inserting them to different // places. tags.add(0,new Tag(startPos, startTag)); tags.add(new Tag(endPos,endTag)); } private void rangeCheck(int pos) { if(pos<0 || pos>text.length()) throw new IndexOutOfBoundsException(); } /** * Returns the fully marked-up text. */ public String toString() { if(tags.isEmpty()) return text; // the most common case // somewhat inefficient implementation, if there are a lot of mark up and text is large. Collections.sort(tags); StringBuilder buf = new StringBuilder(); buf.append(text); int offset = 0; // remember the # of chars inserted. for (Tag tag : tags) { buf.insert(tag.pos+offset,tag.markup); offset += tag.markup.length(); } return buf.toString(); } // perhaps this method doesn't need to be here to remain binary compatible with past versions, // but having this seems to be safer. @Override public List findTokens(Pattern pattern) { return super.findTokens(pattern); } @Override protected SubText createSubText(Matcher m) { return new SubText(m,0); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy