1. Introduction
During the Library Evolution Working Group review of [D0645R6], it has been suggested that formatting of negative floating point zero should be clarified. This is done in the current paper.
2. Status quo
Floating point formatting in [D0645R6] is expressed in terms of 
is converted to a string in the style ofvalue in theprintf locale."C" 
[N1256] doesn’t appear to explicitly specify whether 
to_chars ( begin , end , - 0.0 ); 
and
printf ( "%g" , - 0.0 ); 
produce 
3. Suppressing the output of '-' 
   In a use case Alan is familiar with the software generates dozens of tabular reports, each of which has dozens or hundreds of columns, most of which display floating point numbers. The consumers of these reports do not care about or understand negative zero, and will complain if some zeros have a minus sign. With existing output options, negative zeros appear a significant percentage of the time for no reason which a user of the software would understand. It is therefore necessary to do a floating point test for negative zero and change the floating point value in every conversion from floating point to text. This of course has been factored out into a home-grown formatting facility, which is a source of subtle bugs.
With a standard text formatting facility, 
To address this use case we could add a new format specifier to suppress the
output of 
string s1 = format ( "{0:z} {0:+z} {0:-z} {0: z}" , 0.0 ); // s1 == "0 +0 0 0" string s2 = format ( "{0:z} {0:+z} {0:-z} {0: z}" , - 0.0 ); // s2 == "0 +0 0 0" 
in addition to
string s3 = format ( "{0} {0:+} {0:-} {0: }" , 0.0 ); // s3 == "0 +0 0 0" string s4 = format ( "{0} {0:+} {0:-} {0: }" , - 0.0 ); // s4 == "-0 -0 -0 -0" 
It is possible to achieve similar functionality with [D0645R6] by providing a custom formatter:
struct dbl { double value ; dbl ( double val ) : value ( val ) {} }; template <> struct formatter < dbl > : formatter < double > { bool allow_negative_zero = true; auto parse ( format_parse_context & ctx ) { auto it = ctx . begin (), end = ctx . end (); if ( it != end && * it == 'z' ) { allow_negative_zero = false; ++ it ; } ctx . advance_to ( it ); return formatter < double >:: parse ( ctx ); } auto format ( dbl d , format_context & ctx ) { if ( ! allow_negative_zero ) d . value -= - 0.0 ; return formatter < double >:: format ( d . value , ctx ); } }; string s1 = format ( "{0:z} {0:z+} {0:z-} {0:z }" , dbl ( 0.0 )); // s1 == "0.0 +0.0 0.0 0.0" string s2 = format ( "{0:z} {0:z+} {0:z-} {0:z }" , dbl ( - 0.0 )); // s2 == "0.0 +0.0 0.0 0.0" 
It is also possible to implement a custom format function that has such behavior by default:
template < typename T > const T & maparg ( const T & value ) { return value ; } dbl maparg ( double value ) { return value ; } template < typename ... Args > string myformat ( string_view fmt , const Args & ... args ) { return format ( fmt , maparg ( args )...); } string s3 = myformat ( "{0:z} {0:z+} {0:z-} {0:z }" , 0.0 ); // s3 == "0.0 +0.0 0.0 0.0" string s4 = myformat ( "{0:z} {0:z+} {0:z-} {0:z }" , - 0.0 ); // s4 == "0.0 +0.0 0.0 0.0" 
4. Options
- 
     Don’t do anything: std :: format '-' - 0.0 std :: to_chars 
- 
     Add a format specifier to suppress the output of '-' - 0.0