[libcxx-commits] [PATCH] D117449: [libcxx] Constrain common_iterator's iterator_traits specialization
Arthur O'Dwyer via Phabricator via libcxx-commits
libcxx-commits at lists.llvm.org
Tue Jan 18 07:44:51 PST 2022
Quuxplusone added a comment.
@ldionne rubberstamp here as-is, and revisit in D117400 <https://reviews.llvm.org/D117400>? :)
================
Comment at: libcxx/test/std/iterators/predef.iterators/iterators.common/iterator_traits.compile.pass.cpp:55
+ static_assert(!HasIteratorConcept<IterTraits>);
+ static_assert(std::same_as<IterTraits::iterator_category, std::output_iterator_tag>);
+ static_assert(std::same_as<IterTraits::value_type, void>);
----------------
CaseyCarter wrote:
> ldionne wrote:
> > Quuxplusone wrote:
> > > Well this is weird. `non_const_deref_iterator<int*>::iterator_category` appears to be `input_iterator_tag`, but `std::common_iterator<Iter, sentinel_type<int*>>` is an output iterator instead?
> > >
> > > Also, I'm seeing now that `non_const_deref_iterator` is a template, but it's used in only one place (with `int*`), so it can be massively simplified. Would you like me to just take this over and merge it into my existing D117400?
> > Yeah, I'd like to understand this part as well.
> `input_iterator` requires that `const` iterators are dereferenceable. Hopefully it's obvious that is not the case for `non_const_deref_iterator`, so it does not trigger the `iterator_traits<common_iterator<I, S>>` partial specialization once that partial specialization is properly constrained to require `input_iterator`.
I get everything you said, but I still don't get why "`Iter` doesn't satisfy `input_iterator`" should lead us to "`iterator_traits<CommonIter>::iterator_category` is defined and is equal to `output_iterator_tag`." Like, `Iter` isn't an output iterator //either//... is it? So the most logical outcomes (in increasing order of wild-west-ness) would have been for `CommonIter` to be ill-formed, or for `CommonIter` to be well-formed but not an iterator, or for `iterator_traits<CommonIter>::iterator_category` to be defined as equal to `iterator_traits<Iter>::iterator_category`. Having it just randomly equal to `output_iterator_tag` seems bizarre!
(I'm not disputing that it's probably //correct// according to C++20; I'm just confused about both the mental model and, literally, I don't see by what codepath we end up with `output_iterator_tag`. Not that I've looked hard at all.)
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D117449/new/
https://reviews.llvm.org/D117449
More information about the libcxx-commits
mailing list