2020-03-30 04:58:39 +03:00
|
|
|
/*
|
|
|
|
Copyright 2019-2020 Dmitry Isaenko
|
|
|
|
|
|
|
|
This file is part of NS-USBloader.
|
|
|
|
|
|
|
|
NS-USBloader is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
NS-USBloader is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with NS-USBloader. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
2019-10-27 00:02:40 +03:00
|
|
|
package nsusbloader.COM.USB;
|
|
|
|
|
|
|
|
import javafx.concurrent.Task;
|
2020-07-03 04:01:20 +03:00
|
|
|
import nsusbloader.ModelControllers.ILogPrinter;
|
2019-10-27 00:02:40 +03:00
|
|
|
import nsusbloader.NSLDataTypes.EFileStatus;
|
|
|
|
import nsusbloader.NSLDataTypes.EMsgType;
|
|
|
|
import org.usb4java.DeviceHandle;
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
import java.util.*;
|
|
|
|
|
|
|
|
public abstract class TransferModule {
|
|
|
|
EFileStatus status = EFileStatus.UNKNOWN;
|
|
|
|
|
|
|
|
LinkedHashMap<String, File> nspMap;
|
2020-07-03 04:01:20 +03:00
|
|
|
ILogPrinter logPrinter;
|
2019-10-27 00:02:40 +03:00
|
|
|
DeviceHandle handlerNS;
|
|
|
|
Task<Void> task;
|
|
|
|
|
2020-07-03 04:01:20 +03:00
|
|
|
TransferModule(DeviceHandle handler, LinkedHashMap<String, File> nspMap, Task<Void> task, ILogPrinter printer){
|
2019-10-27 00:02:40 +03:00
|
|
|
this.handlerNS = handler;
|
|
|
|
this.nspMap = nspMap;
|
|
|
|
this.task = task;
|
|
|
|
this.logPrinter = printer;
|
|
|
|
|
|
|
|
// Validate split files to be sure that there is no crap
|
2020-03-30 04:58:39 +03:00
|
|
|
//logPrinter.print("TransferModule: Validating split files ...", EMsgType.INFO); // NOTE: Used for debug
|
2019-10-27 00:02:40 +03:00
|
|
|
Iterator<Map.Entry<String, File>> iterator = nspMap.entrySet().iterator();
|
|
|
|
while (iterator.hasNext()){
|
|
|
|
File f = iterator.next().getValue();
|
|
|
|
if (f.isDirectory()){
|
|
|
|
File[] subFiles = f.listFiles((file, name) -> name.matches("[0-9]{2}"));
|
|
|
|
if (subFiles == null || subFiles.length == 0) {
|
|
|
|
logPrinter.print("TransferModule: Removing empty folder: " + f.getName(), EMsgType.WARNING);
|
|
|
|
iterator.remove();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
Arrays.sort(subFiles, Comparator.comparingInt(file -> Integer.parseInt(file.getName())));
|
|
|
|
|
|
|
|
for (int i = subFiles.length - 2; i > 0 ; i--){
|
|
|
|
if (subFiles[i].length() < subFiles[i-1].length()) {
|
|
|
|
logPrinter.print("TransferModule: Removing strange split file: "+f.getName()+
|
|
|
|
"\n (Chunk sizes of the split file are not the same, but has to be.)", EMsgType.WARNING);
|
|
|
|
iterator.remove();
|
|
|
|
} // what
|
|
|
|
} // a
|
|
|
|
} // nice
|
|
|
|
} // stairway
|
|
|
|
} // here =)
|
2020-03-30 04:58:39 +03:00
|
|
|
//logPrinter.print("TransferModule: Validation complete.", EMsgType.INFO); // NOTE: Used for debug
|
2019-10-27 00:02:40 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public EFileStatus getStatus(){ return status; }
|
|
|
|
}
|