| File name | Explanation | 
|---|---|
| physical_key_data.g.json | Contains the merged physical key data from all the other sources. This file is regenerated if “--collect” is specified for the gen_keycodes script, or used as a source otherwise. | 
| logical_key_data.g.json | Contains the merged logical key data from all the other sources. This file is regenerated if “--collect” is specified for the gen_keycodes script, or used as a source otherwise. | 
| supplemental_hid_codes.inc | A supplementary HID list on top of Chromium‘s list of HID codes for extra physical keys. Certain entries may also overwrite Chromium’s corresponding entries. | 
| supplemental_key_data.inc | A supplementary key list on top of Chromium's list of keys for extra logical keys. | 
| chromium_modifiers.json | Maps the web‘s keyfor modifier keys to the names of the logical keys for these keys’ left and right variations.This is used when generating logical keys to provide independent values for sided logical keys. Web uses the samekeyfor modifier keys of different sides, but Flutter's logical key model treats them as different keys. | 
| printable.json | Maps Flutter key name to its printable character. This character is used as the key label. | 
| synonyms.json | Maps pseudo-keys that represent other keys to the sets of keys they represent. For example, this contains the “shift” key that represents either a “shiftLeft” or “shiftRight” key. | 
| layout_goals.json | A list of layout goals, keys that the platform keyboard manager should find mappings for. Each key in this file is the key name of the goal, both logical and physical simultaneously, while its value represents whether the goal is mandatory. A mandatory goal must be fulfilled, and the manager will use the default value from this file if a mapping can not be found. A non-mandatory goal is suggestive, only used if the key mapping information is malformed (e.g. contains no ASCII characters.) | 
| File name | Explanation | 
|---|---|
| keyboard_key.tmpl | The template for keyboard_key.g.dart. | 
| keyboard_maps.tmpl | The template for keyboard_maps.g.dart. | 
| File name | Explanation | 
|---|---|
| android_keyboard_map_java.tmpl | The template for KeyboardMap.java. | 
| android_key_name_to_name.json | Maps a logical key name to the names of its corresponding keycode constants. This is used to convert logical keys. | 
| File name | Explanation | 
|---|---|
| ios_logical_to_physical.json | Maps a logical key name to the names of its corresponding physical keys. This is used to derive logical keys (from keyCode) that can‘t or shouldn’t be derived fromcharacterIgnoringModifiers. | 
| ios_key_code_map_mm.tmpl | The template for KeyCodeMap.mm. | 
| File name | Explanation | 
|---|---|
| web_key_map_dart.tmpl | The template for key_map.dart. | 
| web_logical_location_mapping.json | Maps a pair of the web's keyandlocationto the name for its corresponding logical key. This is used to distinguish between logical keys with the samekeybut differentlocations. | 
| File name | Explanation | 
|---|---|
| windows_flutter_key_map_cc.tmpl | The template for flutter_key_map.cc. | 
| windows_logical_to_window_vk.json | Maps a logical key name to the names of its corresponding virtual keys in Win32. | 
| windows_scancode_logical_map.json | Maps a physical key name to a logical key name. This is used to when a keycodemaps to multiple keys (including when thekeycodeis 0), therefore can only be told apart by the scan code. | 
| File name | Explanation | 
|---|---|
| gtk_key_mapping_cc.tmpl | The template for key_mapping.cc. | 
| gtk_lock_bit_mapping.json | Maps a name for GTK‘s modifier bit macro to Flutter’s logical name (element #0) and physical name (element #1). This is used to generate checked keys that GTK should keep lock state synchronous on. | 
| gtk_logical_name_mapping.json | Maps a logical key name to the macro names of its corresponding keyvals. This is used to convert logical keys. | 
| gtk_modifier_bit_mapping.json | Maps a name for GTK‘s modifier bit macro to Flutter’s physical name (element #0), logical name (element #1), and the logical name for the paired key (element #2). This is used to generate checked keys where GTK should keep the pressed state synchronized. | 
| gtk_numpad_shift.json | Maps the name of a keyvalmacro of a numpad key to that of the corresponding key with NumLock on. GTK uses differentkeyvalfor numpad keys with and without NumLock on, but Flutter's logical key model treats them as the same key. | 
| File name | Explanation | 
|---|---|
| glfw_key_name_to_name.json | Maps a logical key name to the names of its GLFW macro. (Unused for now.) | 
| glfw_keyboard_map_cc.tmpl | The template for keyboard_map.cc. (Unused for now.) | 
| File name | Explanation | 
|---|---|
| macos_key_code_map_cc.tmpl | The template for KeyCodeMap.mm. | 
| macos_logical_to_physical.json | Maps a logical key name to the names of its corresponding physical keys. This is used to derive logical keys (from keyCode) that can‘t or shouldn’t be derived fromcharacterIgnoringModifiers. | 
| File name | Explanation | 
|---|---|
| fuchsia_keyboard_map_cc.tmpl | The template for keyboard_map.cc. (Unused for now.) |