List of usage examples for java.text CharacterIterator next
public char next();
From source file:Base64.java
public static byte[] decodeKreative85(String s) { CharacterIterator it = new StringCharacterIterator(s.trim()); ByteArrayOutputStream out = new ByteArrayOutputStream(); long i = 0;//from ww w .j a v a 2 s.c om int j = 0; for (char ch = it.first(); ch != CharacterIterator.DONE; ch = it.next()) { int v = k85d(ch); if (v >= 0) { i = i * 85L + v; j++; if (j >= 5) { out.write((int) (i >> 24L)); out.write((int) (i >> 16L)); out.write((int) (i >> 8L)); out.write((int) i); i = 0; j = 0; } } } switch (j) { case 4: i = i * 85L + 84L; out.write((int) (i >> 24L)); out.write((int) (i >> 16L)); out.write((int) (i >> 8L)); break; case 3: i = i * 85L + 84L; i = i * 85L + 84L; out.write((int) (i >> 24L)); out.write((int) (i >> 16L)); break; case 2: i = i * 85L + 84L; i = i * 85L + 84L; i = i * 85L + 84L; out.write((int) (i >> 24L)); break; } return out.toByteArray(); }
From source file:Base64.java
public static byte[] decodeBinHex(String s) { // phase 1 - base64 encoding CharacterIterator it = new StringCharacterIterator(s.trim()); ByteArrayOutputStream iout = new ByteArrayOutputStream(); int i = 0, j = 0; char ch = it.first(); if (ch == ':') ch = it.next(); while (ch != CharacterIterator.DONE && ch != ':') { int v = hqxd(ch); if (v >= 0) { i = (i << 6) | v;/*from w w w . j a va2s . com*/ j++; if (j >= 4) { iout.write(i >> 16); iout.write(i >> 8); iout.write(i); i = 0; j = 0; } } ch = it.next(); } switch (j) { case 3: iout.write(i >> 10); iout.write(i >> 2); break; case 2: iout.write(i >> 4); break; } byte[] b = iout.toByteArray(); // phase 2 - RLE int off = 0; ByteArrayOutputStream out = new ByteArrayOutputStream(); byte last = 0; while (off < b.length) { byte v = b[off++]; if (v == (byte) 0x90 && off < b.length) { int r = b[off++] & 0xFF; if (r == 0) { out.write(last = (byte) 0x90); } else { r--; while (r-- > 0) { out.write(last); } } } else { out.write(last = v); } } return out.toByteArray(); }
From source file:org.gradle.api.internal.plugins.StartScriptTemplateBindingFactory.java
private String escapeWindowsJvmOpt(String jvmOpts) { boolean wasOnBackslash = false; StringBuilder escapedJvmOpt = new StringBuilder(); CharacterIterator it = new StringCharacterIterator(jvmOpts); //argument quoting: // - " must be encoded as \" // - % must be encoded as %% // - pathological case: \" must be encoded as \\\", but other than that, \ MUST NOT be quoted // - other characters (including ') will not be quoted // - use a state machine rather than regexps for (char ch = it.first(); ch != CharacterIterator.DONE; ch = it.next()) { String repl = Character.toString(ch); if (ch == '%') { repl = "%%"; } else if (ch == '"') { repl = (wasOnBackslash ? '\\' : "") + "\\\""; }//from www. j a va2 s .co m wasOnBackslash = ch == '\\'; escapedJvmOpt.append(repl); } return escapedJvmOpt.toString(); }
From source file:Base64.java
public static byte[] decodeLegacy85(String s) { int targetLength = -1; s = s.trim();// w ww. java2 s . c om if (s.length() >= 7 && s.charAt(0) == '<' && s.charAt(6) == '>') { targetLength = k85d(s.charAt(1)) + k85d(s.charAt(2)) * 85 + k85d(s.charAt(3)) * 7225 + k85d(s.charAt(4)) * 614125 + k85d(s.charAt(5)) * 52200625; s = s.substring(7).trim(); } CharacterIterator it = new StringCharacterIterator(s); ByteArrayOutputStream out = new ByteArrayOutputStream(); long i = 0; int j = 0; long k = 1; for (char ch = it.first(); ch != CharacterIterator.DONE; ch = it.next()) { int v = k85d(ch); if (v >= 0) { i += v * k; j++; k *= 85; if (j >= 5) { out.write((int) i); out.write((int) (i >> 8L)); out.write((int) (i >> 16L)); out.write((int) (i >> 24L)); i = 0; j = 0; k = 1; } } } if (j > 0) { out.write((int) i); out.write((int) (i >> 8L)); out.write((int) (i >> 16L)); out.write((int) (i >> 24L)); } if (targetLength >= 0) { byte[] b = out.toByteArray(); byte[] bt = new byte[targetLength]; for (int x = 0; x < targetLength && x < b.length; x++) { bt[x] = b[x]; } return bt; } else { return out.toByteArray(); } }
From source file:Base64.java
public static byte[] decodeASCII85(String s) { s = s.trim();// w w w. ja v a 2s . c om if (s.startsWith("<~") && s.endsWith("~>")) { s = s.substring(2, s.length() - 2).trim(); } CharacterIterator it = new StringCharacterIterator(s); ByteArrayOutputStream out = new ByteArrayOutputStream(); long i = 0; int j = 0; for (char ch = it.first(); ch != CharacterIterator.DONE && ch != '~'; ch = it.next()) { if (ch == 'z' && j == 0) { out.write(0); out.write(0); out.write(0); out.write(0); } else if (ch == 'y' && j == 0) { out.write(' '); out.write(' '); out.write(' '); out.write(' '); } else if (ch == 'x' && j == 0) { out.write(-1); out.write(-1); out.write(-1); out.write(-1); } else if (ch >= '!' && ch <= 'u') { i = i * 85L + (long) (ch - '!'); j++; if (j >= 5) { out.write((int) (i >> 24L)); out.write((int) (i >> 16L)); out.write((int) (i >> 8L)); out.write((int) i); i = 0; j = 0; } } } switch (j) { case 4: i = i * 85L + 84L; out.write((int) (i >> 24L)); out.write((int) (i >> 16L)); out.write((int) (i >> 8L)); break; case 3: i = i * 85L + 84L; i = i * 85L + 84L; out.write((int) (i >> 24L)); out.write((int) (i >> 16L)); break; case 2: i = i * 85L + 84L; i = i * 85L + 84L; i = i * 85L + 84L; out.write((int) (i >> 24L)); break; } return out.toByteArray(); }
From source file:XmlNameEncoder.java
/** * {@inheritDoc}//from ww w . j a va2 s. c o m * * @see org.jboss.dna.common.text.TextEncoder#encode(java.lang.String) */ public String encode(String text) { if (text == null) return null; if (text.length() == 0) return text; StringBuilder sb = new StringBuilder(); String hex = null; CharacterIterator iter = new StringCharacterIterator(text); for (char c = iter.first(); c != CharacterIterator.DONE; c = iter.next()) { if (c == '_') { // Read the next character (if there is one) ... char next = iter.next(); if (next == CharacterIterator.DONE) { sb.append(c); break; } // If the next character is not 'x', then these are just regular characters ... if (next != 'x') { sb.append(c).append(next); continue; } // The next character is 'x', so write out the '_' character in encoded form ... sb.append("_x005f_"); // And then write out the next character ... sb.append(next); } else if (XML_NAME_ALLOWED_CHARACTERS.get(c)) { // Legal characters for an XML Name ... sb.append(c); } else { // All other characters must be escaped with '_xHHHH_' where 'HHHH' is the hex string for the code point hex = Integer.toHexString(c); // The hex string excludes the leading '0's, so check the character values so we know how many to prepend if (c >= '\u0000' && c <= '\u000f') { sb.append("_x000").append(hex); } else if (c >= '\u0010' && c <= '\u00ff') { sb.append("_x00").append(hex); } else if (c >= '\u0100' && c <= '\u0fff') { sb.append("_x0").append(hex); } else { sb.append("_x").append(hex); } sb.append('_'); } } return sb.toString(); }
From source file:com.googlecode.jsonplugin.JSONWriter.java
/** * escape characters/*from w ww . ja v a 2s .c om*/ */ private void string(Object obj) { this.add('"'); CharacterIterator it = new StringCharacterIterator(obj.toString()); for (char c = it.first(); c != CharacterIterator.DONE; c = it.next()) { if (c == '"') { this.add("\\\""); } else if (c == '\\') { this.add("\\\\"); } else if (c == '/') { this.add("\\/"); } else if (c == '\b') { this.add("\\b"); } else if (c == '\f') { this.add("\\f"); } else if (c == '\n') { this.add("\\n"); } else if (c == '\r') { this.add("\\r"); } else if (c == '\t') { this.add("\\t"); } else if (Character.isISOControl(c)) { this.unicode(c); } else { this.add(c); } } this.add('"'); }
From source file:org.semanticscience.narf.structures.parts.Sequence.java
/** * Create the set of nucleotides from a nucleic acid sequence string. A * mapping is constructed of the residue position of the nucleotides to the * nucleotides. The method enables the sequence to commence at an arbitrary * sequence position.//from w w w . j a v a 2 s.com * * @param aSequence * sequence string * @param aStartingPosition * the residue position of the first nucleotide * @return a mapping of the nucleotide residue positions to their respective * nucleotide residue position * @throws InvalidSequenceException * if any of the characters in the sequence string is not a * valid residue identifier * @throws InvalidResidueException * if the created nucleotide contains a residue exception * @since 1.6 */ SortedMap<Integer, Nucleotide> makeNucleotides(String aSequence, int aStartingPosition) throws InvalidSequenceException, InvalidResidueException { //first make the sequence all upper case aSequence = aSequence.toUpperCase(); if ((aSequence == null) || (aSequence.length() == 0)) { throw new InvalidSequenceException("The provided sequence has no characters."); } if (!this.checkStringSequence(aSequence)) { throw new InvalidSequenceException( "The inputted sequence has a invalid sequence character.\n" + aSequence + "\n"); } SortedMap<Integer, Nucleotide> returnMe = new TreeMap<Integer, Nucleotide>(); int currentPosition = aStartingPosition; CharacterIterator it = new StringCharacterIterator(aSequence); for (char ch = it.first(); ch != CharacterIterator.DONE; ch = it.next()) { returnMe.put(currentPosition, new Nucleotide(currentPosition, String.valueOf(ch))); currentPosition++; } return returnMe; }
From source file:XmlNameEncoder.java
/** * {@inheritDoc}// w ww.j a v a 2 s . c o m * * @see org.jboss.dna.common.text.TextDecoder#decode(java.lang.String) */ public String decode(String encodedText) { if (encodedText == null) return null; if (encodedText.length() < 7) { // Not big enough to have an encoded sequence return encodedText; } StringBuilder sb = new StringBuilder(); char[] digits = new char[4]; CharacterIterator iter = new StringCharacterIterator(encodedText); for (char c = iter.first(); c != CharacterIterator.DONE; c = iter.next()) { if (c == '_') { // Read the next character, if there is one ... char next = iter.next(); if (next == CharacterIterator.DONE) { sb.append(c); break; } // If the next character is not 'x', then these are just regular characters ... if (next != 'x') { sb.append(c).append(next); continue; } // Read the next 4 characters (digits) and another '_' character ... digits[0] = iter.next(); if (digits[0] == CharacterIterator.DONE) { sb.append(c).append(next); break; } digits[1] = iter.next(); if (digits[1] == CharacterIterator.DONE) { sb.append(c).append(next).append(digits, 0, 1); break; } digits[2] = iter.next(); if (digits[2] == CharacterIterator.DONE) { sb.append(c).append(next).append(digits, 0, 2); break; } digits[3] = iter.next(); if (digits[3] == CharacterIterator.DONE) { sb.append(c).append(next).append(digits, 0, 3); break; } char underscore = iter.next(); if (underscore != '_') { // includes DONE sb.append(c).append(next).append(digits, 0, 4); if (underscore == CharacterIterator.DONE) break; sb.append(underscore); continue; } // We've read all 4 digits, including the trailing '_' // Now parse into the resulting character try { sb.appendCodePoint(Integer.parseInt(new String(digits), 16)); } catch (NumberFormatException e) { // code was not hexadecimal, so just write out the characters as is ... sb.append(c).append(next).append(digits).append(underscore); } } else { // Just append other characters ... sb.append(c); } } return sb.toString(); }
From source file:stg.utils.RandomStringGenerator.java
/** * Validates the given format.//from w ww . j a v a 2s . c o m * Valid characters are : * <li>a<dt>For lower case alphabets. * <li>A<dt>For upper case alphabets. * <li>9<dt>For numbers. * <li>#<dt>For special characters. * The format characters can be repeated in whatever sequence. * The random string generated will have the same length as that of the format. * * @param format */ private void validate(String format) { CharacterIterator iter = new StringCharacterIterator(format); char c = iter.first(); boolean constantStarted = false; while (c != CharacterIterator.DONE) { switch (c) { case ESCAPE: c = iter.next(); if (c == CharacterIterator.DONE) { throw new IllegalArgumentException( "Invalid format! Escape character found without any associated character that was to be escaped."); } break; case LOWER_CASE: break; case UPPER_CASE: break; case NUMBER: break; case SPECIAL: break; case START_CONSTANT: if (!constantStarted) constantStarted = true; break; case END_CONSTANT: if (constantStarted) constantStarted = false; break; default: if (!constantStarted) throw new IllegalArgumentException("Invalid format character found '" + c + "'"); } c = iter.next(); } }