diff options
Diffstat (limited to 'gnu/lib/libreadline')
-rw-r--r-- | gnu/lib/libreadline/bind.c | 21 | ||||
-rw-r--r-- | gnu/lib/libreadline/complete.c | 47 | ||||
-rw-r--r-- | gnu/lib/libreadline/display.c | 14 | ||||
-rw-r--r-- | gnu/lib/libreadline/histexpand.c | 24 | ||||
-rw-r--r-- | gnu/lib/libreadline/histfile.c | 20 | ||||
-rw-r--r-- | gnu/lib/libreadline/histlib.h | 10 | ||||
-rw-r--r-- | gnu/lib/libreadline/isearch.c | 29 | ||||
-rw-r--r-- | gnu/lib/libreadline/kill.c | 12 | ||||
-rw-r--r-- | gnu/lib/libreadline/readline.c | 8 | ||||
-rw-r--r-- | gnu/lib/libreadline/rldefs.h | 7 | ||||
-rw-r--r-- | gnu/lib/libreadline/savestring.c | 17 | ||||
-rw-r--r-- | gnu/lib/libreadline/search.c | 2 | ||||
-rw-r--r-- | gnu/lib/libreadline/shell.c | 15 | ||||
-rw-r--r-- | gnu/lib/libreadline/tilde.c | 17 | ||||
-rw-r--r-- | gnu/lib/libreadline/util.c | 6 | ||||
-rw-r--r-- | gnu/lib/libreadline/xmalloc.c | 2 | ||||
-rw-r--r-- | gnu/lib/libreadline/xmalloc.h | 2 |
17 files changed, 119 insertions, 134 deletions
diff --git a/gnu/lib/libreadline/bind.c b/gnu/lib/libreadline/bind.c index d9947c389df..fc6fe284116 100644 --- a/gnu/lib/libreadline/bind.c +++ b/gnu/lib/libreadline/bind.c @@ -1761,15 +1761,14 @@ rl_invoking_keyseqs_in_map (function, map) for (i = 0; seqs[i]; i++) { - int len = 6 + strlen(seqs[i]); - char *keyname = (char *)xmalloc (len); + char *keyname = (char *)xmalloc (6 + strlen (seqs[i])); if (key == ESC) - snprintf(keyname, len, "\\e"); + sprintf (keyname, "\\e"); else if (CTRL_CHAR (key)) - snprintf(keyname, len, "\\C-%c", _rl_to_lower (UNCTRL (key))); + sprintf (keyname, "\\C-%c", _rl_to_lower (UNCTRL (key))); else if (key == RUBOUT) - snprintf(keyname, len, "\\C-?"); + sprintf (keyname, "\\C-?"); else if (key == '\\' || key == '"') { keyname[0] = '\\'; @@ -1782,7 +1781,7 @@ rl_invoking_keyseqs_in_map (function, map) keyname[1] = '\0'; } - strlcat (keyname, seqs[i], len); + strcat (keyname, seqs[i]); free (seqs[i]); if (result_index + 2 > result_size) @@ -1936,10 +1935,9 @@ _rl_macro_dumper_internal (print_readably, map, prefix) prefix_len = prefix ? strlen (prefix) : 0; if (key == ESC) { - int len = 3 + prefix_len; - keyname = xmalloc (len); + keyname = xmalloc (3 + prefix_len); if (prefix) - strlcpy (keyname, prefix, len); + strcpy (keyname, prefix); keyname[prefix_len] = '\\'; keyname[prefix_len + 1] = 'e'; keyname[prefix_len + 2] = '\0'; @@ -1949,8 +1947,9 @@ _rl_macro_dumper_internal (print_readably, map, prefix) keyname = _rl_get_keyname (key); if (prefix) { - if (asprintf(&out, "%s%s", prefix, keyname) == -1) - memory_error_and_abort("asprintf"); + out = xmalloc (strlen (keyname) + prefix_len + 1); + strcpy (out, prefix); + strcpy (out + prefix_len, keyname); free (keyname); keyname = out; } diff --git a/gnu/lib/libreadline/complete.c b/gnu/lib/libreadline/complete.c index d5f983b0489..fb48712a4e0 100644 --- a/gnu/lib/libreadline/complete.c +++ b/gnu/lib/libreadline/complete.c @@ -459,7 +459,7 @@ print_filename (to_print, full_pathname) } #else char *s, c, *new_full_pathname; - int extension_char; + int extension_char, slen, tlen; for (s = to_print; *s; s++) { @@ -485,9 +485,16 @@ print_filename (to_print, full_pathname) s = tilde_expand (full_pathname && *full_pathname ? full_pathname : "/"); if (rl_directory_completion_hook) (*rl_directory_completion_hook) (&s); - if (asprintf(&new_full_pathname, "%s/%s", s, to_print) == -1) - memory_error_and_abort("asprintf"); + + slen = strlen (s); + tlen = strlen (to_print); + new_full_pathname = xmalloc (slen + tlen + 2); + strcpy (new_full_pathname, s); + new_full_pathname[slen] = '/'; + strcpy (new_full_pathname + slen + 1, to_print); + extension_char = stat_char (new_full_pathname); + free (new_full_pathname); to_print[-1] = c; } @@ -515,11 +522,10 @@ rl_quote_filename (s, rtype, qcp) char *qcp; { char *r; - int len = strlen(s) + 2; - r = xmalloc (len); + r = xmalloc (strlen (s) + 2); *r = *rl_completer_quote_characters; - strlcpy (r + 1, s, len - 1); + strcpy (r + 1, s); if (qcp) *qcp = *rl_completer_quote_characters; return r; @@ -814,9 +820,8 @@ compute_lcd_of_matches (match_list, matches, text) value of matches[0]. */ if (low == 0 && text && *text) { - match_list[0] = strdup(text); - if (match_list[0] == NULL) - memory_error_and_abort("strdup"); + match_list[0] = xmalloc (strlen (text) + 1); + strcpy (match_list[0], text); } else { @@ -1447,12 +1452,11 @@ username_completion_function (text, state) } else { - int len = 2 + strlen(entry->pw_name); - value = xmalloc (len); + value = xmalloc (2 + strlen (entry->pw_name)); *value = *text; - strlcpy (value + first_char_loc, entry->pw_name, len - first_char_loc); + strcpy (value + first_char_loc, entry->pw_name); if (first_char == '~') rl_filename_completion_desired = 1; @@ -1495,7 +1499,6 @@ filename_completion_function (text, state) FREE (users_dirname); filename = savestring (text); - filename_len = strlen(filename); if (*text == 0) text = "."; dirname = savestring (text); @@ -1510,15 +1513,14 @@ filename_completion_function (text, state) if (temp) { - strlcpy (filename, ++temp, filename_len); + strcpy (filename, ++temp); *temp = '\0'; } #if defined (__MSDOS__) /* searches from current directory on the drive */ else if (isalpha (dirname[0]) && dirname[1] == ':') { - /* XXX DOS strlcpy anyone? */ - strlcpy (filename, dirname + 2, filename_len); + strcpy (filename, dirname + 2); dirname[2] = '\0'; } #endif @@ -1623,13 +1625,11 @@ filename_completion_function (text, state) /* dirname && (strcmp (dirname, ".") != 0) */ if (dirname && (dirname[0] != '.' || dirname[1])) { - int templen; if (rl_complete_with_tilde_expansion && *users_dirname == '~') { dirlen = strlen (dirname); - templen = 2 + dirlen + D_NAMLEN (entry); - temp = xmalloc (templen); - strlcpy (temp, dirname, templen); + temp = xmalloc (2 + dirlen + D_NAMLEN (entry)); + strcpy (temp, dirname); /* Canonicalization cuts off any final slash present. We may need to add it back. */ if (dirname[dirlen - 1] != '/') @@ -1641,12 +1641,11 @@ filename_completion_function (text, state) else { dirlen = strlen (users_dirname); - templen = 1 + dirlen + D_NAMLEN (entry); - temp = xmalloc (templen); - strlcpy (temp, users_dirname, templen); + temp = xmalloc (1 + dirlen + D_NAMLEN (entry)); + strcpy (temp, users_dirname); } - strlcat (temp, entry->d_name, templen); + strcpy (temp + dirlen, entry->d_name); } else temp = savestring (entry->d_name); diff --git a/gnu/lib/libreadline/display.c b/gnu/lib/libreadline/display.c index c26bdf44c7a..4487004a027 100644 --- a/gnu/lib/libreadline/display.c +++ b/gnu/lib/libreadline/display.c @@ -501,7 +501,7 @@ rl_redisplay () { if (_rl_output_meta_chars == 0) { - snprintf (line + out, line_size - out, "\\%o", c); + sprintf (line + out, "\\%o", c); if (lpos + 4 >= screenwidth) { @@ -1092,8 +1092,8 @@ rl_on_new_line_with_prompt () /* Make sure the line structures hold the already-displayed prompt for redisplay. */ - strlcpy (visible_line, rl_prompt, line_size); - strlcpy (invisible_line, rl_prompt, line_size); + strcpy (visible_line, rl_prompt); + strcpy (invisible_line, rl_prompt); /* If the prompt contains newlines, take the last tail. */ prompt_last_line = strrchr (rl_prompt, '\n'); @@ -1312,7 +1312,7 @@ rl_message (va_alist) format = va_arg (args, char *); #endif - vsnprintf (msg_buf, sizeof(msg_buf), format, args); + vsprintf (msg_buf, format, args); va_end (args); rl_display_prompt = msg_buf; @@ -1324,7 +1324,7 @@ int rl_message (format, arg1, arg2) char *format; { - snprintf (msg_buf, sizeof(msg_buf), format, arg1, arg2); + sprintf (msg_buf, format, arg1, arg2); rl_display_prompt = msg_buf; (*rl_redisplay_function) (); return 0; @@ -1395,7 +1395,7 @@ _rl_make_prompt_for_search (pchar) len = (rl_prompt && *rl_prompt) ? strlen (rl_prompt) : 0; pmt = xmalloc (len + 2); if (len) - strlcpy (pmt, rl_prompt, len + 2); + strcpy (pmt, rl_prompt); pmt[len] = pchar; pmt[len+1] = '\0'; } @@ -1404,7 +1404,7 @@ _rl_make_prompt_for_search (pchar) len = *saved_local_prompt ? strlen (saved_local_prompt) : 0; pmt = xmalloc (len + 2); if (len) - strlcpy (pmt, saved_local_prompt, len + 2); + strcpy (pmt, saved_local_prompt); pmt[len] = pchar; pmt[len+1] = '\0'; local_prompt = savestring (pmt); diff --git a/gnu/lib/libreadline/histexpand.c b/gnu/lib/libreadline/histexpand.c index 4c42a213c0e..78da3e585a6 100644 --- a/gnu/lib/libreadline/histexpand.c +++ b/gnu/lib/libreadline/histexpand.c @@ -341,7 +341,7 @@ hist_error(s, start, current, errtype) int start, current, errtype; { char *temp, *emsg; - int ll, elen, len; + int ll, elen; ll = current - start; @@ -373,11 +373,11 @@ hist_error(s, start, current, errtype) break; } - len = ll + elen + 3; - temp = xmalloc (len); + temp = xmalloc (ll + elen + 3); strncpy (temp, s + start, ll); - strlcat (temp, ": ", len); - strlcat (temp, emsg, len); + temp[ll] = ':'; + temp[ll + 1] = ' '; + strcpy (temp + ll + 2, emsg); return (temp); } @@ -443,7 +443,7 @@ postproc_subst_rhs () { if (j + subst_lhs_len >= new_size) new = xrealloc (new, (new_size = new_size * 2 + subst_lhs_len)); - strlcpy (new + j, subst_lhs, new_size - j); + strcpy (new + j, subst_lhs); j += subst_lhs_len; } else @@ -754,7 +754,7 @@ history_expand_internal (string, start, end_index_ptr, ret_string, current_line) n = strlen (temp); if (n >= result_len) result = xrealloc (result, n + 2); - strlcpy (result, temp, n + 2); + strcpy (result, temp); free (temp); *end_index_ptr = i; @@ -786,7 +786,7 @@ history_expand_internal (string, start, end_index_ptr, ret_string, current_line) result_len += 128; \ result = xrealloc (result, result_len); \ } \ - strlcpy (result + j - sl, s, result_len - j + sl); \ + strcpy (result + j - sl, s); \ } \ while (0) @@ -847,7 +847,7 @@ history_expand (hstring, output) string[0] = string[1] = history_expansion_char; string[2] = ':'; string[3] = 's'; - strlcpy (string + 4, hstring, l - 4); + strcpy (string + 4, hstring); l += 4; } else @@ -966,7 +966,7 @@ history_expand (hstring, output) if (i == 0 || member (string[i - 1], HISTORY_WORD_DELIMITERS)) { temp = xmalloc (l - i + 1); - strlcpy (temp, string + i, l - i + 1); + strcpy (temp, string + i); ADD_STRING (temp); free (temp); i = l; @@ -998,7 +998,7 @@ history_expand (hstring, output) if (result) { temp = xmalloc (1 + strlen (result)); - strlcpy (temp, result, 1 + strlen(result)); + strcpy (temp, result); ADD_STRING (temp); free (temp); } @@ -1192,7 +1192,7 @@ history_arg_extract (first, last, string) for (i = first, offset = 0; i < last; i++) { - strlcpy (result + offset, list[i], size + 1 - offset); + strcpy (result + offset, list[i]); offset += strlen (list[i]); if (i + 1 < last) { diff --git a/gnu/lib/libreadline/histfile.c b/gnu/lib/libreadline/histfile.c index ad200d3051b..0b3135d2a6b 100644 --- a/gnu/lib/libreadline/histfile.c +++ b/gnu/lib/libreadline/histfile.c @@ -88,7 +88,6 @@ history_filename (filename) { char *return_val, *home; int home_len; - char dot; return_val = filename ? savestring (filename) : (char *)NULL; @@ -103,13 +102,15 @@ history_filename (filename) } home_len = strlen (home); + return_val = xmalloc (2 + home_len + 8); /* strlen(".history") == 8 */ + strcpy (return_val, home); + return_val[home_len] = '/'; #if defined (__MSDOS__) - dot = '_'; + strcpy (return_val + home_len + 1, "_history"); #else - dot = '.'; + strcpy (return_val + home_len + 1, ".history"); #endif - if (asprintf(&return_val, "%s/%c%s", home, dot, "history") == -1) - memory_error_and_abort("asprintf"); + return (return_val); } @@ -334,6 +335,7 @@ history_do_write (filename, nelements, overwrite) Suggested by Peter Ho (peter@robosts.oxford.ac.uk). */ { HIST_ENTRY **the_history; /* local */ + register int j; int buffer_size; char *buffer; @@ -344,12 +346,12 @@ history_do_write (filename, nelements, overwrite) /* Allocate the buffer, and fill it. */ buffer = xmalloc (buffer_size); - buffer[0] = '\0'; - for (i = history_length - nelements; i < history_length; i++) + for (j = 0, i = history_length - nelements; i < history_length; i++) { - strlcat (buffer, the_history[i]->line, buffer_size); - strlcat (buffer, "\n", buffer_size); + strcpy (buffer + j, the_history[i]->line); + j += strlen (the_history[i]->line); + buffer[j++] = '\n'; } write (file, buffer, buffer_size); diff --git a/gnu/lib/libreadline/histlib.h b/gnu/lib/libreadline/histlib.h index e509381791f..88a34d10f1d 100644 --- a/gnu/lib/libreadline/histlib.h +++ b/gnu/lib/libreadline/histlib.h @@ -37,10 +37,12 @@ typedef char **CPPFunction (); : ((a)[0] == (b)[0]) && (strncmp ((a), (b), (n)) == 0)) #endif -#if !defined (savestring) -extern char *xstrdup (char *); -#define savestring(x) xstrdup(x) -#endif /* !savestring */ +#ifndef savestring +# ifndef strcpy +extern char *strcpy (); +# endif +#define savestring(x) strcpy (xmalloc (1 + strlen (x)), (x)) +#endif #ifndef whitespace #define whitespace(c) (((c) == ' ') || ((c) == '\t')) diff --git a/gnu/lib/libreadline/isearch.c b/gnu/lib/libreadline/isearch.c index be051203335..952c10ddf8e 100644 --- a/gnu/lib/libreadline/isearch.c +++ b/gnu/lib/libreadline/isearch.c @@ -93,18 +93,17 @@ rl_display_search (search_string, reverse_p, where) int reverse_p, where; { char *message; - int msglen, searchlen, mlen; + int msglen, searchlen; searchlen = (search_string && *search_string) ? strlen (search_string) : 0; - mlen = searchlen + 33; - message = xmalloc (mlen); + message = xmalloc (searchlen + 33); msglen = 0; #if defined (NOTDEF) if (where != -1) { - snprintf (message, mlen, "[%d]", where + history_base); + sprintf (message, "[%d]", where + history_base); msglen = strlen (message); } #endif /* NOTDEF */ @@ -113,17 +112,20 @@ rl_display_search (search_string, reverse_p, where) if (reverse_p) { - strlcat (message, "reverse-", mlen); + strcpy (message + msglen, "reverse-"); + msglen += 8; } - strlcat (message, "i-search)`", mlen); + strcpy (message + msglen, "i-search)`"); + msglen += 10; if (search_string) { - strlcat (message, search_string, mlen); + strcpy (message + msglen, search_string); + msglen += searchlen; } - strlcat (message, "': ", mlen); + strcpy (message + msglen, "': "); rl_message ("%s", message, 0); free (message); @@ -200,9 +202,8 @@ rl_search_history (direction, invoking_key) else { /* Keep track of this so we can free it. */ - allocated_line = strdup(rl_line_buffer); - if (allocated_line == NULL) - memory_error_and_abort("strdup"); + allocated_line = xmalloc (1 + strlen (rl_line_buffer)); + strcpy (allocated_line, &rl_line_buffer[0]); lines[i] = allocated_line; } @@ -296,7 +297,7 @@ rl_search_history (direction, invoking_key) break; case CTRL ('G'): - strlcpy (rl_line_buffer, lines[orig_line], rl_line_buffer_len); + strcpy (rl_line_buffer, lines[orig_line]); rl_point = orig_point; rl_end = strlen (rl_line_buffer); rl_restore_prompt(); @@ -401,7 +402,7 @@ rl_search_history (direction, invoking_key) if (line_len >= rl_line_buffer_len) rl_extend_line_buffer (line_len); - strlcpy (rl_line_buffer, lines[i], rl_line_buffer_len); + strcpy (rl_line_buffer, lines[i]); rl_point = line_index; rl_end = line_len; last_found_line = i; @@ -415,7 +416,7 @@ rl_search_history (direction, invoking_key) not found. We use this to determine where to place rl_point. */ /* First put back the original state. */ - strlcpy (rl_line_buffer, lines[orig_line], rl_line_buffer_len); + strcpy (rl_line_buffer, lines[orig_line]); rl_restore_prompt (); diff --git a/gnu/lib/libreadline/kill.c b/gnu/lib/libreadline/kill.c index b30dd707627..c3241bdadd0 100644 --- a/gnu/lib/libreadline/kill.c +++ b/gnu/lib/libreadline/kill.c @@ -128,20 +128,18 @@ _rl_copy_to_kill_ring (text, append) /* If the last command was a kill, prepend or append. */ if (_rl_last_command_was_kill && rl_editing_mode != vi_mode) { - int len; old = rl_kill_ring[slot]; - len = 1 + strlen (old) + strlen (text); - new = xmalloc (len); + new = xmalloc (1 + strlen (old) + strlen (text)); if (append) { - strlcpy (new, old, len); - strlcat (new, text, len); + strcpy (new, old); + strcat (new, text); } else { - strlcpy (new, text, len); - strlcat (new, old, len); + strcpy (new, text); + strcat (new, old); } free (old); free (text); diff --git a/gnu/lib/libreadline/readline.c b/gnu/lib/libreadline/readline.c index 5ccc001748a..2c6aef68f48 100644 --- a/gnu/lib/libreadline/readline.c +++ b/gnu/lib/libreadline/readline.c @@ -341,7 +341,7 @@ readline_internal_teardown (eof) entry = replace_history_entry (where_history (), the_line, (histdata_t)NULL); _rl_free_history_entry (entry); - strlcpy (the_line, temp, rl_line_buffer_len); + strcpy (the_line, temp); free (temp); } @@ -1865,7 +1865,7 @@ maybe_unsave_line () if (line_len >= rl_line_buffer_len) rl_extend_line_buffer (line_len); - strlcpy (the_line, saved_line_for_history->line, rl_line_buffer_len); + strcpy (the_line, saved_line_for_history->line); rl_undo_list = (UNDO_LIST *)saved_line_for_history->data; _rl_free_history_entry (saved_line_for_history); saved_line_for_history = (HIST_ENTRY *)NULL; @@ -1948,7 +1948,7 @@ rl_get_next_history (count, key) if (line_len >= rl_line_buffer_len) rl_extend_line_buffer (line_len); - strlcpy (the_line, temp->line, rl_line_buffer_len); + strcpy (the_line, temp->line); rl_undo_list = (UNDO_LIST *)temp->data; rl_end = rl_point = strlen (the_line); #if defined (VI_MODE) @@ -2005,7 +2005,7 @@ rl_get_previous_history (count, key) if (line_len >= rl_line_buffer_len) rl_extend_line_buffer (line_len); - strlcpy (the_line, temp->line, rl_line_buffer_len); + strcpy (the_line, temp->line); rl_undo_list = (UNDO_LIST *)temp->data; rl_end = rl_point = line_len; diff --git a/gnu/lib/libreadline/rldefs.h b/gnu/lib/libreadline/rldefs.h index 35bdafccc23..e504d9b1c30 100644 --- a/gnu/lib/libreadline/rldefs.h +++ b/gnu/lib/libreadline/rldefs.h @@ -93,11 +93,10 @@ extern int _rl_stricmp (), _rl_strnicmp (); # define KEYMAP_TO_FUNCTION(data) (Function *)(data) #endif +#ifndef savestring extern char *xmalloc (); -#if !defined (savestring) -extern char *xstrdup (char *); -#define savestring(x) xstrdup(x) -#endif /* !savestring */ +#define savestring(x) strcpy (xmalloc (1 + strlen (x)), (x)) +#endif /* Possible values for _rl_bell_preference. */ #define NO_BELL 0 diff --git a/gnu/lib/libreadline/savestring.c b/gnu/lib/libreadline/savestring.c index 679adeb86e1..0916ab8b0a4 100644 --- a/gnu/lib/libreadline/savestring.c +++ b/gnu/lib/libreadline/savestring.c @@ -22,25 +22,14 @@ #include <string.h> -extern char * xmalloc(); -extern void memory_error_and_abort(char *); +extern char *strcpy (); +extern char *xmalloc (); /* Backwards compatibility, now that savestring has been removed from all `public' readline header files. */ - -char * -xstrdup(char *s) -{ - char * cp; - cp = strdup(s); - if (cp == NULL) - memory_error_and_abort("savestring"); - return(cp); -} - char * savestring (s) char *s; { - return(xstrdup(s)); + return ((char *)strcpy (xmalloc (1 + (int)strlen (s)), (s))); } diff --git a/gnu/lib/libreadline/search.c b/gnu/lib/libreadline/search.c index 8a6d42b12a3..112f8072866 100644 --- a/gnu/lib/libreadline/search.c +++ b/gnu/lib/libreadline/search.c @@ -78,7 +78,7 @@ make_history_line_current (entry) line_len = strlen (entry->line); if (line_len >= rl_line_buffer_len) rl_extend_line_buffer (line_len); - strlcpy (rl_line_buffer, entry->line, rl_line_buffer_len); + strcpy (rl_line_buffer, entry->line); rl_undo_list = (UNDO_LIST *)entry->data; rl_end = line_len; diff --git a/gnu/lib/libreadline/shell.c b/gnu/lib/libreadline/shell.c index a51e45482b3..3daef69b4c2 100644 --- a/gnu/lib/libreadline/shell.c +++ b/gnu/lib/libreadline/shell.c @@ -102,20 +102,19 @@ set_lines_and_columns (lines, cols) char *b; #if defined (HAVE_PUTENV) - if (asprintf (&b, "LINES=%d", lines) == -1) - memory_error_and_abort("asprintf"); + b = xmalloc (24); + sprintf (b, "LINES=%d", lines); putenv (b); b = xmalloc (24); - if (asprintf (&b, "COLUMNS=%d", cols) == -1) - memory_error_and_abort("asprintf"); + sprintf (b, "COLUMNS=%d", cols); putenv (b); #else /* !HAVE_PUTENV */ # if defined (HAVE_SETENV) - if (asprintf(&b, "%d", lines) == -1) - memory_error_and_abort("asprintf"); + b = xmalloc (8); + sprintf (b, "%d", lines); setenv ("LINES", b, 1); - if (asprintf (&b, "%d", cols) == -1) - memory_error_and_abort("asprintf"); + b = xmalloc (8); + sprintf (b, "%d", cols); setenv ("COLUMNS", b, 1); # endif /* HAVE_SETENV */ #endif /* !HAVE_PUTENV */ diff --git a/gnu/lib/libreadline/tilde.c b/gnu/lib/libreadline/tilde.c index c82291be6ae..009c6992396 100644 --- a/gnu/lib/libreadline/tilde.c +++ b/gnu/lib/libreadline/tilde.c @@ -63,9 +63,11 @@ extern struct passwd *getpwuid (), *getpwnam (); #endif /* !HAVE_GETPW_DECLS */ #if !defined (savestring) -extern char *xstrdup (char *); -#define savestring(x) xstrdup(x) -#endif /* !savestring */ +# ifndef strcpy +extern char *strcpy (); +# endif +#define savestring(x) strcpy (xmalloc (1 + strlen (x)), (x)) +#endif /* !savestring */ #if !defined (NULL) # if defined (__STDC__) @@ -242,8 +244,7 @@ tilde_expand (string) if ((result_index + len + 1) > result_size) result = xrealloc (result, 1 + (result_size += (len + 20))); - strlcpy (result + result_index, expansion, - result_size - result_index); + strcpy (result + result_index, expansion); result_index += len; } free (expansion); @@ -292,8 +293,8 @@ glue_prefix_and_suffix (prefix, suffix, suffind) slen = strlen (suffix + suffind); ret = xmalloc (plen + slen + 1); if (plen) - strlcpy (ret, prefix, plen + slen + 1); - strlcat (ret, suffix + suffind, plen + slen + 1); + strcpy (ret, prefix); + strcpy (ret + plen, suffix + suffind); return ret; } @@ -395,7 +396,7 @@ main (argc, argv) fflush (stdout); if (!gets (line)) - strlcpy (line, "done", sizeof(line)); + strcpy (line, "done"); if ((strcmp (line, "done") == 0) || (strcmp (line, "quit") == 0) || diff --git a/gnu/lib/libreadline/util.c b/gnu/lib/libreadline/util.c index e96a401dfd3..be9e0a9869a 100644 --- a/gnu/lib/libreadline/util.c +++ b/gnu/lib/libreadline/util.c @@ -347,9 +347,5 @@ char * _rl_savestring (s) char *s; { - char *cp; - cp = strdup(s); - if (cp == NULL) - memory_error_and_abort ("savestring"); - return(cp); + return ((char *)strcpy (xmalloc (1 + (int)strlen (s)), (s))); } diff --git a/gnu/lib/libreadline/xmalloc.c b/gnu/lib/libreadline/xmalloc.c index 0393c29f2ff..c0d06403a3c 100644 --- a/gnu/lib/libreadline/xmalloc.c +++ b/gnu/lib/libreadline/xmalloc.c @@ -40,7 +40,7 @@ /* */ /* **************************************************************** */ -void +static void memory_error_and_abort (fname) char *fname; { diff --git a/gnu/lib/libreadline/xmalloc.h b/gnu/lib/libreadline/xmalloc.h index 898d3906f09..bdf251b070a 100644 --- a/gnu/lib/libreadline/xmalloc.h +++ b/gnu/lib/libreadline/xmalloc.h @@ -42,5 +42,5 @@ extern char *xmalloc __P((int)); extern char *xrealloc __P((void *, int)); extern void xfree __P((void *)); -extern void memory_error_and_abort __P((char *)); + #endif /* _XMALLOC_H_ */ |