aboutsummaryrefslogtreecommitdiffstats
path: root/src/org/apg/PositionAwareInputStream.java
diff options
context:
space:
mode:
authorDominik <dominik@dominikschuermann.de>2012-03-09 16:27:29 +0100
committerDominik <dominik@dominikschuermann.de>2012-03-09 16:27:29 +0100
commit8452fb62b7d80c297395a8d12acd55a0375bff44 (patch)
treea05f61cf17bb9c58dd4043b465c038b86a8dd685 /src/org/apg/PositionAwareInputStream.java
parentdf6933bfb83e131f9ed66c35cfdb0cb6268bc480 (diff)
downloadopen-keychain-8452fb62b7d80c297395a8d12acd55a0375bff44.tar.gz
open-keychain-8452fb62b7d80c297395a8d12acd55a0375bff44.tar.bz2
open-keychain-8452fb62b7d80c297395a8d12acd55a0375bff44.zip
renaming whole package to org.apg to simplifiy name
Diffstat (limited to 'src/org/apg/PositionAwareInputStream.java')
-rw-r--r--src/org/apg/PositionAwareInputStream.java67
1 files changed, 67 insertions, 0 deletions
diff --git a/src/org/apg/PositionAwareInputStream.java b/src/org/apg/PositionAwareInputStream.java
new file mode 100644
index 000000000..c59459670
--- /dev/null
+++ b/src/org/apg/PositionAwareInputStream.java
@@ -0,0 +1,67 @@
+package org.apg;
+
+import java.io.IOException;
+import java.io.InputStream;
+
+public class PositionAwareInputStream extends InputStream {
+ private InputStream mStream;
+ private long mPosition;
+
+ public PositionAwareInputStream(InputStream in) {
+ mStream = in;
+ mPosition = 0;
+ }
+
+ @Override
+ public int read() throws IOException {
+ int ch = mStream.read();
+ ++mPosition;
+ return ch;
+ }
+
+ @Override
+ public int available() throws IOException {
+ return mStream.available();
+ }
+
+ @Override
+ public void close() throws IOException {
+ mStream.close();
+ }
+
+ @Override
+ public boolean markSupported() {
+ return false;
+ }
+
+ @Override
+ public int read(byte[] b) throws IOException {
+ int result = mStream.read(b);
+ mPosition += result;
+ return result;
+ }
+
+ @Override
+ public int read(byte[] b, int offset, int length) throws IOException {
+ int result = mStream.read(b, offset, length);
+ mPosition += result;
+ return result;
+ }
+
+ @Override
+ public synchronized void reset() throws IOException {
+ mStream.reset();
+ mPosition = 0;
+ }
+
+ @Override
+ public long skip(long n) throws IOException {
+ long result = mStream.skip(n);
+ mPosition += result;
+ return result;
+ }
+
+ public long position() {
+ return mPosition;
+ }
+}