/* * Copyright (c) 2023 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "hisysevent_rust_querier.h" #include "hilog/log.h" #include "hisysevent_record_convertor.h" #undef LOG_DOMAIN #define LOG_DOMAIN 0xD002D08 #undef LOG_TAG #define LOG_TAG "HISYSEVENT_RUST_QURIER" namespace { using HiSysEventRecordCls = OHOS::HiviewDFX::HiSysEventRecord; using OHOS::HiviewDFX::HiSysEventRecordConvertor; } HiSysEventRustQuerier::HiSysEventRustQuerier(HiSysEventRustQuerierC* querier) : querier_(querier) { } HiSysEventRustQuerier::~HiSysEventRustQuerier() { RecycleQuerier(querier_); } void HiSysEventRustQuerier::OnQuery(std::shared_ptr> sysEvents) { if (querier_ == nullptr) { HILOG_ERROR(LOG_CORE, "OnQuery callback is null"); return; } if (sysEvents == nullptr || sysEvents->empty()) { querier_->onQueryWrapperCb(querier_->onQueryRustCb, nullptr, 0); return; } size_t size = sysEvents->size(); auto records = new(std::nothrow) HiSysEventRecordC[size]; if (records == nullptr) { return; } for (size_t i = 0; i < size; i++) { HiSysEventRecordConvertor::InitRecord(records[i]); if (HiSysEventRecordConvertor::ConvertRecord(sysEvents->at(i), records[i]) != 0) { HILOG_ERROR(LOG_CORE, "Failed to convert record, index=%{public}zu, size=%{public}zu", i, size); HiSysEventRecordConvertor::DeleteRecords(&records, i + 1); // +1 for release the current record return; } } querier_->onQueryWrapperCb(querier_->onQueryRustCb, records, size); HiSysEventRecordConvertor::DeleteRecords(&records, size); } void HiSysEventRustQuerier::OnComplete(int32_t reason, int32_t total) { if (querier_ == nullptr) { HILOG_ERROR(LOG_CORE, "OnComplete callback is null"); return; } querier_->onCompleteWrapperCb(querier_->onCompleteRustCb, reason, total); } void HiSysEventRustQuerier::RecycleQuerier(HiSysEventRustQuerierC* querier) { std::lock_guard lock(querierMutex_); if ((querier == nullptr) || (querier->status == STATUS_MEM_FREED)) { return; } if (querier->status == STATUS_MEM_NEED_RECYCLE) { querier->status = STATUS_MEM_FREED; delete querier; return; } querier->status = STATUS_MEM_NEED_RECYCLE; }