[Asterisk-cvs] asterisk cli.c,1.71,1.72
markster at lists.digium.com
markster at lists.digium.com
Sat Feb 5 10:48:33 CST 2005
Update of /usr/cvsroot/asterisk
In directory mongoose.digium.com:/tmp/cvs-serv20138
Modified Files:
cli.c
Log Message:
Allow uptime to be displayed in seconds (bug #3510, with mods)
Index: cli.c
===================================================================
RCS file: /usr/cvsroot/asterisk/cli.c,v
retrieving revision 1.71
retrieving revision 1.72
diff -u -d -r1.71 -r1.72
--- cli.c 1 Feb 2005 07:09:56 -0000 1.71
+++ cli.c 5 Feb 2005 16:49:14 -0000 1.72
@@ -250,7 +250,12 @@
static char version_help[] =
"Usage: show version\n"
-" Shows Asterisk version information.\n ";
+" Shows Asterisk version information.\n";
+
+static char uptime_help[] =
+"Usage: show uptime [seconds]\n"
+" Shows Asterisk uptime information.\n"
+" The seconds word returns the uptime in seconds only.\n";
static char *format_uptimestr(time_t timeval)
{
@@ -333,22 +338,35 @@
{
time_t curtime, tmptime;
char *timestr;
+ int printsec;
+
+ printsec = ((argc == 3) && (!strcasecmp(argv[2],"seconds")));
+ if ((argc != 2) && (!printsec))
+ return RESULT_SHOWUSAGE;
time(&curtime);
if (ast_startuptime) {
tmptime = curtime - ast_startuptime;
- timestr = format_uptimestr(tmptime);
- if (timestr) {
- ast_cli(fd, "System uptime: %s\n", timestr);
- free(timestr);
+ if (printsec) {
+ ast_cli(fd, "System uptime: %lu\n",tmptime);
+ } else {
+ timestr = format_uptimestr(tmptime);
+ if (timestr) {
+ ast_cli(fd, "System uptime: %s\n", timestr);
+ free(timestr);
+ }
}
}
if (ast_lastreloadtime) {
tmptime = curtime - ast_lastreloadtime;
- timestr = format_uptimestr(tmptime);
- if (timestr) {
- ast_cli(fd, "Last reload: %s\n", timestr);
- free(timestr);
+ if (printsec) {
+ ast_cli(fd, "Last reload: %lu\n", tmptime);
+ } else {
+ timestr = format_uptimestr(tmptime);
+ if ((timestr) && (!printsec)) {
+ ast_cli(fd, "Last reload: %s\n", timestr);
+ free(timestr);
+ }
}
}
return RESULT_SUCCESS;
@@ -782,7 +800,7 @@
{ { "show", "channels", NULL }, handle_chanlist, "Display information on channels", chanlist_help },
{ { "show", "modules", NULL }, handle_modlist, "List modules and info", modlist_help },
{ { "show", "modules", "like", NULL }, handle_modlist, "List modules and info", modlist_help, complete_mod_4 },
- { { "show", "uptime", NULL }, handle_showuptime, "Show uptime information", modlist_help },
+ { { "show", "uptime", NULL }, handle_showuptime, "Show uptime information", uptime_help },
{ { "show", "version", NULL }, handle_version, "Display version info", version_help },
{ { "soft", "hangup", NULL }, handle_softhangup, "Request a hangup on a given channel", softhangup_help, complete_ch_3 },
{ { "unload", NULL }, handle_unload, "Unload a dynamic module by name", unload_help, complete_fn },
More information about the svn-commits
mailing list