10825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville/* 20825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * Copyright (C) 2012 The Android Open Source Project 30825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * 40825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * Licensed under the Apache License, Version 2.0 (the "License"); 50825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * you may not use this file except in compliance with the License. 60825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * You may obtain a copy of the License at 70825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * 80825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * http://www.apache.org/licenses/LICENSE-2.0 90825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * 100825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * Unless required by applicable law or agreed to in writing, software 110825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * distributed under the License is distributed on an "AS IS" BASIS, 120825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 130825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * See the License for the specific language governing permissions and 140825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * limitations under the License. 150825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville */ 160825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 170825495a331bb44df395a0cdb79fab85e68db5d5Wink Savillepackage com.android.internal.telephony; 180825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 19ded9c0af7fa49504c047275ed34c2d3b22bf0c3aWink Savilleimport android.telephony.Rlog; 20f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yuimport android.text.TextUtils; 210825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 22f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yuimport com.android.internal.telephony.metrics.TelephonyMetrics; 2305ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka 240825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport java.io.FileDescriptor; 250825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport java.io.PrintWriter; 260825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 270825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville/** 280825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * A debug service that will dump telephony's state 290825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * 300825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * Currently this "Service" has a proxy in the phone app 310825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * com.android.phone.TelephonyDebugService which actually 320825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * invokes the dump method. 330825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville */ 340825495a331bb44df395a0cdb79fab85e68db5d5Wink Savillepublic class DebugService { 350825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville private static String TAG = "DebugService"; 360825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 370825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville /** Constructor */ 380825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville public DebugService() { 390825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville log("DebugService:"); 400825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 410825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 420825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville /** 430825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * Dump the state of various objects, add calls to other objects as desired. 440825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville */ 450825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville public void dump(FileDescriptor fd, PrintWriter pw, String[] args) { 46f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yu if (args != null && args.length > 0) { 47f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yu if (TextUtils.equals(args[0], "--metrics") || 48f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yu TextUtils.equals(args[0], "--metricsproto")) 49f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yu { 50f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yu log("Collecting telephony metrics.."); 51f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yu TelephonyMetrics.getInstance().dump(fd, pw, args); 52f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yu return; 53f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yu } 54f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yu } 55f2d0fa64860a12423fb8709766d6af90fba5e6cfJack Yu log("Dump telephony."); 56e97be3971cb6b55e019433c32524cc60ce0d037bWink Saville PhoneFactory.dump(fd, pw, args); 570825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 580825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 590825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville private static void log(String s) { 60ded9c0af7fa49504c047275ed34c2d3b22bf0c3aWink Saville Rlog.d(TAG, "DebugService " + s); 610825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 620825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville} 63