/* echo.c - Command to display a line of text */ /* * VAS_EBOOT -- GRand Unified Bootloader * Copyright (C) 2011 Free Software Foundation, Inc. * * VAS_EBOOT is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * VAS_EBOOT is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with VAS_EBOOT. If not, see . */ #include #include #include #include #include VAS_EBOOT_MOD_LICENSE ("GPLv3+"); static VasEBoot_err_t VasEBoot_cmd_time (VasEBoot_command_t ctxt __attribute__ ((unused)), int argc, char **args) { VasEBoot_command_t cmd; VasEBoot_uint32_t start; VasEBoot_uint32_t end; if (argc == 0) return VasEBoot_error (VAS_EBOOT_ERR_BAD_ARGUMENT, N_("no command is specified")); cmd = VasEBoot_command_find (args[0]); if (!cmd) return VasEBoot_error (VAS_EBOOT_ERR_UNKNOWN_COMMAND, N_("can't find command `%s'"), args[0]); start = VasEBoot_get_time_ms (); (cmd->func) (cmd, argc - 1, &args[1]); end = VasEBoot_get_time_ms (); VasEBoot_printf_ (N_("Elapsed time: %d.%03d seconds \n"), (end - start) / 1000, (end - start) % 1000); return VasEBoot_errno; } static VasEBoot_command_t cmd; VAS_EBOOT_MOD_INIT(time) { cmd = VasEBoot_register_command ("time", VasEBoot_cmd_time, N_("COMMAND [ARGS]"), N_("Measure time used by COMMAND")); } VAS_EBOOT_MOD_FINI(time) { VasEBoot_unregister_command (cmd); }