On 9/5/2023 5:47 PM, Jim Porter wrote: > On 9/5/2023 4:36 PM, Stefan Kangas wrote: >> Jim Porter writes: >> >>> On 1/30/2023 6:54 AM, Stefan Monnier via Bug reports for GNU Emacs, >>> the Swiss >>> army knife of text editors wrote: >>>> It sounds good to me, but I'm definitely not well versed in this aspect >>>> of the interaction between Eshell and Pcomplete (more specifically, >>>> this is a part of their interaction which I find quite tricky), so it's >>>> good that you add corresponding regression tests. >>> >>> Thanks for taking a look. I've merged my patches as e7d0aa248e. We >>> can leave >>> this open though to discuss what to do about the Pcomplete side of >>> things. I >>> think we can remove the workaround for Emacs 29, but maybe we want some >>> additional changes. >> >> That was 9 months ago.  Is it still relevant to keep this bug open? > > Yes, I believe so. I was planning to wait until Emacs 29.1 was released > before pinging people on this, but then forgot all about it. We should > probably use this time to fix the FIXME in 'pcomplete-arg', since (I > think) the current behavior in Eshell no longer requires the FIXME bit: > >             ;; FIXME: 'last' is handled specially in Emacs 29, because >             ;; 'pcomplete-parse-arguments' accepts a list of strings >             ;; (which are completion candidates) as return value for >             ;; (pcomplete-arg 'last).  See below: "it means it's a >             ;; list of completions computed during parsing, >             ;; e.g. Eshell uses that to turn globs into lists of >             ;; completions".  This special case will be dealt with >             ;; differently in Emacs 30: the pcomplete-arg-value >             ;; property will be used by 'pcomplete-parse-arguments'. Attached is a patch to revert the Emacs 29 workarounds. I *believe* I've fixed this on the Eshell side by always providing Pcomplete with the arguments in their string form. Could everyone try the patch out to make sure things still work? In particular, see the cases in the following bugs: bug#60464, bug#60021, and bug#59956.