mirror of
https://github.com/php/php-src.git
synced 2025-08-18 06:58:55 +02:00

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
80 lines
2 KiB
PHP
80 lines
2 KiB
PHP
--TEST--
|
|
json_encode() Serialization tests
|
|
--INI--
|
|
serialize_precision=-1
|
|
--SKIPIF--
|
|
<?php if (!extension_loaded("json")) print "skip"; ?>
|
|
--FILE--
|
|
<?php
|
|
|
|
class NonSerializingTest
|
|
{
|
|
public $data;
|
|
|
|
public function __construct($data)
|
|
{
|
|
$this->data = $data;
|
|
}
|
|
}
|
|
|
|
class SerializingTest extends NonSerializingTest implements JsonSerializable
|
|
{
|
|
public function jsonSerialize()
|
|
{
|
|
return $this->data;
|
|
}
|
|
}
|
|
|
|
class ValueSerializingTest extends SerializingTest
|
|
{
|
|
public function jsonSerialize()
|
|
{
|
|
return array_values(is_array($this->data) ? $this->data : get_object_vars($this->data));
|
|
}
|
|
}
|
|
|
|
class SelfSerializingTest extends SerializingTest
|
|
{
|
|
public function jsonSerialize()
|
|
{
|
|
return $this;
|
|
}
|
|
}
|
|
|
|
$adata = array(
|
|
'str' => 'foo',
|
|
'int' => 1,
|
|
'float' => 2.3,
|
|
'bool' => false,
|
|
'nil' => null,
|
|
'arr' => array(1,2,3),
|
|
'obj' => new StdClass,
|
|
);
|
|
|
|
$ndata = array_values($adata);
|
|
|
|
$odata = (object)$adata;
|
|
|
|
foreach(array('NonSerializingTest','SerializingTest','ValueSerializingTest','SelfSerializingTest') as $class) {
|
|
echo "==$class==\n";
|
|
echo json_encode(new $class($adata)), "\n";
|
|
echo json_encode(new $class($ndata)), "\n";
|
|
echo json_encode(new $class($odata)), "\n";
|
|
}
|
|
--EXPECT--
|
|
==NonSerializingTest==
|
|
{"data":{"str":"foo","int":1,"float":2.3,"bool":false,"nil":null,"arr":[1,2,3],"obj":{}}}
|
|
{"data":["foo",1,2.3,false,null,[1,2,3],{}]}
|
|
{"data":{"str":"foo","int":1,"float":2.3,"bool":false,"nil":null,"arr":[1,2,3],"obj":{}}}
|
|
==SerializingTest==
|
|
{"str":"foo","int":1,"float":2.3,"bool":false,"nil":null,"arr":[1,2,3],"obj":{}}
|
|
["foo",1,2.3,false,null,[1,2,3],{}]
|
|
{"str":"foo","int":1,"float":2.3,"bool":false,"nil":null,"arr":[1,2,3],"obj":{}}
|
|
==ValueSerializingTest==
|
|
["foo",1,2.3,false,null,[1,2,3],{}]
|
|
["foo",1,2.3,false,null,[1,2,3],{}]
|
|
["foo",1,2.3,false,null,[1,2,3],{}]
|
|
==SelfSerializingTest==
|
|
{"data":{"str":"foo","int":1,"float":2.3,"bool":false,"nil":null,"arr":[1,2,3],"obj":{}}}
|
|
{"data":["foo",1,2.3,false,null,[1,2,3],{}]}
|
|
{"data":{"str":"foo","int":1,"float":2.3,"bool":false,"nil":null,"arr":[1,2,3],"obj":{}}}
|