RUN asdl/examples/typed_arith_parse_test.py > _test/py-unit/asdl/examples/typed_arith_parse_test.py.log
OK
RUN asdl/format_test.py > _test/py-unit/asdl/format_test.py.log
OK
RUN asdl/front_end_test.py > _test/py-unit/asdl/front_end_test.py.log
OK
RUN asdl/gen_python_test.py > _test/py-unit/asdl/gen_python_test.py.log
OK
RUN asdl/target_lang_test.py > _test/py-unit/asdl/target_lang_test.py.log
OK
RUN benchmarks/uftrace_allocs_test.py > _test/py-unit/benchmarks/uftrace_allocs_test.py.log
OK
RUN build/dynamic_deps_test.py > _test/py-unit/build/dynamic_deps_test.py.log
OK
RUN build/ninja_lib_test.py > _test/py-unit/build/ninja_lib_test.py.log
OK
RUN builtin/bracket_osh_test.py > _test/py-unit/builtin/bracket_osh_test.py.log
OK
RUN builtin/completion_osh_test.py > _test/py-unit/builtin/completion_osh_test.py.log
OK
RUN builtin/func_misc_test.py > _test/py-unit/builtin/func_misc_test.py.log
OK
RUN builtin/misc_osh_test.py > _test/py-unit/builtin/misc_osh_test.py.log
OK
RUN builtin/read_osh_test.py > _test/py-unit/builtin/read_osh_test.py.log
OK
RUN builtin/readline_osh_test.py > _test/py-unit/builtin/readline_osh_test.py.log
OK
RUN client/py_fanos_test.py > _test/py-unit/client/py_fanos_test.py.log
OK
RUN core/alloc_test.py > _test/py-unit/core/alloc_test.py.log
OK
RUN core/comp_ui_test.py > _test/py-unit/core/comp_ui_test.py.log
OK
RUN core/completion_test.py > _test/py-unit/core/completion_test.py.log

=== /home/uke/oil/_test/py-unit/core/completion_test.py.log ===

.
-- PREFIX 'm'

-- PREFIX 'opy/doc'

-- PREFIX o

-- PREFIX nonexistent/

-- PREFIX README.

-- PREFIX core

-- PREFIX asdl/R

-- PREFIX opy/doc

-- PREFIX opy/doc/

-- PREFIX /bi

-- PREFIX /tmp/oil_comp_test/

-- PREFIX ./o

-- PREFIX i
..Running completion function 'f' with 3 arguments
comp.first '', commands_changed: 
...
--- Case 3: 'noflags foo:bar --color=auto\t' with flags []

[]
['../oil/']
py <core.completion.UserSpec object at 0x7ff82cb7cf50>
rb (None, None)
  words:
(w <Lit_Chars noflags>)
(w <Lit_Chars foo> <Lit_Colon ":"> <Lit_Chars bar>)
(w <Lit_Chars --color> <Lit_Equals "="> <Lit_Chars auto> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars noflags>
<WS_Space " ">
<Lit_Chars foo>
<Lit_Colon ":">
<Lit_Chars bar>
<WS_Space " ">
<Lit_Chars --color>
<Lit_Equals "=">
<Lit_Chars auto>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'noflags foo:bar --color=auto'
rl_slice from byte 0 to 28: 'noflags foo:bar --color=auto'
Completing words
partial_argv: [noflags,foo:bar,--color=auto]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:7
      col:16
      line:(SourceLine
        line_num:1
        content:"noflags foo:bar --color=auto"
        src:(source.MainFile path:"<test_lib>")
      )
      tval:--color
    )
    (Token id:Lit_Equals length:1 col:23 line:...0x7ff82cab4b50 tval:"=")
    (Token id:Lit_Chars length:4 col:24 line:...0x7ff82cab4b50 tval:auto)
    (Token id:Lit_CompDummy length:0 col:28 line:...0x7ff82cab4b50 tval:"")
  ]
)
]
display_pos 16
Completing 'noflags foo:bar --color=auto' ... (Ctrl-C to cancel)
Running completion function 'my_complete' with 3 arguments
E  words:
(w <Lit_Chars ls>)
(w <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars ls>
<WS_Space " ">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'ls '
rl_slice from byte 0 to 3: 'ls '
Completing words
partial_argv: [ls,]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_CompDummy
      length:0
      col:3
      line:(SourceLine
        line_num:1
        content:"ls "
        src:(source.MainFile path:"<test_lib>")
      )
      tval:""
    )
  ]
)
]
display_pos 3
Completing 'ls ' ... (Ctrl-C to cancel)
Found 2 matches for 'ls ' in 0 ms
  words:
(w <Lit_Chars ll>)
(w <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars ll>
<WS_Space " ">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:
(w <Lit_Chars ls>)
(w <Lit_Chars -l>)

line: 'll '
rl_slice from byte 0 to 3: 'll '
Completing words
partial_argv: [ll,]
alias_words: [[(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:2
      col:0
      line:(SourceLine
        line_num:1
        content:"ls -l "
        src:(source.Alias
          argv0:ll
          argv0_loc:(loc.Word
            w:(CompoundWord
              parts:[
                (Token
                  id:Lit_Chars
                  length:2
                  col:0
                  line:(SourceLine
                    line_num:1
                    content:"ll "
                    src:(source.MainFile path:"<test_lib>")
                  )
                  tval:ll
                )
              ]
            )
          )
        )
      )
    )
  ]
)
, (CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:2
      col:3
      line:(SourceLine
        line_num:1
        content:"ls -l "
        src:(source.Alias
          argv0:ll
          argv0_loc:(loc.Word
            w:(CompoundWord
              parts:[
                (Token
                  id:Lit_Chars
                  length:2
                  col:0
                  line:(SourceLine
                    line_num:1
                    content:"ll "
                    src:(source.MainFile path:"<test_lib>")
                  )
                  tval:ll
                )
              ]
            )
          )
        )
      )
    )
  ]
)
]]
alias_first: ls
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_CompDummy
      length:0
      col:3
      line:(SourceLine
        line_num:1
        content:"ll "
        src:(source.MainFile path:"<test_lib>")
      )
      tval:""
    )
  ]
)
]
display_pos 3
Completing 'll ' ... (Ctrl-C to cancel)
Found 2 matches for 'll ' in 0 ms
  words:
(w <Lit_Chars ll_classify>)
(w <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars ll_classify>
<WS_Space " ">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:
(w <Lit_Chars ls>)
(w <Lit_Chars -l>)
(w <Lit_Chars --classify>)

line: 'll_classify '
rl_slice from byte 0 to 12: 'll_classify '
Completing words
partial_argv: [ll_classify,]
alias_words: [[(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:2
      col:0
      line:(SourceLine
        line_num:1
        content:"ls -l --classify"
        src:(source.Alias
          argv0:ll
          argv0_loc:(loc.Word
            w:(CompoundWord
              parts:[
                (Token
                  id:Lit_Chars
                  length:2
                  col:0
                  line:(SourceLine
                    line_num:1
                    content:"ll --classify "
                    src:(source.Alias
                      argv0:ll_classify
                      argv0_loc:(loc.Word
                        w:(CompoundWord
                          parts:[
                            (Token
                              id:Lit_Chars
                              length:11
                              col:0
                              line:(SourceLine
                                line_num:1
                                content:"ll_classify "
                                src:(source.MainFile path:"<test_lib>")
                              )
                              tval:ll_classify
                            )
                          ]
                        )
                      )
                    )
                  )
                )
              ]
            )
          )
        )
      )
    )
  ]
)
, (CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:2
      col:3
      line:(SourceLine
        line_num:1
        content:"ls -l --classify"
        src:(source.Alias
          argv0:ll
          argv0_loc:(loc.Word
            w:(CompoundWord
              parts:[
                (Token
                  id:Lit_Chars
                  length:2
                  col:0
                  line:(SourceLine
                    line_num:1
                    content:"ll --classify "
                    src:(source.Alias
                      argv0:ll_classify
                      argv0_loc:(loc.Word
                        w:(CompoundWord
                          parts:[
                            (Token
                              id:Lit_Chars
                              length:11
                              col:0
                              line:(SourceLine
                                line_num:1
                                content:"ll_classify "
                                src:(source.MainFile path:"<test_lib>")
                              )
                              tval:ll_classify
                            )
                          ]
                        )
                      )
                    )
                  )
                )
              ]
            )
          )
        )
      )
    )
  ]
)
, (CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:10
      col:6
      line:(SourceLine
        line_num:1
        content:"ls -l --classify"
        src:(source.Alias
          argv0:ll
          argv0_loc:(loc.Word
            w:(CompoundWord
              parts:[
                (Token
                  id:Lit_Chars
                  length:2
                  col:0
                  line:(SourceLine
                    line_num:1
                    content:"ll --classify "
                    src:(source.Alias
                      argv0:ll_classify
                      argv0_loc:(loc.Word
                        w:(CompoundWord
                          parts:[
                            (Token
                              id:Lit_Chars
                              length:11
                              col:0
                              line:(SourceLine
                                line_num:1
                                content:"ll_classify "
                                src:(source.MainFile path:"<test_lib>")
                              )
                              tval:ll_classify
                            )
                          ]
                        )
                      )
                    )
                  )
                )
              ]
            )
          )
        )
      )
    )
  ]
)
]]
alias_first: ls
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_CompDummy
      length:0
      col:12
      line:(SourceLine
        line_num:1
        content:"ll_classify "
        src:(source.MainFile path:"<test_lib>")
      )
      tval:""
    )
  ]
)
]
display_pos 12
Completing 'll_classify ' ... (Ctrl-C to cancel)
Found 2 matches for 'll_classify ' in 0 ms
  words:
(w <Lit_Chars ll_trailing>)
(w <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars ll_trailing>
<WS_Space " ">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:
(w <Lit_Chars ls>)
(w <Lit_Chars -l>)

line: 'll_trailing '
rl_slice from byte 0 to 12: 'll_trailing '
Completing words
partial_argv: [ll_trailing,]
alias_words: [[(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:2
      col:0
      line:(SourceLine
        line_num:1
        content:"ls -l "
        src:(source.Alias
          argv0:ll_trailing
          argv0_loc:(loc.Word
            w:(CompoundWord
              parts:[
                (Token
                  id:Lit_Chars
                  length:11
                  col:0
                  line:(SourceLine
                    line_num:1
                    content:"ll_trailing "
                    src:(source.MainFile path:"<test_lib>")
                  )
                  tval:ll_trailing
                )
              ]
            )
          )
        )
      )
    )
  ]
)
, (CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:2
      col:3
      line:(SourceLine
        line_num:1
        content:"ls -l "
        src:(source.Alias
          argv0:ll_trailing
          argv0_loc:(loc.Word
            w:(CompoundWord
              parts:[
                (Token
                  id:Lit_Chars
                  length:11
                  col:0
                  line:(SourceLine
                    line_num:1
                    content:"ll_trailing "
                    src:(source.MainFile path:"<test_lib>")
                  )
                  tval:ll_trailing
                )
              ]
            )
          )
        )
      )
    )
  ]
)
]]
alias_first: ls
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_CompDummy
      length:0
      col:12
      line:(SourceLine
        line_num:1
        content:"ll_trailing "
        src:(source.MainFile path:"<test_lib>")
      )
      tval:""
    )
  ]
)
]
display_pos 12
Completing 'll_trailing ' ... (Ctrl-C to cancel)
Found 2 matches for 'll_trailing ' in 0 ms
  words:
(w <Lit_Chars ll_own_completion>)
(w <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars ll_own_completion>
<WS_Space " ">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:
(w <Lit_Chars ls>)
(w <Lit_Chars -l>)

line: 'll_own_completion '
rl_slice from byte 0 to 18: 'll_own_completion '
Completing words
partial_argv: [ll_own_completion,]
alias_words: [[(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:2
      col:0
      line:(SourceLine
        line_num:1
        content:"ls -l "
        src:(source.Alias
          argv0:ll_own_completion
          argv0_loc:(loc.Word
            w:(CompoundWord
              parts:[
                (Token
                  id:Lit_Chars
                  length:17
                  col:0
                  line:(SourceLine
                    line_num:1
                    content:"ll_own_completion "
                    src:(source.MainFile path:"<test_lib>")
                  )
                  tval:ll_own_completion
                )
              ]
            )
          )
        )
      )
    )
  ]
)
, (CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:2
      col:3
      line:(SourceLine
        line_num:1
        content:"ls -l "
        src:(source.Alias
          argv0:ll_own_completion
          argv0_loc:(loc.Word
            w:(CompoundWord
              parts:[
                (Token
                  id:Lit_Chars
                  length:17
                  col:0
                  line:(SourceLine
                    line_num:1
                    content:"ll_own_completion "
                    src:(source.MainFile path:"<test_lib>")
                  )
                  tval:ll_own_completion
                )
              ]
            )
          )
        )
      )
    )
  ]
)
]]
alias_first: ls
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_CompDummy
      length:0
      col:18
      line:(SourceLine
        line_num:1
        content:"ll_own_completion "
        src:(source.MainFile path:"<test_lib>")
      )
      tval:""
    )
  ]
)
]
display_pos 18
Completing 'll_own_completion ' ... (Ctrl-C to cancel)
Found 2 matches for 'll_own_completion ' in 0 ms
.  words:
(w <Lit_Chars gre> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars gre>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'gre'
rl_slice from byte 0 to 3: 'gre'
Completing words
partial_argv: [gre]
alias_words: [[]]
** DISPLAY_POS = 0
Completing 'gre' ... (Ctrl-C to cancel)
Found 1 match for 'gre' in 0 ms
  words:
(w <Lit_Chars gre> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_DollarParen "$(">
<Lit_Chars gre>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo $(gre'
rl_slice from byte 0 to 10: 'echo $(gre'
Completing words
partial_argv: [gre]
alias_words: [[]]
** DISPLAY_POS = 7
Completing 'echo $(gre' ... (Ctrl-C to cancel)
Found 1 match for 'echo $(gre' in 0 ms
  words:
(w <Lit_Chars gre> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_Backtick "`">
<Lit_Chars gre>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo `gre'
rl_slice from byte 0 to 9: 'echo `gre'
Completing words
partial_argv: [gre]
alias_words: [[]]
** DISPLAY_POS = 6
Completing 'echo `gre' ... (Ctrl-C to cancel)
Found 1 match for 'echo `gre' in 0 ms
  words:
(w <Lit_Chars grep>)
(w <Lit_Chars f> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_Backtick "`">
<Lit_Chars grep>
<WS_Space " ">
<Lit_Chars f>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo `grep f'
rl_slice from byte 0 to 12: 'echo `grep f'
Completing words
partial_argv: [grep,f]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:1
      col:11
      line:(SourceLine
        line_num:1
        content:"echo `grep f"
        src:(source.MainFile path:"<test_lib>")
      )
      tval:f
    )
    (Token id:Lit_CompDummy length:0 col:12 line:...0x7ff82c9bf8e8 tval:"")
  ]
)
]
display_pos 11
Completing 'echo `grep f' ... (Ctrl-C to cancel)
Found 2 matches for 'echo `grep f' in 0 ms
.<Api 'echo ~r' 0-7>
  words:
(w <Lit_Chars echo>)
(w <Lit_Tilde "~"> <Lit_Chars r> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Lit_Tilde "~">
<Lit_Chars r>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo ~r'
rl_slice from byte 0 to 7: 'echo ~r'
<Api 'echo ~' 0-6>
  words:
(w <Lit_Chars echo>)
(w <Lit_Tilde "~"> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Lit_Tilde "~">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo ~'
rl_slice from byte 0 to 6: 'echo ~'
  words:
(w <Lit_Chars echo>)
(w <Lit_Chars a> <Lit_Tilde "~"> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Lit_Chars a>
<Lit_Tilde "~">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo a~'
rl_slice from byte 0 to 7: 'echo a~'
Completing words
partial_argv: [echo,a~]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:1
      col:5
      line:(SourceLine
        line_num:1
        content:"echo a~"
        src:(source.MainFile path:"<test_lib>")
      )
      tval:a
    )
    (Token id:Lit_Tilde length:1 col:6 line:...0x7ff82c9bfba8 tval:"~")
    (Token id:Lit_CompDummy length:0 col:7 line:...0x7ff82c9bfba8 tval:"")
  ]
)
]
display_pos 5
Completing 'echo a~' ... (Ctrl-C to cancel)
Found 0 matches for 'echo a~' in 0 ms
.  words:
(w <Lit_Chars cat>)

  redirects:
(Redir
  op:<Redir_Less "<">
  loc:(redir_loc.Fd fd:0)
  arg:(w <Lit_Chars b> <Lit_CompDummy "">)
)

  tokens:
<Lit_Chars cat>
<WS_Space " ">
<Redir_Less "<">
<WS_Space " ">
<Lit_Chars b>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'cat < b'
rl_slice from byte 0 to 7: 'cat < b'
Completing redirect arg
  words:
(w <Lit_Chars echo>)

  redirects:
(Redir
  op:<Redir_GreatAnd ">&">
  loc:(redir_loc.Fd fd:1)
  arg:(w <Lit_CompDummy "">)
)

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Redir_GreatAnd ">&">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo >&'
rl_slice from byte 0 to 7: 'echo >&'
Didn't find anything to complete
..<Api 'echo $' 0-6>
  words:
(w <Lit_Chars echo>)
(w <Lit_Dollar "$"> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Lit_Dollar "$">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo $'
rl_slice from byte 0 to 6: 'echo $'
<Api 'echo $P' 0-7>
  words:
(w <Lit_Chars echo>)
(w ($ P) <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<VSub_DollarName "$P">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo $P'
rl_slice from byte 0 to 7: 'echo $P'
<Api 'echo _${' 0-8>
  words:

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Lit_Chars _>
<Left_DollarBrace "${">
<Lit_CompDummy "">

  alias_words:

line: 'echo _${'
rl_slice from byte 0 to 8: 'echo _${'
<Api 'echo ${P' 0-8>
  words:

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_DollarBrace "${">
<VSub_Name P>
<Lit_CompDummy "">

  alias_words:

line: 'echo ${P'
rl_slice from byte 0 to 8: 'echo ${P'
<Api 'echo ${undef:-$P' 0-16>
  words:

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_DollarBrace "${">
<VSub_Name undef>
<VTest_ColonHyphen ":-">
<VSub_DollarName "$P">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo ${undef:-$P'
rl_slice from byte 0 to 16: 'echo ${undef:-$P'
<Api 'echo ${undef:-$' 0-15>
  words:

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_DollarBrace "${">
<VSub_Name undef>
<VTest_ColonHyphen ":-">
<Lit_Dollar "$">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo ${undef:-$'
rl_slice from byte 0 to 15: 'echo ${undef:-$'
<Api 'echo "$' 0-7>
  words:

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_DoubleQuote "\"">
<Lit_Dollar "$">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo "$'
rl_slice from byte 0 to 7: 'echo "$'
<Api 'echo "$P' 0-8>
  words:

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_DoubleQuote "\"">
<VSub_DollarName "$P">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo "$P'
rl_slice from byte 0 to 8: 'echo "$P'
<Api 'echo "${#P' 0-10>
  words:

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_DoubleQuote "\"">
<Left_DollarBrace "${">
<VSub_Pound "#">
<VSub_Name P>
<Lit_CompDummy "">

  alias_words:

line: 'echo "${#P'
rl_slice from byte 0 to 10: 'echo "${#P'
<Api 'echo "$((PWD +P' 0-15>
  words:

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_DoubleQuote "\"">
<Left_DollarDParen "$((">
<Lit_ArithVarLike PWD>
<Ignored_Space " ">
<Arith_Plus "+">
<Lit_ArithVarLike P>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo "$((PWD +P'
rl_slice from byte 0 to 15: 'echo "$((PWD +P'
<Api 'echo "$(( $P' 0-12>
  words:

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Left_DoubleQuote "\"">
<Left_DollarDParen "$((">
<Ignored_Space " ">
<VSub_DollarName "$P">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo "$(( $P'
rl_slice from byte 0 to 12: 'echo "$(( $P'
.  words:
(w <Lit_Chars grep>)
(w <Lit_Chars f> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars grep>
<WS_Space " ">
<Lit_Chars f>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'grep f'
rl_slice from byte 0 to 6: 'grep f'
Completing words
partial_argv: [grep,f]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:1
      col:5
      line:(SourceLine
        line_num:1
        content:"grep f"
        src:(source.MainFile path:"<test_lib>")
      )
      tval:f
    )
    (Token id:Lit_CompDummy length:0 col:6 line:...0x7ff82c9bf940 tval:"")
  ]
)
]
display_pos 5
Completing 'grep f' ... (Ctrl-C to cancel)
Found 2 matches for 'grep f' in 0 ms
  words:
(w <Lit_Chars grep>)
(w <Lit_Chars g> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars grep>
<WS_Space " ">
<Lit_Chars g>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'grep g'
rl_slice from byte 0 to 6: 'grep g'
Completing words
partial_argv: [grep,g]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:1
      col:5
      line:(SourceLine
        line_num:1
        content:"grep g"
        src:(source.MainFile path:"<test_lib>")
      )
      tval:g
    )
    (Token id:Lit_CompDummy length:0 col:6 line:...0x7ff82c9bfcb0 tval:"")
  ]
)
]
display_pos 5
Completing 'grep g' ... (Ctrl-C to cancel)
Found 0 matches for 'grep g' in 0 ms
  words:
(w <Lit_Chars g> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars g>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'g'
rl_slice from byte 0 to 1: 'g'
Completing words
partial_argv: [g]
alias_words: [[]]
** DISPLAY_POS = 0
Completing 'g' ... (Ctrl-C to cancel)
Found 1 match for 'g' in 0 ms
  words:
(w <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: ''
rl_slice from byte 0 to 0: ''
Completing words
partial_argv: []
alias_words: [[]]
** DISPLAY_POS = 0
Completing '' ... (Ctrl-C to cancel)
Found 3 matches for '' in 0 ms
  words:
(w <Lit_Chars grep>)
(w <Lit_Chars f> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Lit_Chars hi>
<WS_Space " ">
<Op_DPipe "||">
<WS_Space " ">
<Lit_Chars grep>
<WS_Space " ">
<Lit_Chars f>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo hi || grep f'
rl_slice from byte 0 to 17: 'echo hi || grep f'
Completing words
partial_argv: [grep,f]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:1
      col:16
      line:(SourceLine
        line_num:1
        content:"echo hi || grep f"
        src:(source.MainFile path:"<test_lib>")
      )
      tval:f
    )
    (Token id:Lit_CompDummy length:0 col:17 line:...0x7ff82ca9f208 tval:"")
  ]
)
]
display_pos 16
Completing 'echo hi || grep f' ... (Ctrl-C to cancel)
Found 2 matches for 'echo hi || grep f' in 0 ms
  words:
(w <Lit_Chars grep>)
(w <Lit_Chars f> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars echo>
<WS_Space " ">
<Lit_Chars hi>
<Op_Semi ";">
<WS_Space " ">
<Lit_Chars grep>
<WS_Space " ">
<Lit_Chars f>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'echo hi; grep f'
rl_slice from byte 0 to 15: 'echo hi; grep f'
Completing words
partial_argv: [grep,f]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:1
      col:14
      line:(SourceLine
        line_num:1
        content:"echo hi; grep f"
        src:(source.MainFile path:"<test_lib>")
      )
      tval:f
    )
    (Token id:Lit_CompDummy length:0 col:15 line:...0x7ff82ca9f158 tval:"")
  ]
)
]
display_pos 14
Completing 'echo hi; grep f' ... (Ctrl-C to cancel)
Found 2 matches for 'echo hi; grep f' in 0 ms
  words:
(w <Lit_Chars grep>)
(w <Lit_Chars f> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_LBrace "{">
<WS_Space " ">
<Lit_Chars echo>
<WS_Space " ">
<Lit_Chars hi>
<Op_Semi ";">
<WS_Space " ">
<Lit_Chars grep>
<WS_Space " ">
<Lit_Chars f>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: '{ echo hi; grep f'
rl_slice from byte 0 to 17: '{ echo hi; grep f'
Completing words
partial_argv: [grep,f]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:1
      col:16
      line:(SourceLine
        line_num:1
        content:"{ echo hi; grep f"
        src:(source.MainFile path:"<test_lib>")
      )
      tval:f
    )
    (Token id:Lit_CompDummy length:0 col:17 line:...0x7ff82ca9f100 tval:"")
  ]
)
]
display_pos 16
Completing '{ echo hi; grep f' ... (Ctrl-C to cancel)
Found 2 matches for '{ echo hi; grep f' in 0 ms
  words:

  redirects:

  tokens:
<Lit_VarLike "var=">
<VSub_DollarName "$v">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'var=$v'
rl_slice from byte 0 to 6: 'var=$v'
  words:
(w <Lit_Chars local>)
(w <Lit_VarLike "var="> ($ v) <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars local>
<WS_Space " ">
<Lit_VarLike "var=">
<VSub_DollarName "$v">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'local var=$v'
rl_slice from byte 0 to 12: 'local var=$v'
.  words:
(w <Lit_Chars bad>)
(w <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars bad>
<WS_Space " ">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'bad '
rl_slice from byte 0 to 4: 'bad '
Completing words
partial_argv: [bad,]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_CompDummy
      length:0
      col:4
      line:(SourceLine
        line_num:1
        content:"bad "
        src:(source.MainFile path:"<test_lib>")
      )
      tval:""
    )
  ]
)
]
display_pos 4
Completing 'bad ' ... (Ctrl-C to cancel)
Running completion function '_bad' with 3 arguments
_bad returning 124
comp.first 'bad', commands_changed: 
Function '_bad' returned 124, but the completion spec for 'bad' wasn't changed
Found 0 matches for 'bad ' in 0 ms
  words:
(w <Lit_Chars both>)
(w <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars both>
<WS_Space " ">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'both '
rl_slice from byte 0 to 5: 'both '
Completing words
partial_argv: [both,]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_CompDummy
      length:0
      col:5
      line:(SourceLine
        line_num:1
        content:"both "
        src:(source.MainFile path:"<test_lib>")
      )
      tval:""
    )
  ]
)
]
display_pos 5
Completing 'both ' ... (Ctrl-C to cancel)
Running completion function '_both' with 3 arguments
comp.first 'both', commands_changed: 
Function '_both' returned 124, but the completion spec for 'both' wasn't changed
Found 0 matches for 'both ' in 0 ms
  words:
(w <Lit_Chars both2>)
(w <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars both2>
<WS_Space " ">
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'both2 '
rl_slice from byte 0 to 6: 'both2 '
Completing words
partial_argv: [both2,]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_CompDummy
      length:0
      col:6
      line:(SourceLine
        line_num:1
        content:"both2 "
        src:(source.MainFile path:"<test_lib>")
      )
      tval:""
    )
  ]
)
]
display_pos 6
Completing 'both2 ' ... (Ctrl-C to cancel)
Running completion function '_both2' with 3 arguments
comp.first 'both2', commands_changed: both2
Got 124, trying again ...
Completing 'both2 ' ... (Ctrl-C to cancel)
Found 2 matches for 'both2 ' in 0 ms
.  words:
(w <Lit_Chars mywords>)
(w <Lit_Chars t> <Lit_CompDummy "">)

  redirects:

  tokens:
<Lit_Chars mywords>
<WS_Space " ">
<Lit_Chars t>
<Lit_CompDummy "">
<Eof_Real "">

  alias_words:

line: 'mywords t'
rl_slice from byte 0 to 9: 'mywords t'
Completing words
partial_argv: [mywords,t]
alias_words: [[]]
words[-1]: [(CompoundWord
  parts:[
    (Token
      id:Lit_Chars
      length:1
      col:8
      line:(SourceLine
        line_num:1
        content:"mywords t"
        src:(source.MainFile path:"<test_lib>")
      )
      tval:t
    )
    (Token id:Lit_CompDummy length:0 col:9 line:...0x7ff82c97a470 tval:"")
  ]
)
]
display_pos 8
Completing 'mywords t' ... (Ctrl-C to cancel)
Running completion function 'complete_mywords' with 3 arguments
E
======================================================================
ERROR: testMatchesOracle (__main__.InitCompletionTest)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "/home/uke/oil/core/completion_test.py", line 787, in testMatchesOracle
    m = list(r.Matches(comp))
  File "/home/uke/oil/core/completion.py", line 1312, in Matches
    user_spec, comp):
  File "/home/uke/oil/core/completion.py", line 1354, in _PostProcess
    for candidate, action_kind in user_spec.AllMatches(comp):
  File "/home/uke/oil/core/completion.py", line 894, in AllMatches
    for match in a.Matches(comp):
  File "/home/uke/oil/core/completion.py", line 601, in Matches
    status = self.cmd_ev.RunFuncForCompletion(self.func, argv)
  File "/home/uke/oil/osh/cmd_eval.py", line 2349, in RunFuncForCompletion
    status = self.RunProc(proc, cmd_val)
  File "/home/uke/oil/osh/cmd_eval.py", line 2323, in RunProc
    status = self._Execute(proc.body)
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1754, in _Dispatch
    status = self._ExecuteList(node.children)
  File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList
    status = self._Execute(child)
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1771, in _Dispatch
    status = self._DoIf(node)
  File "/home/uke/oil/osh/cmd_eval.py", line 1419, in _DoIf
    b = self._EvalCondition(if_arm.cond, if_arm.keyword)
  File "/home/uke/oil/osh/cmd_eval.py", line 644, in _EvalCondition
    cond_status = self._ExecuteList(cond)
  File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList
    status = self._Execute(child)
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1653, in _Dispatch
    status = self._Execute(node.child)
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1635, in _Dispatch
    status = self._DoSimple(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 914, in _DoSimple
    status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags)
  File "/home/uke/oil/osh/cmd_eval.py", line 575, in _RunSimpleCommand
    run_flags)
  File "/home/uke/oil/core/executor.py", line 420, in RunSimpleCommand
    status = self.cmd_ev.RunProc(proc, cmd_val)
  File "/home/uke/oil/osh/cmd_eval.py", line 2323, in RunProc
    status = self._Execute(proc.body)
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1754, in _Dispatch
    status = self._ExecuteList(node.children)
  File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList
    status = self._Execute(child)
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1801, in _Dispatch
    status = self._DoForExpr(node)
  File "/home/uke/oil/osh/cmd_eval.py", line 1372, in _DoForExpr
    self.arith_ev.Eval(update)
  File "/home/uke/oil/osh/sh_expr_eval.py", line 611, in Eval
    old_big, lval = self._EvalLhsAndLookupArith(node.child)
  File "/home/uke/oil/osh/sh_expr_eval.py", line 520, in _EvalLhsAndLookupArith
    location.TokenForArith(node))
  File "/home/uke/oil/osh/sh_expr_eval.py", line 130, in OldValue
    cell = mem.GetCellDeref(var_name)
  File "/home/uke/oil/core/state.py", line 2318, in GetCellDeref
    cell, _ = self._ResolveNameOrRef(name, which_scopes)
ValueError: too many values to unpack

======================================================================
ERROR: testRunsUserDefinedFunctions (__main__.RootCompleterTest)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "/home/uke/oil/core/completion_test.py", line 453, in testRunsUserDefinedFunctions
    m = list(r.Matches(MockApi('mywords t')))
  File "/home/uke/oil/core/completion.py", line 1312, in Matches
    user_spec, comp):
  File "/home/uke/oil/core/completion.py", line 1354, in _PostProcess
    for candidate, action_kind in user_spec.AllMatches(comp):
  File "/home/uke/oil/core/completion.py", line 894, in AllMatches
    for match in a.Matches(comp):
  File "/home/uke/oil/core/completion.py", line 601, in Matches
    status = self.cmd_ev.RunFuncForCompletion(self.func, argv)
  File "/home/uke/oil/osh/cmd_eval.py", line 2349, in RunFuncForCompletion
    status = self.RunProc(proc, cmd_val)
  File "/home/uke/oil/osh/cmd_eval.py", line 2323, in RunProc
    status = self._Execute(proc.body)
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1754, in _Dispatch
    status = self._ExecuteList(node.children)
  File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList
    status = self._Execute(child)
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1795, in _Dispatch
    status = self._DoForEach(node)
  File "/home/uke/oil/osh/cmd_eval.py", line 1333, in _DoForEach
    status = self._Execute(node.body)  # last one wins
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1750, in _Dispatch
    status = self._ExecuteList(node.children)
  File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList
    status = self._Execute(child)
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1771, in _Dispatch
    status = self._DoIf(node)
  File "/home/uke/oil/osh/cmd_eval.py", line 1421, in _DoIf
    status = self._ExecuteList(if_arm.action)
  File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList
    status = self._Execute(child)
  File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 1645, in _Dispatch
    status = self._DoShAssignment(node, cmd_st)
  File "/home/uke/oil/osh/cmd_eval.py", line 988, in _DoShAssignment
    node.left)
  File "/home/uke/oil/osh/sh_expr_eval.py", line 130, in OldValue
    cell = mem.GetCellDeref(var_name)
  File "/home/uke/oil/core/state.py", line 2318, in GetCellDeref
    cell, _ = self._ResolveNameOrRef(name, which_scopes)
ValueError: too many values to unpack

----------------------------------------------------------------------
Ran 16 tests in 0.165s

FAILED (errors=2)

FAIL: core/completion_test.py with code 1