Merge "Check for null in applyDefiningSharedLibraryUpdateLocked."

This commit is contained in:
Nicolas Geoffray
2018-11-16 12:30:48 +00:00
committed by Gerrit Code Review

View File

@@ -9483,7 +9483,7 @@ public class PackageManagerService extends IPackageManager.Stub
}
}
private SharedLibraryInfo getSharedLibraryInfoLPr(String name, long version) {
private @Nullable SharedLibraryInfo getSharedLibraryInfoLPr(String name, long version) {
LongSparseArray<SharedLibraryInfo> versionedLib = mSharedLibraries.get(name);
if (versionedLib == null) {
return null;
@@ -9728,16 +9728,26 @@ public class PackageManagerService extends IPackageManager.Stub
private void applyDefiningSharedLibraryUpdateLocked(
PackageParser.Package pkg, SharedLibraryInfo libInfo,
BiConsumer<SharedLibraryInfo, SharedLibraryInfo> action) {
// Note that libraries defined by this package may be null if:
// - Package manager was unable to create the shared library. The package still
// gets installed, but the shared library does not get created.
// Or:
// - Package manager is in a state where package isn't scanned yet. This will
// get called again after scanning to fix the dependencies.
if (pkg.isLibrary()) {
if (pkg.staticSharedLibName != null) {
SharedLibraryInfo definedLibrary = getSharedLibraryInfoLPr(
pkg.staticSharedLibName, pkg.staticSharedLibVersion);
action.accept(definedLibrary, libInfo);
if (definedLibrary != null) {
action.accept(definedLibrary, libInfo);
}
} else {
for (String libraryName : pkg.libraryNames) {
SharedLibraryInfo definedLibrary = getSharedLibraryInfoLPr(
libraryName, SharedLibraryInfo.VERSION_UNDEFINED);
action.accept(definedLibrary, libInfo);
if (definedLibrary != null) {
action.accept(definedLibrary, libInfo);
}
}
}
}