Meeting Agenda March 1, 2023
Agenda
- No meeting March 15
- Perennial/Plumhall status - haven’t got any response back from Plumhall. Have talked to Perennial, but initial feedback is that the license is not set up for opensource use.
- Status of other floating point formats, specifically DFP. Fair amount of design work and some done internally. It’s not really ready to share yet. Ariel: would like to discuss. Tom: would be happy to share current status and possibly collaborate.
- Undefined behaviour: have got a number of bug reports recently. One about unreachable, other about indeterminate values. May be related to changes and adoption of LLVM 15, may also be more awareness. Hubert: regarding indeterminate behaviour, it may be C specific. Changes in LLVM 15 have definite impact. Aaron: C committee working on this. Committee needs to engage with LLVM community. Shafik: does this warrant a Discourse discussion? Aaron/Hubert: yes, but want to make sure that discussion is not had in multiple venues. Discussion also needs to be documented. Shafik to kick off the discussion, likely on the side for now.
Round Table
- Aaron
- Largely working on code reviews
- Working on Clang 16 release work, tagging bugs. Please make sure that potential release blockers are identified
- Ariel
- Locale issue, some work relating to floating point
- Corentin
- Waiting on review from Shafik on some changes that were reverted
- Looking at start_lifetime_as issue, thinks it needs a new intrinsic
- Probably need to talk to Richard
- PR for deducing this, likely targeting Clang 17
- Fahad
- Implementing intrinsic for new type traits std::is_layout_compatible
- std::is_corresponding_member, hoping to land PR later this week
- Any discussion on extending standard testing?
- Nothing specific, but lots of discussion
- Hubert
- Responded to one of the issues that Shafik raised
- Luke
- C++20 compiles are ~10-20% slower, likely const_eval and template stuff happening. Some libc++ changes also have impact. Profiling and further investigation necessary.
- Have we seen any runtime improvements? None identified thus far. Should investigate PGO compilers with C++20 mode turned on.
- Corentin: anyone working on the const_expr interpreter? Yes for quite some time from Tim, but it’s a huge project. Some help in reviewing the PRs would be helpful.
- Tracking down a crash in modules
- Tom: tried to reproduce with preprocessed source?
- Luke: able to reproduce with a debug
- Hubert: possibly a serialization problem?
- Luke: Decl data structure is malformed
- Reach out to Chuanqi Xu (ChuanqiXu), he’s investigated something similar.
- Tom: tried to reproduce with preprocessed source?
- C++20 compiles are ~10-20% slower, likely const_eval and template stuff happening. Some libc++ changes also have impact. Profiling and further investigation necessary.
- Shafik
- Bug screening, trying to catch up on code reviews.
- Tom
- Plan to turn to DFP
- Tony
- C23 auto keyword. Reverting patch, treating auto as a type specifier. Some tests to fix to reflect the standard.
Meeting Agenda February 15, 2023
Agenda
- Feedback from Perennial - their license model doesn’t allow for us to put the tests into version control and so we’re not able to find a way for arbitrary developers to see test failures after a change to the compiler.
- GSOC proposals - looking for mentors on each project. Can reach out to Jeff on Discourse.
-
Improve C and C++ language conformance by triaging and fixing DRs
-
Issue here is that advanced C++ knowledge would be necessary, and would also require a mentor who has advanced understanding of the standard.
-
Improve C and C++ language conformance by creating new conformance test cases
-
Issue here is that advanced C++ knowledge would be necessary, and would also require a mentor who has advanced understanding of the standard,
-
Focus on newer features-concepts (maybe secondary), modules and coroutines. Template engine.
-
Often find crashes on invalid code. This may be indicative that we’re missing test coverage. Potential issues with error recovery. Finishing recovery expressions would be helpful, its an a half baked state right now. Double check with Aaron on some background.
Round Table
- Ariel
- working on locale issue reported
- Erich
- WG21 meeting
- 4 concept template based regressions that need to be worked on, potential 16.0 blocker
- Fahad
- Where are standard reference available?
- Clang - C++ Programming Language Status is the best place, has been updated recently
- Concepts is listed as partial, is it supported yet? A: not yet, still listed as partial as there is still significant bugs open.
- ICE in clang::StmtVisitorBase on shark quoted constraint nested evaluation · Issue #60642 · llvm/llvm-project · GitHub
- [Clang] [C++20] regression in Clang 16 · Issue #60749 · llvm/llvm-project · GitHub
- [16 regression] Partial specialization with constrained parameters declared in wrong order is suddenly "not more specialized" · Issue #58896 · llvm/llvm-project · GitHub
- False positive compile error when expanding packs in function parameters · Issue #58452 · llvm/llvm-project · GitHub
- Is there somewhere to find out Clang related crashes? A: there are some tags you can filter ‘crash on valid’, ‘crash on invalid’ (need to validate the exact tag)
- Started investigating MSVC Compatibility: Implement intrinsics for P0466R5 - Layout-compatibility and Pointer-interconvertibility Traits · Issue #48204 · llvm/llvm-project · GitHub
- Where are standard reference available?
- Hubert
- WG21 meeting, many followups
- D143819 review, some concern about ABI stability. Don’t have well documented criteria about ABI versioning control. Suggestion: ask Richard for his perspective.
- Shafik
- WG21 meeting, followups as well.
- January was busy on Clang bug reports, starting to die down.
- 2 bugs - fixed issue not catching unary overflow in constexpr. Found another issue but could lead to a large refactor.
- Tony
- Waiting a bit more on the auto keyword feature for C
- Vlad
- P1787 - should fix ~60 DRs on name lookup
- Extending pragma debug dump
- Extending conformance tests - wanted to discuss with Aaron about how to structure new or update existing tests.
Meeting Agenda February 1, 2023
Agenda
- Feedback from perennial/plumhall - no response. Issue is how do we get access to failures and get reproducers? Expectation is that the test cases are run on a non-visible server, and test case source is not made available.
- How do we ensure conformance? Usually a combination of test cases developed, existing tests and customer bugs
- Have we validated that unit testing is insufficient?
- One option is to set up a separate repository to accumulate test cases from elsewhere, ex. leveraging gcc test suite. Would need to be careful of GPL contamination.
- Is there interest in other test cases other than conformance, ex performance. We have some performance tracking already https://llvm-compile-time-tracker.com/
- Possibility of adding larger code bases for testing purposes? Could set up separate builders using clang trunk. Likely orthogonal.
- Action: Aaron to see if he can reengage with perennial/plumhall
- Suggestion: possibility of having perennial/plumhall to open/analyze failures
- Once pricing information is gathered, can approach LLVM foundation
- May want to have an action on end-to-end testing
- Branch split - anything to note?
- Complete last week, seems stable. Feel free to start dropping experimental items back to trunk. Although most feedback usually comes in during RC1, which is still pending.
Roundtable
- Aaron
- C standards meetings, catching up on reviews
- C++ meetings next week
- Expect code review velocity to be a bit slow
- C++23 seems on track. C has received many comments, likely needed for next CD. C23 is a bit at risk for end of year.
- Ariel
- PR for a PTR32 issue, fix re OpenCL builtins rewriting prototype for parameters passed. May want OpenCL to review.
- Fahad
- Working on a Concept issue, having parentheses on constraints in atomic clause. Waiting on review comments. To reach out to Hubert for clarification.
- C++ 20 demand? Aaron answers: concepts, const expr, modules. Seen use cases of ranges, need to validate exactly which applications. Some bug reports open.
- C++ 23? Aaron answers: still early
- Hubert
- C++ committee meeting next week
- Tracking some of the C committee traffic
- Small fix for vaopt from Shafik, still need to review
- Luke
- Some reprioritization on Google projects
- Tony
- Stopped working on C23 auto feature, waiting for news from C committee. Potential for more change after next ballot.
- Looking at github issue Clang incorrectly identifies a member variable access as a free function template name · Issue #59910 · llvm/llvm-project · GitHub, but more involved than expected. Discussing with Erich.
Meeting Agenda January 18, 2023
Agenda
- We’re branching next week on Tue Jan 24th! Try to get things you want in the Clang 16 in before the branch date, but please do not push things that are not believed to be rock solid (we’re running out of time for speculation) as those can wait for Clang 17.
- Big thanks to folks who’ve been helping get things finished up for the release, like Chuanqi’s help getting the coroutines and modules TS command line flags deprecated so we can remove them in Clang 17
Round Table
- Ariel - PTR32 change going through internal review, will take another few days
- Question for Aaron, did he follow up with Plumhall/Perennial? He did send out an email, not sure if he got a response (but probably not yet). Will follow up next time.
- Erich
- Lambda deferred instantiation - still outstanding
- Working on branch prep, catching up on reviews
- working through some of the regressions for the sugaring patches, reverting them took some time to work through
- Fahad
- Still working on the issues mentioned previously
- Looking at next work items as well, feedback appreciated
- Hubert
- Evaluating patch that changed ABI for default/deleted functions for POD, wanted to understand why people opted out of this change for Darwin. Change was for gcc compatibility.
- Gcc is not of major concern on Darwin, likely why they opted out. Clang is assumed the default ABI on those platforms.
- Is there concern about risk, or was there lack of motivation? Usually Darwin doesn’t break ABI simply for compatibility with other compilers, since Clang is the assumed de facto.
- Evaluating patch that changed ABI for default/deleted functions for POD, wanted to understand why people opted out of this change for Darwin. Change was for gcc compatibility.
- James
- Luke
- Did push patch for C++20 crash, up for review
- Shafik
- DFP implementation
- Fixed constexpr bug, not diagnosing overflows
- Tom
- Plan to push change to add diagnostic for lambdas
Meeting Agenda January 4, 2023
Agenda
- Previous proposal for test suite checking items in the standard
- Some work for C std DRs and features
- Is there some work to get a license for Plumhall/Perennial? Alternatively should we be developing a test suite ourselves
- AR: Aaron to send an email to Plumhall/Perennial to see about the possibility of supporting open source projects
Round Table
- Fahad - working on Clang conformance
- Aaron
- C committee just finished collecting national body comments, 80 pages worth. C committee meetings on Jan 23, so will be reconciling issues.
- Please ping for urgent issues.
- Ariel
- PTR32 issues, cropping up in different areas on a continuous basis. Current issue regarding builtins, expect to have something ready soon.
- Corentin
- Spent time working on visibility 2631. Number of bugs, still evaluating.
- A number of PRs waiting for lambda trailing, capture bindings. Hoping to get in to Clang 16, hoping to resolve by end of month but need some reviews.
- Deducing this ⚙ D140828 [C++] Implement "Deducing this" (P0847R7)
- Erich
- Sizeable list of bugs, if constexpr evaluation, evaluation of lambdas. Need to evaluate priorities.
- Please ping if reviews needed.
- Fahad
- Constraint normalization of a parenthesized atomic constraint yields a different expression than an identical non-parenthesized atomic constraint · Issue #50748 · llvm/llvm-project · GitHub
- Clang accepts constraint mismatch at argument in template parameter-list · Issue #49185 · llvm/llvm-project · GitHub
- clang fails to compile constexpr std::vector from libstdc++ · Issue #56167 · llvm/llvm-project · GitHub
- Started looking at the above issues
- Regarding 49185, think there was a prior patch that was submitted, any insights?
- Tom
- Mostly getting back, resolved Incorrect `__LINE__` with `-frewrite-includes` and mixed CRLF · Issue #59736 · llvm/llvm-project · GitHub
- Will get back to DFP
- Tony
- Working on C23 auto keyword, just one remaining test case to figure out
auto b = { 1, };
auto d = { 1 };
- Hubert
- C++23 papers and issues status, Corentin had updated (thanks!)
- Reviewed “Lifetime extension in range-based for loops”: https://reviews.llvm.org/D139586
- Corentin: should be easier to implement after the source location fix [can we add a comment to the review to this effect]
Meeting Agenda Nov 16, 2022
Agenda
- Will cancel the December meetings, restart in January
- Hubert: const eval propagation and range for. How to add those?
- Should show up on the cxx standard pages. Not sure if those are done for papers. May need to be done manually.
- Tom: should we add github issues
- Do we have a C++23 tracker? Not certain if this is done automatically. C++20 tracker C++ 20 in Clang · GitHub . Hubert/Aaron to see about adding C++23.
Round Table
- Aaron
- C++ standards meeting, C++23 readiness. Some issues may have impacts for Clang.
- C standard national body comments due Nov 17. Please contact Aaron if any comments should be added.
- Caught up on code reviews
- Ariel
- Erich
- C++ standards committee meetings
- Go through the concepts bugs, fix as many as possible
- Revisiting friend mangling for constrained functions, handful of bugs
- Catching up on code reviews
- Luke
- LLVM dev meeting
- Looking to pick up Concepts with parameter pack not at end silently ignores errors when used · Issue #48182 · llvm/llvm-project · GitHub
- Matheus
- LLVM dev meeting, presented on the resugaring work. Comment that we need more Clang representation
- Enabler patches, worked on performance. LLVM compile time tracker, demonstrates ~1.5% degradation, but missing one of the enabler patches.
- Working on backlog of reviews
- Hubert
- C++ standards meeting, there were 1-2 core issues that impact Clang. Will follow up and update/open issues. Answered a few open issues.
- Catching up after meetings
- Shafik
- C++ standards committee meetings, processing national body comments and defect reports
- Working on DFP, parsing simple expressions. Lowering to LLVM IR. Working on fixed point lowering.
- Triaging bugs, pushing out quick fixes.
- Extend the number of case Sema::CheckForIntOverflow covers: ⚙ D137897 Extend the number of case Sema::CheckForIntOverflow covers
- Using enum bug, patch is up: ⚙ D138091 [Clang] Fix Sema::ClassifyName so that it classifies EnumConstantDecl as NonType when they are brought into scope via using enum
- Hubert: using enum grammar was updated at meeting. Hubert to open a bug report.
- Put up blog posts on enum bugs.
- Tom
- C++ standard meeting
- Code review from John Mcall for guards for static variables
- Will be focusing on DFP going forward
- Tony
- Documentation fixes
- Reviewing patch comments on auto keyword
- Akira
- Looked at a couple of github issues 50748 and 49185
- One of the issues about class template taking a template template parameter, cases where Clang is not rejecting invalid code. Matheus was originally working on this and got some feedback from Richard Smith, may refocus on this.
Meeting Agenda Nov 2, 2022
Agenda
- Is there a value to having a standard-ese mailing list to discuss issues
- Discourse - create a private topic?
- WG21 chat service?
Round Table
- Aaron - mostly catching up on code reviews
- Preparing for C++ meetings
- Akira
- Just started looking at some github issues
- Ariel
- Corentin
- Working on getting std::source_location to work, should target for v16
- Questions for core on init captures, still not sure how it will be resolved
- Ex. void func(int a = [b = std::source_location::current().line()] { return b; }());
- Fix for identifier and unicode
- Working on getting std::source_location to work, should target for v16
- Erich
- Work through as many of the concepts defects, a little triage
- Recursive instantiation bugs, turned out to be caching issue
- Need to determine when we can set the feature macro to enable concepts, may or may not make it for upcoming release
- Away on C++ meetings next weeks
- Luke
- Working on concepts infinite recursion crash, but concede to Erich’s implementation
- Will pick up a different C++20 bug
- Hubert
- Looking at abi breaking change, POD for layout purposes: ⚙ D119051 Extend the C++03 definition of POD to include defaulted functions
- Looking at patch for C++23 const expr math: ⚙ D136568 [Clang] Support constexpr builtin ilogb
- incorrect on Power currently
- What can be constexpr in C
- what can __double names do in C?
- Tom
- Will be shifting focus to DFP (feel free to pull in Sean Perry and Hubert)
- Tony
- Finished parsing rework for auto C23 keyword
- Several tests to do, and minor bugs to fix
- Utkarsh
- Mostly working on concepts bugs, using declaration for base class in template members
- Reconciling differences between standard/clang/gcc
- Hope someone can review and provide feedback Using-decls for templated member functions should create ambiguity · Issue #58571 · llvm/llvm-project · GitHub
- SFINAE failure in a nested requirement: Hard error on `x.value` in constraint, when evaluated for a non-class type · Issue #45563 · llvm/llvm-project · GitHub need some resolution from standard
- Mostly working on concepts bugs, using declaration for base class in template members
Meeting Agenda Oct 19, 2022
Agenda
- Safe C++ RFC
- Aaron got some feedback from the Apple developers working on this. There’s a lack of a design, should be less ambiguous once that’s available.
- How are we going to deal with -Weverything warnings as a result?
Round Table
- Aaron
- Pushed changes for nullptr to C2x, pending direction from committee
- Storage durations for compound literals (C2x), existing model doesn’t work too well, seeing if we can rewrite the way we do it in C. A bit experimental at this point, may just do the parsing if it goes poorly.
- There may be a gnu extension that this proposal may collide
- Ariel
- Erich
- Working through deferred concept instantiation regressions, the way we model is insufficient. Been a lot of work trying to come up with a better way to model.
- Hubert
- Been involved in a few reviews,
- One for thread local guard
- Applications for DRs, whether they should be turned on by default. One was for preemptively option control, to remove
- Working on -p option which Clang doesn’t really implement, looking for comments on RFC
- Been involved in a few reviews,
- Reid
- Tom
- Pushed update for MS asm blocks
- Bug for bitfields in gnu, but not planning on looking at this one
- Thread local guard, agree that’s reasonable. Should respond by end of day.
- Tony
- Working on parsing rework for auto keyword patch for C23, mostly done. An extra attribute on AST.
Meeting Agenda Oct 5, 2022
Agenda
- Note that build bots are failing, is anyone taking a look into it?
- Some were failing due to C++17 changeover, but otherwise green
Round Table
- Aaron
- Nullptr review for C23, some differences from C++, still some chance that they implementation may change as WG14 locks down the specification
- Most differences from C++ seem to be edge cases, so likely won’t be hit too often
- Need to get back to Automatic type deduction proposal, hope that through review will be able to identify/resolve any discrepancies between C and C++
- Would be good to post code samples as discrepancies are found
- typeof and typeof_unqual change landed, thanks Matheus for comments
- Updating document on potential breaking changes ⚙ D134878 Update developer policy on potentially breaking changes, please update documentation and note in the announcement channel if you have any breaking changes, focus on DR fixes - please include Aaron and Hubert so they can report back to WG21 in case breaking changes are found during implementation
- Chaofan
- Corentin
- Erich
- deferred concepts implementation, mostly caught up on bugs, triaging the rest
- trying to catch up on reviews, please ping if needed
- bugs on parsing require and lookup
- RFC on stopping allowing to dereference void *, we seem to be the only implementation that does so RFC: Can we stop the extension to allow dereferencing void* in C++?
- To add as a warning, with intention of switching to error down the line
- Luke
- Matheus
- Rebased the resugaring work on top of concepts patch
- Fixed all known bugs
- One more patch in review state, need to respond. 5 other enablers in queue, but will likely be a bit unavailable over the next little while
- Tom
- Pushed change for improving support for immediately invoked lambdas in default arguments, please report any issues found
- Some other small fixes, will move back to DFP support, Shafik has been making good progress here
- Discovered that there are default arguments in blocks that is never used, suggest to create a github issue to track further
- Bitfields that appear in MS asm blocks don’t make a lot of sense, may look into this. MS compiler adds a diagnostic, we want to create a similar diagnostic. Do we want to create an option to disable for backwards compiler?
- Seems to only be in place to support MS headers, we may want to disable bitfields in MS asm blocks and add an error. We can respond to feedback afterwards, likely state that there is no good semantic
- Tony
- Not a lot of progress on the auto keyword. Working on patching on the parsing side. Trying to generate an auto type by default.
- Utkarsh
- Implementing http://wg21.link/p2468r2 in ⚙ D134529 [C++20][Clang] P2468R2 The Equality Operator You Are Looking For
- Working on fixing ambiguity in equality operators, have almost implemented
Code Review
Meeting Agenda Sept 21, 2022
Agenda
Round Table
- Aaron - typeof and typeof_unqual for C23
- Lots of code reviews
- Restarting discussions on ABI for bit int (⚙ D115169 Create a generic ABI document for _BitInt)
- Document started last year, but bringing it back for further comment
- Need codegen code owners to review and approve
- Akira
- Ariel - change up for DWARF related work
- PTR32 related work
- Chaofan
- Erich - catching up on code reviews
- Deferred concepts implementation is about ready to commit, asking commenters to do some testing
- Next is several concepts related item,
- mangling friends with constraints, some ABI issues to resolve
- Hubert: brought up in CWG, some wording still needs to be worked out. Question if unique per instantiation (Erich’s assumption) or unique per template. Some libc++ assumption of unique per instantiation. Waiting on Itanium folks to decide on ABI issues
- Hubert - open a defect out of CWG for clarification on one of the core issues (CWG 2611 decltype and fold-expressions · Issue #57396 · llvm/llvm-project · GitHub), behaviour to change in Clang. Someone is looking into it.
- Question about bit int - review at ⚙ D115169 Create a generic ABI document for _BitInt
- Luke - mostly looking at C++20 features based on the hot list
- Const eval and concepts space - current PR: ⚙ D133052 [clang] Avoid crash when expanding conversion templates in concepts.
- clang-language-wg can add as a reviewer
- Matheus - work continues on template specialization resugaring
- Merged some large patches, thanks for the reviews!
- Main template resugaring patch is still in review, split many parts out, but still in progress
- One patch stuck on resolving content
- Another patch needs review, the most urgent one to make progress on ⚙ D131858 [clang] Track the templated entity in type substitution.
- Assessing a few enablers to balance the cost of resugaring with the benefits
- Template specialization main patch ⚙ D127695 [clang] Template Specialization Resugaring - TypeDecl
- Nathan - posted a patch for using enum DR2621
- Shafik - working with Tom on DFP, started with parsing trying to get small test programs
- Working on basic functionality, iterating through some of the initial blockers
- Some quick fixes and open source bugs, code reviews
- ⚙ D132695 [Clang] Avoid crashes when parsing using enum declarations
- ⚙ D132906 [Clang] Fix lambda CheckForDefaultedFunction(...) so that it checks the CXXMethodDecl is a special member function before attempting to call DefineDefaultedFunction(...)
- ⚙ D133177 [Clang] Fix lambda CheckForDefaultedFunction(...) so that it checks the CXXMethodDecl is not deleted before attempting to call DefineDefaultedFunction(...)
- ⚙ D132990 [Clang] Fix compat diagnostic to detect a nontype template parameter has a placeholder type using getContainedAutoType()
- ⚙ D134334 [Clang] Fix crash in isCXXDeclarationSpecifier when attempting to annotate template name
- Tom - will be building a test suite for DFP
- Filed some bugs (thread local in instantiations, referencing bitfields in an asm block)
- https://github.com/llvm/llvm-project/issues/57828
- https://github.com/llvm/llvm-project/issues/57791
- Tony - auto key keyword for C23 patch D133289
- Fixed some issues in the patch
- added a diagnostic when we use auto in a compound literal, we don’t support this feature yet
- Ex int a = (int){12}
Code Reviews
Meeting Agenda Sept 7, 2022
Agenda
- Congratulations to the new code owners! Thanks to Aaron for driving the code ownership changes!
- Will similar code ownership changes be made in LLVM? Likely, but will expect the LLVM folks to drive change in the project.
- Jeff to clean up the Google calendar
- Bug dashboard: C++ 20 in Clang · GitHub
- This is great! Once ready, we should share the existence of the dashboard on Discourse, and incorporate in to the main page once matured a bit.
- Priorities are established with some rules (example crash on valid code higher than crash on invalid code), some will be resolved in future standard revisions
- Use Github projects for establishing the dashboard
- LLVM dev conference - Matheus will be attending
Round Table
- Aaron
- Mostly establishing code owners
- Will move to C23 and CRs
- Would like to get more folks focused on documentation, have pushed in recent versions for release notes. Recent release notes have been well received. Should focus on documenting implementation defined behavior. May formulate an RFC around this.
- Is there some way to automate from pulling github pushes during a release? Have had some experience in the past (prior to github) and it didn’t quite work. It might be useful as a secondary check. But anyway that we can automate, would be good.
- Ariel
- Working on some DWARF issues
- Chaofan
- Looking at an old issue for a clash in Clang 41302, ambiguity in struct passing
- Erich
- Deferred concepts, fixing bugs that have been reported (by Facebook)
- Catching up on reviews
- Ilya
- ⚙ D129488 [Sema] Delay evaluation of std::source_location::current() in default arguments - source_location, need some clarification in the standard expectations, there are a couple of options for resolving. On Aaron’s radar, but may want to draft something with Hubert for the standards group. In the meantime may want to proceed with a hack.
- ⚙ D133029 [Sema] Allow to diagnose the references to std::vector<T> with incomplete T - vector where T is incomplete. Changes in libc++ has caused some new compile failures as moving to C++20, due to this issue. Warning seems quite verbose, and seems to be a pedantic interpretation. Should we make this warning optional? Should we integrate in clang_tidy (probably not possible)? May need some more data to make a decision, like running over other large C++ sources. Will continue discussion in the review.
- Matheus
- Responding to many reviews
- Working on splitting the resugaring patch in to more manageable chunks
- Duplicate bugs reported for builtin templates, should have a fix that will resolve several of these.
- Several loose threads to resolve, documentation to work on
- Tony
- C23 auto keyword patch ⚙ D133289 [C2X] N3007 Type inference for object definitions
- Responding to feedback on how to handle in older versions
- Preparing another patch on extensions
- C23 auto keyword patch ⚙ D133289 [C2X] N3007 Type inference for object definitions
- Utkarsh
- Recently started working on C++20
- Consteval bugs and crashes, ~5-10 bugs
- Consteval crash in codegen
- Will move over to Concepts bugs
Code Reviews
Meeting Agenda Aug 17, 2022
Agenda
- Matheus - bugs in Phabricator
- Erich reviewed patch for desurgaring, split in to two
- Asking for help in reviews ⚙ D131926 [clang-tidy] Fix for bugprone-sizeof-expression PR57167
- Bugs exposed from desurgaring, one from checker from large number of cases exposed
- Erich: would be good to cut down the patches into smaller patches
- Matheus is progress from cutting down the patches
- Ariel: how much has been committed? Matheus: elaborate type has been committed, some others still in progress. May have impacted the PTR32 work.
Round Table
Aaron - const eval (thanks to Ilya and Utkarsh for help)
- C feature reviewing, set up directory structure for new features. Please ask for clarification if needed. Leverage paper numbers
- Tom: what about similar C and C++ features? Aaron: probably makes sense to have separate tests
Ariel - ptr32 stuff complete, now focusing on DWARF
Chaofan
Corentin - update the DR page for C++
- Structure binding capture was merged last week
Erich - review and work on libc++ tests, follow up bugs where Concepts isn’t checked right
Guillot Tony - a bit of C23 work, auto keyword
Ilya - looked at const eval, closed several issues on Github
Reid
Shafik - dealing with fallout from enum diagnostics, affected Boost and QT, turned into a warning. Should resolve most things, but will be temporary.
- Aaron: -w-noerror flag led to some unexpected issues. Warnings as errors often get upgraded to errors in later releases, should serve as an early warning to migrate code
Shivam
Tom H - still wrapping up lambda expressions in default arguments, getting close
- Will look in to char8_t support up next
- Shafik and Tom to focus on DFP support soon
- Aaron: will it be extended to C++? Tom: eventually but not initially
- Ariel: library support? Tom: will look into later, focus on core language for gcc C library and LLVM C library.
- Hope to have some contributions early next year
- Initial focus on Intel architecture, but additional support for zOS and PPC will be needed, will collaborate with IBM
- Any LLVM IR impacts? Tom: hope to lower to existing types
Code Reviews
Meeting Agenda Aug 2, 2022
Agenda
- GSOC project - resugaring templates
- Proposal to add a pass when access template specialization, improving diagnostics
- Compiler explorer experimental implementation, please try and provide feedback Compiler Explorer
- Patch is getting pretty big, depending on Richard for reviews, need some help here for feedback
- Working on a demo
- Aaron: are we always going to get diagnostics? Matheus: may put behind a flag
- Template instantiation is slow, question is how do we limit analysis to limit impact on compile time. Memory consumption is also an issue. Recommendation is that we might want to do some performance analysis. Resource for measuring compile time http://llvm-compile-time-tracker.com/
- Todo Jeff: add the group alias so Matheus can use
Round Table
(Chaofan) I’m on vacation today so I can’t join this meeting.
- Jeff Heath
- Aaron Ballman
- Trying to get back to const eval work, but bogged down in code reviews
- Ilya: any way to help? Aaron will reach out afterwards
- Ariel Burton
- PTR32 MS extension, working through feedback
- Corentin
- Close to getting constexpr structured bindings PR merged
- Some standard papers Clang - C++ Programming Language Status
- Tony Guillot
- Ilya Biryukov
- Fixed a few problems with concepts, merging with modules
- Merging variable template instantiations
- https://github.com/llvm/llvm-project/issues/56379 source location, almost fixed. Offloaded review.
- Lambas in unevaluated contexts, what is the status?
- Corentin: think there are a lot of bugs here, several reported in github. Please reach out if need assistance.
- Code reviews
- D122768 [Clang][C++20] Support capturing structured bindings in lambdas
- [clang][C++20] P0960R3: Allow initializing aggregates from a parenthesized list of values
- [c++20] Implement P2113R0: Changes to the Partial Ordering of Constrained Functions
- any opinions how to move this forward? Looks like it’s not making much progress
- Try to ping and maybe finish.
D53847 [C++2a] P0634r3: Down with typename!
- Matheus Izvekov
- Michael Spencer
- Shafik Yaghmour
- Working on diagnosing ill formed constant expressions: [Clang] Diagnose ill-formed constant expression when setting a non fixed enum to a value outside the range of the enumeration values ClosedPublic
- Starting to look at P2280
- Tom Honerman
- Lambdas in default arguments, working through several bugs
Code Review
Meeting Agenda June 15, 2022
Agenda
- Unassigned C++20 issues, now at 263. How to handle? https://github.com/llvm/llvm-project/issues?q=is%3Aopen+label%3Ac%2B%2B20+no%3Aassignee
- Historically we’ve never assigned issues
- Probably not a bad idea for folks to self assign issues, as long as they’re willing to unassign if they want to give it up
- Top level triage is likely more important, would be good to at least acknowledge with ‘confirmed’ label
- Dedicated QA resource would be the preferable approach - challenging to get managerial approval
- AR Jeff to see if business case can be raised
- [Chaofan] https://docs.google.com/spreadsheets/d/1wzrew07cgzhEu4zZGDOqIZ0AqSLFupOv_nreMeghSeU/edit?usp=sharing
- Note that several issues reported against libc++ in query
- Triage currently done by community, on a volunteer basis
Round Table
- Aaron - code reviews
- Expect to get back to const eval after getting through CR backlog
- Working on the C standard DR page
- Ariel
- Bob
- Chaofan - continue to confirm bugs
- Erich - deferred concepts implementation, Chuanxi has done a lot of reviews (thanks!) and run on other platforms.
- Hoping to fix reported bug this week
- Hubert
- Ilya - first time, goal to help with C++20
- Mostly looking at bugs
- Fixed assertion, sent for review
- Recommendation: triaging bugs above
- Question: Is looking at C++ DRs also useful? Yes
- Question: how to indicate ownership? A: either self assigning issue, or creating RFC on Discourse
- Should we create issues for all DRs or use the bug tracker page to indicate? A: Either can be done, but traditionally bug tracker has been the source of truth
- For issues that have a partial tag, it would be preferable to add details on the status page about what is missing
- James
- Krzysztof
- Nathan
- Shivam -first time
- Nick - first time, interested in helping with C related issues
- How to help? A: either looking at C23 features, C DRs fixed, triaging bugs
- https://clang.llvm.org/c_status.html
- Add clang-language-wg reviewer if you want the group to be aware of any PRs
- Jeff
Code Reviews
Meeting Agenda June 1, 2022
Agenda
- Status on consteval (e.g. https://github.com/llvm/llvm-project/issues/48230)
- Aaron had done an original review, think there was a proposed patch
- Chuanqi had done an initial look at the proposed patch, it seemed good but needs a review
- Aaron to take a look at the CR and try to get it unstuck
Round table
- Jeff - need to review preexisting action items
- Aaron - currently working on a regression, losing information on AST re qualifiers
- Started work on page to track C defect reports, similar to C++ status page. C DRs are not as automated https://clang.llvm.org/c_dr_status.html. C89 DRs are going quite quickly, but expecting the more complex ones will slow down.
- Question: anything new from the last C standards meeting? Not a lot was added. C committee has started tracking papers for implementers that have different language modes. https://www9.open-std.org/jtc1/sc22/wg14/www/previous.html
- [From chat] At the last meeting, we adopted: N2886 N2888 N2861 N2992 N2897
- Ariel
- Chaofan - took a look at Github, there are 277 issues tagged with C++20, most are migrated from bugzilla. Do we need to triage? [Aaron] signed up for new bugs, which are triaged. Old ones are neglected though. Will park for future meeting. https://github.com/llvm/llvm-project/issues?q=is%3Aopen+label%3Ac%2B%2B20+no%3Aassignee
- Erich - making progress on deferred concepts, got some feedback from Richard that was very useful. Now working on a mangling change. Pointed out that Modules test is required as well, would be nice to have some help. Tom mentioned that he can help with constructing a test.
- Hubert - haven’t had a chance to review the DFP RFC as of yet. Not sure about scope of the RFC, currently highlights the core language steps
- Joe
- Nathan
- Bob
- Tom - dealing with issue relating to instantiation of default arguments https://github.com/llvm/llvm-project/issues/49178 . Struggling with the assertion errors. Not familiar with the section of code, but concerned that there is some steps out of order. Please ping Tom if anyone knows this area of code.
- James - const eval source location bug is a blocker. Also taking a look at coroutines. Thread local variable CR merging across coroutine thread points. Difficult to evaluate the change. Current intent to prototype the small change. Local static in thread local is pretty messy right now due to OMP/objc blocks, evaluating if it can be cleaned up. [Tom] does anyone know if the objc blocks are buggy? Running in to odd errors.
Code Reviews
Meeting Agenda May 4, 2022
Agenda
-
Clang release notes
- As we go through CRs, if there is a user facing change, please add release notes
- This was initiated as a result of public mention that there was no new C++ enhancements in a recent release
- Coding standards have been updated to reflect how to add release notes
- https://github.com/llvm/llvm-project/blob/main/clang/docs/ReleaseNotes.rst#id17
-
Phabricator group
- clang-language-wg
- Please let me or Bruno know if you want to be added to the group
-
STDC macro behavior in MS compatibility mode
- User report that was surprised what STDC expands to
- Expectation that when macro is set, you specify which version you want to conform to
- MS compatibility mode doesn’t set the standard macro, inconsistent
- Nathan: did MSVC not used to set, and now does?
- There are many conformance flags, may need to see which need to be set
-
Round table
- Jeff
- Clang WG tag in discourse
- Test case licensing issues
- Aaron
- Continuing to work on C compatibility, landed some changes on implicit int handling, error in various C modes. Test suites now need to be updated.
- Some bug triage on C bugs
- Chaofan Qiu
- Hubert
- DFP RFC, newer draft posted by Tom. needs to be looked at
- Jan
- Krzsztof
- Nathan
- Demangler, patch on unnamed enumerations in header units
- Array conversion, have taken ownership of bug #54831
- Steven
- Jeff
-
Retrospective
- Live code reviews would be good, if people had suggestions ahead of time
- Call for agenda items ahead of time, also propose agenda
-
Code Reviews
Meeting Agenda April 6, 2022
Agenda
-
Phabricator group created
- Please let Jeff or Bruno know if you would like to be added to the C++ WG, and please add the group for reviews
- https://reviews.llvm.org/tag/clang-language-wg/
-
Reproducers from commercial test suites
- Licensing terms associated with test suites benchmarks, issues with creating reproducers
- Contractual considerations in addition to copyright
- Proposal: short reproducers would likely not be problematic
- Probably need a legal opinion
- Can it be rewritten in a way that removes it from the context of the source material
- Can Creduce significantly anonymize the source code
- Proposal: Reduce code in a way that the original essence is no longer present
- Sources typically from benchmarks and conformance suites
- Unit tests and gcc test suites used in Clang community
- Potentially donation or licensing of older test suites?
- Proposal: describing the issue and having someone else to create the reproducer. A clean reproducer. If we can point to the section of the standard that is problematic, can someone else write the reproducer.
- Licensing terms associated with test suites benchmarks, issues with creating reproducers
-
Round table
- Jeff Heath
- Creation of ‘C/C++ WG’ subcategory
- Ariel Burton
- Chaofan Qiu
- Summarized defects listed as unknown, but it’s a huge list (~1500)
- Checked gcc defect report in GCC, even larger (~2000)
- Chuangqi Xu
- Initial support for reachable definition is waiting for review: D113545. Our internal experiment shows that we could use C++20 modules with some other bug fix after D113545 landed.
- Corentin
- Couple of PRs that need review, Corentin will check that he’s added the WG
- https://reviews.llvm.org/D122768 Support capturing structured bindings in lambdas
- https://reviews.llvm.org/D119136 Implement Change scope of lambda trailing-return-type
- Couple of PRs that need review, Corentin will check that he’s added the WG
- Erich Keane
- Deferred concepts to allow compiling of ranges, PR is ready for review. Pretty complex patch, may need to accept at some point.
- Hubert Tong
- Reviewed patch from Corentin
- Jan Korous
- Jan Svoboda
- Krzysztof P
- Michael Spencer
- Ian
- Shraiysh Vaishay
- Vlad
- Closed CWG2354
- Working on P1787 Declarations and where to find them
- Aaron Ballman
- Predominantly look at C strict prototypes, need review
- Implicit function declarations, need review
- A bit concerned about change in behaviour, would be helpful to get feedback testing the patch on larger code bases
- https://reviews.llvm.org/D122895
- https://reviews.llvm.org/D122983
- Jeff Heath
-
Code reviews
-
Bug triaging
-
Question - is there a recommended way to be able to decipher the C++ standard?
- Typically discussed amongst committee members, but that is a closed discussion
- Draft is available in github
- Can also ask the group here, and can forward to committee as requested
- Finding a paper where wording came from could be helpful
- git blame on https://github.com/cplusplus/draft ?
- if it came before github, working drafts are publicly available since 2005
- if you’re unlucky to encounter the wording in C++98, searching through papers becomes very time-consuming, but still feasible if you have a good idea what you’re looking for
-
Contact information - Jeff to aggregate and then move to a protected document
Attendees
Meeting Agenda March 2, 2022
Agenda
- Introductions
- Jeff Heath, Aaron Ballman, Bruno Cardoso Lopes, Chanqi Xu, Corentin, Erich Keane, Hubert Tong, Krzystof Parzyszek, Markus Böck, Tom Honerman, Steven (Yu) Wan, Vlad Serebrennikov, Chaofan Qiu, Arthur O’Dwyer, Bob Montelone