[asterisk-commits] tilghman: trunk r134353 - in /trunk: doc/tex/cliprompt.tex main/asterisk.c

SVN commits to the Asterisk project asterisk-commits at lists.digium.com
Wed Jul 30 10:30:19 CDT 2008


Author: tilghman
Date: Wed Jul 30 10:30:18 2008
New Revision: 134353

URL: http://svn.digium.com/view/asterisk?view=rev&rev=134353
Log:
Add %u and %g to the ASTERISK_PROMPT settings, for username and group,
respectively.  Also, take the opportunity to clean up the CLI prompt
generation code.
(closes issue #13175)
 Reported by: eliel
 Patches: 
       cliprompt.patch uploaded by eliel (license 64)

Modified:
    trunk/doc/tex/cliprompt.tex
    trunk/main/asterisk.c

Modified: trunk/doc/tex/cliprompt.tex
URL: http://svn.digium.com/view/asterisk/trunk/doc/tex/cliprompt.tex?view=diff&rev=134353&r1=134352&r2=134353
==============================================================================
--- trunk/doc/tex/cliprompt.tex (original)
+++ trunk/doc/tex/cliprompt.tex Wed Jul 30 10:30:18 2008
@@ -12,18 +12,18 @@
     \item \%h - Full hostname
     \item \%H - Short hostname
     \item \%t - Time
+    \item \%u - Username
+    \item \%g - Groupname
     \item \%\% - Percent sign
     \item \%\# - '\#' if Asterisk is run in console mode, '$>$' if running as remote console
     \item \%Cn[;n] - Change terminal foreground (and optional background) color to specified
     A full list of colors may be found in \path{include/asterisk/term.h}
 \end{itemize}
 
-On Linux systems, you may also use:
+On systems which implement getloadavg(3), you may also use:
 
 \begin{itemize}
     \item \%l1 - Load average over past minute
     \item \%l2 - Load average over past 5 minutes
     \item \%l3 - Load average over past 15 minutes
-    \item \%l4 - Process fraction (processes running / total processes)
-    \item \%l5 - The most recently allocated pid
 \end{itemize}

Modified: trunk/main/asterisk.c
URL: http://svn.digium.com/view/asterisk/trunk/main/asterisk.c?view=diff&rev=134353&r1=134352&r2=134353
==============================================================================
--- trunk/main/asterisk.c (original)
+++ trunk/main/asterisk.c Wed Jul 30 10:30:18 2008
@@ -1991,25 +1991,34 @@
 	return (0);
 }
 
+static struct ast_str *prompt = NULL;
+
 static char *cli_prompt(EditLine *el)
 {
-	static char prompt[200];
+	char tmp[100];
 	char *pfmt;
 	int color_used = 0;
+	static int cli_prompt_changes = 0;
 	char term_code[20];
+	struct passwd *pw;
+	struct group *gr;
+
+	if (prompt == NULL) {
+		prompt = ast_str_create(100);
+	} else if (!cli_prompt_changes) {
+		return prompt->str;
+	} else {
+		ast_str_reset(prompt);
+	}
 
 	if ((pfmt = getenv("ASTERISK_PROMPT"))) {
-		char *t = pfmt, *p = prompt;
-		memset(prompt, 0, sizeof(prompt));
-		while (*t != '\0' && *p < sizeof(prompt)) {
+		char *t = pfmt;
+		struct timeval ts = ast_tvnow();
+		while (*t != '\0') {
 			if (*t == '%') {
-				char hostname[MAXHOSTNAMELEN]="";
-				int i;
-				struct timeval ts = ast_tvnow();
+				char hostname[MAXHOSTNAMELEN] = "";
+				int i, which;
 				struct ast_tm tm = { 0, };
-#ifdef linux
-				FILE *LOADAVG;
-#endif
 				int fgcolor = COLOR_WHITE, bgcolor = COLOR_BLACK;
 
 				t++;
@@ -2017,10 +2026,10 @@
 				case 'C': /* color */
 					t++;
 					if (sscanf(t, "%d;%d%n", &fgcolor, &bgcolor, &i) == 2) {
-						strncat(p, term_color_code(term_code, fgcolor, bgcolor, sizeof(term_code)),sizeof(prompt) - strlen(prompt) - 1);
+						ast_str_append(&prompt, 0, "%s", term_color_code(term_code, fgcolor, bgcolor, sizeof(term_code)));
 						t += i - 1;
 					} else if (sscanf(t, "%d%n", &fgcolor, &i) == 1) {
-						strncat(p, term_color_code(term_code, fgcolor, 0, sizeof(term_code)),sizeof(prompt) - strlen(prompt) - 1);
+						ast_str_append(&prompt, 0, "%s", term_color_code(term_code, fgcolor, 0, sizeof(term_code)));
 						t += i - 1;
 					}
 
@@ -2028,102 +2037,91 @@
 					color_used = ((fgcolor == COLOR_WHITE) && (bgcolor == COLOR_BLACK)) ? 0 : 1;
 					break;
 				case 'd': /* date */
-					if (ast_localtime(&ts, &tm, NULL))
-						ast_strftime(p, sizeof(prompt) - strlen(prompt), "%Y-%m-%d", &tm);
+					if (ast_localtime(&ts, &tm, NULL)) {
+						ast_strftime(tmp, sizeof(tmp), "%Y-%m-%d", &tm);
+						ast_str_append(&prompt, 0, "%s", tmp);
+						cli_prompt_changes++;
+					}
+					break;
+				case 'g': /* group */
+					if ((gr = getgrgid(getgid()))) {
+						ast_str_append(&prompt, 0, "%s", gr->gr_name);
+					}
 					break;
 				case 'h': /* hostname */
-					if (!gethostname(hostname, sizeof(hostname) - 1))
-						strncat(p, hostname, sizeof(prompt) - strlen(prompt) - 1);
-					else
-						strncat(p, "localhost", sizeof(prompt) - strlen(prompt) - 1);
+					if (!gethostname(hostname, sizeof(hostname) - 1)) {
+						ast_str_append(&prompt, 0, "%s", hostname);
+					} else {
+						ast_str_append(&prompt, 0, "%s", "localhost");
+					}
 					break;
 				case 'H': /* short hostname */
 					if (!gethostname(hostname, sizeof(hostname) - 1)) {
-						for (i = 0; i < sizeof(hostname); i++) {
-							if (hostname[i] == '.') {
-								hostname[i] = '\0';
-								break;
-							}
+						char *dotptr;
+						if ((dotptr = strchr(hostname, '.'))) {
+							*dotptr = '\0';
 						}
-						strncat(p, hostname, sizeof(prompt) - strlen(prompt) - 1);
-					} else
-						strncat(p, "localhost", sizeof(prompt) - strlen(prompt) - 1);
+						ast_str_append(&prompt, 0, "%s", hostname);
+					} else {
+						ast_str_append(&prompt, 0, "%s", "localhost");
+					}
 					break;
-#ifdef linux
+#ifdef HAVE_GETLOADAVG
 				case 'l': /* load avg */
 					t++;
-					if ((LOADAVG = fopen("/proc/loadavg", "r"))) {
-						float avg1, avg2, avg3;
-						int actproc, totproc, npid, which;
-						fscanf(LOADAVG, "%f %f %f %d/%d %d",
-							&avg1, &avg2, &avg3, &actproc, &totproc, &npid);
-						if (sscanf(t, "%d", &which) == 1) {
-							switch (which) {
-							case 1:
-								snprintf(p, sizeof(prompt) - strlen(prompt), "%.2f", avg1);
-								break;
-							case 2:
-								snprintf(p, sizeof(prompt) - strlen(prompt), "%.2f", avg2);
-								break;
-							case 3:
-								snprintf(p, sizeof(prompt) - strlen(prompt), "%.2f", avg3);
-								break;
-							case 4:
-								snprintf(p, sizeof(prompt) - strlen(prompt), "%d/%d", actproc, totproc);
-								break;
-							case 5:
-								snprintf(p, sizeof(prompt) - strlen(prompt), "%d", npid);
-								break;
-							}
-						}
+					if (sscanf(t, "%d", &which) == 1 && which > 0 && which <= 3) {
+						double list[3];
+						getloadavg(list, 3);
+						ast_str_append(&prompt, 0, "%.2f", list[which - 1]);
+						cli_prompt_changes++;
 					}
 					break;
 #endif
 				case 's': /* Asterisk system name (from asterisk.conf) */
-					strncat(p, ast_config_AST_SYSTEM_NAME, sizeof(prompt) - strlen(prompt) - 1);
+					ast_str_append(&prompt, 0, "%s", ast_config_AST_SYSTEM_NAME);
 					break;
 				case 't': /* time */
-					if (ast_localtime(&ts, &tm, NULL))
-						ast_strftime(p, sizeof(prompt) - strlen(prompt), "%H:%M:%S", &tm);
+					if (ast_localtime(&ts, &tm, NULL)) {
+						ast_strftime(tmp, sizeof(tmp), "%H:%M:%S", &tm);
+						ast_str_append(&prompt, 0, "%s", tmp);
+						cli_prompt_changes++;
+					}
+					break;
+				case 'u': /* username */
+					if ((pw = getpwuid(getuid()))) {
+						ast_str_append(&prompt, 0, "%s", pw->pw_name);
+					}
 					break;
 				case '#': /* process console or remote? */
-					if (!ast_opt_remote) 
-						strncat(p, "#", sizeof(prompt) - strlen(prompt) - 1);
-					else
-						strncat(p, ">", sizeof(prompt) - strlen(prompt) - 1);
+					ast_str_append(&prompt, 0, "%c", ast_opt_remote ? '>' : '#');
 					break;
 				case '%': /* literal % */
-					strncat(p, "%", sizeof(prompt) - strlen(prompt) - 1);
+					ast_str_append(&prompt, 0, "%c", '%');
 					break;
 				case '\0': /* % is last character - prevent bug */
 					t--;
 					break;
 				}
-				while (*p != '\0')
-					p++;
 				t++;
 			} else {
-				*p = *t;
-				p++;
-				t++;
+				if (prompt->used + 5 > prompt->len) {
+					ast_str_make_space(&prompt, prompt->len + 5);
+				}
+				prompt->str[prompt->used++] = *t++;
+				prompt->str[prompt->used] = '\0';
 			}
 		}
 		if (color_used) {
 			/* Force colors back to normal at end */
-			term_color_code(term_code, COLOR_WHITE, COLOR_BLACK, sizeof(term_code));
-			if (strlen(term_code) > sizeof(prompt) - strlen(prompt) - 1) {
-				ast_copy_string(prompt + sizeof(prompt) - strlen(term_code) - 1, term_code, strlen(term_code) + 1);
-			} else {
-				/* This looks wrong, but we've already checked the length of term_code to ensure it's safe */
-				strncat(p, term_code, sizeof(term_code));
-			}
-		}
-	} else if (remotehostname)
-		snprintf(prompt, sizeof(prompt), ASTERISK_PROMPT2, remotehostname);
-	else
-		ast_copy_string(prompt, ASTERISK_PROMPT, sizeof(prompt));
-
-	return(prompt);	
+			ast_str_append(&prompt, 0, "%s", term_color_code(term_code, COLOR_WHITE, COLOR_BLACK, sizeof(term_code)));
+		}
+	} else if (remotehostname) {
+		ast_str_set(&prompt, 0, ASTERISK_PROMPT2, remotehostname);
+	} else {
+		ast_str_set(&prompt, 0, "%s", ASTERISK_PROMPT);
+	}
+
+	return(prompt->str);	
 }
 
 static char **ast_el_strtoarr(char *buf)




More information about the asterisk-commits mailing list