/* * Copyright (C) 2007 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. */ package com.android.ddmlib; import java.io.IOException; import java.nio.BufferUnderflowException; import java.nio.ByteBuffer; /** * Handle the "app name" chunk (APNM). */ final class HandleAppName extends ChunkHandler { public static final int CHUNK_APNM = ChunkHandler.type("APNM"); private static final HandleAppName mInst = new HandleAppName(); private HandleAppName() {} /** * Register for the packets we expect to get from the client. */ public static void register(MonitorThread mt) { mt.registerChunkHandler(CHUNK_APNM, mInst); } /** * Client is ready. */ @Override public void clientReady(Client client) throws IOException {} /** * Client went away. */ @Override public void clientDisconnected(Client client) {} /** * Chunk handler entry point. */ @Override public void handleChunk(Client client, int type, ByteBuffer data, boolean isReply, int msgId) { Log.d("ddm-appname", "handling " + ChunkHandler.name(type)); if (type == CHUNK_APNM) { assert !isReply; handleAPNM(client, data); } else { handleUnknownChunk(client, type, data, isReply, msgId); } } /* * Handle a reply to our APNM message. */ private static void handleAPNM(Client client, ByteBuffer data) { int appNameLen; String appName; appNameLen = data.getInt(); appName = ByteBufferUtil.getString(data, appNameLen); // Newer devices send user id in the APNM packet. int userId = -1; boolean validUserId = false; if (data.hasRemaining()) { try { userId = data.getInt(); validUserId = true; } catch (BufferUnderflowException e) { // two integers + utf-16 string int expectedPacketLength = 8 + appNameLen * 2; Log.e("ddm-appname", "Insufficient data in APNM chunk to retrieve user id."); Log.e("ddm-appname", "Actual chunk length: " + data.capacity()); Log.e("ddm-appname", "Expected chunk length: " + expectedPacketLength); } } Log.d("ddm-appname", "APNM: app='" + appName + "'"); ClientData cd = client.getClientData(); synchronized (cd) { cd.setClientDescription(appName); if (validUserId) { cd.setUserId(userId); } } client = checkDebuggerPortForAppName(client, appName); if (client != null) { client.update(Client.CHANGE_NAME); } } }