33 lines
1.4 KiB
Markdown
33 lines
1.4 KiB
Markdown
|
|
# 7\. Hardware Compatibility
|
|||
|
|
|
|||
|
|
If a device includes a particular hardware component that has a corresponding
|
|||
|
|
API for third-party developers:
|
|||
|
|
|
|||
|
|
* [C-0-1] The device implementation MUST implement that
|
|||
|
|
API as described in the Android SDK documentation.
|
|||
|
|
|
|||
|
|
If an API in the SDK
|
|||
|
|
interacts with a hardware component that is stated to be optional and the
|
|||
|
|
device implementation does not possess that component:
|
|||
|
|
|
|||
|
|
* [C-0-2] Complete class definitions (as documented by the SDK) for the component
|
|||
|
|
APIs MUST still be presented.
|
|||
|
|
* [C-0-3] The API’s behaviors MUST be implemented as no-ops in some reasonable
|
|||
|
|
fashion.
|
|||
|
|
* [C-0-4] API methods MUST return null values where permitted by the SDK
|
|||
|
|
documentation.
|
|||
|
|
* [C-0-5] API methods MUST return no-op implementations of classes where null values
|
|||
|
|
are not permitted by the SDK documentation.
|
|||
|
|
* [C-0-6] API methods MUST NOT throw exceptions not documented by the SDK
|
|||
|
|
documentation.
|
|||
|
|
* [C-0-7] Device implementations MUST consistently report accurate hardware
|
|||
|
|
configuration information via the `getSystemAvailableFeatures()` and
|
|||
|
|
`hasSystemFeature(String)` methods on the
|
|||
|
|
[android.content.pm.PackageManager](
|
|||
|
|
http://developer.android.com/reference/android/content/pm/PackageManager.html)
|
|||
|
|
class for the same build fingerprint.
|
|||
|
|
|
|||
|
|
A typical example of a scenario where these requirements apply is the telephony
|
|||
|
|
API: Even on non-phone devices, these APIs must be implemented as reasonable
|
|||
|
|
no-ops.
|