Skip to content

Commit

Permalink
fix failed_devices.txt created failure
Browse files Browse the repository at this point in the history
  • Loading branch information
jiangdongguo committed Aug 26, 2019
1 parent af3fc00 commit 7958ab1
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 35 deletions.
4 changes: 3 additions & 1 deletion build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -27,8 +27,10 @@ ext {
commonLibVersion= '2.12.4'
versionCompiler = 27
versionTarget = 27
// if hope supporting 4.4
// please modify it to 16
minSdkVersion = 21
versionNameString = '1.0.0'
versionNameString = '1.1.0.20190826'
javaSourceCompatibility = JavaVersion.VERSION_1_8
javaTargetCompatibility = JavaVersion.VERSION_1_8
}
2 changes: 1 addition & 1 deletion libusbcamera/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ android {
defaultConfig {
minSdkVersion rootProject.ext.minSdkVersion
targetSdkVersion rootProject.ext.versionTarget
versionCode 1
versionCode 2
versionName rootProject.ext.versionNameString
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
Expand Down
71 changes: 38 additions & 33 deletions libusbcamera/src/main/java/com/serenegiant/usb/USBMonitor.java
Original file line number Diff line number Diff line change
Expand Up @@ -311,7 +311,7 @@ public List<UsbDevice> getDeviceList(final List<DeviceFilter> filters) throws Il
// get detected devices
final HashMap<String, UsbDevice> deviceList = mUsbManager.getDeviceList();
// store those devices info before matching filter xml file
String fileName = Environment.getExternalStorageDirectory()+ "/USBCamera/failed_devices.txt";
String fileName = Environment.getExternalStorageDirectory().getAbsolutePath()+ "/USBCamera/failed_devices.txt";

File logFile = new File(fileName);
if(! logFile.exists()) {
Expand All @@ -323,29 +323,35 @@ public List<UsbDevice> getDeviceList(final List<DeviceFilter> filters) throws Il
}
FileWriter fw = null;
PrintWriter pw = null;
final List<UsbDevice> result = new ArrayList<UsbDevice>();
try {
fw = new FileWriter(logFile, true);
} catch (IOException e) {
e.printStackTrace();
}
if(fw != null) {
pw = new PrintWriter(fw);
if (deviceList != null) {
if ((filters == null) || filters.isEmpty()) {
result.addAll(deviceList.values());
} else {
for (final UsbDevice device: deviceList.values() ) {
// match devices
for (final DeviceFilter filter: filters) {
if ((filter != null) && filter.matches(device) || (filter != null && filter.mSubclass == device.getDeviceSubclass())) {
// when filter matches
if (!filter.isExclude) {
result.add(device);
}
break;
} else {
// collection failed dev's class and subclass
String devModel = android.os.Build.MODEL;
String devSystemVersion = android.os.Build.VERSION.RELEASE;
String devClass = String.valueOf(device.getDeviceClass());
String subClass = String.valueOf(device.getDeviceSubclass());
}
final List<UsbDevice> result = new ArrayList<UsbDevice>();
if (deviceList != null) {
if ((filters == null) || filters.isEmpty()) {
result.addAll(deviceList.values());
} else {
for (final UsbDevice device: deviceList.values() ) {
// match devices
for (final DeviceFilter filter: filters) {
if ((filter != null) && filter.matches(device) || (filter != null && filter.mSubclass == device.getDeviceSubclass())) {
// when filter matches
if (!filter.isExclude) {
result.add(device);
}
break;
} else {
// collection failed dev's class and subclass
String devModel = android.os.Build.MODEL;
String devSystemVersion = android.os.Build.VERSION.RELEASE;
String devClass = String.valueOf(device.getDeviceClass());
String subClass = String.valueOf(device.getDeviceSubclass());
try{
if(pw != null) {
StringBuilder sb = new StringBuilder();
sb.append(devModel);
Expand All @@ -357,23 +363,22 @@ public List<UsbDevice> getDeviceList(final List<DeviceFilter> filters) throws Il
pw.flush();
fw.flush();
}
}catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
} catch (IOException e) {
e.printStackTrace();
} finally {
if (pw != null) {
pw.close();
}
if (fw != null) {
try {
fw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
if (pw != null) {
pw.close();
}
if (fw != null) {
try {
fw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return result;
Expand Down

0 comments on commit 7958ab1

Please sign in to comment.