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
190825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport android.util.Log;
200825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
210825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport java.io.FileDescriptor;
220825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport java.io.PrintWriter;
230825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
240825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville/**
250825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * A debug service that will dump telephony's state
260825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville *
270825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * Currently this "Service" has a proxy in the phone app
280825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * com.android.phone.TelephonyDebugService which actually
290825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * invokes the dump method.
300825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville */
310825495a331bb44df395a0cdb79fab85e68db5d5Wink Savillepublic class DebugService {
320825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    private static String TAG = "DebugService";
330825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
340825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    /** Constructor */
350825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    public DebugService() {
360825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        log("DebugService:");
370825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    }
380825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
390825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    /**
400825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville     * Dump the state of various objects, add calls to other objects as desired.
410825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville     */
420825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    public void dump(FileDescriptor fd, PrintWriter pw, String[] args) {
430825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        log("dump: +");
440825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        PhoneProxy phoneProxy = null;
450825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        PhoneBase phoneBase = null;
460825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
470825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
480825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneProxy = (PhoneProxy) PhoneFactory.getDefaultPhone();
490825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
500825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            pw.println("Telephony DebugService: Could not getDefaultPhone e=" + e);
510825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            return;
520825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
530825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
540825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneBase = (PhoneBase)phoneProxy.getActivePhone();
550825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
560825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            pw.println("Telephony DebugService: Could not PhoneBase e=" + e);
570825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            return;
580825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
590825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
600825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        /**
610825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville         * Surround each of the sub dump's with try/catch so even
620825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville         * if one fails we'll be able to dump the next ones.
630825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville         */
640825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println();
650825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
660825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
670825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
680825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneBase.dump(fd, pw, args);
690825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
700825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            e.printStackTrace();
710825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
720825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
730825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
740825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
750825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneBase.mDataConnectionTracker.dump(fd, pw, args);
760825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
770825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            e.printStackTrace();
780825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
790825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
800825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
810825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
820825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneBase.getServiceStateTracker().dump(fd, pw, args);
830825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
840825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            e.printStackTrace();
850825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
860825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
870825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
880825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
890825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneBase.getCallTracker().dump(fd, pw, args);
900825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
910825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            e.printStackTrace();
920825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
930825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
940825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
950825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
960825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            ((RIL)phoneBase.mCM).dump(fd, pw, args);
970825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
980825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            e.printStackTrace();
990825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
1000825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
1010825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
1020825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        log("dump: -");
1030825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    }
1040825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
1050825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    private static void log(String s) {
1060825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        Log.d(TAG, "DebugService " + s);
1070825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    }
1080825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville}
109