GNU bug report logs - #53644
29.0.50; xref-search-program breaks if programm not installed on a remote host

Previous Next

Package: emacs;

Reported by: Philip Kaludercic <philipk <at> posteo.net>

Date: Sun, 30 Jan 2022 23:39:01 UTC

Severity: normal

Found in version 29.0.50

Full log


Message #62 received at 53644 <at> debbugs.gnu.org (full text, mbox):

From: Dmitry Gutov <dgutov <at> yandex.ru>
To: Philip Kaludercic <philipk <at> posteo.net>
Cc: Michael Albinus <michael.albinus <at> gmx.de>, 53644 <at> debbugs.gnu.org
Subject: Re: bug#53644: 29.0.50; xref-search-program breaks if programm not
 installed on a remote host
Date: Tue, 15 Feb 2022 03:27:48 +0200
On 14.02.2022 19:32, Philip Kaludercic wrote:
> Dmitry Gutov <dgutov <at> yandex.ru> writes:
> 
>> On 14.02.2022 15:57, Philip Kaludercic wrote:
>>>> And use a simpler test: (only when the host is remote) write some text
>>>> to a file in the temp dir, then search through it. Only doing it once,
>>>> of course, when the connection-local value is initialized.
>>> I am afraid I don't understand what you mean here, specifically "some
>>> text".
>>>
>>
>> Well, we need some file to search and some knowledge about its
>> contents in advance (so the search can succeed).
> 
> I guess this is what confuses me, what about the contents is relevant to
> the query?  `xref-matches-in-files' is already passed a list of files
> that can be concatenated into the input for xargs.  The current version
> already works and is reasonably fast, so I don't recognise the
> improvement.

Sorry, I guess I wasn't clear enough.

When I said "extract the detection logic", I meant implement something 
similar to 'grep-compute-defaults' where there is a bunch of "probing" 
code which detects which commands work on the given system (and which 
arguments, etc). But a shorter function, of course, since it would only 
need to choose between two alternatives -- and return it.

And it seems to be it would be simpler (conceptually) if the said 
function didn't itself depend on xref-matches-in-files (the 
implementation or the return type). Though it's certainly possible to 
use it as well.

...so that function (let's call it xref--choose-search-program, perhaps) 
would write to a file in the temporary directory on the remote system, 
and then search in it using the configured search program, and then fall 
back to the default one if the first one fails.

WDYT?

>> Since we don't know anything about the remote system, we probably have
>> to create the file ourselves. Put something like "aaa\nbbb\nccc" in
>> it, and then search for "bbb".
> 
> My apologies, I feel stupid for not understanding, but what would aaa,
> bbb and ccc be?

Those are characters. "aaa\nbbb\nccc" would be the temporary file's 
contents, verbatim.

To clarify, I think your code quality is just fine, but the way the main 
function gets two responsibilities intertwined (both program detection 
and the actual search) seems a bit too much for me, clarity-wise.




This bug report was last modified 3 years and 121 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.