--- "Frank M. Kromann" <[EMAIL PROTECTED]> wrote:

> I'm running on Windows XP and using MSSQL server 7.0 and 2000 both
> with the latest service packs.
> 
> PHP 4.3.5-dev (cli) (built: Nov  4 2003 16:23:54)
> Copyright (c) 1997-2003 The PHP Group
> Zend Engine v1.3.0, Copyright (c) 1998-2003 Zend Technologies
> 
> ntwdblib is 2000.2.8.0
> 

Frank,

I've found the reason for the crash in the bug report, although I can't
explain why we are getting such different outcomes.  The current
PHP_RSHUTDOWN_FUNCTION(mssql) is:

PHP_RSHUTDOWN_FUNCTION(mssql)
{
        STR_FREE(MS_SQL_G(appname));
        if (MS_SQL_G(server_message)) {
                STR_FREE(MS_SQL_G(server_message));
        }
        return SUCCESS;
}

The string is free'd, but the MS_SQL_G(server_message) isn't properly
reset to empty_string.  If I change this to:

PHP_RSHUTDOWN_FUNCTION(mssql)
{
        STR_FREE(MS_SQL_G(appname));
        if (MS_SQL_G(server_message)) {
                STR_FREE(MS_SQL_G(server_message));
                MS_SQL_G(server_message) = empty_string;
        }
        return SUCCESS;
}

then the crash goes away.  (For consistancy sake the
"MS_SQL_G(server_message) = NULL;" on line 1315 should probably be
changed to "= empty_string" also.)

When I run the query in the bug report the call to mssql_query only
processes the first chunk of statements of the multi-statement query
and it holds on to the output of the rest of them.  They remainder
don't actually end up getting processed until during the call to
dbclose() in _close_mssql_link.  The output I end up seeing is:

Warning: mssql_query(): message: Cannot insert the value NULL into
column 'myFie
ld1', table 'myDB.dbo.myTable'; column does not allow nulls. INSERT
fails. (seve
rity 16) in c:\temp\test.php on line 30
Result is true
DB Error is The statement has been terminated.

Warning: Unknown(): message: Some error (severity 18) in Unknown on
line 0

Note that the "Some error" message comes after all the other output
lines and has no script location tied to it.  I'm going to continue to
dig into this.  Please let me know if you have any thoughts about where
I might look.

Michael

__________________________________
Do you Yahoo!?
Free Pop-Up Blocker - Get it now
http://companion.yahoo.com/

-- 
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to