On 9/6/2020 2:43 PM, David Dyck via Cygwin wrote:
This command triggers an assertion failure
   "ag" is from the_silver_searcher
$ ag 2 <(echo 2)
assertion "p >= path" failed: file
"/home/corinna/src/cygwin/cygwin-3.1.7/cygwin-3.1.7-1.x86_64/src/newlib-cygwin/winsup/cygwin/path.cc",
line 3065, function: int symlink_info::check(char*, const
suffix_info*, fs_info&, path_conv_handle&)
Aborted (core dumped)

  3473k 2020/08/22 C:\cygwin64\bin\cygwin1.dll
     Cygwin DLL version info:
         DLL version: 3.1.7
bash                                    4.4.12-3                        OK
the_silver_searcher                     2.2.0-1                         OK

Wrapping in "bash -c" gives identical results ( see above)
$ /usr/bin/bash -c '/usr/bin/ag 2 <(echo 2)'

Turning on some "ag" debugging reveals worker threads and the
"special" /dev/fd/63 file handle creation ( used with bash "Process
Substitution" )

$ /usr/bin/bash -c '/usr/bin/ag -D 2 <(echo 2)'
  ....
DEBUG: Query is 2
DEBUG: PCRE Version: 8.44 2020-02-12
DEBUG: Using 7 workers
DEBUG: Thread 0 set to CPU 0
DEBUG: Thread 1 set to CPU 1
DEBUG: Worker 1 started
DEBUG: Worker 0 started
  ...
DEBUG: searching path /dev/fd/63 for 2
assertion "p >= path" failed: file
"/home/corinna/src/cygwin/cygwin-3.1.7/cygwin-3.1.7-1.x86_64/src/newlib-cygwin/winsup/cygwin/path.cc",
line 3065, function: int symlink_info::check(char*, const
suffix_info*, fs_info&, path_conv_handle&)
Aborted (core dumped)


I expected behaviour like ack

$ ack 2 <(echo 2)
2

Noticed that input from pipe works

$ echo 2 | ag 2
2

I've reported this on github as an "ag" bug, but I think it is a bug in cygwin
    https://github.com/ggreer/the_silver_searcher/issues/1408

I would appreciate hearing if someone else can reproduce this issue in
3.1.7 or later dll
   ( 3.1.6 seems to hang )

Attached cygcheck.out
   UserName and HostName substituted into cygcheck.out
   one environment variable deleted
I just tried this:

  grep 2 <(echo 2)

on cygwin 3.1.7 and it worked fine.  I am not familiar with Silver Searcher, 
but it would
seem that the problem is more idiosyncratic to that program than to Cygwin more 
generally.
I am _not_ saying the problem is not in Cygwin - only that ag must be doing 
something
somewhat different from what grep does with <( ) command input.  Perhaps ag is 
testing
what sort of "thing" (device, etc.) the input file is, while grep does not - 
something
like that might give different behavior.

Now I have CYGWIN=winsymlinks:native, which may (almost certainly does) affect 
what
path.cc is doing (the error message is concerned about symlinks; presumably 
Cygwin
is trying to check whether /dev/fd/63 is a symlink.

Well, those are the clues I can offer :-) ...   EM
--
Problem reports:      https://cygwin.com/problems.html
FAQ:                  https://cygwin.com/faq/
Documentation:        https://cygwin.com/docs.html
Unsubscribe info:     https://cygwin.com/ml/#unsubscribe-simple

Reply via email to