From 4397a2a4ca5e04a5a736eb792d8cc3ac50f32db1 Mon Sep 17 00:00:00 2001 From: Daniel Verkamp Date: Tue, 3 Mar 2009 23:17:06 -0600 Subject: [PATCH] [time] Add the time command Signed-off-by: Michael Brown --- src/config/general.h | 1 + src/core/config.c | 3 +++ src/hci/commands/time_cmd.c | 54 +++++++++++++++++++++++++++++++++++++ 3 files changed, 58 insertions(+) create mode 100644 src/hci/commands/time_cmd.c diff --git a/src/config/general.h b/src/config/general.h index 04b5bef3..52d8323b 100644 --- a/src/config/general.h +++ b/src/config/general.h @@ -101,6 +101,7 @@ #define DHCP_CMD /* DHCP management commands */ #define SANBOOT_CMD /* SAN boot commands */ #define LOGIN_CMD /* Login command */ +#undef TIME_CMD /* Time command */ /* * Obscure configuration options diff --git a/src/core/config.c b/src/core/config.c index bd0d66ec..59bd8fa1 100644 --- a/src/core/config.c +++ b/src/core/config.c @@ -196,6 +196,9 @@ REQUIRE_OBJECT ( sanboot_cmd ); #ifdef LOGIN_CMD REQUIRE_OBJECT ( login_cmd ); #endif +#ifdef TIME_CMD +REQUIRE_OBJECT ( time_cmd ); +#endif /* * Drag in miscellaneous objects diff --git a/src/hci/commands/time_cmd.c b/src/hci/commands/time_cmd.c new file mode 100644 index 00000000..9866ab9c --- /dev/null +++ b/src/hci/commands/time_cmd.c @@ -0,0 +1,54 @@ +/* + * Copyright (C) 2009 Daniel Verkamp . + * + * This program 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 2 of the + * License, or any later version. + * + * This program 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 this program; if not, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + */ + +#include +#include +#include +#include +#include + +static int time_exec ( int argc, char **argv ) { + unsigned long start; + int rc, secs; + + if ( argc == 1 || + !strcmp ( argv[1], "--help" ) || + !strcmp ( argv[1], "-h" ) ) + { + printf ( "Usage:\n" + " %s \n" + "\n" + "Time a command\n", + argv[0] ); + return 1; + } + + start = currticks(); + rc = execv ( argv[1], argv + 1 ); + secs = (currticks() - start) / ticks_per_sec(); + + printf ( "%s: %ds\n", argv[0], secs ); + + return rc; +} + +struct command time_command __command = { + .name = "time", + .exec = time_exec, +}; +