Fix folder count in output

This commit is contained in:
Tim Keller 2021-10-17 22:07:43 +00:00
parent 2690c274af
commit eabbbfa373
2 changed files with 40 additions and 20 deletions

View File

@ -78,7 +78,7 @@ int FSService::FSCommandHandler(uint16_t connectionHandle, os_mbuf* om) {
resp.status = 1; // TODO actually use res above!
resp.totalentries = 0;
resp.entry = 0;
int sr;
int res = fs.DirOpen(path, &dir);
NRF_LOG_INFO("[FS_S] ->diropen %d ", res);
@ -115,7 +115,6 @@ int FSService::FSCommandHandler(uint16_t connectionHandle, os_mbuf* om) {
resp.entry++;
}
fs.DirClose(&dir);
resp.entry++;
resp.file_size = 0;
resp.path_length = 0;
resp.flags = 0;
@ -123,6 +122,7 @@ int FSService::FSCommandHandler(uint16_t connectionHandle, os_mbuf* om) {
auto* om = ble_hs_mbuf_from_flat(&resp,sizeof(ListDirResponse)-70+resp.path_length);
ble_gattc_notify_custom(connectionHandle,transferCharacteristicHandle,om);
NRF_LOG_INFO("[FS_S] -> done ");
break;
}
}
return 0;

View File

@ -44,23 +44,8 @@ namespace Pinetime {
struct ble_gatt_svc_def serviceDefinition[2];
uint16_t versionCharacteristicHandle;
uint16_t transferCharacteristicHandle;
typedef struct __attribute__((packed)) {
uint8_t command;
uint8_t padding;
uint16_t pathlen;
char pathstr[70];
} ListDirHeader;
typedef struct __attribute__((packed)) {
uint8_t command;
uint8_t status;
uint16_t path_length;
uint32_t entry;
uint32_t totalentries;
uint32_t flags;
uint32_t modification_time;
uint32_t file_size;
char path[70];
} ListDirResponse;
int FSCommandHandler(uint16_t connectionHandle, os_mbuf* om);
enum class commands : uint8_t {
INVALID = 0x00,
@ -80,7 +65,42 @@ namespace Pinetime {
MOVE_STATUS = 0x61
};
int FSCommandHandler(uint16_t connectionHandle, os_mbuf* om);
using ListDirHeader = struct __attribute__((packed)) {
uint8_t command;
uint8_t padding;
uint16_t pathlen;
char pathstr[70];
};
using ListDirResponse = struct __attribute__((packed)) {
uint8_t command;
uint8_t status;
uint16_t path_length;
uint32_t entry;
uint32_t totalentries;
uint32_t flags;
uint32_t modification_time;
uint32_t file_size;
char path[70];
};
using MKDirHeader = struct __attribute__((packed)) {
uint8_t command;
uint8_t padding;
uint16_t pathlen;
uint32_t padding2;
uint64_t time;
char pathstr[70];
};
using MKDirResponse = struct __attribute__((packed)) {
uint8_t command;
uint8_t status;
uint32_t padding1;
uint16_t padding2;
uint64_t modification_time;
};
};
}
}