blob: 400b31f8d5ca37fbb0b1268974139577b5f3b615 [file] [log] [blame]
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2007 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Joe Onorato7a0f36b2010-06-07 10:24:36 -070017package com.android.server;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080018
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080019import android.app.PendingIntent;
20import android.app.StatusBarManager;
21import android.content.BroadcastReceiver;
Joe Onorato9e875fc2010-06-07 11:12:11 -070022import android.content.ComponentName;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080023import android.content.Context;
24import android.content.Intent;
25import android.content.IntentFilter;
26import android.content.pm.PackageManager;
27import android.content.res.Resources;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080028import android.net.Uri;
29import android.os.IBinder;
30import android.os.RemoteException;
31import android.os.Binder;
Joe Onoratof3f0e052010-05-14 18:49:29 -070032import android.os.Handler;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080033import android.os.SystemClock;
Joe Onorato8a9b2202010-02-26 18:56:32 -080034import android.util.Slog;
Joe Onorato0cbda992010-05-02 16:28:15 -070035
36import com.android.internal.statusbar.IStatusBar;
37import com.android.internal.statusbar.IStatusBarService;
38import com.android.internal.statusbar.StatusBarIcon;
39import com.android.internal.statusbar.StatusBarIconList;
Joe Onorato18e69df2010-05-17 22:26:12 -070040import com.android.internal.statusbar.StatusBarNotification;
The Android Open Source Project10592532009-03-18 17:39:46 -070041
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080042import java.io.FileDescriptor;
43import java.io.PrintWriter;
44import java.util.ArrayList;
45import java.util.HashMap;
Joe Onorato75199e32010-05-29 17:22:51 -040046import java.util.List;
47import java.util.Map;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080048
49
50/**
Joe Onoratof3f0e052010-05-14 18:49:29 -070051 * A note on locking: We rely on the fact that calls onto mBar are oneway or
52 * if they are local, that they just enqueue messages to not deadlock.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080053 */
Joe Onorato089de882010-04-12 08:18:45 -070054public class StatusBarManagerService extends IStatusBarService.Stub
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080055{
Joe Onorato4762c2d2010-05-17 15:42:59 -070056 static final String TAG = "StatusBarManagerService";
Joe Onorato431bb222010-10-18 19:13:23 -040057 static final boolean SPEW = false;
Joe Onoratodf7dbb62009-11-17 10:43:37 -080058
Joe Onoratof3f0e052010-05-14 18:49:29 -070059 final Context mContext;
60 Handler mHandler = new Handler();
61 NotificationCallbacks mNotificationCallbacks;
Joe Onorato4762c2d2010-05-17 15:42:59 -070062 volatile IStatusBar mBar;
Joe Onoratof3f0e052010-05-14 18:49:29 -070063 StatusBarIconList mIcons = new StatusBarIconList();
Joe Onorato75199e32010-05-29 17:22:51 -040064 HashMap<IBinder,StatusBarNotification> mNotifications
65 = new HashMap<IBinder,StatusBarNotification>();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080066
Joe Onoratof3f0e052010-05-14 18:49:29 -070067 // for disabling the status bar
68 ArrayList<DisableRecord> mDisableRecords = new ArrayList<DisableRecord>();
69 int mDisabled = 0;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080070
Joe Onorato93056472010-09-10 10:30:46 -040071 Object mLock = new Object();
72 // We usually call it lights out mode, but double negatives are annoying
73 boolean mLightsOn = true;
74
Daniel Sandlere02d8082010-10-08 15:13:22 -040075 boolean mMenuVisible = false;
76
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080077 private class DisableRecord implements IBinder.DeathRecipient {
78 String pkg;
79 int what;
80 IBinder token;
81
82 public void binderDied() {
Joe Onorato8a9b2202010-02-26 18:56:32 -080083 Slog.i(TAG, "binder died for pkg=" + pkg);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080084 disable(0, token, pkg);
Suchi Amalapurapufff2fda2009-06-30 21:36:16 -070085 token.unlinkToDeath(this, 0);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080086 }
87 }
88
89 public interface NotificationCallbacks {
90 void onSetDisabled(int status);
91 void onClearAll();
Fred Quintana6ecaff12009-09-25 14:23:13 -070092 void onNotificationClick(String pkg, String tag, int id);
Daniel Sandler0f0b11c2010-08-04 15:54:58 -040093 void onNotificationClear(String pkg, String tag, int id);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080094 void onPanelRevealed();
Dianne Hackborn9d39d0c2010-06-24 15:57:42 -070095 void onNotificationError(String pkg, String tag, int id,
96 int uid, int initialPid, String message);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080097 }
98
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080099 /**
100 * Construct the service, add the status bar view to the window manager
101 */
Joe Onorato089de882010-04-12 08:18:45 -0700102 public StatusBarManagerService(Context context) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800103 mContext = context;
Joe Onorato0cbda992010-05-02 16:28:15 -0700104
105 final Resources res = context.getResources();
Joe Onorato75144ea2010-06-07 12:36:25 -0700106 mIcons.defineSlots(res.getStringArray(com.android.internal.R.array.config_statusBarIcons));
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800107 }
108
109 public void setNotificationCallbacks(NotificationCallbacks listener) {
110 mNotificationCallbacks = listener;
111 }
112
113 // ================================================================================
Joe Onorato25f95f92010-04-08 18:37:10 -0500114 // From IStatusBarService
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800115 // ================================================================================
Joe Onoratof3f0e052010-05-14 18:49:29 -0700116 public void expand() {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800117 enforceExpandStatusBar();
Joe Onorato4762c2d2010-05-17 15:42:59 -0700118
119 if (mBar != null) {
120 try {
121 mBar.animateExpand();
122 } catch (RemoteException ex) {
123 }
124 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800125 }
126
Joe Onoratof3f0e052010-05-14 18:49:29 -0700127 public void collapse() {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800128 enforceExpandStatusBar();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800129
Joe Onorato4762c2d2010-05-17 15:42:59 -0700130 if (mBar != null) {
131 try {
132 mBar.animateCollapse();
133 } catch (RemoteException ex) {
134 }
135 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800136 }
137
138 public void disable(int what, IBinder token, String pkg) {
139 enforceStatusBar();
Joe Onoratof3f0e052010-05-14 18:49:29 -0700140
141 // It's important that the the callback and the call to mBar get done
142 // in the same order when multiple threads are calling this function
143 // so they are paired correctly. The messages on the handler will be
144 // handled in the order they were enqueued, but will be outside the lock.
145 synchronized (mDisableRecords) {
146 manageDisableListLocked(what, token, pkg);
147 final int net = gatherDisableActionsLocked();
Joe Onoratof3f0e052010-05-14 18:49:29 -0700148 if (net != mDisabled) {
149 mDisabled = net;
150 mHandler.post(new Runnable() {
151 public void run() {
152 mNotificationCallbacks.onSetDisabled(net);
153 }
154 });
155 if (mBar != null) {
156 try {
157 mBar.disable(net);
158 } catch (RemoteException ex) {
159 }
160 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800161 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800162 }
163 }
164
Joe Onorato0cbda992010-05-02 16:28:15 -0700165 public void setIcon(String slot, String iconPackage, int iconId, int iconLevel) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800166 enforceStatusBar();
Joe Onorato0cbda992010-05-02 16:28:15 -0700167
168 synchronized (mIcons) {
169 int index = mIcons.getSlotIndex(slot);
170 if (index < 0) {
171 throw new SecurityException("invalid status bar icon slot: " + slot);
172 }
173
174 StatusBarIcon icon = new StatusBarIcon(iconPackage, iconId, iconLevel);
Joe Onorato66d7d012010-05-14 10:05:10 -0700175 //Slog.d(TAG, "setIcon slot=" + slot + " index=" + index + " icon=" + icon);
Joe Onorato0cbda992010-05-02 16:28:15 -0700176 mIcons.setIcon(index, icon);
177
Joe Onorato0cbda992010-05-02 16:28:15 -0700178 if (mBar != null) {
179 try {
180 mBar.setIcon(index, icon);
181 } catch (RemoteException ex) {
182 }
183 }
184 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800185 }
186
Joe Onorato0cbda992010-05-02 16:28:15 -0700187 public void setIconVisibility(String slot, boolean visible) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800188 enforceStatusBar();
Joe Onorato0cbda992010-05-02 16:28:15 -0700189
Joe Onorato514ad6632010-05-13 18:49:00 -0700190 synchronized (mIcons) {
191 int index = mIcons.getSlotIndex(slot);
192 if (index < 0) {
193 throw new SecurityException("invalid status bar icon slot: " + slot);
194 }
195
196 StatusBarIcon icon = mIcons.getIcon(index);
197 if (icon == null) {
198 return;
199 }
200
201 if (icon.visible != visible) {
202 icon.visible = visible;
203
Joe Onorato514ad6632010-05-13 18:49:00 -0700204 if (mBar != null) {
205 try {
206 mBar.setIcon(index, icon);
207 } catch (RemoteException ex) {
208 }
209 }
210 }
211 }
Joe Onorato0cbda992010-05-02 16:28:15 -0700212 }
213
214 public void removeIcon(String slot) {
215 enforceStatusBar();
216
217 synchronized (mIcons) {
218 int index = mIcons.getSlotIndex(slot);
219 if (index < 0) {
220 throw new SecurityException("invalid status bar icon slot: " + slot);
221 }
222
223 mIcons.removeIcon(index);
224
Joe Onorato0cbda992010-05-02 16:28:15 -0700225 if (mBar != null) {
226 try {
227 mBar.removeIcon(index);
228 } catch (RemoteException ex) {
229 }
230 }
231 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800232 }
233
Daniel Sandlere02d8082010-10-08 15:13:22 -0400234 /**
235 * Hide or show the on-screen Menu key. Only call this from the window manager, typically in
236 * response to a window with FLAG_NEEDS_MENU_KEY set.
237 */
238 public void setMenuKeyVisible(final boolean visible) {
239 enforceStatusBar();
240
241 if (SPEW) Slog.d(TAG, (visible?"showing":"hiding") + " MENU key");
242
243 synchronized(mLock) {
244 if (mMenuVisible != visible) {
245 mMenuVisible = visible;
246 mHandler.post(new Runnable() {
247 public void run() {
248 if (mBar != null) {
249 try {
250 mBar.setMenuKeyVisible(visible);
251 } catch (RemoteException ex) {
252 }
253 }
254 }
255 });
256 }
257 }
258 }
259
Joe Onoratof63b0f42010-09-12 17:03:19 -0400260 /**
261 * This is used for the automatic version of lights-out mode. Only call this from
262 * the window manager.
263 *
264 * @see setLightsOn(boolean)
265 */
Joe Onorato93056472010-09-10 10:30:46 -0400266 public void setActiveWindowIsFullscreen(boolean fullscreen) {
267 // We could get away with a separate permission here, but STATUS_BAR is
268 // signatureOrSystem which is probably good enough. There is no public API
269 // for this, so the question is a security issue, not an API compatibility issue.
270 enforceStatusBar();
271
Joe Onorato93056472010-09-10 10:30:46 -0400272 synchronized (mLock) {
Joe Onoratof63b0f42010-09-12 17:03:19 -0400273 updateLightsOnLocked(!fullscreen);
274 }
275 }
276
277 /**
278 * This is used for the user-controlled version of lights-out mode. Only call this from
279 * the status bar itself.
280 *
281 * We have two different functions here, because I think we're going to want to
282 * tweak the behavior when the user keeps turning lights-out mode off and the
283 * app keeps trying to turn it on. For now they can just fight it out. Having
284 * these two separte inputs will allow us to keep that change local to here. --joeo
285 */
286 public void setLightsOn(boolean lightsOn) {
287 enforceStatusBarService();
288
289 synchronized (mLock) {
290 updateLightsOnLocked(lightsOn);
291 }
292 }
293
294 private void updateLightsOnLocked(final boolean lightsOn) {
295 if (mLightsOn != lightsOn) {
296 mLightsOn = lightsOn;
297 mHandler.post(new Runnable() {
298 public void run() {
299 if (mBar != null) {
300 try {
301 mBar.setLightsOn(lightsOn);
302 } catch (RemoteException ex) {
Joe Onorato93056472010-09-10 10:30:46 -0400303 }
304 }
Joe Onoratof63b0f42010-09-12 17:03:19 -0400305 }
306 });
Joe Onorato93056472010-09-10 10:30:46 -0400307 }
308 }
309
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800310 private void enforceStatusBar() {
Joe Onorato0cbda992010-05-02 16:28:15 -0700311 mContext.enforceCallingOrSelfPermission(android.Manifest.permission.STATUS_BAR,
Joe Onorato089de882010-04-12 08:18:45 -0700312 "StatusBarManagerService");
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800313 }
314
315 private void enforceExpandStatusBar() {
Joe Onorato0cbda992010-05-02 16:28:15 -0700316 mContext.enforceCallingOrSelfPermission(android.Manifest.permission.EXPAND_STATUS_BAR,
Joe Onorato089de882010-04-12 08:18:45 -0700317 "StatusBarManagerService");
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800318 }
319
Joe Onorato8bc6c512010-06-04 16:21:12 -0400320 private void enforceStatusBarService() {
321 mContext.enforceCallingOrSelfPermission(android.Manifest.permission.STATUS_BAR_SERVICE,
322 "StatusBarManagerService");
323 }
324
Joe Onorato4762c2d2010-05-17 15:42:59 -0700325
326 // ================================================================================
327 // Callbacks from the status bar service.
328 // ================================================================================
Joe Onorato75199e32010-05-29 17:22:51 -0400329 public void registerStatusBar(IStatusBar bar, StatusBarIconList iconList,
Joe Onorato93056472010-09-10 10:30:46 -0400330 List<IBinder> notificationKeys, List<StatusBarNotification> notifications,
Daniel Sandlere02d8082010-10-08 15:13:22 -0400331 boolean switches[]) {
Joe Onorato8bc6c512010-06-04 16:21:12 -0400332 enforceStatusBarService();
333
Joe Onorato0cbda992010-05-02 16:28:15 -0700334 Slog.i(TAG, "registerStatusBar bar=" + bar);
335 mBar = bar;
Joe Onorato75199e32010-05-29 17:22:51 -0400336 synchronized (mIcons) {
337 iconList.copyFrom(mIcons);
338 }
339 synchronized (mNotifications) {
340 for (Map.Entry<IBinder,StatusBarNotification> e: mNotifications.entrySet()) {
341 notificationKeys.add(e.getKey());
342 notifications.add(e.getValue());
343 }
344 }
Joe Onorato93056472010-09-10 10:30:46 -0400345 synchronized (mLock) {
Daniel Sandlere02d8082010-10-08 15:13:22 -0400346 switches[0] = mLightsOn;
347 switches[1] = mMenuVisible;
Joe Onorato93056472010-09-10 10:30:46 -0400348 }
Joe Onorato2314aab2010-04-08 16:41:23 -0500349 }
Joe Onoratoaaba60b2010-05-23 15:18:41 -0400350
Joe Onorato4762c2d2010-05-17 15:42:59 -0700351 /**
Joe Onoratof1f25912010-06-07 11:52:41 -0700352 * The status bar service should call this each time the user brings the panel from
353 * invisible to visible in order to clear the notification light.
Joe Onorato4762c2d2010-05-17 15:42:59 -0700354 */
Joe Onoratof1f25912010-06-07 11:52:41 -0700355 public void onPanelRevealed() {
Joe Onorato8bc6c512010-06-04 16:21:12 -0400356 enforceStatusBarService();
357
Joe Onoratof1f25912010-06-07 11:52:41 -0700358 // tell the notification manager to turn off the lights.
359 mNotificationCallbacks.onPanelRevealed();
Joe Onorato4762c2d2010-05-17 15:42:59 -0700360 }
361
Joe Onoratoaaba60b2010-05-23 15:18:41 -0400362 public void onNotificationClick(String pkg, String tag, int id) {
Joe Onorato8bc6c512010-06-04 16:21:12 -0400363 enforceStatusBarService();
364
Joe Onoratoaaba60b2010-05-23 15:18:41 -0400365 mNotificationCallbacks.onNotificationClick(pkg, tag, id);
366 }
367
Dianne Hackborn9d39d0c2010-06-24 15:57:42 -0700368 public void onNotificationError(String pkg, String tag, int id,
369 int uid, int initialPid, String message) {
Joe Onorato8bc6c512010-06-04 16:21:12 -0400370 enforceStatusBarService();
371
Joe Onorato005847b2010-06-04 16:08:02 -0400372 // WARNING: this will call back into us to do the remove. Don't hold any locks.
Dianne Hackborn9d39d0c2010-06-24 15:57:42 -0700373 mNotificationCallbacks.onNotificationError(pkg, tag, id, uid, initialPid, message);
Joe Onorato005847b2010-06-04 16:08:02 -0400374 }
375
Daniel Sandler0f0b11c2010-08-04 15:54:58 -0400376 public void onNotificationClear(String pkg, String tag, int id) {
377 enforceStatusBarService();
378
379 mNotificationCallbacks.onNotificationClear(pkg, tag, id);
380 }
381
Joe Onoratoaaba60b2010-05-23 15:18:41 -0400382 public void onClearAllNotifications() {
Joe Onorato8bc6c512010-06-04 16:21:12 -0400383 enforceStatusBarService();
384
Joe Onoratoaaba60b2010-05-23 15:18:41 -0400385 mNotificationCallbacks.onClearAll();
386 }
387
Joe Onorato18e69df2010-05-17 22:26:12 -0700388 // ================================================================================
389 // Callbacks for NotificationManagerService.
390 // ================================================================================
391 public IBinder addNotification(StatusBarNotification notification) {
392 synchronized (mNotifications) {
Joe Onoratoa0c56fe2010-05-20 10:21:52 -0700393 IBinder key = new Binder();
Joe Onorato75199e32010-05-29 17:22:51 -0400394 mNotifications.put(key, notification);
Joe Onoratoe345fff2010-05-23 15:18:27 -0400395 if (mBar != null) {
396 try {
397 mBar.addNotification(key, notification);
398 } catch (RemoteException ex) {
399 }
400 }
Joe Onorato18e69df2010-05-17 22:26:12 -0700401 return key;
402 }
Joe Onorato0cbda992010-05-02 16:28:15 -0700403 }
404
Joe Onorato18e69df2010-05-17 22:26:12 -0700405 public void updateNotification(IBinder key, StatusBarNotification notification) {
406 synchronized (mNotifications) {
Joe Onorato75199e32010-05-29 17:22:51 -0400407 if (!mNotifications.containsKey(key)) {
408 throw new IllegalArgumentException("updateNotification key not found: " + key);
409 }
410 mNotifications.put(key, notification);
Joe Onoratoe345fff2010-05-23 15:18:27 -0400411 if (mBar != null) {
412 try {
413 mBar.updateNotification(key, notification);
414 } catch (RemoteException ex) {
415 }
416 }
Joe Onorato18e69df2010-05-17 22:26:12 -0700417 }
Joe Onorato0cbda992010-05-02 16:28:15 -0700418 }
419
420 public void removeNotification(IBinder key) {
Joe Onorato18e69df2010-05-17 22:26:12 -0700421 synchronized (mNotifications) {
Joe Onorato75199e32010-05-29 17:22:51 -0400422 final StatusBarNotification n = mNotifications.remove(key);
423 if (n == null) {
424 throw new IllegalArgumentException("removeNotification key not found: " + key);
425 }
Joe Onoratoe345fff2010-05-23 15:18:27 -0400426 if (mBar != null) {
427 try {
428 mBar.removeNotification(key);
429 } catch (RemoteException ex) {
430 }
431 }
Joe Onorato18e69df2010-05-17 22:26:12 -0700432 }
Joe Onorato0cbda992010-05-02 16:28:15 -0700433 }
Joe Onorato2314aab2010-04-08 16:41:23 -0500434
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800435 // ================================================================================
436 // Can be called from any thread
437 // ================================================================================
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800438
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800439 // lock on mDisableRecords
440 void manageDisableListLocked(int what, IBinder token, String pkg) {
441 if (SPEW) {
Joe Onoratof3f0e052010-05-14 18:49:29 -0700442 Slog.d(TAG, "manageDisableList what=0x" + Integer.toHexString(what) + " pkg=" + pkg);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800443 }
444 // update the list
445 synchronized (mDisableRecords) {
446 final int N = mDisableRecords.size();
447 DisableRecord tok = null;
448 int i;
449 for (i=0; i<N; i++) {
450 DisableRecord t = mDisableRecords.get(i);
451 if (t.token == token) {
452 tok = t;
453 break;
454 }
455 }
456 if (what == 0 || !token.isBinderAlive()) {
457 if (tok != null) {
458 mDisableRecords.remove(i);
Suchi Amalapurapufff2fda2009-06-30 21:36:16 -0700459 tok.token.unlinkToDeath(tok, 0);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800460 }
461 } else {
462 if (tok == null) {
463 tok = new DisableRecord();
464 try {
465 token.linkToDeath(tok, 0);
466 }
467 catch (RemoteException ex) {
468 return; // give up
469 }
470 mDisableRecords.add(tok);
471 }
472 tok.what = what;
473 tok.token = token;
474 tok.pkg = pkg;
475 }
476 }
477 }
478
479 // lock on mDisableRecords
480 int gatherDisableActionsLocked() {
481 final int N = mDisableRecords.size();
482 // gather the new net flags
483 int net = 0;
484 for (int i=0; i<N; i++) {
485 net |= mDisableRecords.get(i).what;
486 }
487 return net;
488 }
489
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800490 // ================================================================================
491 // Always called from UI thread
492 // ================================================================================
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800493
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800494 protected void dump(FileDescriptor fd, PrintWriter pw, String[] args) {
495 if (mContext.checkCallingOrSelfPermission(android.Manifest.permission.DUMP)
496 != PackageManager.PERMISSION_GRANTED) {
497 pw.println("Permission Denial: can't dump StatusBar from from pid="
498 + Binder.getCallingPid()
499 + ", uid=" + Binder.getCallingUid());
500 return;
501 }
Joe Onorato0cbda992010-05-02 16:28:15 -0700502
Joe Onorato0cbda992010-05-02 16:28:15 -0700503 synchronized (mIcons) {
504 mIcons.dump(pw);
505 }
Joe Onorato18e69df2010-05-17 22:26:12 -0700506
507 synchronized (mNotifications) {
Joe Onorato75199e32010-05-29 17:22:51 -0400508 int i=0;
509 pw.println("Notification list:");
510 for (Map.Entry<IBinder,StatusBarNotification> e: mNotifications.entrySet()) {
511 pw.printf(" %2d: %s\n", i, e.getValue().toString());
512 i++;
513 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800514 }
Joe Onorato18e69df2010-05-17 22:26:12 -0700515
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800516 synchronized (mDisableRecords) {
517 final int N = mDisableRecords.size();
518 pw.println(" mDisableRecords.size=" + N
519 + " mDisabled=0x" + Integer.toHexString(mDisabled));
520 for (int i=0; i<N; i++) {
521 DisableRecord tok = mDisableRecords.get(i);
522 pw.println(" [" + i + "] what=0x" + Integer.toHexString(tok.what)
523 + " pkg=" + tok.pkg + " token=" + tok.token);
524 }
525 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800526 }
527
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800528 private BroadcastReceiver mBroadcastReceiver = new BroadcastReceiver() {
529 public void onReceive(Context context, Intent intent) {
530 String action = intent.getAction();
Joe Onoratof9e0e6b2009-09-08 16:24:36 -0400531 if (Intent.ACTION_CLOSE_SYSTEM_DIALOGS.equals(action)
532 || Intent.ACTION_SCREEN_OFF.equals(action)) {
Joe Onoratof3f0e052010-05-14 18:49:29 -0700533 collapse();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800534 }
Joe Onorato0cbda992010-05-02 16:28:15 -0700535 /*
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800536 else if (Telephony.Intents.SPN_STRINGS_UPDATED_ACTION.equals(action)) {
537 updateNetworkName(intent.getBooleanExtra(Telephony.Intents.EXTRA_SHOW_SPN, false),
538 intent.getStringExtra(Telephony.Intents.EXTRA_SPN),
539 intent.getBooleanExtra(Telephony.Intents.EXTRA_SHOW_PLMN, false),
540 intent.getStringExtra(Telephony.Intents.EXTRA_PLMN));
541 }
542 else if (Intent.ACTION_CONFIGURATION_CHANGED.equals(action)) {
543 updateResources();
544 }
Joe Onorato0cbda992010-05-02 16:28:15 -0700545 */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800546 }
547 };
548
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800549}