blob: 6c6fcb2ea5583a94cd480ff665e51a30b8c79ad6 [file] [log] [blame]
Kenny Root15a4d2f2010-03-11 18:20:12 -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
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080017package android.content.pm;
18
Jeff Sharkey9bc89af2017-01-11 11:25:50 -070019import static android.os.Build.VERSION_CODES.DONUT;
20
21import android.annotation.IntDef;
Alan Viveretteb6a25732017-11-21 14:49:24 -050022import android.annotation.Nullable;
Jeff Sharkey8a372a02016-03-16 16:25:45 -060023import android.annotation.SystemApi;
Jeff Sharkeya73b8fd2016-01-06 17:02:08 -070024import android.annotation.TestApi;
Mathew Inwood5c0d3542018-08-14 13:54:31 +010025import android.annotation.UnsupportedAppUsage;
Jeff Sharkey8a372a02016-03-16 16:25:45 -060026import android.content.Context;
Jeff Brown07330792010-03-30 19:57:08 -070027import android.content.pm.PackageManager.NameNotFoundException;
28import android.content.res.Resources;
29import android.graphics.drawable.Drawable;
Mathew Inwood31755f92018-12-20 13:53:36 +000030import android.os.Build;
Jeff Sharkey15447792015-11-05 16:18:51 -080031import android.os.Environment;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080032import android.os.Parcel;
33import android.os.Parcelable;
Jeff Sharkey15447792015-11-05 16:18:51 -080034import android.os.UserHandle;
Jeff Sharkey789a8fc2017-04-16 13:18:35 -060035import android.os.storage.StorageManager;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080036import android.util.Printer;
Adam Lesinski1665d0f2017-03-10 14:46:57 -080037import android.util.SparseArray;
Yi Jin148d7f42017-11-28 14:23:56 -080038import android.util.proto.ProtoOutputStream;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080039
Jeff Sharkey8a4c9722014-06-16 13:48:42 -070040import com.android.internal.util.ArrayUtils;
Mathew Inwood4693a752018-02-20 16:04:25 +000041import com.android.server.SystemConfig;
Jeff Sharkey8a4c9722014-06-16 13:48:42 -070042
Jeff Sharkey9bc89af2017-01-11 11:25:50 -070043import java.lang.annotation.Retention;
44import java.lang.annotation.RetentionPolicy;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080045import java.text.Collator;
Jeff Sharkey8a4c9722014-06-16 13:48:42 -070046import java.util.Arrays;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080047import java.util.Comparator;
Nicolas Geoffray8d144eb2018-11-15 12:59:52 +000048import java.util.List;
Jeff Sharkey8a4c9722014-06-16 13:48:42 -070049import java.util.Objects;
Jeff Sharkey789a8fc2017-04-16 13:18:35 -060050import java.util.UUID;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080051
52/**
53 * Information you can retrieve about a particular application. This
54 * corresponds to information collected from the AndroidManifest.xml's
55 * <application> tag.
56 */
57public class ApplicationInfo extends PackageItemInfo implements Parcelable {
58
59 /**
60 * Default task affinity of all activities in this application. See
61 * {@link ActivityInfo#taskAffinity} for more information. This comes
62 * from the "taskAffinity" attribute.
63 */
64 public String taskAffinity;
65
66 /**
67 * Optional name of a permission required to be able to access this
68 * application's components. From the "permission" attribute.
69 */
70 public String permission;
71
72 /**
73 * The name of the process this application should run in. From the
74 * "process" attribute or, if not set, the same as
75 * <var>packageName</var>.
76 */
77 public String processName;
78
79 /**
80 * Class implementing the Application object. From the "class"
81 * attribute.
82 */
83 public String className;
84
85 /**
86 * A style resource identifier (in the package's resources) of the
87 * description of an application. From the "description" attribute
88 * or, if not set, 0.
89 */
90 public int descriptionRes;
91
92 /**
93 * A style resource identifier (in the package's resources) of the
94 * default visual theme of the application. From the "theme" attribute
95 * or, if not set, 0.
96 */
97 public int theme;
98
99 /**
100 * Class implementing the Application's manage space
101 * functionality. From the "manageSpaceActivity"
102 * attribute. This is an optional attribute and will be null if
Christopher Tate181fafa2009-05-14 11:12:14 -0700103 * applications don't specify it in their manifest
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800104 */
105 public String manageSpaceActivityName;
106
107 /**
Christopher Tate181fafa2009-05-14 11:12:14 -0700108 * Class implementing the Application's backup functionality. From
109 * the "backupAgent" attribute. This is an optional attribute and
110 * will be null if the application does not specify it in its manifest.
111 *
112 * <p>If android:allowBackup is set to false, this attribute is ignored.
Christopher Tate181fafa2009-05-14 11:12:14 -0700113 */
114 public String backupAgentName;
Christopher Tate4a627c72011-04-01 14:43:32 -0700115
116 /**
Matthew Williams303650c2015-04-17 18:22:51 -0700117 * An optional attribute that indicates the app supports automatic backup of app data.
118 * <p>0 is the default and means the app's entire data folder + managed external storage will
119 * be backed up;
120 * Any negative value indicates the app does not support full-data backup, though it may still
121 * want to participate via the traditional key/value backup API;
122 * A positive number specifies an xml resource in which the application has defined its backup
123 * include/exclude criteria.
124 * <p>If android:allowBackup is set to false, this attribute is ignored.
125 *
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600126 * @see android.content.Context#getNoBackupFilesDir()
127 * @see #FLAG_ALLOW_BACKUP
Christopher Tate98fa6562015-05-14 13:20:10 -0700128 *
129 * @hide
Matthew Williams303650c2015-04-17 18:22:51 -0700130 */
Mathew Inwood5c0d3542018-08-14 13:54:31 +0100131 @UnsupportedAppUsage
Matthew Williams303650c2015-04-17 18:22:51 -0700132 public int fullBackupContent = 0;
133
134 /**
Adam Powell269248d2011-08-02 10:26:54 -0700135 * The default extra UI options for activities in this application.
136 * Set from the {@link android.R.attr#uiOptions} attribute in the
137 * activity's manifest.
138 */
139 public int uiOptions = 0;
140
141 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800142 * Value for {@link #flags}: if set, this application is installed in the
143 * device's system image.
144 */
145 public static final int FLAG_SYSTEM = 1<<0;
146
147 /**
148 * Value for {@link #flags}: set to true if this application would like to
149 * allow debugging of its
150 * code, even when installed on a non-development system. Comes
151 * from {@link android.R.styleable#AndroidManifestApplication_debuggable
152 * android:debuggable} of the &lt;application&gt; tag.
153 */
154 public static final int FLAG_DEBUGGABLE = 1<<1;
155
156 /**
157 * Value for {@link #flags}: set to true if this application has code
158 * associated with it. Comes
159 * from {@link android.R.styleable#AndroidManifestApplication_hasCode
160 * android:hasCode} of the &lt;application&gt; tag.
161 */
162 public static final int FLAG_HAS_CODE = 1<<2;
163
164 /**
165 * Value for {@link #flags}: set to true if this application is persistent.
166 * Comes from {@link android.R.styleable#AndroidManifestApplication_persistent
167 * android:persistent} of the &lt;application&gt; tag.
168 */
169 public static final int FLAG_PERSISTENT = 1<<3;
170
171 /**
Christopher Tate181fafa2009-05-14 11:12:14 -0700172 * Value for {@link #flags}: set to true if this application holds the
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800173 * {@link android.Manifest.permission#FACTORY_TEST} permission and the
174 * device is running in factory test mode.
175 */
176 public static final int FLAG_FACTORY_TEST = 1<<4;
177
178 /**
179 * Value for {@link #flags}: default value for the corresponding ActivityInfo flag.
180 * Comes from {@link android.R.styleable#AndroidManifestApplication_allowTaskReparenting
181 * android:allowTaskReparenting} of the &lt;application&gt; tag.
182 */
183 public static final int FLAG_ALLOW_TASK_REPARENTING = 1<<5;
184
185 /**
186 * Value for {@link #flags}: default value for the corresponding ActivityInfo flag.
187 * Comes from {@link android.R.styleable#AndroidManifestApplication_allowClearUserData
188 * android:allowClearUserData} of the &lt;application&gt; tag.
189 */
190 public static final int FLAG_ALLOW_CLEAR_USER_DATA = 1<<6;
191
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800192 /**
Dianne Hackborn851a5412009-05-08 12:06:44 -0700193 * Value for {@link #flags}: this is set if this application has been
Kweku Adams8de29ca2016-01-22 12:30:26 -0800194 * installed as an update to a built-in system application.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800195 */
196 public static final int FLAG_UPDATED_SYSTEM_APP = 1<<7;
Dianne Hackborn851a5412009-05-08 12:06:44 -0700197
198 /**
Svet Ganov354cd3c2015-12-17 11:35:04 -0800199 * Value for {@link #flags}: this is set if the application has specified
Dianne Hackborn7f205432009-07-28 00:13:47 -0700200 * {@link android.R.styleable#AndroidManifestApplication_testOnly
201 * android:testOnly} to be true.
Dianne Hackborn851a5412009-05-08 12:06:44 -0700202 */
Dianne Hackborna96cbb42009-05-13 15:06:13 -0700203 public static final int FLAG_TEST_ONLY = 1<<8;
Dianne Hackbornade3eca2009-05-11 18:54:45 -0700204
205 /**
Dianne Hackborn5c1e00b2009-06-18 17:10:57 -0700206 * Value for {@link #flags}: true when the application's window can be
Dianne Hackborn723738c2009-06-25 19:48:04 -0700207 * reduced in size for smaller screens. Corresponds to
208 * {@link android.R.styleable#AndroidManifestSupportsScreens_smallScreens
209 * android:smallScreens}.
Dianne Hackborn5c1e00b2009-06-18 17:10:57 -0700210 */
Dianne Hackborn723738c2009-06-25 19:48:04 -0700211 public static final int FLAG_SUPPORTS_SMALL_SCREENS = 1<<9;
212
213 /**
214 * Value for {@link #flags}: true when the application's window can be
215 * displayed on normal screens. Corresponds to
216 * {@link android.R.styleable#AndroidManifestSupportsScreens_normalScreens
217 * android:normalScreens}.
218 */
219 public static final int FLAG_SUPPORTS_NORMAL_SCREENS = 1<<10;
220
221 /**
222 * Value for {@link #flags}: true when the application's window can be
223 * increased in size for larger screens. Corresponds to
224 * {@link android.R.styleable#AndroidManifestSupportsScreens_largeScreens
Dianne Hackborn22ec9ab2010-04-29 17:56:03 -0700225 * android:largeScreens}.
Dianne Hackborn723738c2009-06-25 19:48:04 -0700226 */
227 public static final int FLAG_SUPPORTS_LARGE_SCREENS = 1<<11;
Dianne Hackborn5c1e00b2009-06-18 17:10:57 -0700228
229 /**
Dianne Hackbornc4db95c2009-07-21 17:46:02 -0700230 * Value for {@link #flags}: true when the application knows how to adjust
231 * its UI for different screen sizes. Corresponds to
232 * {@link android.R.styleable#AndroidManifestSupportsScreens_resizeable
233 * android:resizeable}.
234 */
235 public static final int FLAG_RESIZEABLE_FOR_SCREENS = 1<<12;
236
237 /**
Dianne Hackborn11b822d2009-07-21 20:03:02 -0700238 * Value for {@link #flags}: true when the application knows how to
kopriva219f7dc2018-10-09 13:42:28 -0700239 * accommodate different screen densities. Corresponds to
Dianne Hackborn11b822d2009-07-21 20:03:02 -0700240 * {@link android.R.styleable#AndroidManifestSupportsScreens_anyDensity
241 * android:anyDensity}.
242 */
243 public static final int FLAG_SUPPORTS_SCREEN_DENSITIES = 1<<13;
244
245 /**
Ben Cheng23085b72010-02-08 16:06:32 -0800246 * Value for {@link #flags}: set to true if this application would like to
247 * request the VM to operate under the safe mode. Comes from
Ben Chengef3f5dd2010-03-29 15:47:26 -0700248 * {@link android.R.styleable#AndroidManifestApplication_vmSafeMode
249 * android:vmSafeMode} of the &lt;application&gt; tag.
Ben Cheng23085b72010-02-08 16:06:32 -0800250 */
251 public static final int FLAG_VM_SAFE_MODE = 1<<14;
252
253 /**
Christopher Tate3de55bc2010-03-12 17:28:08 -0800254 * Value for {@link #flags}: set to <code>false</code> if the application does not wish
255 * to permit any OS-driven backups of its data; <code>true</code> otherwise.
Christopher Tate181fafa2009-05-14 11:12:14 -0700256 *
Christopher Tate3de55bc2010-03-12 17:28:08 -0800257 * <p>Comes from the
258 * {@link android.R.styleable#AndroidManifestApplication_allowBackup android:allowBackup}
259 * attribute of the &lt;application&gt; tag.
Christopher Tate181fafa2009-05-14 11:12:14 -0700260 */
Ben Cheng23085b72010-02-08 16:06:32 -0800261 public static final int FLAG_ALLOW_BACKUP = 1<<15;
Christopher Tate5e1ab332009-09-01 20:32:49 -0700262
263 /**
Christopher Tate3de55bc2010-03-12 17:28:08 -0800264 * Value for {@link #flags}: set to <code>false</code> if the application must be kept
265 * in memory following a full-system restore operation; <code>true</code> otherwise.
266 * Ordinarily, during a full system restore operation each application is shut down
267 * following execution of its agent's onRestore() method. Setting this attribute to
268 * <code>false</code> prevents this. Most applications will not need to set this attribute.
Christopher Tate5e1ab332009-09-01 20:32:49 -0700269 *
Christopher Tate3de55bc2010-03-12 17:28:08 -0800270 * <p>If
271 * {@link android.R.styleable#AndroidManifestApplication_allowBackup android:allowBackup}
272 * is set to <code>false</code> or no
273 * {@link android.R.styleable#AndroidManifestApplication_backupAgent android:backupAgent}
Christopher Tate5e1ab332009-09-01 20:32:49 -0700274 * is specified, this flag will be ignored.
275 *
Christopher Tate3de55bc2010-03-12 17:28:08 -0800276 * <p>Comes from the
277 * {@link android.R.styleable#AndroidManifestApplication_killAfterRestore android:killAfterRestore}
278 * attribute of the &lt;application&gt; tag.
Christopher Tate5e1ab332009-09-01 20:32:49 -0700279 */
Ben Cheng23085b72010-02-08 16:06:32 -0800280 public static final int FLAG_KILL_AFTER_RESTORE = 1<<16;
Christopher Tate5e1ab332009-09-01 20:32:49 -0700281
282 /**
Christopher Tate3de55bc2010-03-12 17:28:08 -0800283 * Value for {@link #flags}: Set to <code>true</code> if the application's backup
284 * agent claims to be able to handle restore data even "from the future,"
285 * i.e. from versions of the application with a versionCode greater than
286 * the one currently installed on the device. <i>Use with caution!</i> By default
287 * this attribute is <code>false</code> and the Backup Manager will ensure that data
288 * from "future" versions of the application are never supplied during a restore operation.
Christopher Tate5e1ab332009-09-01 20:32:49 -0700289 *
Christopher Tate3de55bc2010-03-12 17:28:08 -0800290 * <p>If
291 * {@link android.R.styleable#AndroidManifestApplication_allowBackup android:allowBackup}
292 * is set to <code>false</code> or no
293 * {@link android.R.styleable#AndroidManifestApplication_backupAgent android:backupAgent}
Christopher Tate5e1ab332009-09-01 20:32:49 -0700294 * is specified, this flag will be ignored.
295 *
Christopher Tate3de55bc2010-03-12 17:28:08 -0800296 * <p>Comes from the
297 * {@link android.R.styleable#AndroidManifestApplication_restoreAnyVersion android:restoreAnyVersion}
298 * attribute of the &lt;application&gt; tag.
Christopher Tate5e1ab332009-09-01 20:32:49 -0700299 */
Christopher Tate3de55bc2010-03-12 17:28:08 -0800300 public static final int FLAG_RESTORE_ANY_VERSION = 1<<17;
Christopher Tate5e1ab332009-09-01 20:32:49 -0700301
Christopher Tate181fafa2009-05-14 11:12:14 -0700302 /**
Dianne Hackborn3202d382010-04-26 17:51:34 -0700303 * Value for {@link #flags}: Set to true if the application is
304 * currently installed on external/removable/unprotected storage. Such
305 * applications may not be available if their storage is not currently
306 * mounted. When the storage it is on is not available, it will look like
307 * the application has been uninstalled (its .apk is no longer available)
308 * but its persistent data is not removed.
Suchi Amalapurapuaf8e9f42010-01-12 10:17:28 -0800309 */
Dianne Hackborn94c567e2010-04-26 18:13:10 -0700310 public static final int FLAG_EXTERNAL_STORAGE = 1<<18;
Suchi Amalapurapuaf8e9f42010-01-12 10:17:28 -0800311
312 /**
Dianne Hackborn14cee9f2010-04-23 17:51:26 -0700313 * Value for {@link #flags}: true when the application's window can be
314 * increased in size for extra large screens. Corresponds to
315 * {@link android.R.styleable#AndroidManifestSupportsScreens_xlargeScreens
Dianne Hackborn22ec9ab2010-04-29 17:56:03 -0700316 * android:xlargeScreens}.
Dianne Hackborn14cee9f2010-04-23 17:51:26 -0700317 */
318 public static final int FLAG_SUPPORTS_XLARGE_SCREENS = 1<<19;
319
320 /**
Dianne Hackborn3b81bc12011-01-15 11:50:52 -0800321 * Value for {@link #flags}: true when the application has requested a
322 * large heap for its processes. Corresponds to
323 * {@link android.R.styleable#AndroidManifestApplication_largeHeap
324 * android:largeHeap}.
Jason parksa3cdaa52011-01-13 14:15:43 -0600325 */
Dianne Hackborn3b81bc12011-01-15 11:50:52 -0800326 public static final int FLAG_LARGE_HEAP = 1<<20;
Jason parksa3cdaa52011-01-13 14:15:43 -0600327
328 /**
Dianne Hackborne7f97212011-02-24 14:40:20 -0800329 * Value for {@link #flags}: true if this application's package is in
330 * the stopped state.
331 */
332 public static final int FLAG_STOPPED = 1<<21;
333
334 /**
Fabrice Di Meglio59dfce82012-04-02 16:17:20 -0700335 * Value for {@link #flags}: true when the application is willing to support
336 * RTL (right to left). All activities will inherit this value.
337 *
338 * Set from the {@link android.R.attr#supportsRtl} attribute in the
339 * activity's manifest.
340 *
341 * Default value is false (no support for RTL).
342 */
343 public static final int FLAG_SUPPORTS_RTL = 1<<22;
344
345 /**
Dianne Hackborn7767eac2012-08-23 18:25:40 -0700346 * Value for {@link #flags}: true if the application is currently
347 * installed for the calling user.
348 */
349 public static final int FLAG_INSTALLED = 1<<23;
350
351 /**
Dianne Hackborn5e03e2c2012-09-06 14:21:19 -0700352 * Value for {@link #flags}: true if the application only has its
353 * data installed; the application package itself does not currently
354 * exist on the device.
355 */
356 public static final int FLAG_IS_DATA_ONLY = 1<<24;
357
358 /**
Jeff Sharkey9bc89af2017-01-11 11:25:50 -0700359 * Value for {@link #flags}: true if the application was declared to be a
360 * game, or false if it is a non-game application.
361 *
362 * @deprecated use {@link #CATEGORY_GAME} instead.
Jose Lima12d0b4c2014-03-14 16:55:12 -0700363 */
Jeff Sharkey9bc89af2017-01-11 11:25:50 -0700364 @Deprecated
Jose Lima12d0b4c2014-03-14 16:55:12 -0700365 public static final int FLAG_IS_GAME = 1<<25;
366
367 /**
Christopher Tated1de2562014-06-17 17:12:35 -0700368 * Value for {@link #flags}: {@code true} if the application asks that only
369 * full-data streaming backups of its data be performed even though it defines
370 * a {@link android.app.backup.BackupAgent BackupAgent}, which normally
371 * indicates that the app will manage its backed-up data via incremental
372 * key/value updates.
373 */
374 public static final int FLAG_FULL_BACKUP_ONLY = 1<<26;
375
376 /**
Alex Klyubin01a959d2015-03-18 10:05:45 -0700377 * Value for {@link #flags}: {@code true} if the application may use cleartext network traffic
378 * (e.g., HTTP rather than HTTPS; WebSockets rather than WebSockets Secure; XMPP, IMAP, STMP
379 * without STARTTLS or TLS). If {@code false}, the app declares that it does not intend to use
380 * cleartext network traffic, in which case platform components (e.g., HTTP stacks,
Alex Klyubinfbf45992015-04-21 13:44:29 -0700381 * {@code DownloadManager}, {@code MediaPlayer}) will refuse app's requests to use cleartext
382 * traffic. Third-party libraries are encouraged to honor this flag as well.
383 *
Nate Fischer6a2a5412017-10-23 18:02:41 -0700384 * <p>NOTE: {@code WebView} honors this flag for applications targeting API level 26 and up.
Alex Klyubinfbf45992015-04-21 13:44:29 -0700385 *
Chad Brubaker2df5ba72016-04-11 13:31:24 -0700386 * <p>This flag is ignored on Android N and above if an Android Network Security Config is
387 * present.
388 *
Alex Klyubinfbf45992015-04-21 13:44:29 -0700389 * <p>This flag comes from
390 * {@link android.R.styleable#AndroidManifestApplication_usesCleartextTraffic
391 * android:usesCleartextTraffic} of the &lt;application&gt; tag.
Alex Klyubin01a959d2015-03-18 10:05:45 -0700392 */
393 public static final int FLAG_USES_CLEARTEXT_TRAFFIC = 1<<27;
394
395 /**
Dmitriy Ivanovff193d62014-09-30 15:10:48 -0700396 * When set installer extracts native libs from .apk files.
397 */
398 public static final int FLAG_EXTRACT_NATIVE_LIBS = 1<<28;
399
400 /**
Alan Viveretted70b9e72015-05-27 14:29:20 -0700401 * Value for {@link #flags}: {@code true} when the application's rendering
402 * should be hardware accelerated.
403 */
404 public static final int FLAG_HARDWARE_ACCELERATED = 1<<29;
405
406 /**
Andrei Stingaceanu1e283912015-11-26 15:26:28 +0000407 * Value for {@link #flags}: true if this application's package is in
408 * the suspended state.
409 */
410 public static final int FLAG_SUSPENDED = 1<<30;
411
412 /**
Narayan Kamath589a1bc2014-07-03 14:43:26 +0100413 * Value for {@link #flags}: true if code from this application will need to be
414 * loaded into other applications' processes. On devices that support multiple
415 * instruction sets, this implies the code might be loaded into a process that's
416 * using any of the devices supported instruction sets.
417 *
418 * <p> The system might treat such applications specially, for eg., by
419 * extracting the application's native libraries for all supported instruction
420 * sets or by compiling the application's dex code for all supported instruction
421 * sets.
422 */
423 public static final int FLAG_MULTIARCH = 1 << 31;
Amith Yamasani655d0e22013-06-12 14:19:10 -0700424
425 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800426 * Flags associated with the application. Any combination of
427 * {@link #FLAG_SYSTEM}, {@link #FLAG_DEBUGGABLE}, {@link #FLAG_HAS_CODE},
428 * {@link #FLAG_PERSISTENT}, {@link #FLAG_FACTORY_TEST}, and
429 * {@link #FLAG_ALLOW_TASK_REPARENTING}
Dianne Hackborn851a5412009-05-08 12:06:44 -0700430 * {@link #FLAG_ALLOW_CLEAR_USER_DATA}, {@link #FLAG_UPDATED_SYSTEM_APP},
Dianne Hackborn723738c2009-06-25 19:48:04 -0700431 * {@link #FLAG_TEST_ONLY}, {@link #FLAG_SUPPORTS_SMALL_SCREENS},
432 * {@link #FLAG_SUPPORTS_NORMAL_SCREENS},
Dianne Hackborn14cee9f2010-04-23 17:51:26 -0700433 * {@link #FLAG_SUPPORTS_LARGE_SCREENS}, {@link #FLAG_SUPPORTS_XLARGE_SCREENS},
434 * {@link #FLAG_RESIZEABLE_FOR_SCREENS},
Dianne Hackborn7767eac2012-08-23 18:25:40 -0700435 * {@link #FLAG_SUPPORTS_SCREEN_DENSITIES}, {@link #FLAG_VM_SAFE_MODE},
Alex Klyubinb9f8a522015-02-03 11:12:59 -0800436 * {@link #FLAG_ALLOW_BACKUP}, {@link #FLAG_KILL_AFTER_RESTORE},
437 * {@link #FLAG_RESTORE_ANY_VERSION}, {@link #FLAG_EXTERNAL_STORAGE},
438 * {@link #FLAG_LARGE_HEAP}, {@link #FLAG_STOPPED},
439 * {@link #FLAG_SUPPORTS_RTL}, {@link #FLAG_INSTALLED},
440 * {@link #FLAG_IS_DATA_ONLY}, {@link #FLAG_IS_GAME},
Alex Klyubin7cb000f2015-03-26 11:00:04 -0700441 * {@link #FLAG_FULL_BACKUP_ONLY}, {@link #FLAG_USES_CLEARTEXT_TRAFFIC},
442 * {@link #FLAG_MULTIARCH}.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800443 */
444 public int flags = 0;
Amith Yamasani655d0e22013-06-12 14:19:10 -0700445
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800446 /**
Alex Klyubinb9f8a522015-02-03 11:12:59 -0800447 * Value for {@link #privateFlags}: true if the application is hidden via restrictions and for
448 * most purposes is considered as not installed.
449 * {@hide}
450 */
451 public static final int PRIVATE_FLAG_HIDDEN = 1<<0;
452
453 /**
454 * Value for {@link #privateFlags}: set to <code>true</code> if the application
455 * has reported that it is heavy-weight, and thus can not participate in
456 * the normal application lifecycle.
457 *
458 * <p>Comes from the
459 * android.R.styleable#AndroidManifestApplication_cantSaveState
460 * attribute of the &lt;application&gt; tag.
461 *
462 * {@hide}
463 */
464 public static final int PRIVATE_FLAG_CANT_SAVE_STATE = 1<<1;
465
466 /**
Alex Klyubinb9f8a522015-02-03 11:12:59 -0800467 * Value for {@link #privateFlags}: set to {@code true} if the application
468 * is permitted to hold privileged permissions.
469 *
470 * {@hide}
471 */
Jeff Sharkeyc6091162018-06-29 17:15:40 -0600472 @TestApi
Alex Klyubinb9f8a522015-02-03 11:12:59 -0800473 public static final int PRIVATE_FLAG_PRIVILEGED = 1<<3;
474
475 /**
Svet Ganov2acf0632015-11-24 19:10:59 -0800476 * Value for {@link #privateFlags}: {@code true} if the application has any IntentFiler
477 * with some data URI using HTTP or HTTPS with an associated VIEW action.
Fabrice Di Megliod3d8a322015-04-01 15:58:47 -0700478 *
479 * {@hide}
480 */
481 public static final int PRIVATE_FLAG_HAS_DOMAIN_URLS = 1<<4;
482
483 /**
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600484 * When set, the default data storage directory for this app is pointed at
485 * the device-protected location.
Jeff Sharkey15447792015-11-05 16:18:51 -0800486 *
487 * @hide
488 */
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600489 public static final int PRIVATE_FLAG_DEFAULT_TO_DEVICE_PROTECTED_STORAGE = 1 << 5;
Jeff Sharkey15447792015-11-05 16:18:51 -0800490
491 /**
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600492 * When set, assume that all components under the given app are direct boot
Jeff Sharkeyf9fc6d62015-11-08 16:46:05 -0800493 * aware, unless otherwise specified.
494 *
495 * @hide
496 */
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600497 public static final int PRIVATE_FLAG_DIRECT_BOOT_AWARE = 1 << 6;
Jeff Sharkeyf9fc6d62015-11-08 16:46:05 -0800498
499 /**
Todd Kennedybe0b8892017-02-15 14:13:52 -0800500 * Value for {@link #privateFlags}: {@code true} if the application is installed
501 * as instant app.
502 *
503 * @hide
Chad Brubaker4389c232016-11-04 14:50:50 -0700504 */
Todd Kennedybe0b8892017-02-15 14:13:52 -0800505 public static final int PRIVATE_FLAG_INSTANT = 1 << 7;
Chad Brubaker4389c232016-11-04 14:50:50 -0700506
507 /**
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600508 * When set, at least one component inside this application is direct boot
509 * aware.
Jeff Sharkey8924e872015-11-30 12:52:10 -0700510 *
511 * @hide
512 */
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600513 public static final int PRIVATE_FLAG_PARTIALLY_DIRECT_BOOT_AWARE = 1 << 8;
Jeff Sharkey8924e872015-11-30 12:52:10 -0700514
Fyodor Kupolovf99104d2015-12-14 11:31:29 -0800515
516 /**
Fyodor Kupolovbdbc9692015-12-14 13:11:13 -0800517 * When set, signals that the application is required for the system user and should not be
518 * uninstalled.
519 *
520 * @hide
521 */
Chad Brubaker4389c232016-11-04 14:50:50 -0700522 public static final int PRIVATE_FLAG_REQUIRED_FOR_SYSTEM_USER = 1 << 9;
Fyodor Kupolovbdbc9692015-12-14 13:11:13 -0800523
524 /**
Wale Ogunwalee633eb02017-03-30 12:57:29 -0700525 * When set, the application explicitly requested that its activities be resizeable by default.
Wale Ogunwale6afdf912016-01-30 13:01:33 -0800526 * @see android.R.styleable#AndroidManifestActivity_resizeableActivity
527 *
528 * @hide
529 */
Wale Ogunwalee633eb02017-03-30 12:57:29 -0700530 public static final int PRIVATE_FLAG_ACTIVITIES_RESIZE_MODE_RESIZEABLE = 1 << 10;
531
532 /**
533 * When set, the application explicitly requested that its activities *not* be resizeable by
534 * default.
535 * @see android.R.styleable#AndroidManifestActivity_resizeableActivity
536 *
537 * @hide
538 */
539 public static final int PRIVATE_FLAG_ACTIVITIES_RESIZE_MODE_UNRESIZEABLE = 1 << 11;
Wale Ogunwale72a73e32016-10-13 12:16:39 -0700540
541 /**
542 * The application isn't requesting explicitly requesting for its activities to be resizeable or
543 * non-resizeable by default. So, we are making it activities resizeable by default based on the
544 * target SDK version of the app.
545 * @see android.R.styleable#AndroidManifestActivity_resizeableActivity
546 *
547 * NOTE: This only affects apps with target SDK >= N where the resizeableActivity attribute was
548 * introduced. It shouldn't be confused with {@link ActivityInfo#RESIZE_MODE_FORCE_RESIZEABLE}
549 * where certain pre-N apps are forced to the resizeable.
550 *
551 * @hide
552 */
Wale Ogunwalee633eb02017-03-30 12:57:29 -0700553 public static final int PRIVATE_FLAG_ACTIVITIES_RESIZE_MODE_RESIZEABLE_VIA_SDK_VERSION =
554 1 << 12;
Wale Ogunwale6afdf912016-01-30 13:01:33 -0800555
556 /**
Christopher Tate43fbc5f2016-02-17 18:00:48 -0800557 * Value for {@link #privateFlags}: {@code true} means the OS should go ahead and
558 * run full-data backup operations for the app even when it is in a
559 * foreground-equivalent run state. Defaults to {@code false} if unspecified.
560 * @hide
561 */
Wale Ogunwalee633eb02017-03-30 12:57:29 -0700562 public static final int PRIVATE_FLAG_BACKUP_IN_FOREGROUND = 1 << 13;
Christopher Tate43fbc5f2016-02-17 18:00:48 -0800563
564 /**
Svet Ganov67882122016-12-11 16:36:34 -0800565 * Value for {@link #privateFlags}: {@code true} means this application
566 * contains a static shared library. Defaults to {@code false} if unspecified.
567 * @hide
568 */
Wale Ogunwalee633eb02017-03-30 12:57:29 -0700569 public static final int PRIVATE_FLAG_STATIC_SHARED_LIBRARY = 1 << 14;
Svet Ganov67882122016-12-11 16:36:34 -0800570
571 /**
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700572 * Value for {@link #privateFlags}: When set, the application will only have its splits loaded
Adam Lesinski4e862812016-11-21 16:02:24 -0800573 * if they are required to load a component. Splits can be loaded on demand using the
574 * {@link Context#createContextForSplit(String)} API.
575 * @hide
576 */
Wale Ogunwalee633eb02017-03-30 12:57:29 -0700577 public static final int PRIVATE_FLAG_ISOLATED_SPLIT_LOADING = 1 << 15;
Adam Lesinski4e862812016-11-21 16:02:24 -0800578
579 /**
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700580 * Value for {@link #privateFlags}: When set, the application was installed as
581 * a virtual preload.
582 * @hide
Alex Klyubinb9f8a522015-02-03 11:12:59 -0800583 */
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700584 public static final int PRIVATE_FLAG_VIRTUAL_PRELOAD = 1 << 16;
585
Svet Ganov087dce22017-09-07 15:42:16 -0700586 /**
Mathew Inwood9d895432018-04-04 16:08:21 +0100587 * Value for {@link #privateFlags}: whether this app is pre-installed on the
Svet Ganov087dce22017-09-07 15:42:16 -0700588 * OEM partition of the system image.
589 * @hide
590 */
591 public static final int PRIVATE_FLAG_OEM = 1 << 17;
592
Jiyong Park002fdbd2017-02-13 20:50:31 +0900593 /**
Mathew Inwood9d895432018-04-04 16:08:21 +0100594 * Value for {@link #privateFlags}: whether this app is pre-installed on the
Jiyong Park002fdbd2017-02-13 20:50:31 +0900595 * vendor partition of the system image.
596 * @hide
597 */
598 public static final int PRIVATE_FLAG_VENDOR = 1 << 18;
599
Jaekyun Seok1713d9e2018-01-12 21:47:26 +0900600 /**
Mathew Inwood9d895432018-04-04 16:08:21 +0100601 * Value for {@link #privateFlags}: whether this app is pre-installed on the
Jaekyun Seok1713d9e2018-01-12 21:47:26 +0900602 * product partition of the system image.
603 * @hide
604 */
605 public static final int PRIVATE_FLAG_PRODUCT = 1 << 19;
606
Mathew Inwood9d895432018-04-04 16:08:21 +0100607 /**
David Brazdila5b4df22018-09-06 09:49:14 +0100608 * Value for {@link #privateFlags}: whether this app is signed with the
609 * platform key.
610 * @hide
611 */
612 public static final int PRIVATE_FLAG_SIGNED_WITH_PLATFORM_KEY = 1 << 20;
613
614 /**
Dario Freni2bef1762018-06-01 14:02:08 +0100615 * Value for {@link #privateFlags}: whether this app is pre-installed on the
616 * google partition of the system image.
617 * @hide
618 */
619 public static final int PRIVATE_FLAG_PRODUCT_SERVICES = 1 << 21;
620
621 /**
David Brazdila5b4df22018-09-06 09:49:14 +0100622 * Indicates whether this package requires access to non-SDK APIs.
623 * Only system apps and tests are allowed to use this property.
Mathew Inwood9d895432018-04-04 16:08:21 +0100624 * @hide
625 */
David Brazdila5b4df22018-09-06 09:49:14 +0100626 public static final int PRIVATE_FLAG_USES_NON_SDK_API = 1 << 22;
Mathew Inwood9d895432018-04-04 16:08:21 +0100627
Chris Craikce030282018-10-16 14:33:11 -0700628 /**
629 * Indicates whether this application can be profiled by the shell user,
630 * even when running on a device that is running in user mode.
631 * @hide
632 */
633 public static final int PRIVATE_FLAG_PROFILEABLE_BY_SHELL = 1 << 23;
634
Philip P. Moltmannae4a4b92018-12-12 11:28:57 -0800635 /**
636 * Indicates whether this package requires access to non-SDK APIs.
637 * Only system apps and tests are allowed to use this property.
638 * @hide
639 */
640 public static final int PRIVATE_FLAG_HAS_FRAGILE_USER_DATA = 1 << 24;
641
Victor Hsiehe7b5a8d2018-11-16 10:27:06 -0800642 /**
Victor Hsiehfa9df0b2019-01-29 12:48:36 -0800643 * Indicates whether this application wants to use the embedded dex in the APK, rather than
644 * extracted or locally compiled variants. This keeps the dex code protected by the APK
645 * signature. Such apps will always run in JIT mode (same when they are first installed), and
646 * the system will never generate ahead-of-time compiled code for them. Depending on the app's
647 * workload, there may be some run time performance change, noteably the cold start time.
Victor Hsiehe7b5a8d2018-11-16 10:27:06 -0800648 *
649 * @hide
650 */
Victor Hsiehfa9df0b2019-01-29 12:48:36 -0800651 public static final int PRIVATE_FLAG_USE_EMBEDDED_DEX = 1 << 25;
Victor Hsiehe7b5a8d2018-11-16 10:27:06 -0800652
Ruslan Tkhakokhov75674852019-01-22 13:35:00 +0000653 /**
654 * Value for {@link #privateFlags}: indicates whether this application's data will be cleared
655 * on a failed restore.
656 *
657 * <p>Comes from the
658 * android.R.styleable#AndroidManifestApplication_allowClearUserDataOnFailedRestore attribute
659 * of the &lt;application&gt; tag.
660 *
661 * @hide
662 */
663 public static final int PRIVATE_FLAG_ALLOW_CLEAR_USER_DATA_ON_FAILED_RESTORE = 1 << 26;
664
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700665 /** @hide */
666 @IntDef(flag = true, prefix = { "PRIVATE_FLAG_" }, value = {
Svet Ganov087dce22017-09-07 15:42:16 -0700667 PRIVATE_FLAG_ACTIVITIES_RESIZE_MODE_RESIZEABLE,
668 PRIVATE_FLAG_ACTIVITIES_RESIZE_MODE_RESIZEABLE_VIA_SDK_VERSION,
669 PRIVATE_FLAG_ACTIVITIES_RESIZE_MODE_UNRESIZEABLE,
670 PRIVATE_FLAG_BACKUP_IN_FOREGROUND,
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700671 PRIVATE_FLAG_CANT_SAVE_STATE,
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700672 PRIVATE_FLAG_DEFAULT_TO_DEVICE_PROTECTED_STORAGE,
673 PRIVATE_FLAG_DIRECT_BOOT_AWARE,
Svet Ganov087dce22017-09-07 15:42:16 -0700674 PRIVATE_FLAG_HAS_DOMAIN_URLS,
675 PRIVATE_FLAG_HIDDEN,
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700676 PRIVATE_FLAG_INSTANT,
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700677 PRIVATE_FLAG_ISOLATED_SPLIT_LOADING,
Svet Ganov087dce22017-09-07 15:42:16 -0700678 PRIVATE_FLAG_OEM,
679 PRIVATE_FLAG_PARTIALLY_DIRECT_BOOT_AWARE,
Victor Hsiehfa9df0b2019-01-29 12:48:36 -0800680 PRIVATE_FLAG_USE_EMBEDDED_DEX,
Svet Ganov087dce22017-09-07 15:42:16 -0700681 PRIVATE_FLAG_PRIVILEGED,
Jaekyun Seok1713d9e2018-01-12 21:47:26 +0900682 PRIVATE_FLAG_PRODUCT,
Dario Freni2bef1762018-06-01 14:02:08 +0100683 PRIVATE_FLAG_PRODUCT_SERVICES,
Chris Craikce030282018-10-16 14:33:11 -0700684 PRIVATE_FLAG_PROFILEABLE_BY_SHELL,
Svet Ganov087dce22017-09-07 15:42:16 -0700685 PRIVATE_FLAG_REQUIRED_FOR_SYSTEM_USER,
Mathew Inwood9d895432018-04-04 16:08:21 +0100686 PRIVATE_FLAG_SIGNED_WITH_PLATFORM_KEY,
Svet Ganov087dce22017-09-07 15:42:16 -0700687 PRIVATE_FLAG_STATIC_SHARED_LIBRARY,
Jiyong Park002fdbd2017-02-13 20:50:31 +0900688 PRIVATE_FLAG_VENDOR,
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700689 PRIVATE_FLAG_VIRTUAL_PRELOAD,
Philip P. Moltmannae4a4b92018-12-12 11:28:57 -0800690 PRIVATE_FLAG_HAS_FRAGILE_USER_DATA,
Ruslan Tkhakokhov75674852019-01-22 13:35:00 +0000691 PRIVATE_FLAG_ALLOW_CLEAR_USER_DATA_ON_FAILED_RESTORE
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700692 })
693 @Retention(RetentionPolicy.SOURCE)
694 public @interface ApplicationInfoPrivateFlags {}
695
696 /**
697 * Private/hidden flags. See {@code PRIVATE_FLAG_...} constants.
698 * @hide
699 */
Jeff Sharkeyc6091162018-06-29 17:15:40 -0600700 @TestApi
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -0700701 public @ApplicationInfoPrivateFlags int privateFlags;
Alex Klyubinb9f8a522015-02-03 11:12:59 -0800702
703 /**
Clara Bayarri4b5a4d22017-01-27 20:15:45 +0000704 * @hide
705 */
706 public static final String METADATA_PRELOADED_FONTS = "preloaded_fonts";
707
708 /**
Dianne Hackborndf6e9802011-05-26 14:20:23 -0700709 * The required smallest screen width the application can run on. If 0,
710 * nothing has been specified. Comes from
711 * {@link android.R.styleable#AndroidManifestSupportsScreens_requiresSmallestWidthDp
712 * android:requiresSmallestWidthDp} attribute of the &lt;supports-screens&gt; tag.
713 */
714 public int requiresSmallestWidthDp = 0;
715
716 /**
717 * The maximum smallest screen width the application is designed for. If 0,
718 * nothing has been specified. Comes from
719 * {@link android.R.styleable#AndroidManifestSupportsScreens_compatibleWidthLimitDp
720 * android:compatibleWidthLimitDp} attribute of the &lt;supports-screens&gt; tag.
721 */
722 public int compatibleWidthLimitDp = 0;
723
724 /**
Dianne Hackborn2762ff32011-06-01 21:27:05 -0700725 * The maximum smallest screen width the application will work on. If 0,
726 * nothing has been specified. Comes from
727 * {@link android.R.styleable#AndroidManifestSupportsScreens_largestWidthLimitDp
728 * android:largestWidthLimitDp} attribute of the &lt;supports-screens&gt; tag.
729 */
730 public int largestWidthLimitDp = 0;
731
Jeff Sharkey61128602017-01-26 17:07:35 -0700732 /**
Wale Ogunwale55ddf8f2017-03-20 08:56:38 -0700733 * Value indicating the maximum aspect ratio the application supports.
734 * <p>
735 * 0 means unset.
736 * @See {@link android.R.attr#maxAspectRatio}.
737 * @hide
738 */
739 public float maxAspectRatio;
740
Adrian Roos917791e2018-11-28 16:30:44 +0100741 /**
742 * Value indicating the minimum aspect ratio the application supports.
743 * <p>
744 * 0 means unset.
745 * @see {@link android.R.attr#minAspectRatio}.
746 * @hide
747 */
748 public float minAspectRatio;
749
Jeff Sharkey789a8fc2017-04-16 13:18:35 -0600750 /** @removed */
751 @Deprecated
752 public String volumeUuid;
753
Wale Ogunwale55ddf8f2017-03-20 08:56:38 -0700754 /**
Jeff Sharkey61128602017-01-26 17:07:35 -0700755 * UUID of the storage volume on which this application is being hosted. For
756 * apps hosted on the default internal storage at
Jeff Sharkey789a8fc2017-04-16 13:18:35 -0600757 * {@link Environment#getDataDirectory()}, the UUID value is
758 * {@link StorageManager#UUID_DEFAULT}.
Jeff Sharkey61128602017-01-26 17:07:35 -0700759 */
Jeff Sharkey789a8fc2017-04-16 13:18:35 -0600760 public UUID storageUuid;
Jeff Sharkey61128602017-01-26 17:07:35 -0700761
Jeff Sharkeyb2b9ab82015-04-05 21:10:42 -0700762 /** {@hide} */
Mathew Inwood5c0d3542018-08-14 13:54:31 +0100763 @UnsupportedAppUsage
Jeff Sharkeyd7460572014-07-06 20:44:55 -0700764 public String scanSourceDir;
765 /** {@hide} */
Mathew Inwood5c0d3542018-08-14 13:54:31 +0100766 @UnsupportedAppUsage
Jeff Sharkeyd7460572014-07-06 20:44:55 -0700767 public String scanPublicSourceDir;
768
Dianne Hackborn2762ff32011-06-01 21:27:05 -0700769 /**
Jeff Sharkey8a4c9722014-06-16 13:48:42 -0700770 * Full path to the base APK for this application.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800771 */
772 public String sourceDir;
773
774 /**
Jeff Sharkey8a4c9722014-06-16 13:48:42 -0700775 * Full path to the publicly available parts of {@link #sourceDir},
776 * including resources and manifest. This may be different from
777 * {@link #sourceDir} if an application is forward locked.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800778 */
779 public String publicSourceDir;
Jeff Sharkey8a4c9722014-06-16 13:48:42 -0700780
781 /**
Adam Lesinski4e862812016-11-21 16:02:24 -0800782 * The names of all installed split APKs, ordered lexicographically.
783 */
784 public String[] splitNames;
785
786 /**
787 * Full paths to zero or more split APKs, indexed by the same order as {@link #splitNames}.
Jeff Sharkey8a4c9722014-06-16 13:48:42 -0700788 */
789 public String[] splitSourceDirs;
790
791 /**
792 * Full path to the publicly available parts of {@link #splitSourceDirs},
793 * including resources and manifest. This may be different from
794 * {@link #splitSourceDirs} if an application is forward locked.
Adam Lesinski4e862812016-11-21 16:02:24 -0800795 *
796 * @see #splitSourceDirs
Jeff Sharkey8a4c9722014-06-16 13:48:42 -0700797 */
798 public String[] splitPublicSourceDirs;
799
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800800 /**
Adam Lesinski4e862812016-11-21 16:02:24 -0800801 * Maps the dependencies between split APKs. All splits implicitly depend on the base APK.
802 *
803 * Available since platform version O.
804 *
805 * Only populated if the application opts in to isolated split loading via the
806 * {@link android.R.attr.isolatedSplits} attribute in the &lt;manifest&gt; tag of the app's
807 * AndroidManifest.xml.
808 *
809 * The keys and values are all indices into the {@link #splitNames}, {@link #splitSourceDirs},
810 * and {@link #splitPublicSourceDirs} arrays.
Adam Lesinski1665d0f2017-03-10 14:46:57 -0800811 * Each key represents a split and its value is an array of splits. The first element of this
812 * array is the parent split, and the rest are configuration splits. These configuration splits
813 * have no dependencies themselves.
Adam Lesinski4e862812016-11-21 16:02:24 -0800814 * Cycles do not exist because they are illegal and screened for during installation.
815 *
816 * May be null if no splits are installed, or if no dependencies exist between them.
Calin Juravleda098152017-09-01 17:30:01 -0700817 *
818 * NOTE: Any change to the way split dependencies are stored must update the logic that
819 * creates the class loader context for dexopt (DexoptUtils#getClassLoaderContexts).
820 *
Adam Lesinski4e862812016-11-21 16:02:24 -0800821 * @hide
822 */
Adam Lesinski1665d0f2017-03-10 14:46:57 -0800823 public SparseArray<int[]> splitDependencies;
Adam Lesinski4e862812016-11-21 16:02:24 -0800824
825 /**
826 * Full paths to the locations of extra resource packages (runtime overlays)
827 * this application uses. This field is only used if there are extra resource
828 * packages, otherwise it is null.
829 *
Kenny Rootace5a3f2010-02-05 12:59:28 -0800830 * {@hide}
Kenny Rootd1ab0162010-01-21 17:27:14 -0800831 */
Mathew Inwood5c0d3542018-08-14 13:54:31 +0100832 @UnsupportedAppUsage
Kenny Rootd1ab0162010-01-21 17:27:14 -0800833 public String[] resourceDirs;
834
835 /**
Jeff Vander Stoepcab36392018-03-06 15:52:22 -0800836 * String retrieved from the seinfo tag found in selinux policy. This value can be set through
837 * the mac_permissions.xml policy construct. This value is used for setting an SELinux security
838 * context on the process as well as its data directory.
Robert Craig0f40dc92013-03-25 06:33:03 -0400839 *
840 * {@hide}
841 */
Jeff Vander Stoepcab36392018-03-06 15:52:22 -0800842 public String seInfo;
Todd Kennedybe0b8892017-02-15 14:13:52 -0800843
844 /**
845 * The seinfo tag generated per-user. This value may change based upon the
846 * user's configuration. For example, when an instant app is installed for
847 * a user. It is an error if this field is ever {@code null} when trying to
848 * start a new process.
849 * <p>NOTE: We need to separate this out because we modify per-user values
850 * multiple times. This needs to be refactored since we're performing more
851 * work than necessary and these values should only be set once. When that
852 * happens, we can merge the per-user value with the seInfo state above.
853 *
854 * {@hide}
855 */
856 public String seInfoUser;
Robert Craig0f40dc92013-03-25 06:33:03 -0400857
858 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800859 * Paths to all shared libraries this application is linked against. This
860 * field is only set if the {@link PackageManager#GET_SHARED_LIBRARY_FILES
861 * PackageManager.GET_SHARED_LIBRARY_FILES} flag was used when retrieving
862 * the structure.
863 */
864 public String[] sharedLibraryFiles;
Nicolas Geoffray8d144eb2018-11-15 12:59:52 +0000865
866 /**
867 * List of all shared libraries this application is linked against. This
868 * field is only set if the {@link PackageManager#GET_SHARED_LIBRARY_FILES
869 * PackageManager.GET_SHARED_LIBRARY_FILES} flag was used when retrieving
870 * the structure.
871 *
872 * {@hide}
873 */
874 public List<SharedLibraryInfo> sharedLibraryInfos;
875
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800876 /**
Jeff Sharkey7a30a302015-12-08 14:20:06 -0700877 * Full path to the default directory assigned to the package for its
878 * persistent data.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800879 */
880 public String dataDir;
Kenny Root85387d72010-08-26 10:13:11 -0700881
Jeff Sharkey7a30a302015-12-08 14:20:06 -0700882 /**
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600883 * Full path to the device-protected directory assigned to the package for
Jeff Sharkey7a30a302015-12-08 14:20:06 -0700884 * its persistent data.
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600885 *
886 * @see Context#createDeviceProtectedStorageContext()
Jeff Sharkey7a30a302015-12-08 14:20:06 -0700887 */
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600888 public String deviceProtectedDataDir;
889
Jeff Sharkey7a30a302015-12-08 14:20:06 -0700890 /**
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600891 * Full path to the credential-protected directory assigned to the package
Jeff Sharkey7a30a302015-12-08 14:20:06 -0700892 * for its persistent data.
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600893 *
894 * @hide
Jeff Sharkey7a30a302015-12-08 14:20:06 -0700895 */
Jeff Sharkey8a372a02016-03-16 16:25:45 -0600896 @SystemApi
897 public String credentialProtectedDataDir;
898
Kenny Root85387d72010-08-26 10:13:11 -0700899 /**
900 * Full path to the directory where native JNI libraries are stored.
Kenny Root85387d72010-08-26 10:13:11 -0700901 */
902 public String nativeLibraryDir;
903
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800904 /**
Narayan Kamath7dba6eb2014-07-16 08:53:30 +0100905 * Full path where unpacked native libraries for {@link #secondaryCpuAbi}
906 * are stored, if present.
907 *
908 * The main reason this exists is for bundled multi-arch apps, where
909 * it's not trivial to calculate the location of libs for the secondary abi
910 * given the location of the primary.
911 *
912 * TODO: Change the layout of bundled installs so that we can use
913 * nativeLibraryRootDir & nativeLibraryRootRequiresIsa there as well.
914 * (e.g {@code [ "/system/app-lib/Foo/arm", "/system/app-lib/Foo/arm64" ]}
915 * instead of {@code [ "/system/lib/Foo", "/system/lib64/Foo" ]}.
916 *
917 * @hide
918 */
Mathew Inwood5c0d3542018-08-14 13:54:31 +0100919 @UnsupportedAppUsage
Narayan Kamath7dba6eb2014-07-16 08:53:30 +0100920 public String secondaryNativeLibraryDir;
921
922 /**
Jeff Sharkey84f12942014-07-10 17:48:11 -0700923 * The root path where unpacked native libraries are stored.
924 * <p>
925 * When {@link #nativeLibraryRootRequiresIsa} is set, the libraries are
926 * placed in ISA-specific subdirectories under this path, otherwise the
927 * libraries are placed directly at this path.
Narayan Kamathff110bd2014-07-04 18:30:45 +0100928 *
Jeff Sharkey84f12942014-07-10 17:48:11 -0700929 * @hide
Narayan Kamathff110bd2014-07-04 18:30:45 +0100930 */
Mathew Inwood5c0d3542018-08-14 13:54:31 +0100931 @UnsupportedAppUsage
Jeff Sharkey84f12942014-07-10 17:48:11 -0700932 public String nativeLibraryRootDir;
933
934 /**
935 * Flag indicating that ISA must be appended to
936 * {@link #nativeLibraryRootDir} to be useful.
937 *
938 * @hide
939 */
940 public boolean nativeLibraryRootRequiresIsa;
Narayan Kamathff110bd2014-07-04 18:30:45 +0100941
942 /**
943 * The primary ABI that this application requires, This is inferred from the ABIs
Ramin Zaghiff0c4702014-04-01 15:02:29 +0100944 * of the native JNI libraries the application bundles. Will be {@code null}
945 * if this application does not require any particular ABI.
946 *
Narayan Kamathff110bd2014-07-04 18:30:45 +0100947 * If non-null, the application will always be launched with this ABI.
948 *
Ramin Zaghiff0c4702014-04-01 15:02:29 +0100949 * {@hide}
950 */
Mathew Inwood5c0d3542018-08-14 13:54:31 +0100951 @UnsupportedAppUsage
Narayan Kamathff110bd2014-07-04 18:30:45 +0100952 public String primaryCpuAbi;
953
954 /**
955 * The secondary ABI for this application. Might be non-null for multi-arch
956 * installs. The application itself never uses this ABI, but other applications that
957 * use its code might.
958 *
959 * {@hide}
960 */
Mathew Inwood5c0d3542018-08-14 13:54:31 +0100961 @UnsupportedAppUsage
Narayan Kamathff110bd2014-07-04 18:30:45 +0100962 public String secondaryCpuAbi;
963
964 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800965 * The kernel user-ID that has been assigned to this application;
966 * currently this is not a unique ID (multiple applications can have
967 * the same uid).
968 */
969 public int uid;
970
Mitsuru Oshima8d112672009-04-27 12:01:23 -0700971 /**
Todd Kennedy89d60182016-03-11 11:18:32 -0800972 * The minimum SDK version this application can run on. It will not run
973 * on earlier versions.
974 */
Todd Kennedy6e2e7f52016-05-02 14:56:45 -0700975 public int minSdkVersion;
Todd Kennedy89d60182016-03-11 11:18:32 -0800976
977 /**
Dianne Hackborn3b3e1452009-09-24 19:22:12 -0700978 * The minimum SDK version this application targets. It may run on earlier
Dianne Hackborna96cbb42009-05-13 15:06:13 -0700979 * versions, but it knows how to work with any new behavior added at this
980 * version. Will be {@link android.os.Build.VERSION_CODES#CUR_DEVELOPMENT}
981 * if this is a development build and the app is targeting that. You should
982 * compare that this number is >= the SDK version number at which your
983 * behavior was introduced.
984 */
985 public int targetSdkVersion;
Dianne Hackborn8472e612014-01-23 17:57:20 -0800986
987 /**
988 * The app's declared version code.
989 * @hide
990 */
Patrick Baumannc2def582018-04-04 12:14:15 -0700991 public long longVersionCode;
992
993 /**
994 * An integer representation of the app's declared version code. This is being left in place as
995 * some apps were using reflection to access it before the move to long in
996 * {@link android.os.Build.VERSION_CODES#P}
997 * @deprecated Use {@link #longVersionCode} instead.
998 * @hide
999 */
1000 @Deprecated
Mathew Inwood5c0d3542018-08-14 13:54:31 +01001001 @UnsupportedAppUsage
Patrick Baumannc2def582018-04-04 12:14:15 -07001002 public int versionCode;
Dianne Hackborn8472e612014-01-23 17:57:20 -08001003
Dianne Hackborna96cbb42009-05-13 15:06:13 -07001004 /**
Alan Viveretteb6a25732017-11-21 14:49:24 -05001005 * The user-visible SDK version (ex. 26) of the framework against which the application claims
1006 * to have been compiled, or {@code 0} if not specified.
1007 * <p>
1008 * This property is the compile-time equivalent of
1009 * {@link android.os.Build.VERSION#CODENAME Build.VERSION.SDK_INT}.
1010 *
1011 * @hide For platform use only; we don't expect developers to need to read this value.
1012 */
1013 public int compileSdkVersion;
1014
1015 /**
1016 * The development codename (ex. "O", "REL") of the framework against which the application
1017 * claims to have been compiled, or {@code null} if not specified.
1018 * <p>
1019 * This property is the compile-time equivalent of
1020 * {@link android.os.Build.VERSION#CODENAME Build.VERSION.CODENAME}.
1021 *
1022 * @hide For platform use only; we don't expect developers to need to read this value.
1023 */
1024 @Nullable
1025 public String compileSdkVersionCodename;
1026
1027 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001028 * When false, indicates that all components within this application are
1029 * considered disabled, regardless of their individually set enabled status.
1030 */
1031 public boolean enabled = true;
1032
Dianne Hackborn54e570f2010-10-04 18:32:32 -07001033 /**
Dianne Hackborn0ac30312011-06-17 14:49:23 -07001034 * For convenient access to the current enabled setting of this app.
1035 * @hide
1036 */
Mathew Inwood5c0d3542018-08-14 13:54:31 +01001037 @UnsupportedAppUsage
Dianne Hackborn0ac30312011-06-17 14:49:23 -07001038 public int enabledSetting = PackageManager.COMPONENT_ENABLED_STATE_DEFAULT;
1039
1040 /**
Dianne Hackborn54e570f2010-10-04 18:32:32 -07001041 * For convenient access to package's install location.
1042 * @hide
1043 */
Mathew Inwood5c0d3542018-08-14 13:54:31 +01001044 @UnsupportedAppUsage
Dianne Hackborn54e570f2010-10-04 18:32:32 -07001045 public int installLocation = PackageInfo.INSTALL_LOCATION_UNSPECIFIED;
Jose Lima12d0b4c2014-03-14 16:55:12 -07001046
Chad Brubakerc845b2a2016-05-13 14:09:27 -07001047 /**
1048 * Resource file providing the application's Network Security Config.
1049 * @hide
1050 */
1051 public int networkSecurityConfigRes;
1052
Jeff Sharkey9bc89af2017-01-11 11:25:50 -07001053 /**
Todd Kennedy11e45072017-01-25 13:24:21 -08001054 * Version of the sandbox the application wants to run in.
1055 * @hide
1056 */
Patrick Baumann159cd022018-01-11 13:25:05 -08001057 @SystemApi
Todd Kennedy11e45072017-01-25 13:24:21 -08001058 public int targetSandboxVersion;
1059
1060 /**
Jason Monka80bfb52017-11-16 17:15:37 -05001061 * The factory of this package, as specified by the &lt;manifest&gt;
1062 * tag's {@link android.R.styleable#AndroidManifestApplication_appComponentFactory}
1063 * attribute.
1064 */
1065 public String appComponentFactory;
1066
1067 /**
Jeff Sharkey9bc89af2017-01-11 11:25:50 -07001068 * The category of this app. Categories are used to cluster multiple apps
1069 * together into meaningful groups, such as when summarizing battery,
1070 * network, or disk usage. Apps should only define this value when they fit
1071 * well into one of the specific categories.
1072 * <p>
1073 * Set from the {@link android.R.attr#appCategory} attribute in the
1074 * manifest. If the manifest doesn't define a category, this value may have
1075 * been provided by the installer via
1076 * {@link PackageManager#setApplicationCategoryHint(String, int)}.
1077 */
1078 public @Category int category = CATEGORY_UNDEFINED;
1079
1080 /** {@hide} */
Jeff Sharkey4347f812017-04-21 12:08:39 -06001081 @IntDef(prefix = { "CATEGORY_" }, value = {
Jeff Sharkey9bc89af2017-01-11 11:25:50 -07001082 CATEGORY_UNDEFINED,
1083 CATEGORY_GAME,
1084 CATEGORY_AUDIO,
1085 CATEGORY_VIDEO,
1086 CATEGORY_IMAGE,
1087 CATEGORY_SOCIAL,
1088 CATEGORY_NEWS,
1089 CATEGORY_MAPS,
1090 CATEGORY_PRODUCTIVITY
1091 })
1092 @Retention(RetentionPolicy.SOURCE)
1093 public @interface Category {
1094 }
1095
1096 /**
1097 * Value when category is undefined.
1098 *
1099 * @see #category
1100 */
1101 public static final int CATEGORY_UNDEFINED = -1;
1102
1103 /**
1104 * Category for apps which are primarily games.
1105 *
1106 * @see #category
1107 */
1108 public static final int CATEGORY_GAME = 0;
1109
1110 /**
1111 * Category for apps which primarily work with audio or music, such as music
1112 * players.
1113 *
1114 * @see #category
1115 */
1116 public static final int CATEGORY_AUDIO = 1;
1117
1118 /**
1119 * Category for apps which primarily work with video or movies, such as
1120 * streaming video apps.
1121 *
1122 * @see #category
1123 */
1124 public static final int CATEGORY_VIDEO = 2;
1125
1126 /**
1127 * Category for apps which primarily work with images or photos, such as
1128 * camera or gallery apps.
1129 *
1130 * @see #category
1131 */
1132 public static final int CATEGORY_IMAGE = 3;
1133
1134 /**
1135 * Category for apps which are primarily social apps, such as messaging,
Jeff Sharkeyd2b69102017-03-21 19:40:38 -06001136 * communication, email, or social network apps.
Jeff Sharkey9bc89af2017-01-11 11:25:50 -07001137 *
1138 * @see #category
1139 */
1140 public static final int CATEGORY_SOCIAL = 4;
1141
1142 /**
1143 * Category for apps which are primarily news apps, such as newspapers,
1144 * magazines, or sports apps.
1145 *
1146 * @see #category
1147 */
1148 public static final int CATEGORY_NEWS = 5;
1149
1150 /**
1151 * Category for apps which are primarily maps apps, such as navigation apps.
1152 *
1153 * @see #category
1154 */
1155 public static final int CATEGORY_MAPS = 6;
1156
1157 /**
1158 * Category for apps which are primarily productivity apps, such as cloud
1159 * storage or workplace apps.
1160 *
1161 * @see #category
1162 */
1163 public static final int CATEGORY_PRODUCTIVITY = 7;
1164
1165 /**
1166 * Return a concise, localized title for the given
1167 * {@link ApplicationInfo#category} value, or {@code null} for unknown
1168 * values such as {@link #CATEGORY_UNDEFINED}.
1169 *
1170 * @see #category
1171 */
1172 public static CharSequence getCategoryTitle(Context context, @Category int category) {
1173 switch (category) {
1174 case ApplicationInfo.CATEGORY_GAME:
1175 return context.getText(com.android.internal.R.string.app_category_game);
1176 case ApplicationInfo.CATEGORY_AUDIO:
1177 return context.getText(com.android.internal.R.string.app_category_audio);
1178 case ApplicationInfo.CATEGORY_VIDEO:
1179 return context.getText(com.android.internal.R.string.app_category_video);
1180 case ApplicationInfo.CATEGORY_IMAGE:
1181 return context.getText(com.android.internal.R.string.app_category_image);
1182 case ApplicationInfo.CATEGORY_SOCIAL:
1183 return context.getText(com.android.internal.R.string.app_category_social);
1184 case ApplicationInfo.CATEGORY_NEWS:
1185 return context.getText(com.android.internal.R.string.app_category_news);
1186 case ApplicationInfo.CATEGORY_MAPS:
1187 return context.getText(com.android.internal.R.string.app_category_maps);
1188 case ApplicationInfo.CATEGORY_PRODUCTIVITY:
1189 return context.getText(com.android.internal.R.string.app_category_productivity);
1190 default:
1191 return null;
1192 }
1193 }
1194
Narayan Kamathf9419f02017-06-15 11:35:38 +01001195 /** @hide */
1196 public String classLoaderName;
1197
1198 /** @hide */
1199 public String[] splitClassLoaderNames;
1200
Rhed Jaocd47c262018-06-13 11:16:16 +08001201 /** @hide */
1202 public boolean hiddenUntilInstalled;
1203
Martijn Coenenfb7caa92019-01-29 11:45:56 +01001204 /** @hide */
1205 public String zygotePreloadName;
1206
Mathew Inwoode3299532018-02-22 13:19:53 +00001207 /**
1208 * Represents the default policy. The actual policy used will depend on other properties of
1209 * the application, e.g. the target SDK version.
1210 * @hide
1211 */
1212 public static final int HIDDEN_API_ENFORCEMENT_DEFAULT = -1;
1213 /**
1214 * No API enforcement; the app can access the entire internal private API. Only for use by
1215 * system apps.
1216 * @hide
1217 */
David Brazdil06ae4b82018-11-02 18:01:45 +00001218 public static final int HIDDEN_API_ENFORCEMENT_DISABLED = 0;
Mathew Inwoode3299532018-02-22 13:19:53 +00001219 /**
Mathew Inwooda6d02fb2018-04-05 15:44:20 +01001220 * No API enforcement, but enable the detection logic and warnings. Observed behaviour is the
David Brazdil06ae4b82018-11-02 18:01:45 +00001221 * same as {@link #HIDDEN_API_ENFORCEMENT_DISABLED} but you may see warnings in the log when
1222 * APIs are accessed.
Mathew Inwoode3299532018-02-22 13:19:53 +00001223 * @hide
1224 * */
Mathew Inwooda6d02fb2018-04-05 15:44:20 +01001225 public static final int HIDDEN_API_ENFORCEMENT_JUST_WARN = 1;
Mathew Inwoode3299532018-02-22 13:19:53 +00001226 /**
1227 * Dark grey list enforcement. Enforces the dark grey and black lists
1228 * @hide
1229 */
David Brazdil06ae4b82018-11-02 18:01:45 +00001230 public static final int HIDDEN_API_ENFORCEMENT_ENABLED = 2;
Mathew Inwoode3299532018-02-22 13:19:53 +00001231
David Brazdil06ae4b82018-11-02 18:01:45 +00001232 private static final int HIDDEN_API_ENFORCEMENT_MIN = HIDDEN_API_ENFORCEMENT_DEFAULT;
1233 private static final int HIDDEN_API_ENFORCEMENT_MAX = HIDDEN_API_ENFORCEMENT_ENABLED;
Mathew Inwoode3299532018-02-22 13:19:53 +00001234
1235 /**
1236 * Values in this IntDef MUST be kept in sync with enum hiddenapi::EnforcementPolicy in
1237 * art/runtime/hidden_api.h
1238 * @hide
1239 */
1240 @IntDef(prefix = { "HIDDEN_API_ENFORCEMENT_" }, value = {
1241 HIDDEN_API_ENFORCEMENT_DEFAULT,
David Brazdil06ae4b82018-11-02 18:01:45 +00001242 HIDDEN_API_ENFORCEMENT_DISABLED,
Mathew Inwooda6d02fb2018-04-05 15:44:20 +01001243 HIDDEN_API_ENFORCEMENT_JUST_WARN,
David Brazdil06ae4b82018-11-02 18:01:45 +00001244 HIDDEN_API_ENFORCEMENT_ENABLED,
Mathew Inwoode3299532018-02-22 13:19:53 +00001245 })
1246 @Retention(RetentionPolicy.SOURCE)
1247 public @interface HiddenApiEnforcementPolicy {}
1248
Mathew Inwood1ab30252018-04-03 14:47:26 +01001249 /** @hide */
1250 public static boolean isValidHiddenApiEnforcementPolicy(int policy) {
David Brazdil06ae4b82018-11-02 18:01:45 +00001251 return policy >= HIDDEN_API_ENFORCEMENT_MIN && policy <= HIDDEN_API_ENFORCEMENT_MAX;
Mathew Inwoode3299532018-02-22 13:19:53 +00001252 }
1253
1254 private int mHiddenApiPolicy = HIDDEN_API_ENFORCEMENT_DEFAULT;
1255
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001256 public void dump(Printer pw, String prefix) {
Dianne Hackborn6ac42ae2015-12-08 17:22:10 -08001257 dump(pw, prefix, DUMP_FLAG_ALL);
1258 }
1259
1260 /** @hide */
Yohei Yukawa8f272172017-08-31 00:26:01 -07001261 public void dump(Printer pw, String prefix, int dumpFlags) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001262 super.dumpFront(pw, prefix);
Yohei Yukawa8f272172017-08-31 00:26:01 -07001263 if ((dumpFlags & DUMP_FLAG_DETAILS) != 0 && className != null) {
Dianne Hackborn12527f92009-11-11 17:39:50 -08001264 pw.println(prefix + "className=" + className);
1265 }
1266 if (permission != null) {
1267 pw.println(prefix + "permission=" + permission);
1268 }
Dianne Hackborn39792d22010-08-19 18:01:52 -07001269 pw.println(prefix + "processName=" + processName);
Yohei Yukawa8f272172017-08-31 00:26:01 -07001270 if ((dumpFlags & DUMP_FLAG_DETAILS) != 0) {
Dianne Hackborn6ac42ae2015-12-08 17:22:10 -08001271 pw.println(prefix + "taskAffinity=" + taskAffinity);
1272 }
Dianne Hackborn39792d22010-08-19 18:01:52 -07001273 pw.println(prefix + "uid=" + uid + " flags=0x" + Integer.toHexString(flags)
Alex Klyubinb9f8a522015-02-03 11:12:59 -08001274 + " privateFlags=0x" + Integer.toHexString(privateFlags)
Dianne Hackborn39792d22010-08-19 18:01:52 -07001275 + " theme=0x" + Integer.toHexString(theme));
Yohei Yukawa8f272172017-08-31 00:26:01 -07001276 if ((dumpFlags & DUMP_FLAG_DETAILS) != 0) {
Dianne Hackborn6ac42ae2015-12-08 17:22:10 -08001277 pw.println(prefix + "requiresSmallestWidthDp=" + requiresSmallestWidthDp
1278 + " compatibleWidthLimitDp=" + compatibleWidthLimitDp
1279 + " largestWidthLimitDp=" + largestWidthLimitDp);
1280 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001281 pw.println(prefix + "sourceDir=" + sourceDir);
Jeff Sharkey8a4c9722014-06-16 13:48:42 -07001282 if (!Objects.equals(sourceDir, publicSourceDir)) {
Dianne Hackborn39792d22010-08-19 18:01:52 -07001283 pw.println(prefix + "publicSourceDir=" + publicSourceDir);
1284 }
Jeff Sharkey8a4c9722014-06-16 13:48:42 -07001285 if (!ArrayUtils.isEmpty(splitSourceDirs)) {
1286 pw.println(prefix + "splitSourceDirs=" + Arrays.toString(splitSourceDirs));
1287 }
1288 if (!ArrayUtils.isEmpty(splitPublicSourceDirs)
1289 && !Arrays.equals(splitSourceDirs, splitPublicSourceDirs)) {
1290 pw.println(prefix + "splitPublicSourceDirs=" + Arrays.toString(splitPublicSourceDirs));
1291 }
Dianne Hackborn39792d22010-08-19 18:01:52 -07001292 if (resourceDirs != null) {
Andreas Gampee6748ce2015-12-11 18:00:38 -08001293 pw.println(prefix + "resourceDirs=" + Arrays.toString(resourceDirs));
Dianne Hackborn39792d22010-08-19 18:01:52 -07001294 }
Yohei Yukawa8f272172017-08-31 00:26:01 -07001295 if ((dumpFlags & DUMP_FLAG_DETAILS) != 0 && seInfo != null) {
Todd Kennedybe0b8892017-02-15 14:13:52 -08001296 pw.println(prefix + "seinfo=" + seInfo);
1297 pw.println(prefix + "seinfoUser=" + seInfoUser);
Robert Craig0f40dc92013-03-25 06:33:03 -04001298 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001299 pw.println(prefix + "dataDir=" + dataDir);
Yohei Yukawa8f272172017-08-31 00:26:01 -07001300 if ((dumpFlags & DUMP_FLAG_DETAILS) != 0) {
Jeff Sharkey8a372a02016-03-16 16:25:45 -06001301 pw.println(prefix + "deviceProtectedDataDir=" + deviceProtectedDataDir);
1302 pw.println(prefix + "credentialProtectedDataDir=" + credentialProtectedDataDir);
Dianne Hackborn6ac42ae2015-12-08 17:22:10 -08001303 if (sharedLibraryFiles != null) {
1304 pw.println(prefix + "sharedLibraryFiles=" + Arrays.toString(sharedLibraryFiles));
1305 }
Dianne Hackborn12527f92009-11-11 17:39:50 -08001306 }
Narayan Kamathf9419f02017-06-15 11:35:38 +01001307 if (classLoaderName != null) {
1308 pw.println(prefix + "classLoaderName=" + classLoaderName);
1309 }
1310 if (!ArrayUtils.isEmpty(splitClassLoaderNames)) {
1311 pw.println(prefix + "splitClassLoaderNames=" + Arrays.toString(splitClassLoaderNames));
1312 }
1313
Todd Kennedy89d60182016-03-11 11:18:32 -08001314 pw.println(prefix + "enabled=" + enabled
1315 + " minSdkVersion=" + minSdkVersion
1316 + " targetSdkVersion=" + targetSdkVersion
Patrick Baumannc2def582018-04-04 12:14:15 -07001317 + " versionCode=" + longVersionCode
Todd Kennedy11e45072017-01-25 13:24:21 -08001318 + " targetSandboxVersion=" + targetSandboxVersion);
Yohei Yukawa8f272172017-08-31 00:26:01 -07001319 if ((dumpFlags & DUMP_FLAG_DETAILS) != 0) {
Dianne Hackborn6ac42ae2015-12-08 17:22:10 -08001320 if (manageSpaceActivityName != null) {
1321 pw.println(prefix + "manageSpaceActivityName=" + manageSpaceActivityName);
1322 }
1323 if (descriptionRes != 0) {
1324 pw.println(prefix + "description=0x" + Integer.toHexString(descriptionRes));
1325 }
1326 if (uiOptions != 0) {
1327 pw.println(prefix + "uiOptions=0x" + Integer.toHexString(uiOptions));
1328 }
1329 pw.println(prefix + "supportsRtl=" + (hasRtlSupport() ? "true" : "false"));
1330 if (fullBackupContent > 0) {
1331 pw.println(prefix + "fullBackupContent=@xml/" + fullBackupContent);
1332 } else {
1333 pw.println(prefix + "fullBackupContent="
1334 + (fullBackupContent < 0 ? "false" : "true"));
1335 }
Chad Brubakerc845b2a2016-05-13 14:09:27 -07001336 if (networkSecurityConfigRes != 0) {
1337 pw.println(prefix + "networkSecurityConfigRes=0x"
1338 + Integer.toHexString(networkSecurityConfigRes));
1339 }
Jeff Sharkey9bc89af2017-01-11 11:25:50 -07001340 if (category != CATEGORY_UNDEFINED) {
1341 pw.println(prefix + "category=" + category);
1342 }
Mathew Inwoode3299532018-02-22 13:19:53 +00001343 pw.println(prefix + "HiddenApiEnforcementPolicy=" + getHiddenApiEnforcementPolicy());
David Brazdila5b4df22018-09-06 09:49:14 +01001344 pw.println(prefix + "usesNonSdkApi=" + usesNonSdkApi());
Matthew Williams303650c2015-04-17 18:22:51 -07001345 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001346 super.dumpBack(pw, prefix);
1347 }
Fabrice Di Meglio59dfce82012-04-02 16:17:20 -07001348
Yi Jin148d7f42017-11-28 14:23:56 -08001349 /** {@hide} */
1350 public void writeToProto(ProtoOutputStream proto, long fieldId, int dumpFlags) {
1351 long token = proto.start(fieldId);
Dianne Hackborn2f55e5a2018-11-30 16:31:31 -08001352 super.writeToProto(proto, ApplicationInfoProto.PACKAGE, dumpFlags);
Yi Jin148d7f42017-11-28 14:23:56 -08001353 proto.write(ApplicationInfoProto.PERMISSION, permission);
1354 proto.write(ApplicationInfoProto.PROCESS_NAME, processName);
1355 proto.write(ApplicationInfoProto.UID, uid);
1356 proto.write(ApplicationInfoProto.FLAGS, flags);
1357 proto.write(ApplicationInfoProto.PRIVATE_FLAGS, privateFlags);
1358 proto.write(ApplicationInfoProto.THEME, theme);
1359 proto.write(ApplicationInfoProto.SOURCE_DIR, sourceDir);
1360 if (!Objects.equals(sourceDir, publicSourceDir)) {
1361 proto.write(ApplicationInfoProto.PUBLIC_SOURCE_DIR, publicSourceDir);
1362 }
1363 if (!ArrayUtils.isEmpty(splitSourceDirs)) {
1364 for (String dir : splitSourceDirs) {
1365 proto.write(ApplicationInfoProto.SPLIT_SOURCE_DIRS, dir);
1366 }
1367 }
1368 if (!ArrayUtils.isEmpty(splitPublicSourceDirs)
1369 && !Arrays.equals(splitSourceDirs, splitPublicSourceDirs)) {
1370 for (String dir : splitPublicSourceDirs) {
1371 proto.write(ApplicationInfoProto.SPLIT_PUBLIC_SOURCE_DIRS, dir);
1372 }
1373 }
1374 if (resourceDirs != null) {
1375 for (String dir : resourceDirs) {
1376 proto.write(ApplicationInfoProto.RESOURCE_DIRS, dir);
1377 }
1378 }
1379 proto.write(ApplicationInfoProto.DATA_DIR, dataDir);
1380 proto.write(ApplicationInfoProto.CLASS_LOADER_NAME, classLoaderName);
1381 if (!ArrayUtils.isEmpty(splitClassLoaderNames)) {
1382 for (String name : splitClassLoaderNames) {
1383 proto.write(ApplicationInfoProto.SPLIT_CLASS_LOADER_NAMES, name);
1384 }
1385 }
1386
1387 long versionToken = proto.start(ApplicationInfoProto.VERSION);
1388 proto.write(ApplicationInfoProto.Version.ENABLED, enabled);
1389 proto.write(ApplicationInfoProto.Version.MIN_SDK_VERSION, minSdkVersion);
1390 proto.write(ApplicationInfoProto.Version.TARGET_SDK_VERSION, targetSdkVersion);
Patrick Baumannc2def582018-04-04 12:14:15 -07001391 proto.write(ApplicationInfoProto.Version.VERSION_CODE, longVersionCode);
Yi Jin148d7f42017-11-28 14:23:56 -08001392 proto.write(ApplicationInfoProto.Version.TARGET_SANDBOX_VERSION, targetSandboxVersion);
1393 proto.end(versionToken);
1394
1395 if ((dumpFlags & DUMP_FLAG_DETAILS) != 0) {
1396 long detailToken = proto.start(ApplicationInfoProto.DETAIL);
1397 if (className != null) {
1398 proto.write(ApplicationInfoProto.Detail.CLASS_NAME, className);
1399 }
1400 proto.write(ApplicationInfoProto.Detail.TASK_AFFINITY, taskAffinity);
1401 proto.write(ApplicationInfoProto.Detail.REQUIRES_SMALLEST_WIDTH_DP,
1402 requiresSmallestWidthDp);
1403 proto.write(ApplicationInfoProto.Detail.COMPATIBLE_WIDTH_LIMIT_DP,
1404 compatibleWidthLimitDp);
1405 proto.write(ApplicationInfoProto.Detail.LARGEST_WIDTH_LIMIT_DP,
1406 largestWidthLimitDp);
1407 if (seInfo != null) {
1408 proto.write(ApplicationInfoProto.Detail.SEINFO, seInfo);
1409 proto.write(ApplicationInfoProto.Detail.SEINFO_USER, seInfoUser);
1410 }
1411 proto.write(ApplicationInfoProto.Detail.DEVICE_PROTECTED_DATA_DIR,
1412 deviceProtectedDataDir);
1413 proto.write(ApplicationInfoProto.Detail.CREDENTIAL_PROTECTED_DATA_DIR,
1414 credentialProtectedDataDir);
1415 if (sharedLibraryFiles != null) {
1416 for (String f : sharedLibraryFiles) {
1417 proto.write(ApplicationInfoProto.Detail.SHARED_LIBRARY_FILES, f);
1418 }
1419 }
1420 if (manageSpaceActivityName != null) {
1421 proto.write(ApplicationInfoProto.Detail.MANAGE_SPACE_ACTIVITY_NAME,
1422 manageSpaceActivityName);
1423 }
1424 if (descriptionRes != 0) {
1425 proto.write(ApplicationInfoProto.Detail.DESCRIPTION_RES, descriptionRes);
1426 }
1427 if (uiOptions != 0) {
1428 proto.write(ApplicationInfoProto.Detail.UI_OPTIONS, uiOptions);
1429 }
1430 proto.write(ApplicationInfoProto.Detail.SUPPORTS_RTL, hasRtlSupport());
1431 if (fullBackupContent > 0) {
1432 proto.write(ApplicationInfoProto.Detail.CONTENT, "@xml/" + fullBackupContent);
1433 } else {
1434 proto.write(ApplicationInfoProto.Detail.IS_FULL_BACKUP, fullBackupContent == 0);
1435 }
1436 if (networkSecurityConfigRes != 0) {
1437 proto.write(ApplicationInfoProto.Detail.NETWORK_SECURITY_CONFIG_RES,
1438 networkSecurityConfigRes);
1439 }
1440 if (category != CATEGORY_UNDEFINED) {
1441 proto.write(ApplicationInfoProto.Detail.CATEGORY, category);
1442 }
1443 proto.end(detailToken);
1444 }
1445 proto.end(token);
1446 }
1447
Fabrice Di Meglio59dfce82012-04-02 16:17:20 -07001448 /**
1449 * @return true if "supportsRtl" has been set to true in the AndroidManifest
1450 * @hide
1451 */
Mathew Inwood5c0d3542018-08-14 13:54:31 +01001452 @UnsupportedAppUsage
Fabrice Di Meglio59dfce82012-04-02 16:17:20 -07001453 public boolean hasRtlSupport() {
1454 return (flags & FLAG_SUPPORTS_RTL) == FLAG_SUPPORTS_RTL;
1455 }
Jeff Sharkeyba75a9b2016-01-07 11:51:33 -07001456
1457 /** {@hide} */
1458 public boolean hasCode() {
1459 return (flags & FLAG_HAS_CODE) != 0;
1460 }
1461
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001462 public static class DisplayNameComparator
1463 implements Comparator<ApplicationInfo> {
1464 public DisplayNameComparator(PackageManager pm) {
1465 mPM = pm;
1466 }
1467
1468 public final int compare(ApplicationInfo aa, ApplicationInfo ab) {
1469 CharSequence sa = mPM.getApplicationLabel(aa);
1470 if (sa == null) {
1471 sa = aa.packageName;
1472 }
1473 CharSequence sb = mPM.getApplicationLabel(ab);
1474 if (sb == null) {
1475 sb = ab.packageName;
1476 }
1477
1478 return sCollator.compare(sa.toString(), sb.toString());
1479 }
1480
Mathew Inwood31755f92018-12-20 13:53:36 +00001481 @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.P, trackingBug = 115609023)
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001482 private final Collator sCollator = Collator.getInstance();
Mathew Inwood31755f92018-12-20 13:53:36 +00001483 @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.P, trackingBug = 115609023)
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001484 private PackageManager mPM;
1485 }
1486
1487 public ApplicationInfo() {
1488 }
1489
1490 public ApplicationInfo(ApplicationInfo orig) {
1491 super(orig);
1492 taskAffinity = orig.taskAffinity;
1493 permission = orig.permission;
1494 processName = orig.processName;
1495 className = orig.className;
1496 theme = orig.theme;
1497 flags = orig.flags;
Alex Klyubinb9f8a522015-02-03 11:12:59 -08001498 privateFlags = orig.privateFlags;
Dianne Hackborndf6e9802011-05-26 14:20:23 -07001499 requiresSmallestWidthDp = orig.requiresSmallestWidthDp;
1500 compatibleWidthLimitDp = orig.compatibleWidthLimitDp;
Dianne Hackborn2762ff32011-06-01 21:27:05 -07001501 largestWidthLimitDp = orig.largestWidthLimitDp;
Jeff Sharkeyb2b9ab82015-04-05 21:10:42 -07001502 volumeUuid = orig.volumeUuid;
Jeff Sharkey789a8fc2017-04-16 13:18:35 -06001503 storageUuid = orig.storageUuid;
Jeff Sharkey7f1a57a2014-10-08 10:14:53 -07001504 scanSourceDir = orig.scanSourceDir;
1505 scanPublicSourceDir = orig.scanPublicSourceDir;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001506 sourceDir = orig.sourceDir;
1507 publicSourceDir = orig.publicSourceDir;
Adam Lesinski4e862812016-11-21 16:02:24 -08001508 splitNames = orig.splitNames;
Jeff Sharkey8a4c9722014-06-16 13:48:42 -07001509 splitSourceDirs = orig.splitSourceDirs;
1510 splitPublicSourceDirs = orig.splitPublicSourceDirs;
Adam Lesinski4e862812016-11-21 16:02:24 -08001511 splitDependencies = orig.splitDependencies;
Kenny Root85387d72010-08-26 10:13:11 -07001512 nativeLibraryDir = orig.nativeLibraryDir;
Narayan Kamath7dba6eb2014-07-16 08:53:30 +01001513 secondaryNativeLibraryDir = orig.secondaryNativeLibraryDir;
Jeff Sharkey84f12942014-07-10 17:48:11 -07001514 nativeLibraryRootDir = orig.nativeLibraryRootDir;
1515 nativeLibraryRootRequiresIsa = orig.nativeLibraryRootRequiresIsa;
Narayan Kamathff110bd2014-07-04 18:30:45 +01001516 primaryCpuAbi = orig.primaryCpuAbi;
1517 secondaryCpuAbi = orig.secondaryCpuAbi;
Kenny Rootd1ab0162010-01-21 17:27:14 -08001518 resourceDirs = orig.resourceDirs;
Todd Kennedybe0b8892017-02-15 14:13:52 -08001519 seInfo = orig.seInfo;
1520 seInfoUser = orig.seInfoUser;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001521 sharedLibraryFiles = orig.sharedLibraryFiles;
Nicolas Geoffray8d144eb2018-11-15 12:59:52 +00001522 sharedLibraryInfos = orig.sharedLibraryInfos;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001523 dataDir = orig.dataDir;
Jeff Sharkeydd9bda82017-02-23 17:38:31 -07001524 deviceProtectedDataDir = orig.deviceProtectedDataDir;
1525 credentialProtectedDataDir = orig.credentialProtectedDataDir;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001526 uid = orig.uid;
Todd Kennedy89d60182016-03-11 11:18:32 -08001527 minSdkVersion = orig.minSdkVersion;
Dianne Hackborna96cbb42009-05-13 15:06:13 -07001528 targetSdkVersion = orig.targetSdkVersion;
Patrick Baumannc2def582018-04-04 12:14:15 -07001529 setVersionCode(orig.longVersionCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001530 enabled = orig.enabled;
Dianne Hackborn0ac30312011-06-17 14:49:23 -07001531 enabledSetting = orig.enabledSetting;
Dianne Hackborn54e570f2010-10-04 18:32:32 -07001532 installLocation = orig.installLocation;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001533 manageSpaceActivityName = orig.manageSpaceActivityName;
1534 descriptionRes = orig.descriptionRes;
Adam Powell269248d2011-08-02 10:26:54 -07001535 uiOptions = orig.uiOptions;
Christopher Tatebcb02552012-10-16 17:14:34 -07001536 backupAgentName = orig.backupAgentName;
Matthew Williams303650c2015-04-17 18:22:51 -07001537 fullBackupContent = orig.fullBackupContent;
Chad Brubakerc845b2a2016-05-13 14:09:27 -07001538 networkSecurityConfigRes = orig.networkSecurityConfigRes;
Jeff Sharkey9bc89af2017-01-11 11:25:50 -07001539 category = orig.category;
Todd Kennedy11e45072017-01-25 13:24:21 -08001540 targetSandboxVersion = orig.targetSandboxVersion;
Narayan Kamathf9419f02017-06-15 11:35:38 +01001541 classLoaderName = orig.classLoaderName;
1542 splitClassLoaderNames = orig.splitClassLoaderNames;
Jason Monka80bfb52017-11-16 17:15:37 -05001543 appComponentFactory = orig.appComponentFactory;
Adam Lesinskid3ea00992018-02-20 16:51:13 -08001544 compileSdkVersion = orig.compileSdkVersion;
1545 compileSdkVersionCodename = orig.compileSdkVersionCodename;
Mathew Inwoode3299532018-02-22 13:19:53 +00001546 mHiddenApiPolicy = orig.mHiddenApiPolicy;
Rhed Jaocd47c262018-06-13 11:16:16 +08001547 hiddenUntilInstalled = orig.hiddenUntilInstalled;
Martijn Coenenfb7caa92019-01-29 11:45:56 +01001548 zygotePreloadName = orig.zygotePreloadName;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001549 }
1550
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001551 public String toString() {
1552 return "ApplicationInfo{"
1553 + Integer.toHexString(System.identityHashCode(this))
1554 + " " + packageName + "}";
1555 }
1556
1557 public int describeContents() {
1558 return 0;
1559 }
1560
Adam Lesinski4e862812016-11-21 16:02:24 -08001561 @SuppressWarnings("unchecked")
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001562 public void writeToParcel(Parcel dest, int parcelableFlags) {
1563 super.writeToParcel(dest, parcelableFlags);
1564 dest.writeString(taskAffinity);
1565 dest.writeString(permission);
1566 dest.writeString(processName);
1567 dest.writeString(className);
1568 dest.writeInt(theme);
1569 dest.writeInt(flags);
Alex Klyubinb9f8a522015-02-03 11:12:59 -08001570 dest.writeInt(privateFlags);
Dianne Hackborndf6e9802011-05-26 14:20:23 -07001571 dest.writeInt(requiresSmallestWidthDp);
1572 dest.writeInt(compatibleWidthLimitDp);
Dianne Hackborn2762ff32011-06-01 21:27:05 -07001573 dest.writeInt(largestWidthLimitDp);
Jeff Sharkey67c8c1e2017-04-19 11:22:02 -06001574 if (storageUuid != null) {
1575 dest.writeInt(1);
Jeff Sharkeya4d34d92017-04-27 11:21:41 -06001576 dest.writeLong(storageUuid.getMostSignificantBits());
1577 dest.writeLong(storageUuid.getLeastSignificantBits());
Jeff Sharkey67c8c1e2017-04-19 11:22:02 -06001578 } else {
1579 dest.writeInt(0);
1580 }
Jeff Sharkey7f1a57a2014-10-08 10:14:53 -07001581 dest.writeString(scanSourceDir);
1582 dest.writeString(scanPublicSourceDir);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001583 dest.writeString(sourceDir);
1584 dest.writeString(publicSourceDir);
Adam Lesinski4e862812016-11-21 16:02:24 -08001585 dest.writeStringArray(splitNames);
Jeff Sharkey8a4c9722014-06-16 13:48:42 -07001586 dest.writeStringArray(splitSourceDirs);
1587 dest.writeStringArray(splitPublicSourceDirs);
Adam Lesinski1665d0f2017-03-10 14:46:57 -08001588 dest.writeSparseArray((SparseArray) splitDependencies);
Kenny Root85387d72010-08-26 10:13:11 -07001589 dest.writeString(nativeLibraryDir);
Narayan Kamath7dba6eb2014-07-16 08:53:30 +01001590 dest.writeString(secondaryNativeLibraryDir);
Jeff Sharkey84f12942014-07-10 17:48:11 -07001591 dest.writeString(nativeLibraryRootDir);
1592 dest.writeInt(nativeLibraryRootRequiresIsa ? 1 : 0);
Narayan Kamathff110bd2014-07-04 18:30:45 +01001593 dest.writeString(primaryCpuAbi);
1594 dest.writeString(secondaryCpuAbi);
Kenny Rootd1ab0162010-01-21 17:27:14 -08001595 dest.writeStringArray(resourceDirs);
Todd Kennedybe0b8892017-02-15 14:13:52 -08001596 dest.writeString(seInfo);
1597 dest.writeString(seInfoUser);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001598 dest.writeStringArray(sharedLibraryFiles);
Nicolas Geoffray8d144eb2018-11-15 12:59:52 +00001599 dest.writeTypedList(sharedLibraryInfos);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001600 dest.writeString(dataDir);
Jeff Sharkey8a372a02016-03-16 16:25:45 -06001601 dest.writeString(deviceProtectedDataDir);
1602 dest.writeString(credentialProtectedDataDir);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001603 dest.writeInt(uid);
Todd Kennedy6e2e7f52016-05-02 14:56:45 -07001604 dest.writeInt(minSdkVersion);
Dianne Hackborna96cbb42009-05-13 15:06:13 -07001605 dest.writeInt(targetSdkVersion);
Patrick Baumannc2def582018-04-04 12:14:15 -07001606 dest.writeLong(longVersionCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001607 dest.writeInt(enabled ? 1 : 0);
Dianne Hackborn0ac30312011-06-17 14:49:23 -07001608 dest.writeInt(enabledSetting);
Dianne Hackborn54e570f2010-10-04 18:32:32 -07001609 dest.writeInt(installLocation);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001610 dest.writeString(manageSpaceActivityName);
Christopher Tate181fafa2009-05-14 11:12:14 -07001611 dest.writeString(backupAgentName);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001612 dest.writeInt(descriptionRes);
Adam Powell269248d2011-08-02 10:26:54 -07001613 dest.writeInt(uiOptions);
Matthew Williams303650c2015-04-17 18:22:51 -07001614 dest.writeInt(fullBackupContent);
Chad Brubakerc845b2a2016-05-13 14:09:27 -07001615 dest.writeInt(networkSecurityConfigRes);
Jeff Sharkey9bc89af2017-01-11 11:25:50 -07001616 dest.writeInt(category);
Todd Kennedy11e45072017-01-25 13:24:21 -08001617 dest.writeInt(targetSandboxVersion);
Narayan Kamathf9419f02017-06-15 11:35:38 +01001618 dest.writeString(classLoaderName);
1619 dest.writeStringArray(splitClassLoaderNames);
Alan Viveretteb6a25732017-11-21 14:49:24 -05001620 dest.writeInt(compileSdkVersion);
1621 dest.writeString(compileSdkVersionCodename);
Jason Monka80bfb52017-11-16 17:15:37 -05001622 dest.writeString(appComponentFactory);
Mathew Inwoode3299532018-02-22 13:19:53 +00001623 dest.writeInt(mHiddenApiPolicy);
Rhed Jaocd47c262018-06-13 11:16:16 +08001624 dest.writeInt(hiddenUntilInstalled ? 1 : 0);
Martijn Coenenfb7caa92019-01-29 11:45:56 +01001625 dest.writeString(zygotePreloadName);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001626 }
1627
1628 public static final Parcelable.Creator<ApplicationInfo> CREATOR
1629 = new Parcelable.Creator<ApplicationInfo>() {
1630 public ApplicationInfo createFromParcel(Parcel source) {
1631 return new ApplicationInfo(source);
1632 }
1633 public ApplicationInfo[] newArray(int size) {
1634 return new ApplicationInfo[size];
1635 }
1636 };
1637
Adam Lesinski4e862812016-11-21 16:02:24 -08001638 @SuppressWarnings("unchecked")
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001639 private ApplicationInfo(Parcel source) {
1640 super(source);
1641 taskAffinity = source.readString();
1642 permission = source.readString();
1643 processName = source.readString();
1644 className = source.readString();
1645 theme = source.readInt();
1646 flags = source.readInt();
Alex Klyubinb9f8a522015-02-03 11:12:59 -08001647 privateFlags = source.readInt();
Dianne Hackborndf6e9802011-05-26 14:20:23 -07001648 requiresSmallestWidthDp = source.readInt();
1649 compatibleWidthLimitDp = source.readInt();
Dianne Hackborn2762ff32011-06-01 21:27:05 -07001650 largestWidthLimitDp = source.readInt();
Jeff Sharkey67c8c1e2017-04-19 11:22:02 -06001651 if (source.readInt() != 0) {
Jeff Sharkeya4d34d92017-04-27 11:21:41 -06001652 storageUuid = new UUID(source.readLong(), source.readLong());
Jeff Sharkey67c8c1e2017-04-19 11:22:02 -06001653 volumeUuid = StorageManager.convert(storageUuid);
1654 }
Jeff Sharkey7f1a57a2014-10-08 10:14:53 -07001655 scanSourceDir = source.readString();
1656 scanPublicSourceDir = source.readString();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001657 sourceDir = source.readString();
1658 publicSourceDir = source.readString();
Adam Lesinski4e862812016-11-21 16:02:24 -08001659 splitNames = source.readStringArray();
Jeff Sharkey8a4c9722014-06-16 13:48:42 -07001660 splitSourceDirs = source.readStringArray();
1661 splitPublicSourceDirs = source.readStringArray();
Adam Lesinski1665d0f2017-03-10 14:46:57 -08001662 splitDependencies = source.readSparseArray(null);
Kenny Root85387d72010-08-26 10:13:11 -07001663 nativeLibraryDir = source.readString();
Narayan Kamath7dba6eb2014-07-16 08:53:30 +01001664 secondaryNativeLibraryDir = source.readString();
Jeff Sharkey84f12942014-07-10 17:48:11 -07001665 nativeLibraryRootDir = source.readString();
1666 nativeLibraryRootRequiresIsa = source.readInt() != 0;
Narayan Kamathff110bd2014-07-04 18:30:45 +01001667 primaryCpuAbi = source.readString();
1668 secondaryCpuAbi = source.readString();
Kenny Rootd1ab0162010-01-21 17:27:14 -08001669 resourceDirs = source.readStringArray();
Todd Kennedybe0b8892017-02-15 14:13:52 -08001670 seInfo = source.readString();
1671 seInfoUser = source.readString();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001672 sharedLibraryFiles = source.readStringArray();
Nicolas Geoffray8d144eb2018-11-15 12:59:52 +00001673 sharedLibraryInfos = source.createTypedArrayList(SharedLibraryInfo.CREATOR);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001674 dataDir = source.readString();
Jeff Sharkeydd9bda82017-02-23 17:38:31 -07001675 deviceProtectedDataDir = source.readString();
1676 credentialProtectedDataDir = source.readString();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001677 uid = source.readInt();
Todd Kennedy6e2e7f52016-05-02 14:56:45 -07001678 minSdkVersion = source.readInt();
Dianne Hackborna96cbb42009-05-13 15:06:13 -07001679 targetSdkVersion = source.readInt();
Patrick Baumannc2def582018-04-04 12:14:15 -07001680 setVersionCode(source.readLong());
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001681 enabled = source.readInt() != 0;
Dianne Hackborn0ac30312011-06-17 14:49:23 -07001682 enabledSetting = source.readInt();
Dianne Hackborn54e570f2010-10-04 18:32:32 -07001683 installLocation = source.readInt();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001684 manageSpaceActivityName = source.readString();
Christopher Tate181fafa2009-05-14 11:12:14 -07001685 backupAgentName = source.readString();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001686 descriptionRes = source.readInt();
Adam Powell269248d2011-08-02 10:26:54 -07001687 uiOptions = source.readInt();
Matthew Williams303650c2015-04-17 18:22:51 -07001688 fullBackupContent = source.readInt();
Chad Brubakerc845b2a2016-05-13 14:09:27 -07001689 networkSecurityConfigRes = source.readInt();
Jeff Sharkey9bc89af2017-01-11 11:25:50 -07001690 category = source.readInt();
Todd Kennedy11e45072017-01-25 13:24:21 -08001691 targetSandboxVersion = source.readInt();
Narayan Kamathf9419f02017-06-15 11:35:38 +01001692 classLoaderName = source.readString();
1693 splitClassLoaderNames = source.readStringArray();
Alan Viveretteb6a25732017-11-21 14:49:24 -05001694 compileSdkVersion = source.readInt();
1695 compileSdkVersionCodename = source.readString();
Jason Monka80bfb52017-11-16 17:15:37 -05001696 appComponentFactory = source.readString();
Mathew Inwoode3299532018-02-22 13:19:53 +00001697 mHiddenApiPolicy = source.readInt();
Rhed Jaocd47c262018-06-13 11:16:16 +08001698 hiddenUntilInstalled = source.readInt() != 0;
Martijn Coenenfb7caa92019-01-29 11:45:56 +01001699 zygotePreloadName = source.readString();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001700 }
Mitsuru Oshima8d112672009-04-27 12:01:23 -07001701
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001702 /**
1703 * Retrieve the textual description of the application. This
1704 * will call back on the given PackageManager to load the description from
1705 * the application.
1706 *
1707 * @param pm A PackageManager from which the label can be loaded; usually
1708 * the PackageManager from which you originally retrieved this item.
1709 *
1710 * @return Returns a CharSequence containing the application's description.
1711 * If there is no description, null is returned.
1712 */
1713 public CharSequence loadDescription(PackageManager pm) {
1714 if (descriptionRes != 0) {
Jeff Brown07330792010-03-30 19:57:08 -07001715 CharSequence label = pm.getText(packageName, descriptionRes, this);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001716 if (label != null) {
1717 return label;
1718 }
1719 }
1720 return null;
1721 }
Mitsuru Oshimae5fb3282009-06-09 21:16:08 -07001722
1723 /**
1724 * Disable compatibility mode
1725 *
1726 * @hide
1727 */
Mathew Inwood31755f92018-12-20 13:53:36 +00001728 @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.P, trackingBug = 115609023)
Mitsuru Oshimae5fb3282009-06-09 21:16:08 -07001729 public void disableCompatibilityMode() {
Mitsuru Oshima69fff4a2009-07-21 09:51:05 -07001730 flags |= (FLAG_SUPPORTS_LARGE_SCREENS | FLAG_SUPPORTS_NORMAL_SCREENS |
Dianne Hackborn11b822d2009-07-21 20:03:02 -07001731 FLAG_SUPPORTS_SMALL_SCREENS | FLAG_RESIZEABLE_FOR_SCREENS |
Dianne Hackborn14cee9f2010-04-23 17:51:26 -07001732 FLAG_SUPPORTS_SCREEN_DENSITIES | FLAG_SUPPORTS_XLARGE_SCREENS);
Mitsuru Oshimae5fb3282009-06-09 21:16:08 -07001733 }
Jeff Sharkey15447792015-11-05 16:18:51 -08001734
skuhne@google.com7e85eb02017-01-04 13:49:54 -08001735 /**
1736 * Is using compatibility mode for non densty aware legacy applications.
1737 *
1738 * @hide
1739 */
1740 public boolean usesCompatibilityMode() {
1741 return targetSdkVersion < DONUT ||
1742 (flags & (FLAG_SUPPORTS_LARGE_SCREENS | FLAG_SUPPORTS_NORMAL_SCREENS |
1743 FLAG_SUPPORTS_SMALL_SCREENS | FLAG_RESIZEABLE_FOR_SCREENS |
1744 FLAG_SUPPORTS_SCREEN_DENSITIES | FLAG_SUPPORTS_XLARGE_SCREENS)) == 0;
1745 }
1746
Jeff Sharkey15447792015-11-05 16:18:51 -08001747 /** {@hide} */
1748 public void initForUser(int userId) {
1749 uid = UserHandle.getUid(userId, UserHandle.getAppId(uid));
1750
1751 if ("android".equals(packageName)) {
1752 dataDir = Environment.getDataSystemDirectory().getAbsolutePath();
1753 return;
1754 }
1755
Jeff Sharkeydd9bda82017-02-23 17:38:31 -07001756 deviceProtectedDataDir = Environment
Jeff Sharkey8212ae02016-02-10 14:46:43 -07001757 .getDataUserDePackageDirectory(volumeUuid, userId, packageName)
Jeff Sharkey15447792015-11-05 16:18:51 -08001758 .getAbsolutePath();
Jeff Sharkeydd9bda82017-02-23 17:38:31 -07001759 credentialProtectedDataDir = Environment
Jeff Sharkey8212ae02016-02-10 14:46:43 -07001760 .getDataUserCePackageDirectory(volumeUuid, userId, packageName)
Jeff Sharkey15447792015-11-05 16:18:51 -08001761 .getAbsolutePath();
1762
Jeff Sharkey8a372a02016-03-16 16:25:45 -06001763 if ((privateFlags & PRIVATE_FLAG_DEFAULT_TO_DEVICE_PROTECTED_STORAGE) != 0
1764 && PackageManager.APPLY_DEFAULT_TO_DEVICE_PROTECTED_STORAGE) {
1765 dataDir = deviceProtectedDataDir;
Jeff Sharkey15447792015-11-05 16:18:51 -08001766 } else {
Jeff Sharkey8a372a02016-03-16 16:25:45 -06001767 dataDir = credentialProtectedDataDir;
Jeff Sharkey15447792015-11-05 16:18:51 -08001768 }
1769 }
1770
Mathew Inwoode3299532018-02-22 13:19:53 +00001771 private boolean isPackageWhitelistedForHiddenApis() {
1772 return SystemConfig.getInstance().getHiddenApiWhitelistedApps().contains(packageName);
1773 }
1774
David Brazdila5b4df22018-09-06 09:49:14 +01001775 /**
1776 * @hide
1777 */
1778 public boolean usesNonSdkApi() {
1779 return (privateFlags & PRIVATE_FLAG_USES_NON_SDK_API) != 0;
1780 }
1781
Philip P. Moltmannae4a4b92018-12-12 11:28:57 -08001782 /**
1783 * Whether an app needs to keep the app data on uninstall.
1784 *
1785 * @return {@code true} if the app indicates that it needs to keep the app data
1786 *
1787 * @hide
1788 */
1789 public boolean hasFragileUserData() {
1790 return (privateFlags & PRIVATE_FLAG_HAS_FRAGILE_USER_DATA) != 0;
1791 }
1792
Mathew Inwood9d895432018-04-04 16:08:21 +01001793 private boolean isAllowedToUseHiddenApis() {
David Brazdil787b6f22a2018-08-28 12:55:56 +01001794 if (isSignedWithPlatformKey()) {
1795 return true;
1796 } else if (isSystemApp() || isUpdatedSystemApp()) {
David Brazdila5b4df22018-09-06 09:49:14 +01001797 return usesNonSdkApi() || isPackageWhitelistedForHiddenApis();
David Brazdil787b6f22a2018-08-28 12:55:56 +01001798 } else {
1799 return false;
1800 }
Mathew Inwood9d895432018-04-04 16:08:21 +01001801 }
1802
Jeff Brown07330792010-03-30 19:57:08 -07001803 /**
1804 * @hide
1805 */
Mathew Inwoode3299532018-02-22 13:19:53 +00001806 public @HiddenApiEnforcementPolicy int getHiddenApiEnforcementPolicy() {
Mathew Inwood9d895432018-04-04 16:08:21 +01001807 if (isAllowedToUseHiddenApis()) {
David Brazdil06ae4b82018-11-02 18:01:45 +00001808 return HIDDEN_API_ENFORCEMENT_DISABLED;
Mathew Inwoode3299532018-02-22 13:19:53 +00001809 }
Mathew Inwood1ab30252018-04-03 14:47:26 +01001810 if (mHiddenApiPolicy != HIDDEN_API_ENFORCEMENT_DEFAULT) {
1811 return mHiddenApiPolicy;
1812 }
David Brazdil06ae4b82018-11-02 18:01:45 +00001813 return HIDDEN_API_ENFORCEMENT_ENABLED;
Mathew Inwoode3299532018-02-22 13:19:53 +00001814 }
1815
1816 /**
1817 * @hide
1818 */
1819 public void setHiddenApiEnforcementPolicy(@HiddenApiEnforcementPolicy int policy) {
1820 if (!isValidHiddenApiEnforcementPolicy(policy)) {
1821 throw new IllegalArgumentException("Invalid API enforcement policy: " + policy);
1822 }
1823 mHiddenApiPolicy = policy;
David Brazdil464ed3d2018-01-18 15:25:18 +00001824 }
1825
1826 /**
Mathew Inwood1ab30252018-04-03 14:47:26 +01001827 * Updates the hidden API enforcement policy for this app from the given values, if appropriate.
1828 *
1829 * This will have no effect if this app is not subject to hidden API enforcement, i.e. if it
1830 * is on the package whitelist.
1831 *
David Brazdil06ae4b82018-11-02 18:01:45 +00001832 * @param policy configured policy for this app, or {@link #HIDDEN_API_ENFORCEMENT_DEFAULT}
David Brazdil5cd148f2018-11-01 09:54:25 +00001833 * if nothing configured.
Mathew Inwood1ab30252018-04-03 14:47:26 +01001834 * @hide
1835 */
David Brazdil06ae4b82018-11-02 18:01:45 +00001836 public void maybeUpdateHiddenApiEnforcementPolicy(@HiddenApiEnforcementPolicy int policy) {
Mathew Inwood1ab30252018-04-03 14:47:26 +01001837 if (isPackageWhitelistedForHiddenApis()) {
1838 return;
1839 }
David Brazdil06ae4b82018-11-02 18:01:45 +00001840 setHiddenApiEnforcementPolicy(policy);
Mathew Inwood1ab30252018-04-03 14:47:26 +01001841 }
1842
1843 /**
David Brazdil464ed3d2018-01-18 15:25:18 +00001844 * @hide
1845 */
Patrick Baumannc2def582018-04-04 12:14:15 -07001846 public void setVersionCode(long newVersionCode) {
1847 longVersionCode = newVersionCode;
1848 versionCode = (int) newVersionCode;
1849 }
1850
1851 /**
1852 * @hide
1853 */
Alexandra Gherghinaa7093142014-07-30 13:43:39 +01001854 @Override
1855 public Drawable loadDefaultIcon(PackageManager pm) {
Jeff Brown07330792010-03-30 19:57:08 -07001856 if ((flags & FLAG_EXTERNAL_STORAGE) != 0
1857 && isPackageUnavailable(pm)) {
1858 return Resources.getSystem().getDrawable(
1859 com.android.internal.R.drawable.sym_app_on_sd_unavailable_icon);
1860 }
1861 return pm.getDefaultActivityIcon();
1862 }
1863
Mathew Inwood31755f92018-12-20 13:53:36 +00001864 @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.P, trackingBug = 115609023)
Jeff Brown07330792010-03-30 19:57:08 -07001865 private boolean isPackageUnavailable(PackageManager pm) {
1866 try {
1867 return pm.getPackageInfo(packageName, 0) == null;
1868 } catch (NameNotFoundException ex) {
1869 return true;
1870 }
1871 }
Jeff Sharkeyd7460572014-07-06 20:44:55 -07001872
Jeff Sharkeyf9fc6d62015-11-08 16:46:05 -08001873 /** @hide */
Jeff Sharkey8a372a02016-03-16 16:25:45 -06001874 public boolean isDefaultToDeviceProtectedStorage() {
1875 return (privateFlags
1876 & ApplicationInfo.PRIVATE_FLAG_DEFAULT_TO_DEVICE_PROTECTED_STORAGE) != 0;
Jeff Sharkeye4697132016-02-06 19:46:15 -07001877 }
1878
1879 /** @hide */
Jeff Sharkey8a372a02016-03-16 16:25:45 -06001880 public boolean isDirectBootAware() {
1881 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_DIRECT_BOOT_AWARE) != 0;
Jeff Sharkeyf9fc6d62015-11-08 16:46:05 -08001882 }
1883
Hai Zhang14ea9ef2019-01-10 14:56:06 -08001884 /**
1885 * Check whether the application is encryption aware.
1886 *
1887 * @see #isDirectBootAware()
1888 * @see #isPartiallyDirectBootAware()
1889 *
1890 * @hide
1891 */
1892 @SystemApi
Todd Kennedyc29b11a2017-10-23 15:55:59 -07001893 public boolean isEncryptionAware() {
1894 return isDirectBootAware() || isPartiallyDirectBootAware();
1895 }
1896
1897 /** @hide */
1898 public boolean isExternal() {
1899 return (flags & ApplicationInfo.FLAG_EXTERNAL_STORAGE) != 0;
1900 }
1901
Patrick Baumann159cd022018-01-11 13:25:05 -08001902 /**
1903 * True if the application is installed as an instant app.
1904 * @hide
1905 */
1906 @SystemApi
Todd Kennedyc29b11a2017-10-23 15:55:59 -07001907 public boolean isInstantApp() {
1908 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_INSTANT) != 0;
1909 }
1910
1911 /** @hide */
1912 public boolean isInternal() {
1913 return (flags & ApplicationInfo.FLAG_EXTERNAL_STORAGE) == 0;
1914 }
1915
1916 /** @hide */
1917 public boolean isOem() {
1918 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_OEM) != 0;
1919 }
1920
1921 /** @hide */
Jeff Sharkey8a372a02016-03-16 16:25:45 -06001922 public boolean isPartiallyDirectBootAware() {
1923 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_PARTIALLY_DIRECT_BOOT_AWARE) != 0;
Jeff Sharkey8924e872015-11-30 12:52:10 -07001924 }
1925
Bryce Lee8558ec72017-08-17 15:37:26 -07001926 /** @hide */
Mathew Inwood9d895432018-04-04 16:08:21 +01001927 public boolean isSignedWithPlatformKey() {
1928 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_SIGNED_WITH_PLATFORM_KEY) != 0;
1929 }
1930
1931 /** @hide */
Todd Kennedyc29b11a2017-10-23 15:55:59 -07001932 @TestApi
1933 public boolean isPrivilegedApp() {
1934 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_PRIVILEGED) != 0;
Bryce Lee8558ec72017-08-17 15:37:26 -07001935 }
1936
Todd Kennedyc29b11a2017-10-23 15:55:59 -07001937 /** @hide */
Fyodor Kupolovbdbc9692015-12-14 13:11:13 -08001938 public boolean isRequiredForSystemUser() {
1939 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_REQUIRED_FOR_SYSTEM_USER) != 0;
1940 }
1941
Todd Kennedyc29b11a2017-10-23 15:55:59 -07001942 /** @hide */
Svet Ganov67882122016-12-11 16:36:34 -08001943 public boolean isStaticSharedLibrary() {
1944 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_STATIC_SHARED_LIBRARY) != 0;
1945 }
1946
Todd Kennedyc29b11a2017-10-23 15:55:59 -07001947 /** @hide */
1948 @TestApi
1949 public boolean isSystemApp() {
1950 return (flags & ApplicationInfo.FLAG_SYSTEM) != 0;
1951 }
1952
1953 /** @hide */
1954 public boolean isUpdatedSystemApp() {
1955 return (flags & ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) != 0;
1956 }
1957
Jiyong Park002fdbd2017-02-13 20:50:31 +09001958 /** @hide */
1959 public boolean isVendor() {
1960 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_VENDOR) != 0;
1961 }
1962
Jaekyun Seok1713d9e2018-01-12 21:47:26 +09001963 /** @hide */
1964 public boolean isProduct() {
1965 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_PRODUCT) != 0;
1966 }
1967
Dario Freni2bef1762018-06-01 14:02:08 +01001968 /** @hide */
1969 public boolean isProductServices() {
1970 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_PRODUCT_SERVICES) != 0;
1971 }
1972
Victor Hsiehf12af2f2019-01-03 10:11:03 -08001973 /** @hide */
Victor Hsiehfa9df0b2019-01-29 12:48:36 -08001974 public boolean isEmbeddedDexUsed() {
1975 return (privateFlags & PRIVATE_FLAG_USE_EMBEDDED_DEX) != 0;
Victor Hsiehf12af2f2019-01-03 10:11:03 -08001976 }
1977
Svet Ganov67882122016-12-11 16:36:34 -08001978 /**
Todd Kennedy5eb5a7d2017-08-01 07:42:47 -07001979 * Returns whether or not this application was installed as a virtual preload.
1980 */
1981 public boolean isVirtualPreload() {
1982 return (privateFlags & PRIVATE_FLAG_VIRTUAL_PRELOAD) != 0;
1983 }
1984
1985 /**
Chris Craikce030282018-10-16 14:33:11 -07001986 * Returns whether or not this application can be profiled by the shell user,
1987 * even when running on a device that is running in user mode.
1988 */
1989 public boolean isProfileableByShell() {
1990 return (privateFlags & PRIVATE_FLAG_PROFILEABLE_BY_SHELL) != 0;
1991 }
1992
1993 /**
Todd Kennedyc29b11a2017-10-23 15:55:59 -07001994 * Returns true if the app has declared in its manifest that it wants its split APKs to be
1995 * loaded into isolated Contexts, with their own ClassLoaders and Resources objects.
Svet Ganov67882122016-12-11 16:36:34 -08001996 * @hide
1997 */
Todd Kennedyc29b11a2017-10-23 15:55:59 -07001998 public boolean requestsIsolatedSplitLoading() {
1999 return (privateFlags & ApplicationInfo.PRIVATE_FLAG_ISOLATED_SPLIT_LOADING) != 0;
Svet Ganov087dce22017-09-07 15:42:16 -07002000 }
2001
2002 /**
2003 * @hide
2004 */
Jeff Brown07330792010-03-30 19:57:08 -07002005 @Override protected ApplicationInfo getApplicationInfo() {
2006 return this;
2007 }
Jeff Sharkeyd7460572014-07-06 20:44:55 -07002008
2009 /** {@hide} */ public void setCodePath(String codePath) { scanSourceDir = codePath; }
2010 /** {@hide} */ public void setBaseCodePath(String baseCodePath) { sourceDir = baseCodePath; }
2011 /** {@hide} */ public void setSplitCodePaths(String[] splitCodePaths) { splitSourceDirs = splitCodePaths; }
2012 /** {@hide} */ public void setResourcePath(String resourcePath) { scanPublicSourceDir = resourcePath; }
2013 /** {@hide} */ public void setBaseResourcePath(String baseResourcePath) { publicSourceDir = baseResourcePath; }
2014 /** {@hide} */ public void setSplitResourcePaths(String[] splitResourcePaths) { splitPublicSourceDirs = splitResourcePaths; }
2015
Mathew Inwood5c0d3542018-08-14 13:54:31 +01002016 /** {@hide} */
2017 @UnsupportedAppUsage
2018 public String getCodePath() { return scanSourceDir; }
Jeff Sharkeyd7460572014-07-06 20:44:55 -07002019 /** {@hide} */ public String getBaseCodePath() { return sourceDir; }
2020 /** {@hide} */ public String[] getSplitCodePaths() { return splitSourceDirs; }
2021 /** {@hide} */ public String getResourcePath() { return scanPublicSourceDir; }
Mathew Inwood5c0d3542018-08-14 13:54:31 +01002022 /** {@hide} */
2023 @UnsupportedAppUsage
2024 public String getBaseResourcePath() { return publicSourceDir; }
Jeff Sharkeya3a43b02016-11-15 17:54:23 -07002025 /** {@hide} */ public String[] getSplitResourcePaths() { return splitPublicSourceDirs; }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002026}