mirror of
https://github.com/php/php-src.git
synced 2024-09-22 18:37:25 +00:00
b746e69887
This patch adds missing newlines, trims multiple redundant final newlines into a single one, and trims redundant leading newlines in all *.phpt sections. According to POSIX, a line is a sequence of zero or more non-' <newline>' characters plus a terminating '<newline>' character. [1] Files should normally have at least one final newline character. C89 [2] and later standards [3] mention a final newline: "A source file that is not empty shall end in a new-line character, which shall not be immediately preceded by a backslash character." Although it is not mandatory for all files to have a final newline fixed, a more consistent and homogeneous approach brings less of commit differences issues and a better development experience in certain text editors and IDEs. [1] http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap03.html#tag_03_206 [2] https://port70.net/~nsz/c/c89/c89-draft.html#2.1.1.2 [3] https://port70.net/~nsz/c/c99/n1256.html#5.1.1.2
192 lines
4.5 KiB
PHP
192 lines
4.5 KiB
PHP
--TEST--
|
|
Test fgetcsv() : usage variations - with default enclosure, line without any csv fields
|
|
--FILE--
|
|
<?php
|
|
/*
|
|
Prototype: array fgetcsv ( resource $handle [, int $length [, string $delimiter [, string $enclosure]]] );
|
|
Description: Gets line from file pointer and parse for CSV fields
|
|
*/
|
|
|
|
/*
|
|
Testing fgetcsv() to read a line without any csv fields from a file
|
|
when provided with default enclosure value
|
|
*/
|
|
|
|
echo "*** Testing fgetcsv() : with default enclosure, line without any csv fields ***\n";
|
|
|
|
$filename = dirname(__FILE__) . '/fgetcsv_variation20.tmp';
|
|
@unlink($filename);
|
|
|
|
$file_modes = array ("r","rb", "rt", "r+", "r+b", "r+t",
|
|
"a+", "a+b", "a+t",
|
|
"w+", "w+b", "w+t",
|
|
"x+", "x+b", "x+t");
|
|
|
|
$loop_counter = 1;
|
|
for($mode_counter = 0; $mode_counter < count($file_modes); $mode_counter++) {
|
|
// create the file and add the content with has csv fields
|
|
if ( strstr($file_modes[$mode_counter], "r") ) {
|
|
$file_handle = fopen($filename, "w");
|
|
} else {
|
|
$file_handle = fopen($filename, $file_modes[$mode_counter] );
|
|
}
|
|
if ( !$file_handle ) {
|
|
echo "Error: failed to create file $filename!\n";
|
|
exit();
|
|
}
|
|
// write line of text
|
|
fwrite($file_handle, "This is line of text without csv fields\n");
|
|
|
|
// close the file if the mode to be used is read mode and re-open using read mode
|
|
// else rewind the file pointer to beginning of the file
|
|
if ( strstr($file_modes[$mode_counter], "r" ) ) {
|
|
fclose($file_handle);
|
|
$file_handle = fopen($filename, $file_modes[$mode_counter]);
|
|
} else {
|
|
// rewind the file pointer to bof
|
|
rewind($file_handle);
|
|
}
|
|
|
|
echo "\n-- Testing fgetcsv() with file opened using $file_modes[$mode_counter] mode --\n";
|
|
|
|
// call fgetcsv() to parse csv fields
|
|
|
|
// read the line which is without csv fields, provide delimiter and see the working of fgetcsv
|
|
$fp_pos = ftell($file_handle);
|
|
var_dump( fgetcsv($file_handle, 1024) );
|
|
// check the file pointer position and if eof
|
|
var_dump( ftell($file_handle) );
|
|
var_dump( feof($file_handle) );
|
|
|
|
// close the file
|
|
fclose($file_handle);
|
|
//delete file
|
|
unlink($filename);
|
|
} //end of mode loop
|
|
|
|
echo "Done\n";
|
|
?>
|
|
--EXPECT--
|
|
*** Testing fgetcsv() : with default enclosure, line without any csv fields ***
|
|
|
|
-- Testing fgetcsv() with file opened using r mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using rb mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using rt mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using r+ mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using r+b mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using r+t mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using a+ mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using a+b mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using a+t mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using w+ mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using w+b mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using w+t mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using x+ mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using x+b mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
|
|
-- Testing fgetcsv() with file opened using x+t mode --
|
|
array(1) {
|
|
[0]=>
|
|
string(39) "This is line of text without csv fields"
|
|
}
|
|
int(40)
|
|
bool(false)
|
|
Done
|