diff options
| author | MySQL Team <mysql@php.net> | 2001-01-23 16:48:50 +0000 | 
|---|---|---|
| committer | MySQL Team <mysql@php.net> | 2001-01-23 16:48:50 +0000 | 
| commit | 800f555b707c696798877c80352ded46289e87c4 (patch) | |
| tree | c540242b6e6da4e9b99b46797a26b215abef0a64 /ext/mysql/libmysql/my_fopen.c | |
| parent | d36858681a0d48414702524ebd16f31289b06fa8 (diff) | |
| download | php-git-800f555b707c696798877c80352ded46289e87c4.tar.gz | |
Upgrade ext/mysql/libmysql to version 3.23.32.  One notable bug fix is
that the client can now connect to a server which is using a default
charset other than latin1.
Diffstat (limited to 'ext/mysql/libmysql/my_fopen.c')
| -rw-r--r-- | ext/mysql/libmysql/my_fopen.c | 27 | 
1 files changed, 18 insertions, 9 deletions
| diff --git a/ext/mysql/libmysql/my_fopen.c b/ext/mysql/libmysql/my_fopen.c index 4930572e3f..5e6cd6682a 100644 --- a/ext/mysql/libmysql/my_fopen.c +++ b/ext/mysql/libmysql/my_fopen.c @@ -30,7 +30,10 @@ FILE *my_fopen(const char *FileName, int Flags, myf MyFlags)        so we can ignore if this doesn't work.      */      if ((uint) fileno(fd) >= MY_NFILE) +    { +      thread_safe_increment(my_stream_opened,&THR_LOCK_open);        DBUG_RETURN(fd);				/* safeguard */ +    }      pthread_mutex_lock(&THR_LOCK_open);      if ((my_file_info[fileno(fd)].name = (char*)  	 my_strdup(FileName,MyFlags))) @@ -73,11 +76,12 @@ int my_fclose(FILE *fd, myf MyFlags)        my_error(EE_BADCLOSE, MYF(ME_BELL+ME_WAITTANG),  	       my_filename(file),errno);    } +  else +    my_stream_opened--;    if ((uint) file < MY_NFILE && my_file_info[file].type != UNOPEN)    {      my_file_info[file].type = UNOPEN; -    my_free(my_file_info[file].name, MYF(0)); -    my_stream_opened--; +    my_free(my_file_info[file].name, MYF(MY_ALLOW_ZERO_PTR));    }    pthread_mutex_unlock(&THR_LOCK_open);    DBUG_RETURN(err); @@ -85,11 +89,9 @@ int my_fclose(FILE *fd, myf MyFlags)  	/* Make a stream out of a file handle */ +	/* Name may be 0 */ -FILE *my_fdopen(File Filedes, int Flags, myf MyFlags) - -				/* Read | write .. */ -				/* Special flags */ +FILE *my_fdopen(File Filedes, const char *name, int Flags, myf MyFlags)  {    FILE *fd;    char type[5]; @@ -107,11 +109,18 @@ FILE *my_fdopen(File Filedes, int Flags, myf MyFlags)    else    {      pthread_mutex_lock(&THR_LOCK_open); -    if (my_file_info[Filedes].type != UNOPEN) +    my_stream_opened++; +    if (Filedes < MY_NFILE)      { +      if (my_file_info[Filedes].type != UNOPEN) +      { +        my_file_opened--;			/* File is opened with my_open ! */ +      } +      else +      { +        my_file_info[Filedes].name=  my_strdup(name,MyFlags); +      }        my_file_info[Filedes].type = STREAM_BY_FDOPEN; -      my_file_opened--;			/* File is opened with my_open ! */ -      my_stream_opened++;      }      pthread_mutex_unlock(&THR_LOCK_open);    } | 
