Mercurial > 510Connectbot
comparison src/ch/ethz/ssh2/SFTPInputStream.java @ 342:175c7d68f3c4
merge ganymed into mainline
author | Carl Byington <carl@five-ten-sg.com> |
---|---|
date | Thu, 31 Jul 2014 16:33:38 -0700 |
parents | 071eccdff8ea |
children |
comparison
equal
deleted
inserted
replaced
272:ce2f4e397703 | 342:175c7d68f3c4 |
---|---|
1 /* | |
2 * Copyright (c) 2011 David Kocher. All rights reserved. | |
3 * Please refer to the LICENSE.txt for licensing details. | |
4 */ | |
5 package ch.ethz.ssh2; | |
6 | |
7 import java.io.IOException; | |
8 import java.io.InputStream; | |
9 | |
10 /** | |
11 * @version $Id: SFTPInputStream.java 151 2014-04-28 10:03:39Z dkocher@sudo.ch $ | |
12 */ | |
13 public class SFTPInputStream extends InputStream { | |
14 | |
15 private SFTPFileHandle handle; | |
16 | |
17 /** | |
18 * Offset (in bytes) in the file to read | |
19 */ | |
20 private long readOffset = 0; | |
21 | |
22 public SFTPInputStream(SFTPFileHandle handle) { | |
23 this.handle = handle; | |
24 } | |
25 | |
26 /** | |
27 * Reads up to <code>len</code> bytes of data from the input stream into | |
28 * an array of bytes. An attempt is made to read as many as | |
29 * <code>len</code> bytes, but a smaller number may be read, possibly | |
30 * zero. The number of bytes actually read is returned as an integer. | |
31 * | |
32 * @see SFTPClient#read(SFTPFileHandle, long, byte[], int, int) | |
33 */ | |
34 @Override | |
35 public int read(byte[] buffer, int offset, int len) throws IOException { | |
36 int read = handle.getClient().read(handle, readOffset, buffer, offset, len); | |
37 | |
38 if (read > 0) { | |
39 readOffset += read; | |
40 } | |
41 | |
42 return read; | |
43 } | |
44 | |
45 /** | |
46 * Reads the next byte of data from the input stream. The value byte is | |
47 * returned as an <code>int</code> in the range <code>0</code> to | |
48 * <code>255</code>. If no byte is available because the end of the stream | |
49 * has been reached, the value <code>-1</code> is returned. This method | |
50 * blocks until input data is available, the end of the stream is detected, | |
51 * or an exception is thrown. | |
52 * <p/> | |
53 * <p> A subclass must provide an implementation of this method. | |
54 * | |
55 * @return the next byte of data, or <code>-1</code> if the end of the | |
56 * stream is reached. | |
57 * @throws IOException if an I/O error occurs. | |
58 */ | |
59 @Override | |
60 public int read() throws IOException { | |
61 byte[] buffer = new byte[1]; | |
62 int b = handle.getClient().read(handle, readOffset, buffer, 0, 1); | |
63 | |
64 if (b > 0) { | |
65 readOffset += 1; | |
66 } | |
67 | |
68 return b; | |
69 } | |
70 | |
71 /** | |
72 * Skips over and discards <code>n</code> bytes of data from this input | |
73 * stream. | |
74 * | |
75 * @param n the number of bytes to be skipped. | |
76 * @return the actual number of bytes skipped. | |
77 */ | |
78 @Override | |
79 public long skip(long n) { | |
80 readOffset += n; | |
81 return n; | |
82 } | |
83 | |
84 @Override | |
85 public void close() throws IOException { | |
86 handle.getClient().closeFile(handle); | |
87 } | |
88 } |