X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/390949b8323633b26d56b3a837e83941cbc24b4b..fa6d145f9147aea0101359d43da3d81107c71597:/src/eu/alefzero/webdav/FileRequestEntity.java?ds=inline diff --git a/src/eu/alefzero/webdav/FileRequestEntity.java b/src/eu/alefzero/webdav/FileRequestEntity.java index 70154ec0..61ba4565 100644 --- a/src/eu/alefzero/webdav/FileRequestEntity.java +++ b/src/eu/alefzero/webdav/FileRequestEntity.java @@ -8,46 +8,63 @@ import java.io.OutputStream; import org.apache.commons.httpclient.methods.RequestEntity; +import com.owncloud.android.files.interfaces.OnDatatransferProgressListener; + +import android.util.Log; + + /** * A RequestEntity that represents a File. - * + * */ public class FileRequestEntity implements RequestEntity { - final File file; - final String contentType; + final File file; + final String contentType; + OnDatatransferProgressListener listener; + + public FileRequestEntity(final File file, final String contentType) { + super(); + if (file == null) { + throw new IllegalArgumentException("File may not be null"); + } + this.file = file; + this.contentType = contentType; + } + + public long getContentLength() { + return this.file.length(); + } + + public String getContentType() { + return this.contentType; + } - public FileRequestEntity(final File file, final String contentType) { - super(); - if (file == null) { - throw new IllegalArgumentException("File may not be null"); + public boolean isRepeatable() { + return true; } - this.file = file; - this.contentType = contentType; - } - public long getContentLength() { - return this.file.length(); - } - - public String getContentType() { - return this.contentType; - } - - public boolean isRepeatable() { - return true; - } - - public void writeRequest(final OutputStream out) throws IOException { - byte[] tmp = new byte[4096]; - int i = 0; - InputStream instream = new FileInputStream(this.file); - try { - while ((i = instream.read(tmp)) >= 0) { - out.write(tmp, 0, i); - } - } finally { - instream.close(); + + public void setOnDatatransferProgressListener(OnDatatransferProgressListener listener) { + this.listener = listener; + } + + public void writeRequest(final OutputStream out) throws IOException { + byte[] tmp = new byte[4096]; + int i = 0; + InputStream instream = new FileInputStream(this.file); + try { + while ((i = instream.read(tmp)) >= 0) { + out.write(tmp, 0, i); + if (listener != null) + listener.transferProgress(i); + } + } catch (IOException io) { + Log.e("FileRequestException", io.getMessage()); + throw new RuntimeException("Ugly solution to workaround the default policy of retries when the server falls while uploading ; temporal fix; really", io); + + } finally { + instream.close(); + } } - } } \ No newline at end of file