From 510d41ff7d12c8a8ba230d3b3f732b19a20f15e3 Mon Sep 17 00:00:00 2001
From: gcontini <1121667+gcontini@users.noreply.github.com>
Date: 周六, 31 10月 2020 10:28:34 +0800
Subject: [PATCH] doc & miscellaneous changes

---
 src/library/os/windows/os_win.cpp |   19 ++++++++++---------
 1 files changed, 10 insertions(+), 9 deletions(-)

diff --git a/src/library/os/windows/os_win.cpp b/src/library/os/windows/os_win.cpp
index cfa6b0d..54dbc75 100644
--- a/src/library/os/windows/os_win.cpp
+++ b/src/library/os/windows/os_win.cpp
@@ -23,11 +23,11 @@
 
 // http://www.ok-soft-gmbh.com/ForStackOverflow/EnumMassStorage.c
 // http://stackoverflow.com/questions/3098696/same-code-returns-diffrent-result-on-windows7-32-bit-system
-#define MAX_UNITS 30
+#define MAX_UNITS 40
 // bug check return with diskinfos == null func_ret_ok
 FUNCTION_RETURN getDiskInfos(std::vector<DiskInfo>& diskInfos) {
 	DWORD fileMaxLen;
-	size_t ndrives = 0;
+	size_t ndrives = 0, drives_scanned = 0;
 	DWORD fileFlags;
 	char volName[MAX_PATH], fileSysName[MAX_PATH];
 	DWORD volSerial = 0;
@@ -40,24 +40,23 @@
 	if (dwResult > 0) {
 		return_value = FUNC_RET_OK;
 		char* szSingleDrive = szLogicalDrives;
-		while (*szSingleDrive && ndrives < MAX_UNITS) {
+		while (*szSingleDrive && drives_scanned < MAX_UNITS) {
 			// get the next drive
 			UINT driveType = GetDriveType(szSingleDrive);
 			if (driveType == DRIVE_FIXED) {
 				BOOL success = GetVolumeInformation(szSingleDrive, volName, MAX_PATH, &volSerial, &fileMaxLen,
 													&fileFlags, fileSysName, MAX_PATH);
 				if (success) {
-					LOG_INFO("drive         : %s", szSingleDrive);
-					LOG_INFO("Volume Name   : %s", volName);
-					LOG_INFO("Volume Serial : 0x%x", volSerial);
-					LOG_DEBUG("Max file length : %d", fileMaxLen);
-					LOG_DEBUG("Filesystem      : %s", fileSysName);
-					DiskInfo diskInfo;
+					LOG_DEBUG("drive: %s,volume Name: %s, Volume Serial: 0x%x,Filesystem: %s", szSingleDrive, volName,
+							  volSerial, fileSysName);
+					DiskInfo diskInfo = {};
 					diskInfo.id = (int)ndrives;
+					diskInfo.label_initialized = true;
 					strncpy(diskInfo.device, volName, min(std::size_t{MAX_PATH}, sizeof(volName)) - 1);
 					strncpy(diskInfo.label, fileSysName,
 							min(sizeof(diskInfos[ndrives].label), sizeof(fileSysName)) - 1);
 					memcpy(diskInfo.disk_sn, &volSerial, sizeof(DWORD));
+					diskInfo.sn_initialized = true;
 					diskInfo.preferred = (szSingleDrive[0] == 'C');
 					diskInfos.push_back(diskInfo);
 					ndrives++;
@@ -67,6 +66,8 @@
 			} else {
 				LOG_DEBUG("This volume is not fixed : %s, type: %d", szSingleDrive);
 			}
+			szSingleDrive += strlen(szSingleDrive) + 1;
+			drives_scanned++;
 		}
 	}
 	if (diskInfos.size() > 0) {

--
Gitblit v1.9.1