Actions
Misc #18652
closedDevMeeting-2022-04-21
Status:
Closed
Assignee:
-
Description
The next dev meeting¶
Date: 2022/04/21 13:00-17:00 (JST)
Log: https://github.com/ruby/dev-meeting-log/blob/master/DevMeeting-2022-04-21.md
- Dev meeting IS NOT a decision-making place. All decisions should be done at the bug tracker.
- Dev meeting is a place we can ask Matz, nobu, nurse and other developers directly.
- Matz is a very busy person. Take this opportunity to ask him. If you can not attend, other attendees can ask instead of you (if attendees can understand your issue).
- We will write a record of the discussion in the file or to each ticket in English.
- All activities are best-effort (keep in mind that most of us are volunteer developers).
- The date, time and place of the meeting are scheduled according to when/where we can reserve Matz's time.
- DO NOT discuss then on this ticket, please.
Call for agenda items¶
If you have a ticket that you want matz and committers to discuss, please post it into this ticket in the following format:
* [Ticket ref] Ticket title (your name)
* Comment (A summary of the ticket, why you put this ticket here, what point should be discussed, etc.)
Example:
* [Feature #14609] `Kernel#p` without args shows the receiver (ko1)
* I feel this feature is very useful and some people say :+1: so let discuss this feature.
- It is recommended to add a comment by 2022/04/18. We hold a preparatory meeting to create an agenda a few days before the dev-meeting.
- The format is strict. We'll use this script to automatically create an markdown-style agenda. We may ignore a comment that does not follow the format.
- Your comment is mandatory. We cannot read all discussion of the ticket in a limited time. We appreciate it if you could write a short summary and update from a previous discussion.
Updated by mame (Yusuke Endoh) almost 3 years ago
- Related to Misc #14770: [META] DevelopersMeeting added
Updated by kddnewton (Kevin Newton) over 2 years ago
- [Feature #18654] Enhancements to prettyprint (kddnewton)
- PrettyPrint currently immediately pushes content onto the output buffer and then inserts newlines where necessary. This makes it impossible to change the output based on how groups are broken. This commit changes the behavior to first build up the entire doc node tree, and the lay it out once it knows all of the content. This allows a lot more flexibility and new nodes like
IfBreak
,BreakParent
, andTrim
. This flexibility is necessary to support formatting Ruby itself as in https://github.com/ruby-syntax-tree/syntax_tree.
- PrettyPrint currently immediately pushes content onto the output buffer and then inserts newlines where necessary. This makes it impossible to change the output based on how groups are broken. This commit changes the behavior to first build up the entire doc node tree, and the lay it out once it knows all of the content. This allows a lot more flexibility and new nodes like
Updated by kddnewton (Kevin Newton) over 2 years ago
- [Feature #18642] Named ripper fields (kddnewton)
- This commit adds a new subclass for ripper that functions similarly to SexpBuilderPP but uses classes with named fields instead of arrays. It additionally includes location information for all of the nodes, and implements pretty printing and pattern matching. This makes it much easier to work with Ripper, as you can get handed an AST with full documentation. (This addresses a lot of the complaints raised in #14844.)
Updated by Eregon (Benoit Daloze) over 2 years ago
- [Feature #18668] Merge
io-nonblock
gems into core (eregon)- Let's do it?
- Unlike io-wait these methods seem all stable and well established.
Updated by jeremyevans0 (Jeremy Evans) over 2 years ago
- [Bug #18628] Link contributing is broken (jeremyevans0)
- Also affects #18665. Problem is that ruby uses the --page-dir rdoc option.
- Any documentation generation that does not use the --page-dir rdoc option has broken links.
- I propose to remove the --page-dir rdoc option, and fix any internal documentation that relies on it.
- This will allow externally generated documentation (which is unlikely to use --page-dir) to have working links.
- [Bug #18155] (nil..nil).cover?(x) is true for all x since beginless ranges were introduced (jeremyevans0)
- How should cover? work for ranges unbounded in both directions?
- In 2.7, with the introduction of beginless ranges, it started always returning true, instead of returning false.
- I propose to reject this bug, and keep the current behavior.
- [Bug #18629] block args array splatting assigns to higher scope _ var (jeremyevans0)
- I believe this is expected behavior. Can we confirm that and reject this bug?
- [Bug #18622] const_get still looks in Object, while lexical constant lookup no longer does (jeremyevans0)
- Can we decide whether const_get should operate like a relative lookup or an absolute lookup?
- Currently, it operates as a relative lookup, so
Array.const_get(:String)
is likeclass Array; String; end
and works. - If switched to an absolute lookup,
Array.const_get(:String)
would be likeArray::String
, and would raise an exception.
- [Bug #18649] Enumerable#first breaks out of the incorect block when across threads (jeremyevans0)
- Can we specify how Enumerator#first should work across threads?
- It currently has definitely incorrect behavior, jumping out of block it should not jump out of.
- I have a patch that fixes the definitely incorrect behavior, but still passes a value to the calling thread, which may be undesireable.
Updated by byroot (Jean Boussier) over 2 years ago
- [Feature #18683] Allow to create hashes with a specific capacity.
- Useful for various parsers and deserializers that know the Hash size in advance, such as Redis protocol, msgpack, etc.
- When creating large hashes of known size, lots of needless reallocations are wasteful.
- Ruby interface:
Hash.new(default = nil, capacity = nil)
- C-Ext interface:
rb_hash_new_capa(long)
Updated by knu (Akinori MUSHA) over 2 years ago
- [Feature #18685] Enumerator.product: Cartesian product of enumerables
Updated by Eregon (Benoit Daloze) over 2 years ago
- [Bug #18729] Method#owner and UnboundMethod#owner are incorrect after using Module#public/protected/private (eregon)
- OK to fix this?
- Any insight why the behavior was inconsistent for
private
/protected
/public
as that's the only case where owner is not "the module on which the method is defined/part of its method table"? - Could someone review the PR?
Updated by mame (Yusuke Endoh) over 2 years ago
- Description updated (diff)
- Status changed from Open to Closed
Actions
Like0
Like0Like0Like0Like0Like0Like0Like0Like0Like0