Move generic classes to com.android.storage

Move generic classes to com.android.storage from
com.android.timezone.location.storage.

Move tzs2 code to tzs2storage from s2storage directory - generic
classes, not related to TZ storage, are now separate.

Some test support classes have been split out so they can be used by
tests in multiple libraries.

Bug: 312242276
Test: Treehugger
(cherry picked from https://googleplex-android-review.googlesource.com/q/commit:b3d5d26d7d4ade1c9ef9f401cb9b91e53ab09ab1)
Merged-In: Ia355db224da7010dbb1534786b84f1948f1a0263
Change-Id: Ia355db224da7010dbb1534786b84f1948f1a0263
96 files changed
tree: 72b70c45b03c53bc951528d86d2590256dcbfa48
  1. apex/
  2. app/
  3. common/
  4. data_pipeline/
  5. geotz_lookup/
  6. locationtzprovider/
  7. output_data/
  8. s2storage/
  9. tzbb_data/
  10. tzs2storage/
  11. validation/
  12. download-tzbb-files.sh
  13. OWNERS
  14. PREUPLOAD.cfg
  15. README.md
  16. run-data-pipeline.sh
README.md

This directory contains code, tools and data for the AOSP reference location time zone provider. Location time zone providers are used for location-based time zone detection on Android. See Android's android.service.timezone.TimeZoneProviderService class for more details.

Directory structure

apex

  • Files associated with a proposed mainline module APEX to hold the AOSP reference location time zone provider.

common

  • Utility code shared between several subdirectories.

data_pipeline

  • Code for a host sample / reference data generation pipeline. See run-data-pipeline.sh below.

geotz_lookup

  • A high-level API for performing time zone ID lookups for a location using the tzs2.dat file. Supports host and device usage.

locationtzprovider

  • A reference location time zone provider that uses AOSP APIs to obtain location and the geotz_lookup APIs to obtain the time zone IDs to pass to the platform.

output_data

  • Holds the tzs2.dat file generated by run-data-pipeline.sh along with the associated license files.

s2storage

  • Generic file reading / writing code and tools to support tzs2.dat generation on host, and the file's use on host and device. See s2storage/README.md for details.

tzs2storage

  • TZ-specific file reading / writing code and tools to support tzs2.dat generation on host, and the file's use on host and device. See tzs2storage/README.md for details.

tzbb_data

  • Data / licenses from the external timezone-boundary-builder project. Used as input for the reference data generation pipeline.

validation

  • Tooling to help validate the tzs2.dat file against other data sources.

Data file update tools

download-tzbb-files.sh

run-data-pipeline.sh

  • Runs the data_pipeline data generation pipeline. It takes data from tzbb_data/, processes it, and puts the resulting tzs2.dat file in output_data/.