miscellaneous fixes
git-svn-id: svn://svn.savannah.gnu.org/nano/trunk/nano@1707 35c25a1d-7b9e-4130-9fde-d3aeb78583b8master
parent
befb25a4e6
commit
a3370c4232
25
ChangeLog
25
ChangeLog
|
@ -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:
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
10
src/proto.h
10
src/proto.h
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
20
src/search.c
20
src/search.c
|
@ -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!!!! */
|
||||||
|
|
57
src/utils.c
57
src/utils.c
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue