-
Notifications
You must be signed in to change notification settings - Fork 2.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fmt::join() not working without formatter specialisation #2040
Comments
I think adding support for streamable types is reasonable. PRs are welcome. |
kamibo
added a commit
to kamibo/fmt
that referenced
this issue
Dec 4, 2020
kamibo
added a commit
to kamibo/fmt
that referenced
this issue
Dec 7, 2020
kamibo
added a commit
to kamibo/fmt
that referenced
this issue
Dec 7, 2020
kamibo
added a commit
to kamibo/fmt
that referenced
this issue
Dec 8, 2020
kamibo
added a commit
to kamibo/fmt
that referenced
this issue
Dec 8, 2020
vitaut
pushed a commit
that referenced
this issue
Dec 8, 2020
tchaikov
added a commit
to tchaikov/ceph
that referenced
this issue
Jul 25, 2022
* add formatter for classes with stream insertion operator. as in fmtlib v6.1.2, which is the one shipped with ubuntu focal, fmt::join() requires the printed element to have formatter. see fmtlib/fmt#2040 and fmtlib/fmt#1462 * use template parameter pack to represent container template argument, simpler this way. also, this enables us to print specialized classes which uses non-default template parameters. * use fmt::join() to print container elements. see also https://fmt.dev/latest/api.html#_CPPv4I0EN3fmt4joinE9join_viewIN6detail10iterator_tI5RangeEEN6detail10sentinel_tI5RangeEEERR5Range11string_view Signed-off-by: Kefu Chai <tchaikov@gmail.com>
tchaikov
added a commit
to tchaikov/ceph
that referenced
this issue
Jul 25, 2022
* add formatter for classes with stream insertion operator. as in fmtlib v6.1.2, which is the one shipped with ubuntu focal, fmt::join() requires the printed element to have formatter. see fmtlib/fmt#2040 and fmtlib/fmt#1462 * use template parameter pack to represent container template argument, simpler this way. also, this enables us to print specialized classes which uses non-default template parameters. * use fmt::join() to print container elements. see also https://fmt.dev/latest/api.html#_CPPv4I0EN3fmt4joinE9join_viewIN6detail10iterator_tI5RangeEEN6detail10sentinel_tI5RangeEEERR5Range11string_view Signed-off-by: Kefu Chai <tchaikov@gmail.com>
tchaikov
added a commit
to tchaikov/ceph
that referenced
this issue
Jul 25, 2022
* add formatter for classes with stream insertion operator. as in fmtlib v6.1.2, which is the one shipped with ubuntu focal, fmt::join() requires the printed element to have formatter. see fmtlib/fmt#2040 and fmtlib/fmt#1462 * use template parameter pack to represent container template argument, simpler this way. also, this enables us to print specialized classes which uses non-default template parameters. * use fmt::join() to print container elements. see also https://fmt.dev/latest/api.html#_CPPv4I0EN3fmt4joinE9join_viewIN6detail10iterator_tI5RangeEEN6detail10sentinel_tI5RangeEEERR5Range11string_view Signed-off-by: Kefu Chai <tchaikov@gmail.com>
dparmar18
pushed a commit
to ceph/ceph-ci
that referenced
this issue
Jul 27, 2022
* add formatter for classes with stream insertion operator. as in fmtlib v6.1.2, which is the one shipped with ubuntu focal, fmt::join() requires the printed element to have formatter. see fmtlib/fmt#2040 and fmtlib/fmt#1462 * use template parameter pack to represent container template argument, simpler this way. also, this enables us to print specialized classes which uses non-default template parameters. * use fmt::join() to print container elements. see also https://fmt.dev/latest/api.html#_CPPv4I0EN3fmt4joinE9join_viewIN6detail10iterator_tI5RangeEEN6detail10sentinel_tI5RangeEEERR5Range11string_view Signed-off-by: Kefu Chai <tchaikov@gmail.com>
dparmar18
pushed a commit
to ceph/ceph-ci
that referenced
this issue
Jul 28, 2022
* add formatter for classes with stream insertion operator. as in fmtlib v6.1.2, which is the one shipped with ubuntu focal, fmt::join() requires the printed element to have formatter. see fmtlib/fmt#2040 and fmtlib/fmt#1462 * use template parameter pack to represent container template argument, simpler this way. also, this enables us to print specialized classes which uses non-default template parameters. * use fmt::join() to print container elements. see also https://fmt.dev/latest/api.html#_CPPv4I0EN3fmt4joinE9join_viewIN6detail10iterator_tI5RangeEEN6detail10sentinel_tI5RangeEEERR5Range11string_view Signed-off-by: Kefu Chai <tchaikov@gmail.com>
nizamial09
pushed a commit
to ceph/ceph-ci
that referenced
this issue
Aug 1, 2022
* add formatter for classes with stream insertion operator. as in fmtlib v6.1.2, which is the one shipped with ubuntu focal, fmt::join() requires the printed element to have formatter. see fmtlib/fmt#2040 and fmtlib/fmt#1462 * use template parameter pack to represent container template argument, simpler this way. also, this enables us to print specialized classes which uses non-default template parameters. * use fmt::join() to print container elements. see also https://fmt.dev/latest/api.html#_CPPv4I0EN3fmt4joinE9join_viewIN6detail10iterator_tI5RangeEEN6detail10sentinel_tI5RangeEEERR5Range11string_view Signed-off-by: Kefu Chai <tchaikov@gmail.com>
nizamial09
pushed a commit
to ceph/ceph-ci
that referenced
this issue
Aug 2, 2022
* add formatter for classes with stream insertion operator. as in fmtlib v6.1.2, which is the one shipped with ubuntu focal, fmt::join() requires the printed element to have formatter. see fmtlib/fmt#2040 and fmtlib/fmt#1462 * use template parameter pack to represent container template argument, simpler this way. also, this enables us to print specialized classes which uses non-default template parameters. * use fmt::join() to print container elements. see also https://fmt.dev/latest/api.html#_CPPv4I0EN3fmt4joinE9join_viewIN6detail10iterator_tI5RangeEEN6detail10sentinel_tI5RangeEEERR5Range11string_view Signed-off-by: Kefu Chai <tchaikov@gmail.com>
bosc0
pushed a commit
to bosc0/ceph
that referenced
this issue
Aug 16, 2022
* add formatter for classes with stream insertion operator. as in fmtlib v6.1.2, which is the one shipped with ubuntu focal, fmt::join() requires the printed element to have formatter. see fmtlib/fmt#2040 and fmtlib/fmt#1462 * use template parameter pack to represent container template argument, simpler this way. also, this enables us to print specialized classes which uses non-default template parameters. * use fmt::join() to print container elements. see also https://fmt.dev/latest/api.html#_CPPv4I0EN3fmt4joinE9join_viewIN6detail10iterator_tI5RangeEEN6detail10sentinel_tI5RangeEEERR5Range11string_view Signed-off-by: Kefu Chai <tchaikov@gmail.com>
Pegonzal
pushed a commit
to ceph/ceph
that referenced
this issue
Oct 13, 2022
* add formatter for classes with stream insertion operator. as in fmtlib v6.1.2, which is the one shipped with ubuntu focal, fmt::join() requires the printed element to have formatter. see fmtlib/fmt#2040 and fmtlib/fmt#1462 * use template parameter pack to represent container template argument, simpler this way. also, this enables us to print specialized classes which uses non-default template parameters. * use fmt::join() to print container elements. see also https://fmt.dev/latest/api.html#_CPPv4I0EN3fmt4joinE9join_viewIN6detail10iterator_tI5RangeEEN6detail10sentinel_tI5RangeEEERR5Range11string_view Signed-off-by: Kefu Chai <tchaikov@gmail.com>
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Hello,
I don't know if this is the intended behaviour, but apparently
fmt::join()
does not work for types which do not provide aformatter
specialisation, even if these types are streamable and can be formatted after the inclusion offmt/ostream.h
.Godbolt link exhibiting the issue: https://godbolt.org/z/7z3jbo
The text was updated successfully, but these errors were encountered: