X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/f3ba107585a68d4108a546f30bf71e13fd22f6ec..f3d61ef57832e5ca37f00ec6702207e0f208bb30:/src/eu/alefzero/webdav/FileRequestEntity.java?ds=sidebyside diff --git a/src/eu/alefzero/webdav/FileRequestEntity.java b/src/eu/alefzero/webdav/FileRequestEntity.java index 3e7977c4..f8ba3204 100644 --- a/src/eu/alefzero/webdav/FileRequestEntity.java +++ b/src/eu/alefzero/webdav/FileRequestEntity.java @@ -5,12 +5,18 @@ import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; +import java.io.RandomAccessFile; +import java.nio.ByteBuffer; +import java.nio.channels.FileChannel; +import java.nio.channels.FileLock; +import java.nio.channels.OverlappingFileLockException; import org.apache.commons.httpclient.methods.RequestEntity; +import eu.alefzero.webdav.OnDatatransferProgressListener; + import android.util.Log; -import eu.alefzero.owncloud.files.interfaces.OnDatatransferProgressListener; /** * A RequestEntity that represents a File. @@ -48,12 +54,19 @@ public class FileRequestEntity implements RequestEntity { } public void writeRequest(final OutputStream out) throws IOException { - byte[] tmp = new byte[4096]; + //byte[] tmp = new byte[4096]; + ByteBuffer tmp = ByteBuffer.allocate(4096); int i = 0; - InputStream instream = new FileInputStream(this.file); + + FileChannel channel = new RandomAccessFile(this.file, "rw").getChannel(); + FileLock lock = channel.tryLock(); + //InputStream instream = new FileInputStream(this.file); + try { - while ((i = instream.read(tmp)) >= 0) { - out.write(tmp, 0, i); + //while ((i = instream.read(tmp)) >= 0) { + while ((i = channel.read(tmp)) >= 0) { + out.write(tmp.array(), 0, i); + tmp.clear(); if (listener != null) listener.transferProgress(i); } @@ -62,7 +75,9 @@ public class FileRequestEntity implements RequestEntity { 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(); + //instream.close(); + lock.release(); + channel.close(); } }