|
From: | J.P. |
Subject: | Re: bug#68861: 30.0.50; ERC 5.x: Introduce a modern message-insertion API |
Date: | Mon, 04 Mar 2024 19:03:29 -0800 |
User-agent: | Gnus/5.13 (Gnus v5.13) |
"J.P." <jp@neverwas.me> writes: > In terms of proposals, I think a successful candidate for adoption > should provide at least two working demos, preferably among the > following: > > - Bidirectional input and display > - Headline style messages w. speaker on a separate line > - Text substitution (language translation, encryption, etc.) > - Display names (e.g., for bridges, perhaps reversible) > > My guess is this feature won't be ready for ERC 5.6, especially without > explicit interest from others. As such, proposals (from me) may be based > atop work that includes changes not currently on HEAD, such as those > from #49860. In the absence of a coherent proposal for a revamped message preparation and insertion API, I believe it may be wise to collect counterexamples exhibiting some of the desperate and ugly measures taken to access the various components of a message and influence its assembly for display. The objective here is to emphasize the considerable shortcomings currently on offer in this regard. To that end, I've attached an adapted version of a POC from another bug (#49860) as a working, practical example of the problem. It attempts to introduce speaker display names for bridge bots by way of a new module. To be clear, this is not being proposed for inclusion in ERC 5.6 (or any subsequent version). Rather, its purpose is in keeping with the aforementioned goal of underscoring the deficiencies of the current situation. Of particular note is the fourth patch and the terrible lengths it goes to in order to access and manipulate the content portion of chat messages before they're fused to their leading "<speaker> " prefixes. Folks at home: even if you don't try this patch set, please look at the module setup code and the interfaces it consumes. And please do post your own scenarios here. They need not come in the form of patches or include any working code. Thanks.
0001-5.x-Add-predicate-for-logical-ERC-module-activation.patch
Description: Text Data
0002-5.x-Indirectly-call-erc-fill-wrap-continued-message-.patch
Description: Text Data
0003-5.x-Expose-erc-response-object-as-dynamic-variable.patch
Description: Text Data
0004-POC-Replace-erc-cmem-from-nick-function-args-with-st.patch
Description: Text Data
0005-POC-Add-general-display-name-support-to-ERC.patch
Description: Text Data
[Prev in Thread] | Current Thread | [Next in Thread] |