fix recall

This commit is contained in:
lnk
2025-10-31 10:59:30 +08:00
parent 5e63adc8f9
commit c02f0cbbdd
2 changed files with 45 additions and 16 deletions

View File

@@ -4281,8 +4281,25 @@ void check_recall_event() {
// 遍历所有 terminal —— 每个 terminal 只挑一条,先不判断运行状态,因为正在处理其他事务的装置也可以记录待补招信息
for (auto& dev : terminal_devlist) {
//如果该终端不是正在补招或者idle则直接跳过节省运行时间
if(dev.busytype != static_cast<int>(DeviceState::READING_EVENTLOG) && dev.busytype != static_cast<int>(DeviceState::IDLE)){
std::cout << "[check_recall_event] skip dev=" << dev.terminal_id << std::endl;
bool allow_check =
dev.busytype == static_cast<int>(DeviceState::IDLE) ||
dev.busytype == static_cast<int>(DeviceState::READING_EVENTLOG);
// 如果你允许“事件抢占文件”,并且当前没有文件 RUNNING则也允许评估事件
if (!allow_check && dev.busytype == static_cast<int>(DeviceState::READING_STATSFILE)) {
bool has_file_running = false;
for (const auto& lm2 : dev.line) {
if (!lm2.recall_list_static.empty() &&
lm2.recall_list_static.front().recall_status == static_cast<int>(RecallStatus::RUNNING)) {
has_file_running = true; break;
}
}
if (!has_file_running) allow_check = true; // 没有文件正在跑,允许事件优先
}
if (!allow_check) {
std::cout << "[check_recall_event] skip dev=" << dev.terminal_id
<< " busytype=" << dev.busytype << std::endl;
continue;
}
// 对正在补招或idle终端的所有监测点的待补招列表进行处理

View File

@@ -762,23 +762,35 @@ bool parseJsonMessageUD(const std::string& json_str, const std::string& output_d
json_data.Righttime = item.value("Righttime", "");
if (item.contains("monitorData") && item["monitorData"].is_array()) {
size_t j = 0;
constexpr size_t kMaxLines = std::extent<decltype(terminal_dev::line)>::value; // 如果是 C 数组
for (const auto& monitor_item : item["monitorData"]) {
if (j >= kMaxLines) break;
auto& m = json_data.line[j++];
json_data.line.emplace_back(); // 追加元素
auto& m = json_data.line.back(); // 引用最后一个
m.monitor_id = monitor_item.value("id", "");
m.monitor_name = monitor_item.value("name", "");
m.voltage_level = monitor_item.value("voltageLevel", "");
m.status = monitor_item.value("status", "");
m.logical_device_seq = monitor_item.value("lineNo", "");
m.voltage_level = monitor_item.value("voltageLevel", "");
// status 可能是数字,统一转成字符串存
if (monitor_item.contains("status") && monitor_item["status"].is_number_integer())
m.status = std::to_string(monitor_item["status"].get<int>());
else
m.status = monitor_item.value("status", "");
m.terminal_connect = monitor_item.value("ptType", "");
//m.timestamp = json_data.timestamp;
m.terminal_id = monitor_item.value("deviceId", json_data.terminal_id);
m.CT1 = monitor_item.value("CT1", 0.0);
m.CT2 = monitor_item.value("CT2", 0.0);
m.PT1 = monitor_item.value("PT1", 0.0);
m.PT2 = monitor_item.value("PT2", 0.0);
// 兼容大小写写法PT1/pt1 等
auto get_num = [&](const nlohmann::json& j, const char* up, const char* lo, double defv) {
if (j.contains(up) && (j[up].is_number_float() || j[up].is_number_integer()))
return j[up].get<double>();
if (j.contains(lo) && (j[lo].is_number_float() || j[lo].is_number_integer()))
return j[lo].get<double>();
return defv;
};
m.PT1 = get_num(monitor_item, "PT1", "pt1", 0.0);
m.PT2 = get_num(monitor_item, "PT2", "pt2", 0.0);
m.CT1 = get_num(monitor_item, "CT1", "ct1", 0.0);
m.CT2 = get_num(monitor_item, "CT2", "ct2", 0.0);
}
}