/* * Copyright (C) 2010 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include #include #include using namespace android; static const char* gProgName = "validatekeymaps"; enum FileType { FILETYPE_UNKNOWN, FILETYPE_KEYLAYOUT, FILETYPE_KEYCHARACTERMAP, }; static void usage() { fprintf(stderr, "Keymap Validation Tool\n\n"); fprintf(stderr, "Usage:\n"); fprintf(stderr, " %s [FILENAME.kl] [FILENAME.kcm] [...]\n" " Validates the specified key layout and/or key character map files.\n\n", gProgName); } static FileType getFileType(const char* filename) { const char *extension = strrchr(filename, '.'); if (extension) { if (strcmp(extension, ".kl") == 0) { return FILETYPE_KEYLAYOUT; } if (strcmp(extension, ".kcm") == 0) { return FILETYPE_KEYCHARACTERMAP; } } return FILETYPE_UNKNOWN; } static bool validateFile(const char* filename) { fprintf(stdout, "Validating file '%s'...\n", filename); FileType fileType = getFileType(filename); switch (fileType) { case FILETYPE_UNKNOWN: fprintf(stderr, "File extension must be .kl or .kcm.\n\n"); return false; case FILETYPE_KEYLAYOUT: { KeyLayoutMap* map; status_t status = KeyLayoutMap::load(String8(filename), &map); if (status) { fprintf(stderr, "Error %d parsing key layout file.\n\n", status); return false; } break; } case FILETYPE_KEYCHARACTERMAP: { KeyCharacterMap* map; status_t status = KeyCharacterMap::load(String8(filename), &map); if (status) { fprintf(stderr, "Error %d parsing key character map file.\n\n", status); return false; } break; } } fputs("No errors.\n\n", stdout); return true; } int main(int argc, const char** argv) { if (argc < 2) { usage(); return 1; } int result = 0; for (int i = 1; i < argc; i++) { if (!validateFile(argv[i])) { result = 1; } } if (result) { fputs("Failed!\n", stderr); } else { fputs("Success.\n", stdout); } return result; }