2009-06-28 15:44:22 -07:00
|
|
|
/*
|
2010-04-09 08:48:29 -07:00
|
|
|
* Copyright (c) 2008-2010 Mozilla Foundation
|
2009-06-28 15:44:22 -07:00
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
|
|
* to deal in the Software without restriction, including without limitation
|
|
|
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
|
|
* and/or sell copies of the Software, and to permit persons to whom the
|
|
|
|
* Software is furnished to do so, subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included in
|
|
|
|
* all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
|
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
|
* DEALINGS IN THE SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package nu.validator.htmlparser.impl;
|
|
|
|
|
|
|
|
import nu.validator.htmlparser.annotation.NoLength;
|
|
|
|
|
2010-04-09 08:48:29 -07:00
|
|
|
/**
|
|
|
|
* An UTF-16 buffer that knows the start and end indeces of its unconsumed
|
|
|
|
* content.
|
|
|
|
*
|
|
|
|
* @version $Id$
|
|
|
|
* @author hsivonen
|
|
|
|
*/
|
2009-06-28 15:44:22 -07:00
|
|
|
public final class UTF16Buffer {
|
2010-04-09 08:48:29 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The backing store of the buffer. May be larger than the logical content
|
|
|
|
* of this <code>UTF16Buffer</code>.
|
|
|
|
*/
|
2009-06-28 15:44:22 -07:00
|
|
|
private final @NoLength char[] buffer;
|
|
|
|
|
2010-04-09 08:48:29 -07:00
|
|
|
/**
|
|
|
|
* The index of the first unconsumed character in the backing buffer.
|
|
|
|
*/
|
2009-06-28 15:44:22 -07:00
|
|
|
private int start;
|
|
|
|
|
2010-04-09 08:48:29 -07:00
|
|
|
/**
|
|
|
|
* The index of the slot immediately after the last character in the backing
|
|
|
|
* buffer that is part of the logical content of this
|
|
|
|
* <code>UTF16Buffer</code>.
|
|
|
|
*/
|
2009-06-28 15:44:22 -07:00
|
|
|
private int end;
|
|
|
|
|
|
|
|
/**
|
2010-04-09 08:48:29 -07:00
|
|
|
* Constructor for wrapping an existing UTF-16 code unit array.
|
|
|
|
*
|
2009-06-28 15:44:22 -07:00
|
|
|
* @param buffer
|
2010-04-09 08:48:29 -07:00
|
|
|
* the backing buffer
|
2009-06-28 15:44:22 -07:00
|
|
|
* @param start
|
2010-04-09 08:48:29 -07:00
|
|
|
* the index of the first character to consume
|
2009-06-28 15:44:22 -07:00
|
|
|
* @param end
|
2010-04-09 08:48:29 -07:00
|
|
|
* the index immediately after the last character to consume
|
2009-06-28 15:44:22 -07:00
|
|
|
*/
|
|
|
|
public UTF16Buffer(@NoLength char[] buffer, int start, int end) {
|
|
|
|
this.buffer = buffer;
|
|
|
|
this.start = start;
|
|
|
|
this.end = end;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-04-09 08:48:29 -07:00
|
|
|
* Returns the start index.
|
2009-06-28 15:44:22 -07:00
|
|
|
*
|
2010-04-09 08:48:29 -07:00
|
|
|
* @return the start index
|
2009-06-28 15:44:22 -07:00
|
|
|
*/
|
|
|
|
public int getStart() {
|
|
|
|
return start;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-04-09 08:48:29 -07:00
|
|
|
* Sets the start index.
|
2009-06-28 15:44:22 -07:00
|
|
|
*
|
2010-04-09 08:48:29 -07:00
|
|
|
* @param start
|
|
|
|
* the start index
|
2009-06-28 15:44:22 -07:00
|
|
|
*/
|
|
|
|
public void setStart(int start) {
|
|
|
|
this.start = start;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-04-09 08:48:29 -07:00
|
|
|
* Returns the backing buffer.
|
2009-06-28 15:44:22 -07:00
|
|
|
*
|
2010-04-09 08:48:29 -07:00
|
|
|
* @return the backing buffer
|
2009-06-28 15:44:22 -07:00
|
|
|
*/
|
|
|
|
public @NoLength char[] getBuffer() {
|
|
|
|
return buffer;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-04-09 08:48:29 -07:00
|
|
|
* Returns the end index.
|
2009-06-28 15:44:22 -07:00
|
|
|
*
|
2010-04-09 08:48:29 -07:00
|
|
|
* @return the end index
|
2009-06-28 15:44:22 -07:00
|
|
|
*/
|
|
|
|
public int getEnd() {
|
|
|
|
return end;
|
|
|
|
}
|
2010-04-09 08:48:29 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks if the buffer has data left.
|
|
|
|
*
|
|
|
|
* @return <code>true</code> if there's data left
|
|
|
|
*/
|
2009-06-28 15:44:22 -07:00
|
|
|
public boolean hasMore() {
|
|
|
|
return start < end;
|
|
|
|
}
|
2010-04-09 08:48:29 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Adjusts the start index to skip over the first character if it is a line
|
|
|
|
* feed and the previous character was a carriage return.
|
|
|
|
*
|
|
|
|
* @param lastWasCR
|
|
|
|
* whether the previous character was a carriage return
|
|
|
|
*/
|
2009-06-28 15:44:22 -07:00
|
|
|
public void adjust(boolean lastWasCR) {
|
|
|
|
if (lastWasCR && buffer[start] == '\n') {
|
|
|
|
start++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-04-09 08:48:29 -07:00
|
|
|
* Sets the end index.
|
2009-06-28 15:44:22 -07:00
|
|
|
*
|
2010-04-09 08:48:29 -07:00
|
|
|
* @param end
|
|
|
|
* the end index
|
2009-06-28 15:44:22 -07:00
|
|
|
*/
|
|
|
|
public void setEnd(int end) {
|
|
|
|
this.end = end;
|
|
|
|
}
|
|
|
|
}
|