mirror of
https://github.com/Maschell/JNUSTool.git
synced 2025-01-07 05:48:18 +01:00
Fixed files bigger than 2gb, skipping exisiting files
This commit is contained in:
parent
e2a6241887
commit
fc6e63fa54
BIN
jar/JNUSTool.jar
BIN
jar/JNUSTool.jar
Binary file not shown.
Binary file not shown.
@ -48,7 +48,6 @@ public class Directory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public Collection<Directory> getFolder() {
|
public Collection<Directory> getFolder() {
|
||||||
return folder.values();
|
return folder.values();
|
||||||
}
|
}
|
||||||
|
@ -39,8 +39,6 @@ public class Downloader {
|
|||||||
|
|
||||||
int bytesRead = -1;
|
int bytesRead = -1;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
byte[] IV = new byte[16];
|
byte[] IV = new byte[16];
|
||||||
IV[1] = (byte)toDownload.getContentID();
|
IV[1] = (byte)toDownload.getContentID();
|
||||||
|
|
||||||
@ -53,8 +51,8 @@ public class Downloader {
|
|||||||
int inBlockBuffer = 0;
|
int inBlockBuffer = 0;
|
||||||
byte[] tmp = new byte[BLOCKSIZE];
|
byte[] tmp = new byte[BLOCKSIZE];
|
||||||
boolean endd = false;
|
boolean endd = false;
|
||||||
int downloadTotalsize = 0;
|
long downloadTotalsize = 0;
|
||||||
int wrote = 0;
|
long wrote = 0;
|
||||||
Decryption decryption = new Decryption(ticket);
|
Decryption decryption = new Decryption(ticket);
|
||||||
boolean first = true;
|
boolean first = true;
|
||||||
do{
|
do{
|
||||||
@ -79,11 +77,9 @@ public class Downloader {
|
|||||||
int tooMuch = (oldInThisBlock + bytesRead) - BLOCKSIZE;
|
int tooMuch = (oldInThisBlock + bytesRead) - BLOCKSIZE;
|
||||||
int toRead = BLOCKSIZE - oldInThisBlock;
|
int toRead = BLOCKSIZE - oldInThisBlock;
|
||||||
|
|
||||||
|
|
||||||
System.arraycopy(overflowBuffer, 0, blockBuffer, oldInThisBlock, toRead);
|
System.arraycopy(overflowBuffer, 0, blockBuffer, oldInThisBlock, toRead);
|
||||||
inBlockBuffer += toRead;
|
inBlockBuffer += toRead;
|
||||||
|
|
||||||
|
|
||||||
overflowsize = tooMuch;
|
overflowsize = tooMuch;
|
||||||
System.arraycopy(overflowBuffer, toRead, tmp, 0, tooMuch);
|
System.arraycopy(overflowBuffer, toRead, tmp, 0, tooMuch);
|
||||||
|
|
||||||
@ -132,7 +128,7 @@ public class Downloader {
|
|||||||
long soffset = fileOffset - (fileOffset / HASHBLOCKSIZE * HASHBLOCKSIZE);
|
long soffset = fileOffset - (fileOffset / HASHBLOCKSIZE * HASHBLOCKSIZE);
|
||||||
fileOffset = ((fileOffset / HASHBLOCKSIZE) * BLOCKSIZE);
|
fileOffset = ((fileOffset / HASHBLOCKSIZE) * BLOCKSIZE);
|
||||||
|
|
||||||
long size = (int) fileLength;
|
long size = fileLength;
|
||||||
|
|
||||||
if( soffset+size > writeSize )
|
if( soffset+size > writeSize )
|
||||||
writeSize = writeSize - soffset;
|
writeSize = writeSize - soffset;
|
||||||
@ -159,7 +155,7 @@ public class Downloader {
|
|||||||
|
|
||||||
byte[] tmp = new byte[BLOCKSIZE];
|
byte[] tmp = new byte[BLOCKSIZE];
|
||||||
boolean lastPart = false;
|
boolean lastPart = false;
|
||||||
int wrote = 0;
|
long wrote = 0;
|
||||||
Decryption decryption = new Decryption(ticket);
|
Decryption decryption = new Decryption(ticket);
|
||||||
do{
|
do{
|
||||||
downloadBuffer = new byte[BLOCKSIZE-bufferPostion];
|
downloadBuffer = new byte[BLOCKSIZE-bufferPostion];
|
||||||
@ -226,7 +222,14 @@ public class Downloader {
|
|||||||
public void download( FEntry toDownload) {
|
public void download( FEntry toDownload) {
|
||||||
File f = new File (String.format("%016X", titleID));
|
File f = new File (String.format("%016X", titleID));
|
||||||
if(!f.exists())f.mkdir();
|
if(!f.exists())f.mkdir();
|
||||||
|
|
||||||
|
f = new File(String.format("%016X", titleID) +"/" +toDownload.getFullPath().substring(1, toDownload.getFullPath().length()));
|
||||||
|
if(f.exists()){
|
||||||
|
if(f.length() == toDownload.getFileLength()){
|
||||||
|
System.out.println("Skipping: " + String.format("%8.2f MB ", toDownload.getFileLength()/1024.0/1024.0) + toDownload.getFullPath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
System.out.println("Downloading: " + String.format("%8.2f MB ", toDownload.getFileLength()/1024.0/1024.0) + toDownload.getFullPath());
|
System.out.println("Downloading: " + String.format("%8.2f MB ", toDownload.getFileLength()/1024.0/1024.0) + toDownload.getFullPath());
|
||||||
|
|
||||||
@ -257,9 +260,7 @@ public class Downloader {
|
|||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
// TODO Auto-generated catch block
|
// TODO Auto-generated catch block
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
//System.out.println("Finished: " + toDownload.getFullPath());
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String URL_BASE = "";
|
public static String URL_BASE = "";
|
||||||
|
Loading…
Reference in New Issue
Block a user