summaryrefslogtreecommitdiffhomepage
path: root/src/java/nginx/unit/InputStream.java
diff options
context:
space:
mode:
authorMax Romanov <max.romanov@gmail.com>2019-02-28 18:02:42 +0300
committerMax Romanov <max.romanov@gmail.com>2019-02-28 18:02:42 +0300
commit5bfdebb9e4161a689113d73775498949a09d7fb5 (patch)
treefcb69169e3da983db0eb1f48d2dccc2ac2ff867b /src/java/nginx/unit/InputStream.java
parentec7319d32c9c41597a99a9422ff324c97a92bb21 (diff)
downloadunit-5bfdebb9e4161a689113d73775498949a09d7fb5.tar.gz
unit-5bfdebb9e4161a689113d73775498949a09d7fb5.tar.bz2
Introducing Java Servlet Container beta.
Diffstat (limited to 'src/java/nginx/unit/InputStream.java')
-rw-r--r--src/java/nginx/unit/InputStream.java90
1 files changed, 90 insertions, 0 deletions
diff --git a/src/java/nginx/unit/InputStream.java b/src/java/nginx/unit/InputStream.java
new file mode 100644
index 00000000..6fe72ace
--- /dev/null
+++ b/src/java/nginx/unit/InputStream.java
@@ -0,0 +1,90 @@
+package nginx.unit;
+
+import java.io.IOException;
+
+import javax.servlet.ReadListener;
+import javax.servlet.ServletInputStream;
+
+public class InputStream extends ServletInputStream {
+
+ private long req_info_ptr;
+
+ public InputStream(long ptr)
+ {
+ req_info_ptr = ptr;
+ }
+
+ @Override
+ public int readLine(byte[] b, int off, int len) throws IOException {
+
+ if (len <= 0) {
+ return 0;
+ }
+ return readLine(req_info_ptr, b, off, len);
+ }
+
+ private static native int readLine(long req_info_ptr, byte[] b, int off, int len);
+
+
+ @Override
+ public boolean isFinished()
+ {
+ return isFinished(req_info_ptr);
+ }
+
+ private static native boolean isFinished(long req_info_ptr);
+
+
+ @Override
+ public boolean isReady()
+ {
+ return true;
+ }
+
+
+ @Override
+ public void setReadListener(ReadListener listener)
+ {
+ }
+
+
+ @Override
+ public int read() throws IOException
+ {
+ return read(req_info_ptr);
+ }
+
+ private static native int read(long req_info_ptr);
+
+
+ @Override
+ public int read(byte b[], int off, int len) throws IOException {
+ if (b == null) {
+ throw new NullPointerException();
+ } else if (off < 0 || len < 0 || len > b.length - off) {
+ throw new IndexOutOfBoundsException();
+ } else if (len == 0) {
+ return 0;
+ }
+
+ return read(req_info_ptr, b, off, len);
+ }
+
+ private static native int read(long req_info_ptr, byte b[], int off, int len);
+
+
+ @Override
+ public long skip(long n) throws IOException {
+ return skip(req_info_ptr, n);
+ }
+
+ private static native long skip(long req_info_ptr, long n);
+
+
+ @Override
+ public int available() throws IOException {
+ return available(req_info_ptr);
+ }
+
+ private static native int available(long req_info_ptr);
+}