Skip to content

sscanf c conversion specifier #19088

Open
@hakre

Description

@hakre

Description

The following code:

<?php

$r = sscanf('     ', '%c%n', $c, $n)
and var_dump(compact('r', 'c', 'n'));

Resulted in this output:

array(3) {
  'r' =>
  int(2)
  'c' =>
  string(0) ""
  'n' =>
  int(0)
}

But I expected this output instead:

array(3) {
  'r' =>
  int(2)
  'c' =>
  string(1) " "
  'n' =>
  int(1)
}

Expectation by fscanf, scanf, sscanf - convert formatted input, cf. Revision of IEEE Std 1003.1-2008, via Open Group Base Specifications Issue 7, 2018 edition, specifically "[CX] The functionality described on this reference page is aligned with the ISO C standard. Any conflict between the requirements described here and the ISO C standard is unintentional. This volume of POSIX.1-2017 defers to the ISO C standard", quoting:

The following conversion specifiers are valid:

[...]

  • c
    • Matches a sequence of bytes of the number specified by the field width (1 if no field width is present in the conversion specification). No null byte is added. The normal skip over white-space characters shall be suppressed in this case.

For PHP versions older of that date, please refer to the equally older documentation for these dates.

Why is the expectation important?

The c conversion specifier is important to scan over white space characters, so that it adjoins the s conversion specifier (supported by PHP sscanf(), compare #11201 (comment) ) and/or leaving a space character in the $format string (supported by PHP sscanf()).


https://3v4l.org/9E2d1

8.4.10

https://3v4l.org/9E2d1	9E2d1

1:	<?php
2:	
3:	$r = sscanf('     ', '%c%n', $c, $n)
4:	and var_dump(compact('r', 'c', 'n'));
5:	
output [versions: 8.4.10 | released 2025-07-03 | took 29 ms, 18.55 MiB]
	O: array(3) {
	O:   ["r"]=>
	O:   int(2)
	O:   ["c"]=>
	O:   string(0) ""
	O:   ["n"]=>
	O:   int(0)
	O: }

+eol:

https://3v4l.org/9E2d1	9E2d1

1:	<?php
2:	
3:	$r = sscanf('     ', '%c%n', $c, $n)
4:	and var_dump(compact('r', 'c', 'n'));
5:	
output [versions: 4.3.2 - 4.3.11, 4.4.0 - 4.4.9, 5.0.0 - 5.0.5, 5.1.0 - 5.1.6, 5.2.0 - 5.2.17, 5.3.0 - 5.3.29, 5.4.0 - 5.4.45, 5.5.0 - 5.5.38, 5.6.0 - 5.6.40, 7.0.4 - 7.0.33, 7.1.0 - 7.1.33, 7.2.0 - 7.2.34, 7.3.0 - 7.3.33, 7.4.0 - 7.4.33, 8.0.0 - 8.0.30, 8.1.0 - 8.1.33, 8.2.0 - 8.2.29, 8.3.0 - 8.3.23, 8.4.1 - 8.4.10]
	O: array(3) {
	O:   ["r"]=>
	O:   int(2)
	O:   ["c"]=>
	O:   string(0) ""
	O:   ["n"]=>
	O:   int(0)
	O: }
output [versions: 7.0.0 - 7.0.3]
	O: array(3) {
	O:   ["r"]=>
	O:   int(2)
	O:   ["c"]=>
	O:   &string(0) ""
	O:   ["n"]=>
	O:   &int(0)
	O: }
output [versions: 4.3.0 - 4.3.1]
	O: array(3) {
	O:   ["r"]=>
	O:   int(2)
	O:   ["c"]=>
	O:   string(0) ""
	O:   ["n"]=>
	O:   string(0) ""
	O: }

PHP Version

PHP 8.4.10 (cli) (built: Jul  3 2025 12:41:53) (NTS)
Copyright (c) The PHP Group
Built by Debian
Zend Engine v4.4.10, Copyright (c) Zend Technologies
    with Zend OPcache v8.4.10, Copyright (c), by Zend Technologies
    with Xdebug v3.4.4, Copyright (c) 2002-2025, by Derick Rethans

Operating System

No response

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions