Validasi Alat Peta Kunci

Kerangka kerja Android memiliki alat kecil yang disebut validatekeymaps untuk memvalidasi sintaks file konfigurasi perangkat input, file tata letak kunci, file peta karakter kunci, dan file definisi kunci virtual.

Kompilasi

Untuk mengompilasi validatekeymaps , siapkan lingkungan pengembangan, unduh hierarki sumber Android, kompilasi, lalu jalankan:

mmm frameworks/base/tools/validatekeymaps

Perintah ini harus mengkompilasi alat host yang disebut validasikeymaps ke dalam direktori out/host/<os>/bin .

Penggunaan

Jika Anda menjalankan envsetup.sh untuk menyiapkan lingkungan pengembangan Anda, maka alat validatekeymaps seharusnya sudah ada di jalur Anda. Anda dapat memverifikasi ini dengan menjalankan validatekeymaps .

validatekeymaps

Anda akan melihat output berikut:

Keymap Validation Tool

Usage:
 validatekeymaps [*.kl] [*.kcm] [*.idc] [virtualkeys.*] [...]
   Validates the specified key layouts, key character maps, 
   input device configurations, or virtual key definitions.

Kemudian yang perlu Anda lakukan adalah menjalankan validatekeymaps dan memberikannya jalur satu atau lebih file untuk divalidasi.

validatekeymaps frameworks/base/data/keyboards/Generic.kl

Contoh:

Validating file 'frameworks/base/data/keyboards/Generic.kl'...
No errors.

Success.

Dan jika ada kesalahan...

validatekeymaps Bad.kl

Contoh:

Validating file 'Bad.kl'...
E/KeyLayoutMap(87688): Bad.kl:24: Expected keyword, got 'ke'.
Error -22 parsing key layout file.

Failed!

Otomatisasi

Ini adalah ide yang sangat baik untuk menjalankan validatekeymaps pada semua file konfigurasi sebelum menginstalnya pada perangkat.

Prosesnya dapat dengan mudah diotomatisasi sebagai bagian dari sistem pembangunan dengan menggunakan skrip atau makefile.

Contoh makefile berikut didasarkan pada konten frameworks/base/data/keyboards/Android.mk .

# This makefile performs build time validation of framework keymap files.

LOCAL_PATH := $(call my-dir)

# Validate all key maps.
include $(CLEAR_VARS)

validatekeymaps := $(HOST_OUT_EXECUTABLES)/validatekeymaps$(HOST_EXECUTABLE_SUFFIX)
files := MyKeyboard.kl MyKeyboard.kcm MyTouchScreen.idc

LOCAL_MODULE := validate_framework_keymaps
LOCAL_MODULE_TAGS := optional
LOCAL_REQUIRED_MODULES := validatekeymaps

validate_framework_keymaps: $(files)
    $(hide) $(validatekeymaps) $(files)

include $(BUILD_PHONY_PACKAGE)