diff options
| author | 2011-10-20 13:08:36 -0700 | |
|---|---|---|
| committer | 2011-10-20 13:08:36 -0700 | |
| commit | d2cd1f722421c33e88df92d036663f30b316fa3f (patch) | |
| tree | 8420d7c39bde1860c14bdf33c03e73473811fd29 | |
| parent | b321cd99c24272494bb9af5662c18c5bdc507186 (diff) | |
| parent | 9cbd360a670ca6deb7f2e933f1b79361b84f80a2 (diff) | |
Merge "Lazily fetch the status bar service." into ics-mr0
| -rw-r--r-- | core/java/android/app/StatusBarManager.java | 44 | 
1 files changed, 35 insertions, 9 deletions
| diff --git a/core/java/android/app/StatusBarManager.java b/core/java/android/app/StatusBarManager.java index 7863102857ed..5b8addf2a7c2 100644 --- a/core/java/android/app/StatusBarManager.java +++ b/core/java/android/app/StatusBarManager.java @@ -22,6 +22,7 @@ import android.os.Binder;  import android.os.RemoteException;  import android.os.IBinder;  import android.os.ServiceManager; +import android.util.Slog;  import android.view.View;  import com.android.internal.statusbar.IStatusBarService; @@ -61,8 +62,17 @@ public class StatusBarManager {      StatusBarManager(Context context) {          mContext = context; -        mService = IStatusBarService.Stub.asInterface( -                ServiceManager.getService(Context.STATUS_BAR_SERVICE)); +    } + +    private synchronized IStatusBarService getService() { +        if (mService == null) { +            mService = IStatusBarService.Stub.asInterface( +                    ServiceManager.getService(Context.STATUS_BAR_SERVICE)); +            if (mService == null) { +                Slog.w("StatusBarManager", "warning: no STATUS_BAR_SERVICE"); +            } +        } +        return mService;      }      /** @@ -71,8 +81,9 @@ public class StatusBarManager {       */      public void disable(int what) {          try { -            if (mService != null) { -                mService.disable(what, mToken, mContext.getPackageName()); +            final IStatusBarService svc = getService(); +            if (svc != null) { +                svc.disable(what, mToken, mContext.getPackageName());              }          } catch (RemoteException ex) {              // system process is dead anyway. @@ -85,7 +96,10 @@ public class StatusBarManager {       */      public void expand() {          try { -            mService.expand(); +            final IStatusBarService svc = getService(); +            if (svc != null) { +                svc.expand(); +            }          } catch (RemoteException ex) {              // system process is dead anyway.              throw new RuntimeException(ex); @@ -97,7 +111,10 @@ public class StatusBarManager {       */      public void collapse() {          try { -            mService.collapse(); +            final IStatusBarService svc = getService(); +            if (svc != null) { +                svc.collapse(); +            }          } catch (RemoteException ex) {              // system process is dead anyway.              throw new RuntimeException(ex); @@ -106,8 +123,11 @@ public class StatusBarManager {      public void setIcon(String slot, int iconId, int iconLevel, String contentDescription) {          try { -            mService.setIcon(slot, mContext.getPackageName(), iconId, iconLevel, +            final IStatusBarService svc = getService(); +            if (svc != null) { +                svc.setIcon(slot, mContext.getPackageName(), iconId, iconLevel,                      contentDescription); +            }          } catch (RemoteException ex) {              // system process is dead anyway.              throw new RuntimeException(ex); @@ -116,7 +136,10 @@ public class StatusBarManager {      public void removeIcon(String slot) {          try { -            mService.removeIcon(slot); +            final IStatusBarService svc = getService(); +            if (svc != null) { +                svc.removeIcon(slot); +            }          } catch (RemoteException ex) {              // system process is dead anyway.              throw new RuntimeException(ex); @@ -125,7 +148,10 @@ public class StatusBarManager {      public void setIconVisibility(String slot, boolean visible) {          try { -            mService.setIconVisibility(slot, visible); +            final IStatusBarService svc = getService(); +            if (svc != null) { +                svc.setIconVisibility(slot, visible); +            }          } catch (RemoteException ex) {              // system process is dead anyway.              throw new RuntimeException(ex); |