diff --git a/cm/lib/main/java/org/cyanogenmod/platform/internal/AppSuggestManagerService.java b/cm/lib/main/java/org/cyanogenmod/platform/internal/AppSuggestManagerService.java index 0673211..b954dfa 100644 --- a/cm/lib/main/java/org/cyanogenmod/platform/internal/AppSuggestManagerService.java +++ b/cm/lib/main/java/org/cyanogenmod/platform/internal/AppSuggestManagerService.java @@ -74,6 +74,12 @@ public class AppSuggestManagerService extends SystemService { Slog.i(TAG, "Bound to to suggest provider"); } - publishBinderService(CMContextConstants.CM_APP_SUGGEST_SERVICE, mService); + if (mContext.getPackageManager().hasSystemFeature( + CMContextConstants.Features.APP_SUGGEST)) { + publishBinderService(CMContextConstants.CM_APP_SUGGEST_SERVICE, mService); + } else { + Log.wtf(TAG, "CM hardware service started by system server but feature xml not" + + " declared. Not publishing binder service!"); + } } } diff --git a/src/java/cyanogenmod/app/CMContextConstants.java b/src/java/cyanogenmod/app/CMContextConstants.java index 622732d..8cfa04b 100644 --- a/src/java/cyanogenmod/app/CMContextConstants.java +++ b/src/java/cyanogenmod/app/CMContextConstants.java @@ -141,5 +141,13 @@ public final class CMContextConstants { */ @SdkConstant(SdkConstant.SdkConstantType.FEATURE) public static final String PROFILES = "org.cyanogenmod.profiles"; + + /** + * Feature for {@link PackageManager#getSystemAvailableFeatures} and + * {@link PackageManager#hasSystemFeature}: The device includes the cm app suggest service + * utilized by the cmsdk. + */ + @SdkConstant(SdkConstant.SdkConstantType.FEATURE) + public static final String APP_SUGGEST = "org.cyanogenmod.appsuggest"; } } diff --git a/src/java/cyanogenmod/app/suggest/AppSuggestManager.java b/src/java/cyanogenmod/app/suggest/AppSuggestManager.java index 7bc034c..0eb55d4 100644 --- a/src/java/cyanogenmod/app/suggest/AppSuggestManager.java +++ b/src/java/cyanogenmod/app/suggest/AppSuggestManager.java @@ -63,10 +63,18 @@ public class AppSuggestManager { return sInstance; } - context = context.getApplicationContext() != null ? context.getApplicationContext() : context; + context = context.getApplicationContext() != null ? + context.getApplicationContext() : context; sInstance = new AppSuggestManager(context); + if (context.getPackageManager().hasSystemFeature(CMContextConstants.Features.APP_SUGGEST) + && sImpl == null) { + throw new RuntimeException("Unable to get AppSuggestManagerService. " + + "The service either crashed, was not started, or the interface has been" + + " called to early in SystemServer init"); + } + return sInstance; }