1 /* 2 * Copyright (C) 2021 The Android Open Source Project * 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS, 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 16 #include "utils.h" 17 #include "vibrator.h" 18 19 namespace android { 20 namespace idlcli { 21 22 class CommandVibrator; 23 24 namespace vibrator { 25 26 class CommandGetBandwidthAmplitudeMap : public Command { getDescription() const27 std::string getDescription() const override { 28 return "Retrieves vibrator bandwidth amplitude map."; 29 } 30 getUsageSummary() const31 std::string getUsageSummary() const override { return ""; } 32 getUsageDetails() const33 UsageDetails getUsageDetails() const override { 34 UsageDetails details{}; 35 return details; 36 } 37 doArgs(Args & args)38 Status doArgs(Args &args) override { 39 if (!args.empty()) { 40 std::cerr << "Unexpected Arguments!" << std::endl; 41 return USAGE; 42 } 43 return OK; 44 } 45 doMain(Args &&)46 Status doMain(Args && /*args*/) override { 47 std::string statusStr; 48 std::vector<float> bandwidthAmplitude; 49 float frequencyMinimumHz; 50 float frequencyResolutionHz; 51 Status ret; 52 53 if (auto hal = getHal<aidl::IVibrator>()) { 54 auto status = 55 hal->call(&aidl::IVibrator::getBandwidthAmplitudeMap, &bandwidthAmplitude); 56 statusStr = status.getDescription(); 57 ret = (status.isOk() ? OK : ERROR); 58 59 status = hal->call(&aidl::IVibrator::getFrequencyMinimum, &frequencyMinimumHz); 60 ret = (status.isOk() ? OK : ERROR); 61 62 status = 63 hal->call(&aidl::IVibrator::getFrequencyResolution, &frequencyResolutionHz); 64 ret = (status.isOk() ? OK : ERROR); 65 } else { 66 return UNAVAILABLE; 67 } 68 69 std::cout << "Status: " << statusStr << std::endl; 70 std::cout << "Bandwidth Amplitude Map: " << std::endl; 71 float frequency = frequencyMinimumHz; 72 for (auto &e : bandwidthAmplitude) { 73 std::cout << frequency << ":" << e << std::endl; 74 frequency += frequencyResolutionHz; 75 } 76 77 return ret; 78 } 79 }; 80 81 static const auto Command = 82 CommandRegistry<CommandVibrator>::Register<CommandGetBandwidthAmplitudeMap>( 83 "getBandwidthAmplitudeMap"); 84 85 } // namespace vibrator 86 } // namespace idlcli 87 } // namespace android 88