documentation and cleanup
This commit is contained in:
@@ -12,7 +12,14 @@ import android.content.ClipDescription;
|
|||||||
import android.support.annotation.NonNull;
|
import android.support.annotation.NonNull;
|
||||||
import android.support.annotation.Nullable;
|
import android.support.annotation.Nullable;
|
||||||
|
|
||||||
|
/** This class can be used to guess whether a stream of data is encoded in a given
|
||||||
|
* charset or not.
|
||||||
|
*
|
||||||
|
* An object of this class must be initialized with a byte[] buffer, which should
|
||||||
|
* be filled with data, then processed with {@link #readBytesFromBuffer}. This can
|
||||||
|
* be done any number of times. Once all data has been read, a final status can be
|
||||||
|
* read using the getter methods.
|
||||||
|
*/
|
||||||
public class CharsetVerifier {
|
public class CharsetVerifier {
|
||||||
|
|
||||||
private final ByteBuffer bufWrap;
|
private final ByteBuffer bufWrap;
|
||||||
@@ -58,7 +65,7 @@ public class CharsetVerifier {
|
|||||||
charsetDecoder.reset();
|
charsetDecoder.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void write(int pos, int len) {
|
public void readBytesFromBuffer(int pos, int len) {
|
||||||
if (isFinished) {
|
if (isFinished) {
|
||||||
throw new IllegalStateException("cannot write again after reading charset status!");
|
throw new IllegalStateException("cannot write again after reading charset status!");
|
||||||
}
|
}
|
||||||
@@ -111,12 +118,25 @@ public class CharsetVerifier {
|
|||||||
return charset;
|
return charset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Returns true if the data which was read is definitely binary.
|
||||||
|
*
|
||||||
|
* This can happen when either the supplied mimeType indicated a non-ambiguous
|
||||||
|
* binary data type, or if we guessed a charset but got errors while decoding.
|
||||||
|
*/
|
||||||
public boolean isDefinitelyBinary() {
|
public boolean isDefinitelyBinary() {
|
||||||
finishIfNecessary();
|
finishIfNecessary();
|
||||||
return !isTextMimeType && (!isPossibleTextMimeType || (isGuessed && isFaulty));
|
return !isTextMimeType && (!isPossibleTextMimeType || (isGuessed && isFaulty));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Returns true iff the data which was read is probably (or
|
||||||
|
* definitely) text.
|
||||||
|
*
|
||||||
|
* The corner case where isDefinitelyBinary returns false but isProbablyText
|
||||||
|
* returns true is where the charset was provided by the data (so is not
|
||||||
|
* guessed) but is still faulty.
|
||||||
|
*/
|
||||||
public boolean isProbablyText() {
|
public boolean isProbablyText() {
|
||||||
|
finishIfNecessary();
|
||||||
return isTextMimeType || isPossibleTextMimeType && (!isGuessed || !isFaulty);
|
return isTextMimeType || isPossibleTextMimeType && (!isGuessed || !isFaulty);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -335,7 +335,7 @@ public class InputDataOperation extends BaseOperation<InputDataParcel> {
|
|||||||
do {
|
do {
|
||||||
totalLength += len;
|
totalLength += len;
|
||||||
out.write(buf, 0, len);
|
out.write(buf, 0, len);
|
||||||
charsetVerifier.write(0, len);
|
charsetVerifier.readBytesFromBuffer(0, len);
|
||||||
} while ((len = is.read(buf)) > 0);
|
} while ((len = is.read(buf)) > 0);
|
||||||
|
|
||||||
log.add(LogType.MSG_DATA_MIME_LENGTH, 3, Long.toString(totalLength));
|
log.add(LogType.MSG_DATA_MIME_LENGTH, 3, Long.toString(totalLength));
|
||||||
|
|||||||
@@ -449,7 +449,7 @@ public class PgpDecryptVerifyOperation extends BaseOperation<PgpDecryptVerifyInp
|
|||||||
// update signature buffer if signature is also present
|
// update signature buffer if signature is also present
|
||||||
signatureChecker.updateSignatureData(buffer, 0, length);
|
signatureChecker.updateSignatureData(buffer, 0, length);
|
||||||
|
|
||||||
charsetVerifier.write(0, length);
|
charsetVerifier.readBytesFromBuffer(0, length);
|
||||||
|
|
||||||
// note down first couple of bytes for "magic bytes" file type detection
|
// note down first couple of bytes for "magic bytes" file type detection
|
||||||
if (alreadyWritten == 0) {
|
if (alreadyWritten == 0) {
|
||||||
|
|||||||
Reference in New Issue
Block a user