Skip to content
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

Documentation for implementation-defined behaviors #5149

Open
FrankHB opened this issue Nov 26, 2024 · 3 comments
Open

Documentation for implementation-defined behaviors #5149

FrankHB opened this issue Nov 26, 2024 · 3 comments
Labels
documentation Related to documentation or comments

Comments

@FrankHB
Copy link

FrankHB commented Nov 26, 2024

Documentataion for implementation-defined beahviors are part of conformance to ISO C++. The standard requires them to be defined in the documentation of the implementation. Where are they maintained?

Currently, nothing about them are in docs, which can be a surprise, e.g. compared to libc++.

I find no entry about them on learn.microsoft.com. There was a bug but closed as "not a bug" in favor of the language reference.

Despite the status of the core language documentation (irrelavant here) and the fact of lacking a list of implementation-defined behavior as the index of the standard, I find some are too insufficient to be usable at all. For example, list::iterator is an alias of some implementation-defined type, and the document just renders it "implementation-defined", but where is the definition? Although libstdc++ effectively undermines this as unspecified and libc++ is simply missing such entries (hence buggy), copying the text of "implementation-defined" as-is from the standard should not be complete.

For the sake of maintability, the documentation of the library can be better maintained in this repository. If this is out of the scope, clarification and pointing to the right place in README.md should improve the status a bit.

@frederick-vs-ja
Copy link
Contributor

For example, list::iterator is an alias of some implementation-defined type, and the document just renders it "implementation-defined", but where is the definition?

Oops, perhaps we should ask LWG what should be documented for iterator types of containers. It seems that implementations tend to treat them as "unspecified" implementation details together with expostion-only iterator types.

@CaseyCarter CaseyCarter added the documentation Related to documentation or comments label Nov 26, 2024
@CaseyCarter
Copy link
Contributor

Oops, perhaps we should ask LWG what should be documented for iterator types of containers. It seems that implementations tend to treat them as "unspecified" implementation details together with expostion-only iterator types.

While not a comment on other uses of "implementation-defined", I think using iterator = implementation-defined; has passed its era of usefulness in the standard. There aren't useful properties of an iterator type that users can't observe directly in the language / library. It might be less work to file an LWG issue to change some implementation-defined items to unspecified than to figure out what to document.

@StephanTLavavej
Copy link
Member

As long as such documentation is kept in the docs subdirectory (next to import_library.md), this would be fine. (I have an over-my-dead-body objection to "bloaty XML comments" in the product code, like what appears in ConcRT, as they massively interfere with code readability. 🤮 😹)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation Related to documentation or comments
Projects
None yet
Development

No branches or pull requests

4 participants