mirror of
https://github.com/php/php-src.git
synced 2026-04-17 13:01:02 +02:00
This patch simplifies line endings tracked in the Git repository and syncs them to all include the LF style instead of the CRLF files. Newline characters: - LF (\n) (*nix and Mac) - CRLF (\r\n) (Windows) - CR (\r) (old Mac, obsolete) To see which line endings are in the index and in the working copy the following command can be used: `git ls-files --eol` Git additionally provides `.gitattributes` file to specify if some files need to have specific line endings on all platforms (either CRLF or LF). Changed files shouldn't cause issues on modern Windows platforms because also Git can do output conversion is core.autocrlf=true is set on Windows and use CRLF newlines in all files in the working tree. Unless CRLF files are tracked specifically, Git by default tracks all files in the index using LF newlines.
61 lines
1.6 KiB
PHP
61 lines
1.6 KiB
PHP
--TEST--
|
|
Returning a reference from a function via another function
|
|
--INI--
|
|
error_reporting = E_ALL & ~E_STRICT
|
|
--FILE--
|
|
<?php
|
|
function returnConstantByValue() {
|
|
return 100;
|
|
}
|
|
|
|
function &returnConstantByRef() {
|
|
return 100;
|
|
}
|
|
|
|
function &returnVariableByRef() {
|
|
return $GLOBALS['a'];
|
|
}
|
|
|
|
function &returnFunctionCallByRef($functionToCall) {
|
|
return $functionToCall();
|
|
}
|
|
|
|
echo "\n---> 1. Via a return by ref function call, assign by reference the return value of a function that returns by value:\n";
|
|
unset($a, $b);
|
|
$a = 4;
|
|
$b = &returnFunctionCallByRef('returnConstantByValue');
|
|
$a++;
|
|
var_dump($a, $b);
|
|
|
|
echo "\n---> 2. Via a return by ref function call, assign by reference the return value of a function that returns a constant by ref:\n";
|
|
unset($a, $b);
|
|
$a = 4;
|
|
$b = &returnFunctionCallByRef('returnConstantByRef');
|
|
$a++;
|
|
var_dump($a, $b);
|
|
|
|
echo "\n---> 3. Via a return by ref function call, assign by reference the return value of a function that returns by ref:\n";
|
|
unset($a, $b);
|
|
$a = 4;
|
|
$b = &returnFunctionCallByRef('returnVariableByRef');
|
|
$a++;
|
|
var_dump($a, $b);
|
|
|
|
?>
|
|
--EXPECTF--
|
|
---> 1. Via a return by ref function call, assign by reference the return value of a function that returns by value:
|
|
|
|
Notice: Only variable references should be returned by reference in %s on line 15
|
|
int(5)
|
|
int(100)
|
|
|
|
---> 2. Via a return by ref function call, assign by reference the return value of a function that returns a constant by ref:
|
|
|
|
Notice: Only variable references should be returned by reference in %s on line 7
|
|
int(5)
|
|
int(100)
|
|
|
|
---> 3. Via a return by ref function call, assign by reference the return value of a function that returns by ref:
|
|
int(5)
|
|
int(5)
|