Loading cmds/dumpstate/Android.bp +2 −0 Original line number Diff line number Diff line Loading @@ -83,7 +83,9 @@ cc_binary { ], srcs: [ "DumpstateInternal.cpp", "DumpstateSectionReporter.cpp", "DumpstateService.cpp", "main.cpp", "utils.cpp", "dumpstate.cpp", ], Loading cmds/dumpstate/DumpstateSectionReporter.cpp 0 → 100644 +42 −0 Original line number Diff line number Diff line /* * Copyright (C) 2018 The Android Open Source Project * * 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. */ #define LOG_TAG "dumpstate" #include "DumpstateSectionReporter.h" namespace android { namespace os { namespace dumpstate { DumpstateSectionReporter::DumpstateSectionReporter(const std::string& title, sp<android::os::IDumpstateListener> listener, bool sendReport) : title_(title), listener_(listener), sendReport_(sendReport), status_(OK), size_(-1) { started_ = std::chrono::steady_clock::now(); } DumpstateSectionReporter::~DumpstateSectionReporter() { if ((listener_ != nullptr) && (sendReport_)) { auto elapsed = std::chrono::duration_cast<std::chrono::milliseconds>( std::chrono::steady_clock::now() - started_); listener_->onSectionComplete(title_, status_, size_, (int32_t)elapsed.count()); } } } // namespace dumpstate } // namespace os } // namespace android cmds/dumpstate/DumpstateSectionReporter.h 0 → 100644 +65 −0 Original line number Diff line number Diff line /* * Copyright (C) 2018 The Android Open Source Project * * 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. */ #ifndef ANDROID_OS_DUMPSTATESECTIONREPORTER_H_ #define ANDROID_OS_DUMPSTATESECTIONREPORTER_H_ #include <android/os/IDumpstateListener.h> #include <utils/StrongPointer.h> namespace android { namespace os { namespace dumpstate { /* * Helper class used to report per section details to a listener. * * Typical usage: * * DumpstateSectionReporter sectionReporter(title, listener, sendReport); * sectionReporter.setSize(5000); * */ class DumpstateSectionReporter { public: DumpstateSectionReporter(const std::string& title, sp<android::os::IDumpstateListener> listener, bool sendReport); ~DumpstateSectionReporter(); void setStatus(status_t status) { status_ = status; } void setSize(int size) { size_ = size; } private: std::string title_; android::sp<android::os::IDumpstateListener> listener_; bool sendReport_; status_t status_; int size_; std::chrono::time_point<std::chrono::steady_clock> started_; }; } // namespace dumpstate } // namespace os } // namespace android #endif // ANDROID_OS_DUMPSTATESECTIONREPORTER_H_ cmds/dumpstate/DumpstateService.cpp +2 −0 Original line number Diff line number Diff line Loading @@ -52,6 +52,7 @@ status_t DumpstateService::Start() { binder::Status DumpstateService::setListener(const std::string& name, const sp<IDumpstateListener>& listener, bool getSectionDetails, sp<IDumpstateToken>* returned_token) { *returned_token = nullptr; if (name.empty()) { Loading @@ -70,6 +71,7 @@ binder::Status DumpstateService::setListener(const std::string& name, ds_.listener_name_ = name; ds_.listener_ = listener; ds_.report_section_ = getSectionDetails; *returned_token = new DumpstateToken(); return binder::Status::ok(); Loading cmds/dumpstate/DumpstateService.h +1 −0 Original line number Diff line number Diff line Loading @@ -38,6 +38,7 @@ class DumpstateService : public BinderService<DumpstateService>, public BnDumpst status_t dump(int fd, const Vector<String16>& args) override; binder::Status setListener(const std::string& name, const sp<IDumpstateListener>& listener, bool getSectionDetails, sp<IDumpstateToken>* returned_token) override; private: Loading Loading
cmds/dumpstate/Android.bp +2 −0 Original line number Diff line number Diff line Loading @@ -83,7 +83,9 @@ cc_binary { ], srcs: [ "DumpstateInternal.cpp", "DumpstateSectionReporter.cpp", "DumpstateService.cpp", "main.cpp", "utils.cpp", "dumpstate.cpp", ], Loading
cmds/dumpstate/DumpstateSectionReporter.cpp 0 → 100644 +42 −0 Original line number Diff line number Diff line /* * Copyright (C) 2018 The Android Open Source Project * * 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. */ #define LOG_TAG "dumpstate" #include "DumpstateSectionReporter.h" namespace android { namespace os { namespace dumpstate { DumpstateSectionReporter::DumpstateSectionReporter(const std::string& title, sp<android::os::IDumpstateListener> listener, bool sendReport) : title_(title), listener_(listener), sendReport_(sendReport), status_(OK), size_(-1) { started_ = std::chrono::steady_clock::now(); } DumpstateSectionReporter::~DumpstateSectionReporter() { if ((listener_ != nullptr) && (sendReport_)) { auto elapsed = std::chrono::duration_cast<std::chrono::milliseconds>( std::chrono::steady_clock::now() - started_); listener_->onSectionComplete(title_, status_, size_, (int32_t)elapsed.count()); } } } // namespace dumpstate } // namespace os } // namespace android
cmds/dumpstate/DumpstateSectionReporter.h 0 → 100644 +65 −0 Original line number Diff line number Diff line /* * Copyright (C) 2018 The Android Open Source Project * * 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. */ #ifndef ANDROID_OS_DUMPSTATESECTIONREPORTER_H_ #define ANDROID_OS_DUMPSTATESECTIONREPORTER_H_ #include <android/os/IDumpstateListener.h> #include <utils/StrongPointer.h> namespace android { namespace os { namespace dumpstate { /* * Helper class used to report per section details to a listener. * * Typical usage: * * DumpstateSectionReporter sectionReporter(title, listener, sendReport); * sectionReporter.setSize(5000); * */ class DumpstateSectionReporter { public: DumpstateSectionReporter(const std::string& title, sp<android::os::IDumpstateListener> listener, bool sendReport); ~DumpstateSectionReporter(); void setStatus(status_t status) { status_ = status; } void setSize(int size) { size_ = size; } private: std::string title_; android::sp<android::os::IDumpstateListener> listener_; bool sendReport_; status_t status_; int size_; std::chrono::time_point<std::chrono::steady_clock> started_; }; } // namespace dumpstate } // namespace os } // namespace android #endif // ANDROID_OS_DUMPSTATESECTIONREPORTER_H_
cmds/dumpstate/DumpstateService.cpp +2 −0 Original line number Diff line number Diff line Loading @@ -52,6 +52,7 @@ status_t DumpstateService::Start() { binder::Status DumpstateService::setListener(const std::string& name, const sp<IDumpstateListener>& listener, bool getSectionDetails, sp<IDumpstateToken>* returned_token) { *returned_token = nullptr; if (name.empty()) { Loading @@ -70,6 +71,7 @@ binder::Status DumpstateService::setListener(const std::string& name, ds_.listener_name_ = name; ds_.listener_ = listener; ds_.report_section_ = getSectionDetails; *returned_token = new DumpstateToken(); return binder::Status::ok(); Loading
cmds/dumpstate/DumpstateService.h +1 −0 Original line number Diff line number Diff line Loading @@ -38,6 +38,7 @@ class DumpstateService : public BinderService<DumpstateService>, public BnDumpst status_t dump(int fd, const Vector<String16>& args) override; binder::Status setListener(const std::string& name, const sp<IDumpstateListener>& listener, bool getSectionDetails, sp<IDumpstateToken>* returned_token) override; private: Loading