miscellaneous fixes

git-svn-id: svn://svn.savannah.gnu.org/nano/trunk/nano@1707 35c25a1d-7b9e-4130-9fde-d3aeb78583b8
master
David Lawrence Ramsey 2004-04-05 01:08:14 +00:00
parent befb25a4e6
commit a3370c4232
9 changed files with 75 additions and 54 deletions

View File

@ -1,4 +1,29 @@
CVS code - CVS code -
- General:
- Minor comment cleanups. (DLR)
- files.c:
add_open_file()
- Rearrange the NANO_SMALL #ifdef so that the code to set the
MODIFIED flag in open_files->flags is included only once.
(DLR)
- search.c:
not_found_msg()
- Convert to properly handle strings generated by
display_string() that have been used in the search prompt
since 1.3.0. (David Benbennick)
do_replace_loop()
- Convert more ints used as boolean values to use TRUE and
FALSE. (David Benbennick)
- utils.c:
nstricmp(), nstrnicmp()
- Add extra blank lines for greater readability, and remove
unneeded test for n's being less than zero (since it's already
been tested for being greater than zero or equal to zero at
that point) from nstrnicmp(). (DLR)
stristr()
- Rename to nstristr() to avoid a potential conflict with an
existing stristr() function, and move up to just after
nstrnicmp(). (DLR) David Benbennick: Tweak for efficiency.
GNU nano 1.3.2 - 2004.03.31 GNU nano 1.3.2 - 2004.03.31
- General: - General:

View File

@ -785,17 +785,14 @@ int add_open_file(int update)
/* if we're updating, save current modification status (and marking /* if we're updating, save current modification status (and marking
status, if available) */ status, if available) */
if (update) { if (update) {
#ifndef NANO_SMALL
if (ISSET(MODIFIED)) if (ISSET(MODIFIED))
open_files->file_flags |= MODIFIED; open_files->file_flags |= MODIFIED;
#ifndef NANO_SMALL
if (ISSET(MARK_ISSET)) { if (ISSET(MARK_ISSET)) {
open_files->file_mark_beginbuf = mark_beginbuf; open_files->file_mark_beginbuf = mark_beginbuf;
open_files->file_mark_beginx = mark_beginx; open_files->file_mark_beginx = mark_beginx;
open_files->file_flags |= MARK_ISSET; open_files->file_flags |= MARK_ISSET;
} }
#else
if (ISSET(MODIFIED))
open_files->file_flags |= MODIFIED;
#endif #endif
} }

View File

@ -125,7 +125,7 @@ void die(const char *msg, ...)
while (open_files->next != NULL) { while (open_files->next != NULL) {
/* if we already saved the file above (i. e. if it was the /* if we already saved the file above (i.e, if it was the
currently loaded file), don't save it again */ currently loaded file), don't save it again */
if (tmp != open_files) { if (tmp != open_files) {
/* make sure open_files->fileage and fileage, and /* make sure open_files->fileage and fileage, and

View File

@ -91,7 +91,7 @@
# endif # endif
#endif #endif
/* If no strcasecmp()/strncasecmp(), use the versions we have. */ /* If no strcasecmp() or strncasecmp(), use the versions we have. */
#ifndef HAVE_STRCASECMP #ifndef HAVE_STRCASECMP
#define strcasecmp nstricmp #define strcasecmp nstricmp
#endif #endif

View File

@ -428,13 +428,13 @@ int nstricmp(const char *s1, const char *s2);
#ifndef HAVE_STRNCASECMP #ifndef HAVE_STRNCASECMP
int nstrnicmp(const char *s1, const char *s2, size_t n); int nstrnicmp(const char *s1, const char *s2, size_t n);
#endif #endif
const char *nstristr(const char *haystack, const char *needle);
#ifndef NANO_SMALL #ifndef NANO_SMALL
const char *revstrstr(const char *haystack, const char *needle, const char *revstrstr(const char *haystack, const char *needle, const
const char *rev_start); char *rev_start);
const char *revstristr(const char *haystack, const char *needle, const char *revstristr(const char *haystack, const char *needle, const
const char *rev_start); char *rev_start);
#endif #endif
const char *stristr(const char *haystack, const char *needle);
const char *strstrwrapper(const char *haystack, const char *needle, const char *strstrwrapper(const char *haystack, const char *needle,
const char *start); const char *start);
void nperror(const char *s); void nperror(const char *s);

View File

@ -326,7 +326,7 @@ void parse_syntax(char *ptr)
ptr = parse_next_regex(ptr); ptr = parse_next_regex(ptr);
newext = (exttype *)nmalloc(sizeof(exttype)); newext = (exttype *)nmalloc(sizeof(exttype));
if (nregcomp(&newext->val, fileregptr, REG_NOSUB)) if (nregcomp(&newext->val, fileregptr, REG_NOSUB) != 0)
free(newext); free(newext);
else { else {
if (endext == NULL) if (endext == NULL)
@ -413,7 +413,7 @@ void parse_colors(char *ptr)
newcolor = (colortype *)nmalloc(sizeof(colortype)); newcolor = (colortype *)nmalloc(sizeof(colortype));
fgstr = ptr; fgstr = ptr;
ptr = parse_next_regex(ptr); ptr = parse_next_regex(ptr);
if (nregcomp(&newcolor->start, fgstr, 0)) { if (nregcomp(&newcolor->start, fgstr, 0) != 0) {
free(newcolor); free(newcolor);
cancelled = 1; cancelled = 1;
} else { } else {
@ -464,7 +464,7 @@ void parse_colors(char *ptr)
if (cancelled) if (cancelled)
continue; continue;
newcolor->end = (regex_t *)nmalloc(sizeof(regex_t)); newcolor->end = (regex_t *)nmalloc(sizeof(regex_t));
if (nregcomp(newcolor->end, fgstr, 0)) { if (nregcomp(newcolor->end, fgstr, 0) != 0) {
free(newcolor->end); free(newcolor->end);
newcolor->end = NULL; newcolor->end = NULL;
} }

View File

@ -56,15 +56,11 @@ void regexp_cleanup(void)
void not_found_msg(const char *str) void not_found_msg(const char *str)
{ {
if (strlen(str) <= COLS / 2) int numchars = actual_x(str, COLS / 2);
statusbar(_("\"%s\" not found"), str);
else {
char *foo = mallocstrcpy(NULL, str);
foo[COLS / 2] = '\0'; assert(str != NULL);
statusbar(_("\"%s...\" not found"), foo); statusbar(_("\"%.*s%s\" not found"), numchars, str, str[numchars] ==
free(foo); '\0' ? "" : "...");
}
} }
void search_abort(void) void search_abort(void)
@ -580,7 +576,7 @@ int do_replace_loop(const char *needle, const filestruct *real_current,
size_t current_x_save = current_x; size_t current_x_save = current_x;
#ifdef HAVE_REGEX_H #ifdef HAVE_REGEX_H
/* The starting-line match and bol/eol regex flags. */ /* The starting-line match and bol/eol regex flags. */
int begin_line = 0, bol_or_eol = 0; int begin_line = FALSE, bol_or_eol = FALSE;
#endif #endif
#ifndef NANO_SMALL #ifndef NANO_SMALL
int mark_set = ISSET(MARK_ISSET); int mark_set = ISSET(MARK_ISSET);
@ -617,8 +613,8 @@ int do_replace_loop(const char *needle, const filestruct *real_current,
* continue. */ * continue. */
else { else {
if (current == real_current) if (current == real_current)
begin_line = 1; begin_line = TRUE;
bol_or_eol = 0; bol_or_eol = FALSE;
} }
#endif #endif
@ -660,7 +656,7 @@ int do_replace_loop(const char *needle, const filestruct *real_current,
* replace ("^", "$", or "^$"). */ * replace ("^", "$", or "^$"). */
if (ISSET(USE_REGEXP) && regexp_bol_or_eol(&search_regexp, if (ISSET(USE_REGEXP) && regexp_bol_or_eol(&search_regexp,
needle)) needle))
bol_or_eol = 1; bol_or_eol = TRUE;
#endif #endif
if (i > 0 || replaceall) { /* Yes, replace it!!!! */ if (i > 0 || replaceall) { /* Yes, replace it!!!! */

View File

@ -116,10 +116,12 @@ void sunder(char *str)
int nstricmp(const char *s1, const char *s2) int nstricmp(const char *s1, const char *s2)
{ {
assert(s1 != NULL && s2 != NULL); assert(s1 != NULL && s2 != NULL);
for (; *s1 != '\0' && *s2 != '\0'; s1++, s2++) { for (; *s1 != '\0' && *s2 != '\0'; s1++, s2++) {
if (tolower(*s1) != tolower(*s2)) if (tolower(*s1) != tolower(*s2))
break; break;
} }
return (tolower(*s1) - tolower(*s2)); return (tolower(*s1) - tolower(*s2));
} }
#endif #endif
@ -129,23 +131,45 @@ int nstricmp(const char *s1, const char *s2)
int nstrnicmp(const char *s1, const char *s2, size_t n) int nstrnicmp(const char *s1, const char *s2, size_t n)
{ {
assert(s1 != NULL && s2 != NULL); assert(s1 != NULL && s2 != NULL);
for (; n > 0 && *s1 != '\0' && *s2 != '\0'; n--, s1++, s2++) { for (; n > 0 && *s1 != '\0' && *s2 != '\0'; n--, s1++, s2++) {
if (tolower(*s1) != tolower(*s2)) if (tolower(*s1) != tolower(*s2))
break; break;
} }
if (n > 0) if (n > 0)
return (tolower(*s1) - tolower(*s2)); return (tolower(*s1) - tolower(*s2));
else if (n == 0) else if (n == 0)
return 0; return 0;
else if (n < 0) else
return -1; return -1;
} }
#endif #endif
/* This function is equivalent to strcasestr(). It was adapted from
* mutt's mutt_stristr() function. */
const char *nstristr(const char *haystack, const char *needle)
{
assert(haystack != NULL && needle != NULL);
for (; *haystack != '\0'; haystack++) {
const char *p = haystack;
const char *q = needle;
for (; tolower(*p) == tolower(*q) && *q != '\0'; p++, q++)
;
if (*q == '\0')
return haystack;
}
return NULL;
}
/* None of this is needed if we're using NANO_SMALL! */ /* None of this is needed if we're using NANO_SMALL! */
#ifndef NANO_SMALL #ifndef NANO_SMALL
const char *revstrstr(const char *haystack, const char *needle, const char *revstrstr(const char *haystack, const char *needle, const
const char *rev_start) char *rev_start)
{ {
for (; rev_start >= haystack; rev_start--) { for (; rev_start >= haystack; rev_start--) {
const char *r, *q; const char *r, *q;
@ -158,8 +182,8 @@ const char *revstrstr(const char *haystack, const char *needle,
return NULL; return NULL;
} }
const char *revstristr(const char *haystack, const char *needle, const char *revstristr(const char *haystack, const char *needle, const
const char *rev_start) char *rev_start)
{ {
for (; rev_start >= haystack; rev_start--) { for (; rev_start >= haystack; rev_start--) {
const char *r = rev_start, *q = needle; const char *r = rev_start, *q = needle;
@ -173,27 +197,6 @@ const char *revstristr(const char *haystack, const char *needle,
} }
#endif /* !NANO_SMALL */ #endif /* !NANO_SMALL */
/* This is now mutt's version (called mutt_stristr) because it doesn't
* use memory allocation to do a simple search (yuck). */
const char *stristr(const char *haystack, const char *needle)
{
const char *p, *q;
if (haystack == NULL)
return NULL;
if (needle == NULL)
return haystack;
while (*(p = haystack) != '\0') {
for (q = needle; *p != 0 && *q != 0 && tolower(*p) == tolower(*q); p++, q++)
;
if (*q == 0)
return haystack;
haystack++;
}
return NULL;
}
/* If we are searching backwards, we will find the last match that /* If we are searching backwards, we will find the last match that
* starts no later than start. Otherwise we find the first match * starts no later than start. Otherwise we find the first match
* starting no earlier than start. If we are doing a regexp search, we * starting no earlier than start. If we are doing a regexp search, we
@ -253,7 +256,7 @@ const char *strstrwrapper(const char *haystack, const char *needle,
else if (ISSET(REVERSE_SEARCH)) else if (ISSET(REVERSE_SEARCH))
return revstristr(haystack, needle, start); return revstristr(haystack, needle, start);
#endif #endif
return stristr(start, needle); return nstristr(start, needle);
} }
/* This is a wrapper for the perror() function. The wrapper takes care /* This is a wrapper for the perror() function. The wrapper takes care

View File

@ -905,7 +905,7 @@ size_t actual_x(const char *str, size_t xplus)
return i; return i;
} }
/* A strlen with tabs factored in, similar to xplustabs(). How many /* A strlen() with tabs factored in, similar to xplustabs(). How many
* columns wide are the first size characters of buf? */ * columns wide are the first size characters of buf? */
size_t strnlenpt(const char *buf, size_t size) size_t strnlenpt(const char *buf, size_t size)
{ {