php-src/ext/standard/tests/file/fputcsv_variation14.phpt
Peter Kokot b746e69887 Sync leading and final newlines in *.phpt sections
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
2018-10-15 04:32:30 +02:00

357 lines
8.2 KiB
PHP

--TEST--
Test fputcsv() : usage variations - with enclosure & delimiter of two chars(read only modes)
--FILE--
<?php
/*
Prototype: array fputcsv ( resource $handle , array $fields [, string $delimiter [, string $enclosure]]] );
Description: Format line as CSV and write to the file pointer
*/
/* Testing fputcsv() to write to a file when default enclosure value and delimiter
of two chars is provided and file is opened in read only mode */
echo "*** Testing fputcsv() : with enclosure & delimiter of two chars and file opened in read mode ***\n";
/* the array is with three elements in it. Each element should be read as
1st element is delimiter, 2nd element is enclosure
and 3rd element is csv fields
*/
$csv_lists = array (
array(',', '"', array('water,fruit') ),
array(',', '"', array('"water","fruit') ),
array(',', '"', array('"water","fruit"') ),
array(' ', '^', array('^water^ ^fruit^')),
array(':', '&', array('&water&:&fruit&')),
array('=', '=', array('=water===fruit=')),
array('-', '-', array('-water--fruit-air')),
array('-', '-', array('-water---fruit---air-')),
array(':', '&', array('&""""&:&"&:,:":&,&:,,,,'))
);
$file_path = dirname(__FILE__);
$filename = "$file_path/fputcsv_variation14.tmp";
$file_modes = array ("r", "rb", "rt");
// create the file
$file_handle = fopen($filename, "w" );
if ( !$file_handle ) {
echo "Error: failed to create file $filename!\n";
exit();
}
fclose($file_handle);
$loop_counter = 1;
foreach ($csv_lists as $csv_list) {
for($mode_counter = 0; $mode_counter < count($file_modes); $mode_counter++) {
// create the file
$file_handle = fopen($filename, "w" );
if ( !$file_handle ) {
echo "Error: failed to create file $filename!\n";
exit();
}
fclose($file_handle);
echo "\n-- file opened in $file_modes[$mode_counter] --\n";
// add the content with has csv fields
$file_handle = fopen($filename, $file_modes[$mode_counter] );
if ( !$file_handle ) {
echo "Error: failed to create file $filename!\n";
exit();
}
$delimiter = $csv_list[0];
$enclosure = $csv_list[1];
$csv_field = $csv_list[2];
// write to a file in csv format
var_dump( fputcsv($file_handle, $csv_field, '++', '%%') );
// check the file pointer position and eof
var_dump( ftell($file_handle) );
var_dump( feof($file_handle) );
//close the file
fclose($file_handle);
// print the file contents
var_dump( file_get_contents($filename) );
//delete file
unlink($filename);
} //end of mode loop
} // end of foreach
echo "Done\n";
?>
--EXPECTF--
*** Testing fputcsv() : with enclosure & delimiter of two chars and file opened in read mode ***
-- file opened in r --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rb --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rt --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in r --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rb --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rt --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in r --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rb --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rt --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in r --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rb --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rt --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in r --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rb --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rt --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in r --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rb --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rt --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in r --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rb --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rt --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in r --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rb --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rt --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in r --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rb --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
-- file opened in rt --
Notice: fputcsv(): delimiter must be a single character in %s on line %d
Notice: fputcsv(): enclosure must be a single character in %s on line %d
int(0)
int(0)
bool(false)
string(0) ""
Done