Merge branch 'PHP-5.6'

* PHP-5.6:
  Fixed bug #67741 (auto_prepend_file messes up __LINE__)

Conflicts:
	main/main.c
This commit is contained in:
Reeze Xia 2015-03-03 11:44:52 +08:00
commit c6e415aeb2
3 changed files with 34 additions and 1 deletions

View File

@ -2524,8 +2524,21 @@ PHPAPI int php_execute_script(zend_file_handle *primary_file)
#endif
zend_set_timeout(INI_INT("max_execution_time"), 0);
}
retval = (zend_execute_scripts(ZEND_REQUIRE, NULL, 3, prepend_file_p, primary_file, append_file_p) == SUCCESS);
{
/*
If cli primary file has shabang line and there is a prepend file,
the `start_lineno` will be used by prepend file but not primary file,
save it and restore after prepend file been executed.
*/
int orig_start_lineno = CG(start_lineno);
CG(start_lineno) = 0;
retval = (zend_execute_scripts(ZEND_REQUIRE, NULL, 1, prepend_file_p) == SUCCESS);
CG(start_lineno) = orig_start_lineno;
retval = retval && (zend_execute_scripts(ZEND_REQUIRE, NULL, 2, primary_file, append_file_p) == SUCCESS);
}
} zend_end_try();
#if HAVE_BROKEN_GETCWD

View File

@ -0,0 +1,17 @@
--TEST--
Bug #67741 (auto_prepend_file messes up __LINE__)
--INI--
include_path={PWD}
auto_prepend_file=bug67741_stub.inc
--SKIPIF--
<?php
include "skipif.inc";
?>
--FILE--
#!/bin/env php
<?php
echo "primary lineno: ", __LINE__, "\n";
?>
--EXPECT--
prepend lineno: 2
primary lineno: 3

View File

@ -0,0 +1,3 @@
<?php
echo "prepend lineno: ", __LINE__, "\n";
?>