Commit a1d57ca1 authored by Sergei Golubchik's avatar Sergei Golubchik Committed by Vladislav Vaintroub

bugfix: EE_OPEN_WARNING could be statistically wrong

don't rely on imprecise my_file_opened | my_stream_opened,
scan the array for open handles instead.

also, remove my_print_open_files() and embed it in my_end()
to have one array scan instead of two.
parent 5c81cb88
...@@ -734,12 +734,6 @@ void my_create_backup_name(char *to, const char *from, ...@@ -734,12 +734,6 @@ void my_create_backup_name(char *to, const char *from,
extern int my_copystat(const char *from, const char *to, int MyFlags); extern int my_copystat(const char *from, const char *to, int MyFlags);
extern char * my_filename(File fd); extern char * my_filename(File fd);
#ifdef EXTRA_DEBUG
void my_print_open_files(void);
#else
#define my_print_open_files()
#endif
extern my_bool init_tmpdir(MY_TMPDIR *tmpdir, const char *pathlist); extern my_bool init_tmpdir(MY_TMPDIR *tmpdir, const char *pathlist);
extern char *my_tmpdir(MY_TMPDIR *tmpdir); extern char *my_tmpdir(MY_TMPDIR *tmpdir);
extern void free_tmpdir(MY_TMPDIR *tmpdir); extern void free_tmpdir(MY_TMPDIR *tmpdir);
......
...@@ -158,17 +158,33 @@ void my_end(int infoflag) ...@@ -158,17 +158,33 @@ void my_end(int infoflag)
} }
if ((infoflag & MY_CHECK_ERROR) || print_info) if ((infoflag & MY_CHECK_ERROR) || print_info)
{ /* Test if some file is left open */
char ebuff[512];
uint i, open_files, open_streams;
{ /* Test if some file is left open */ for (open_streams= open_files= i= 0 ; i < my_file_limit ; i++)
if (my_file_opened | my_stream_opened) {
if (my_file_info[i].type == UNOPEN)
continue;
if (my_file_info[i].type == STREAM_BY_FOPEN ||
my_file_info[i].type == STREAM_BY_FDOPEN)
open_streams++;
else
open_files++;
#ifdef EXTRA_DEBUG
fprintf(stderr, EE(EE_FILE_NOT_CLOSED), my_file_info[i].name, i);
fputc('\n', stderr);
#endif
}
if (open_files || open_streams)
{ {
char ebuff[512];
my_snprintf(ebuff, sizeof(ebuff), EE(EE_OPEN_WARNING), my_snprintf(ebuff, sizeof(ebuff), EE(EE_OPEN_WARNING),
my_file_opened, my_stream_opened); open_files, open_streams);
my_message_stderr(EE_OPEN_WARNING, ebuff, ME_BELL); my_message_stderr(EE_OPEN_WARNING, ebuff, ME_BELL);
DBUG_PRINT("error", ("%s", ebuff)); DBUG_PRINT("error", ("%s", ebuff));
my_print_open_files();
} }
#ifdef CHECK_UNLIKELY #ifdef CHECK_UNLIKELY
end_my_likely(info_file); end_my_likely(info_file);
#endif #endif
......
...@@ -161,26 +161,3 @@ File my_register_filename(File fd, const char *FileName, enum file_type ...@@ -161,26 +161,3 @@ File my_register_filename(File fd, const char *FileName, enum file_type
} }
DBUG_RETURN(-1); DBUG_RETURN(-1);
} }
#ifdef EXTRA_DEBUG
void my_print_open_files(void)
{
if (my_file_opened | my_stream_opened)
{
uint i;
for (i= 0 ; i < my_file_limit ; i++)
{
if (my_file_info[i].type != UNOPEN)
{
fprintf(stderr, EE(EE_FILE_NOT_CLOSED), my_file_info[i].name, i);
fputc('\n', stderr);
}
}
}
}
#endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment