Edit report at http://bugs.php.net/bug.php?id=48465&edit=1

 ID:                 48465
 Updated by:         paj...@php.net
 Reported by:        marcel dot esser at gmail dot com
 Summary:            sys_get_temp_dir() possibly inconsistent when using
                     TMPDIR
-Status:             Assigned
+Status:             Closed
 Type:               Bug
 Package:            Scripting Engine problem
 Operating System:   *
 PHP Version:        5.*, 6CVS (2009-06-04)
 Assigned To:        pajoye
 Block user comment: N
 Private report:     N



Previous Comments:
------------------------------------------------------------------------
[2011-03-28 18:43:55] paj...@php.net

Automatic comment from SVN on behalf of pajoye
Revision: http://svn.php.net/viewvc/?view=revision&revision=309792
Log: -  Fixed bug #48465 (sys_get_temp_dir() possibly inconsistent,
windows fix

------------------------------------------------------------------------
[2011-03-28 15:35:33] paj...@php.net

Not fixed on windows

------------------------------------------------------------------------
[2009-06-24 12:21:54] il...@php.net

This bug has been fixed in CVS.

Snapshots of the sources are packaged every three hours; this change
will be in the next snapshot. You can grab the snapshot at
http://snaps.php.net/.
 
Thank you for the report, and for helping us make PHP better.



------------------------------------------------------------------------
[2009-06-04 11:57:05] j...@php.net

It's not MacOSX specific, you can always set TMPDIR whatever you want.

------------------------------------------------------------------------
[2009-06-04 06:23:14] marcel dot esser at gmail dot com

Alternative patch:



--- php52/php5/main/php_open_temporary_file.c   2009-06-03
13:42:44.000000000 -0400

+++ /Users/marcelesser/php_open_temporary_file.c        2009-06-04
02:19:29.000000000 -0400

@@ -200,9 +200,18 @@

        {

                char* s = getenv("TMPDIR");

                if (s) {

-                       temporary_directory = strdup(s);

+                       int last_char_idx = strlen(s) - 1;

+

+                       /* on some systems (notably mac os x) TMPDIR has a
DIRECTORY_SEPARATOR appended */

+                       if(s[last_char_idx] == DEFAULT_SLASH) {

+                               temporary_directory = 
tsrm_strndup(s,last_char_idx);

+                       } else {

+                               temporary_directory = strdup(s);

+                       }

+

                        return temporary_directory;

                }

+

        }

 #ifdef P_tmpdir

        /* Use the standard default temporary directory. */

------------------------------------------------------------------------


The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at

    http://bugs.php.net/bug.php?id=48465


-- 
Edit this bug report at http://bugs.php.net/bug.php?id=48465&edit=1

Reply via email to