~/oil/_clone/ble.sh ~/oil
ble.sh: insane environment: $USER is empty.
ble.sh: modified USER=uke
ble.sh: suspicious environment: $LANG is empty.
  shopt -s checkwinsize
  ^~~~~
out/ble.osh:2815: 'shopt' got invalid option 'checkwinsize'
ble/term.sh: updating tput cache for TERM=xterm... 
ble/term.sh: updating tput cache for TERM=xterm... done
osh warning: The 'RETURN' hook isn't implemented
real	7.871
user	7.568
sys	0.183
real	0.943
user	0.194
sys	0.020
    declare -i i=1
    ^~~~~~~
lib/test-util.sh:175: 'declare' doesn't implement flag -i (shopt --set ignore_flags_not_impl)
      declare -u u=a
      ^~~~~~~
lib/test-util.sh:181: Warning: OSH doesn't implement flags -l or -u (shopt --set ignore_flags_not_impl)
      declare -l l=B
      ^~~~~~~
lib/test-util.sh:182: Warning: OSH doesn't implement flags -l or -u (shopt --set ignore_flags_not_impl)
      declare -c c=c
              ^~
lib/test-util.sh:183: 'declare' doesn't accept flag -c

Running out/ble.osh --lib


DONE Running out/ble.osh --lib


Running lib/test-main.sh

lib/test-main.sh:25: set -o posix; f2;                 ret=$?; set +o posix
--- 1086.ret.expect	2025-03-01 12:32:26.110537106 +0000
+++ 1086.ret.result	2025-03-01 12:32:26.110537106 +0000
@@ -1 +1 @@
-0
+1

lib/test-main.sh:57: ! ble/bin#has ble_test_dummy_4
--- 1090.exit.expect	2025-03-01 12:32:26.325534333 +0000
+++ 1090.exit.result	2025-03-01 12:32:26.325534333 +0000
@@ -1 +1 @@
-0
+1

lib/test-main.sh:88: 
    ble/util/readlink f.txt
    [[ $ret != /* ]] && ret=${PWD%/}/$ret
--- 1093.ret.expect	2025-03-01 12:32:26.447532760 +0000
+++ 1093.ret.result	2025-03-01 12:32:26.448532747 +0000
@@ -1 +1 @@
-/tmp/blesh/1000/999.test/1093.d/ab/cd/ef/file.txt
+/tmp/blesh/1000/999.test/1093.d/ef/file.txt

lib/test-main.sh:110: 
    path=phys.link/1.txt
    ble/util/readlink/.resolve-physical-directory
    declare -p path PWD >&2
    [[ $path == */phys.dir/1.txt && $PWD == "$pwd" ]]
--- 1093.exit.expect	2025-03-01 12:32:26.647530182 +0000
+++ 1093.exit.result	2025-03-01 12:32:26.647530182 +0000
@@ -1 +1 @@
-0
+1
<STDERR>
declare -- path=/tmp/blesh/1000/999.test/1093.d/1.txt
declare -x PWD=/tmp/blesh/1000/999.test/1093.d
</STDERR>

lib/test-main.sh:131: [[ ${value//$pattern/$'\n'} == $'\n'hello$'\n' ]]
--- 1126.exit.expect	2025-03-01 12:32:26.734529060 +0000
+++ 1126.exit.result	2025-03-01 12:32:26.735529047 +0000
@@ -1 +1 @@
-0
+1

 82.7% [section] ble/main: 24/29 (5 fail, 0 crash, 0 skip)

DONE Running lib/test-main.sh


Running lib/test-util.sh

lib/test-util.sh:190: ble/variable#get-attr i; ret=$attr
--- 1137.ret.expect	2025-03-01 12:32:28.152512763 +0000
+++ 1137.ret.result	2025-03-01 12:32:28.153512752 +0000
@@ -1 +1 @@
-i
+

lib/test-util.sh:191: ble/variable#get-attr x; ret=$attr
--- 1137.ret.expect	2025-03-01 12:32:28.186512404 +0000
+++ 1137.ret.result	2025-03-01 12:32:28.186512404 +0000
@@ -1 +1 @@
-x
+

lib/test-util.sh:192: ble/variable#get-attr r; ret=$attr
--- 1137.ret.expect	2025-03-01 12:32:28.219512055 +0000
+++ 1137.ret.result	2025-03-01 12:32:28.220512044 +0000
@@ -1 +1 @@
-r
+

lib/test-util.sh:195: ble/variable#get-attr u; ret=$attr
--- 1137.ret.expect	2025-03-01 12:32:28.263511590 +0000
+++ 1137.ret.result	2025-03-01 12:32:28.264511580 +0000
@@ -1 +1 @@
-u
+

lib/test-util.sh:196: ble/variable#get-attr l; ret=$attr
--- 1137.ret.expect	2025-03-01 12:32:28.296511242 +0000
+++ 1137.ret.result	2025-03-01 12:32:28.297511231 +0000
@@ -1 +1 @@
-l
+

lib/test-util.sh:197: ble/variable#get-attr c; ret=$attr
--- 1137.ret.expect	2025-03-01 12:32:28.329510893 +0000
+++ 1137.ret.result	2025-03-01 12:32:28.329510893 +0000
@@ -1 +1 @@
-c
+

lib/test-util.sh:203: ble/variable#has-attr i i
--- 1137.exit.expect	2025-03-01 12:32:28.372510438 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.373510428 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:204: ble/variable#has-attr x x
--- 1137.exit.expect	2025-03-01 12:32:28.404510100 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.405510090 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:205: ble/variable#has-attr r r
--- 1137.exit.expect	2025-03-01 12:32:28.436509762 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.436509762 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:212: ble/variable#has-attr u u
--- 1137.exit.expect	2025-03-01 12:32:28.524508833 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.525508822 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:213: ble/variable#has-attr l l
--- 1137.exit.expect	2025-03-01 12:32:28.556508495 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.557508484 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:214: ble/variable#has-attr c c
--- 1137.exit.expect	2025-03-01 12:32:28.588508156 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.588508156 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:226: ble/is-inttype i
--- 1137.exit.expect	2025-03-01 12:32:28.676507227 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.676507227 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:228: ble/is-readonly r
--- 1137.exit.expect	2025-03-01 12:32:28.719506772 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.720506762 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:231: ble/is-transformed u
--- 1137.exit.expect	2025-03-01 12:32:28.763506307 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.764506297 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:232: ble/is-transformed l
--- 1137.exit.expect	2025-03-01 12:32:28.795505969 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.796505959 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:233: ble/is-transformed c
--- 1137.exit.expect	2025-03-01 12:32:28.827505631 +0000
+++ 1137.exit.result	2025-03-01 12:32:28.827505631 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:251: is-global v0
--- 1172.exit.expect	2025-03-01 12:32:28.889504976 +0000
+++ 1172.exit.result	2025-03-01 12:32:28.890504966 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:252: is-global v1
--- 1172.exit.expect	2025-03-01 12:32:28.927504575 +0000
+++ 1172.exit.result	2025-03-01 12:32:28.927504575 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:257: ble/variable#is-global v0
--- 1172.exit.expect	2025-03-01 12:32:29.016503634 +0000
+++ 1172.exit.result	2025-03-01 12:32:29.016503634 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:258: ble/variable#is-global v1
--- 1172.exit.expect	2025-03-01 12:32:29.054503233 +0000
+++ 1172.exit.result	2025-03-01 12:32:29.054503233 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:263: ble/variable#is-global v0u
--- 1172.exit.expect	2025-03-01 12:32:29.144502282 +0000
+++ 1172.exit.result	2025-03-01 12:32:29.144502282 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:265: ble/variable#is-global v1u
--- 1172.exit.expect	2025-03-01 12:32:29.181501891 +0000
+++ 1172.exit.result	2025-03-01 12:32:29.181501891 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:597: ble/string#split-lines a ""  ; status
--- 1220.stdout.expect	2025-03-01 12:32:31.272479800 +0000
+++ 1220.stdout.result	2025-03-01 12:32:31.273479790 +0000
@@ -1 +1 @@
-1:()
+0:()

lib/test-util.sh:599: ble/string#split-lines a "
"  ; status
--- 1220.stdout.expect	2025-03-01 12:32:31.319479304 +0000
+++ 1220.stdout.result	2025-03-01 12:32:31.319479304 +0000
@@ -1 +1 @@
-2:( )
+0:()

lib/test-util.sh:600: ble/string#split-lines a "1
"  ; status
--- 1220.stdout.expect	2025-03-01 12:32:31.352478955 +0000
+++ 1220.stdout.result	2025-03-01 12:32:31.353478945 +0000
@@ -1 +1 @@
-2:(1 )
+1:(1)

lib/test-util.sh:601: ble/string#split-lines a "
2"  ; status
--- 1220.stdout.expect	2025-03-01 12:32:31.385478607 +0000
+++ 1220.stdout.result	2025-03-01 12:32:31.386478596 +0000
@@ -1 +1 @@
-2:( 2)
+0:()

lib/test-util.sh:602: ble/string#split-lines a "1

3"  ; status
--- 1220.stdout.expect	2025-03-01 12:32:31.418478258 +0000
+++ 1220.stdout.result	2025-03-01 12:32:31.419478248 +0000
@@ -1 +1 @@
-3:(1  3)
+1:(1)

lib/test-util.sh:782: ble/string#quote-command echo hello world
--- 1238.ret.expect	2025-03-01 12:32:33.161459849 +0000
+++ 1238.ret.result	2025-03-01 12:32:33.162459838 +0000
@@ -1 +1 @@
-echo 'hello' 'world'
+echo hello world

lib/test-util.sh:784: ble/string#quote-command echo "'test'"
--- 1238.ret.expect	2025-03-01 12:32:33.206459374 +0000
+++ 1238.ret.result	2025-03-01 12:32:33.207459363 +0000
@@ -1 +1 @@
-echo ''\''test'\'''
+echo $'\'test\''

lib/test-util.sh:786: ble/string#quote-command echo a{1..4}
--- 1238.ret.expect	2025-03-01 12:32:33.251458898 +0000
+++ 1238.ret.result	2025-03-01 12:32:33.251458898 +0000
@@ -1 +1 @@
-echo 'a1' 'a2' 'a3' 'a4'
+echo a1 a2 a3 a4

lib/test-util.sh:790: ble/util/print-quoted-command echo hello world
--- 1238.stdout.expect	2025-03-01 12:32:33.309458286 +0000
+++ 1238.stdout.result	2025-03-01 12:32:33.310458275 +0000
@@ -1 +1 @@
-echo 'hello' 'world'
+echo hello world

lib/test-util.sh:792: ble/util/print-quoted-command echo "'test'"
--- 1238.stdout.expect	2025-03-01 12:32:33.356457789 +0000
+++ 1238.stdout.result	2025-03-01 12:32:33.357457779 +0000
@@ -1 +1 @@
-echo ''\''test'\'''
+echo $'\'test\''

lib/test-util.sh:794: ble/util/print-quoted-command echo a{1..4}
--- 1238.stdout.expect	2025-03-01 12:32:33.402457304 +0000
+++ 1238.stdout.result	2025-03-01 12:32:33.403457293 +0000
@@ -1 +1 @@
-echo 'a1' 'a2' 'a3' 'a4'
+echo a1 a2 a3 a4

lib/test-util.sh:843: ble/util/strlen α
--- 1253.ret.expect	2025-  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
03-01 12:32:34.058450374 +0000
+++ 1253.ret.result	2025-03-01 12:32:34.059450363 +0000
@@ -1 +1 @@
-2
+1

lib/test-util.sh:844: ble/util/strlen αβγ
--- 1253.ret.expect	2025-03-01 12:32:34.091450025 +0000
+++ 1253.ret.result	2025-03-01 12:32:34.092450015 +0000
@@ -1 +1 @@
-6
+3

lib/test-util.sh:845: ble/util/strlen あ
--- 1253.ret.expect	2025-03-01 12:32:34.124449677 +0000
+++ 1253.ret.result	2025-03-01 12:32:34.124449677 +0000
@@ -1 +1 @@
-3
+1

lib/test-util.sh:846: ble/util/strlen あいう
--- 1253.ret.expect	2025-03-01 12:32:34.157449328 +0000
+++ 1253.ret.result	2025-03-01 12:32:34.157449328 +0000
@@ -1 +1 @@
-9
+3

lib/test-util.sh:847: ble/util/strlen aα
--- 1253.ret.expect	2025-03-01 12:32:34.189448990 +0000
+++ 1253.ret.result	2025-03-01 12:32:34.190448979 +0000
@@ -1 +1 @@
-3
+2

lib/test-util.sh:848: ble/util/strlen aαあ
--- 1253.ret.expect	2025-03-01 12:32:34.221448652 +0000
+++ 1253.ret.result	2025-03-01 12:32:34.222448642 +0000
@@ -1 +1 @@
-6
+3

lib/test-util.sh:852: ble/util/strlen α
--- 1253.ret.expect	2025-03-01 12:32:34.265448187 +0000
+++ 1253.ret.result	2025-03-01 12:32:34.266448177 +0000
@@ -1 +1 @@
-2
+1

lib/test-util.sh:853: ble/util/strlen あ
--- 1253.ret.expect	2025-03-01 12:32:34.297447849 +0000
+++ 1253.ret.result	2025-03-01 12:32:34.298447839 +0000
@@ -1 +1 @@
-3
+1

lib/test-util.sh:885: ble/util/substr あいう 0 3
--- 1270.ret.expect	2025-03-01 12:32:34.645444174 +0000
+++ 1270.ret.result	2025-03-01 12:32:34.645444174 +0000
@@ -1 +1 @@
-あ
+あいう

lib/test-util.sh:886: ble/util/substr あいう 3 6
--- 1270.ret.expect	2025-03-01 12:32:34.678443825 +0000
+++ 1270.ret.result	2025-03-01 12:32:34.679443815 +0000
@@ -1 +1 @@
-いう
+

lib/test-util.sh:1243: ble/util/mapfile a < <(echo); status
--- 1280.stdout.expect	2025-03-01 12:32:39.308395283 +0000
+++ 1280.stdout.result	2025-03-01 12:32:39.308395283 +0000
@@ -1 +1 @@
-1:()
+0:()

lib/test-util.sh:1244: ble/util/mapfile a < <(echo;echo); status
--- 1280.stdout.expect	2025-03-01 12:32:39.345394920 +0000
+++ 1280.stdout.result	2025-03-01 12:32:39.345394920 +0000
@@ -1 +1 @@
-2:( )
+0:()

lib/test-util.sh:1245: ble/util/mapfile a < <(echo a;echo;echo b); status
--- 1280.stdout.expect	2025-03-01 12:32:39.382394558 +0000
+++ 1280.stdout.result	2025-03-01 12:32:39.382394558 +0000
@@ -1 +1 @@
-3:(a  b)
+1:(a)

lib/test-util.sh:1263: ble/util/assign-array a echo; status
--- 1280.stdout.expect	2025-03-01 12:32:39.520393205 +0000
+++ 1280.stdout.result	2025-03-01 12:32:39.521393195 +0000
@@ -1 +1 @@
-1:()
+0:()

lib/test-util.sh:1266: ble/util/assign-array a "echo; echo; echo"; status
--- 1280.stdout.expect	2025-03-01 12:32:39.589392529 +0000
+++ 1280.stdout.result	2025-03-01 12:32:39.589392529 +0000
@@ -1 +1 @@
-3:(  )
+0:()

lib/test-util.sh:1267: ble/util/assign-array a "echo 1; echo; echo 2"; status
--- 1280.stdout.expect	2025-03-01 12:32:39.624392186 +0000
+++ 1280.stdout.result	2025-03-01 12:32:39.624392186 +0000
@@ -1 +1 @@
-3:(1  2)
+1:(1)

lib/test-util.sh:1364: f1
--- 1364.stdout.expect	2025-03-01 12:32:40.635382278 +0000
+++ 1364.stdout.result	2025-03-01 12:32:40.636382268 +0000
@@ -1,2 +1 @@
 pre
-original
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1366: f1
--- 1364.stdout.expect	2025-03-01 12:32:40.706381582 +0000
+++ 1364.stdout.result	2025-03-01 12:32:40.706381582 +0000
@@ -1,3 +1,2 @@
 pre
-original
 post
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1368: f1
--- 1364.stdout.expect	2025-03-01 12:32:40.777380887 +0000
+++ 1364.stdout.result	2025-03-01 12:32:40.777380887 +0000
@@ -1,3 +1,2 @@
 A
-original
 post
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1370: f1
--- 1364.stdout.expect	2025-03-01 12:32:40.848380191 +0000
+++ 1364.st  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
  ble/function#push/0:echo
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:echo' not found (OILS-ERR-100)
  ble/function#push/0:echo
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:echo' not found (OILS-ERR-100)
  ble/function#push/0:echo
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:echo' not found (OILS-ERR-100)
ble/function#pop: echo is not a function.
ble/function#pop: echo is not a function.
dout.result	2025-03-01 12:32:40.848380191 +0000
@@ -1,3 +1,2 @@
 A
-original
 B
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1372: f1
--- 1364.stdout.expect	2025-03-01 12:32:40.920379485 +0000
+++ 1364.stdout.result	2025-03-01 12:32:40.921379475 +0000
@@ -1,5 +1,4 @@
 A
 [
-original
 ]
 B
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1378: f1
--- 1364.stdout.expect	2025-03-01 12:32:40.994378760 +0000
+++ 1364.stdout.result	2025-03-01 12:32:40.994378760 +0000
@@ -1,5 +1,4 @@
 A
 [
-original quick
 ]
 B
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1381: f1
--- 1364.stdout.expect	2025-03-01 12:32:41.045378260 +0000
+++ 1364.stdout.result	2025-03-01 12:32:41.046378250 +0000
@@ -1 +1 @@
-original
+
--- 1364.exit.expect	2025-03-01 12:32:41.064378074 +0000
+++ 1364.exit.result	2025-03-01 12:32:41.064378074 +0000
@@ -1 +1 @@
-0
+127
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1382: f1 1
--- 1364.stdout.expect	2025-03-01 12:32:41.110377623 +0000
+++ 1364.stdout.result	2025-03-01 12:32:41.110377623 +0000
@@ -1 +1 @@
-original 1
+
--- 1364.exit.expect	2025-03-01 12:32:41.128377447 +0000
+++ 1364.exit.result	2025-03-01 12:32:41.129377437 +0000
@@ -1 +1 @@
-0
+127
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1395: echo 1 2 3
--- 1385.stdout.expect	2025-03-01 12:32:41.254376212 +0000
+++ 1385.stdout.result	2025-03-01 12:32:41.254376212 +0000
@@ -1,3 +1,3 @@
 A
-(1 2 3)
+1 2 3
 Z

lib/test-util.sh:1397: echo 1 2 3
--- 1385.stdout.expect	2025-03-01 12:32:41.299375771 +0000
+++ 1385.stdout.result	2025-03-01 12:32:41.300375761 +0000
@@ -1,5 +1,3 @@
 [
-A
-(1 2 3)
-Z
+1 2 3
 ]

lib/test-util.sh:1400: echo 1 2 3
--- 1385.stdout.expect	2025-03-01 12:32:41.345375320 +0000
+++ 1385.stdout.result	2025-03-01 12:32:41.345375320 +0000
@@ -1,3 +1 @@
-A
-(1 2 3)
-Z
+1 2 3

lib/test-util.sh:1402: echo 1 2 3
--- 1385.stdout.expect	2025-03-01 12:32:41.380374977 +0000
+++ 1385.stdout.result	2025-03-01 12:32:41.381374968 +0000
@@ -1 +1 @@
-(1 2 3)
+1 2 3

lib/test-util.sh:1404: echo 1 2 3
--- 1385.stdout.expect	2025-03-01 12:32:41.415374634 +0000
+++ 1385.stdout.result	2025-03-01 12:32:41.416374624 +0000
@@ -1 +1 @@
-[1 2 3]
+1 2 3

lib/test-util.sh:1405: ble/is-function echo
--- 1385.exit.expect	2025-03-01 12:32:41.447374321 +0000
+++ 1385.exit.result	2025-03-01 12:32:41.447374321 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1406: ble/function#pop echo
--- 1385.exit.expect	2025-03-01 12:32:41.481373988 +0000
+++ 1385.exit.result	2025-03-01 12:32:41.482373978 +0000
@@ -1 +1 @@
-0
+1
<STDERR>
ble/function#pop: echo is not a function.
</STDERR>

lib/test-util.sh:1443: ble/util/sprintf ret "[%#.2g]" 27
--- 1401.ret.expect	2025-03-01 12:32:41.740371449 +0000
+++ 1401.ret.result	2025-03-01 12:32:41.741371439 +0000
@@ -1 +1 @@
-[27.]
+[1b]
<STDERR>
  [%#.2g]
    ^
[ printf arg at line 5263 of out/ble.osh ]:1
</STDERR>

lib/test-util.sh:1444: ble/util/sprintf ret "[%#.2f]" 27
--- 1401.ret.expect	2025-03-01 12:32:41.775371106 +0000
+++ 1401.ret.result	2025-03-01 12:32:41.776371096 +0000
@@ -1 +1 @@
-[27.00]
+[1b]
<STDERR>
  [%#.2f]
    ^
[ printf arg at line 5263 of out/ble.osh ]:1
</STDERR>

lib/test-util.sh:1482: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-01 12:32:41.990368999 +0000
+++ 1407.ret.result	2025-03-01 12:32:41.990368999 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1484: ble/alias#expand aaa2
--- 1407.ret.expect	2025-03-01 12:32:42.022368686 +0000
+++ 1407.ret.result	2025-03-01 12:32:42.0223686    elif [[ -t ${!1} ]]; then
               ^~
out/ble.osh:5825: fatal: Invalid file descriptor ''
  ble/function#push/0:ble/util/msleep
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:ble/util/msleep' not found (OILS-ERR-100)
86 +0000
@@ -1 +1 @@
-aaa3 hello
+aaa2

lib/test-util.sh:1485: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-01 12:32:42.054368372 +0000
+++ 1407.ret.result	2025-03-01 12:32:42.054368372 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1487: ble/alias#expand aaa3
--- 1407.ret.expect	2025-03-01 12:32:42.088368039 +0000
+++ 1407.ret.result	2025-03-01 12:32:42.089368029 +0000
@@ -1 +1 @@
-aaa4
+aaa3

lib/test-util.sh:1488: ble/alias#expand aaa2
--- 1407.ret.expect	2025-03-01 12:32:42.121367716 +0000
+++ 1407.ret.result	2025-03-01 12:32:42.121367716 +0000
@@ -1 +1 @@
-aaa3 hello
+aaa2

lib/test-util.sh:1489: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-01 12:32:42.153367402 +0000
+++ 1407.ret.result	2025-03-01 12:32:42.154367392 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1491: ble/alias#expand aaa4
--- 1407.ret.expect	2025-03-01 12:32:42.186367078 +0000
+++ 1407.ret.result	2025-03-01 12:32:42.187367069 +0000
@@ -1 +1 @@
-echo
+aaa4

lib/test-util.sh:1492: ble/alias#expand aaa3
--- 1407.ret.expect	2025-03-01 12:32:42.219366755 +0000
+++ 1407.ret.result	2025-03-01 12:32:42.220366745 +0000
@@ -1 +1 @@
-aaa4
+aaa3

lib/test-util.sh:1493: ble/alias#expand aaa2
--- 1407.ret.expect	2025-03-01 12:32:42.252366432 +0000
+++ 1407.ret.result	2025-03-01 12:32:42.252366432 +0000
@@ -1 +1 @@
-aaa3 hello
+aaa2

lib/test-util.sh:1494: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-01 12:32:42.284366118 +0000
+++ 1407.ret.result	2025-03-01 12:32:42.285366108 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1619: [[ ! ${v0+set} ]]
--- 1481.exit.expect	2025-03-01 12:32:43.228356867 +0000
+++ 1481.exit.result	2025-03-01 12:32:43.229356857 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1620: status v1
--- 1481.stdout.expect	2025-03-01 12:32:43.262356534 +0000
+++ 1481.stdout.result	2025-03-01 12:32:43.263356524 +0000
@@ -1 +1 @@
-1:(123)
+1:(2)

lib/test-util.sh:1621: status v2
--- 1481.stdout.expect	2025-03-01 12:32:43.296356201 +0000
+++ 1481.stdout.result	2025-03-01 12:32:43.296356201 +0000
@@ -1 +1 @@
-3:(1 2 3)
+1:(3)

lib/test-util.sh:1622: status v3
--- 1481.stdout.expect	2025-03-01 12:32:43.329355877 +0000
+++ 1481.stdout.result	2025-03-01 12:32:43.330355867 +0000
@@ -1 +1 @@
-1:(bbb)
+3:(bbb)

lib/test-util.sh:1623: status v4
--- 1481.stdout.expect	2025-03-01 12:32:43.364355534 +0000
+++ 1481.stdout.result	2025-03-01 12:32:43.364355534 +0000
@@ -1 +1 @@
-1:(ccc)
+1:(5)

lib/test-util.sh:1635: ble/util/print-global-definitions value
--- 1481.stdout.expect	2025-03-01 12:32:43.434354848 +0000
+++ 1481.stdout.result	2025-03-01 12:32:43.435354838 +0000
@@ -1 +1 @@
-declare value='hello '\''world'\'''
+declare value; builtin unset -v value

lib/test-util.sh:1672: shopt -q failglob
--- 1498.exit.expect	2025-03-01 12:32:43.727351977 +0000
+++ 1498.exit.result	2025-03-01 12:32:43.727351977 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1673: shopt -q nullglob
--- 1498.exit.expect	2025-03-01 12:32:43.759351663 +0000
+++ 1498.exit.result	2025-03-01 12:32:43.760351653 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1674: shopt -q extglob
--- 1498.exit.expect	2025-03-01 12:32:43.791351350 +0000
+++ 1498.exit.result	2025-03-01 12:32:43.792351340 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1685: ble-measure -q "ble/util/msleep 100"; echo "$ret usec" >&2; ((msec=ret/1000,90<=msec&&msec<=120))
--- 1508.exit.expect	2025-03-01 12:32:44.047348841 +0000
+++ 1508.exit.result	2025-03-01 12:32:44.048348831 +0000
@@ -1 +1 @@
-0
+1
<STDERR>
0 usec
</STDERR>

lib/test-util.sh:1686: ble-measure -q "ble/util/sleep 0.1"; echo "$ret usec" >&2; ((msec=ret/1000,90<=msec&&msec<=120))
--- 1508.exit.expect	2025-03-01 12:32:44.204347302 +0000
+++ 1508.exit.result	2025-03-01 12:32:44.204347302 +0000
@@ -1 +1 @@
-0
+1
<STDERR>
0 usec
</STDERR>

lib/test-util.sh:1694: ble/util/conditional-sync 'ble/bin/sleep 10' '((time<1000))' 100
--- 1515.stdout.expect	2025-03-01 12:32:54.285243202 +0000
+++ 1515.stdout.result	2025-03-01 12:32:54.285243202 +0000
@@ -1,10 +1 @@
 100
-200
-300
-400
-500
-600
-700
-800
-900
-1000
<STDERR>
[%1] PID 1517 Started
[%1] PID 1517 Done
[%1] PID 1531 Started
[%2] PID 1533 Started
    set -m; ble/bin/sleep 10 & pid3=$!; set +m
        ^~
lib/test-util.sh:1704: 'set' got invalid flag '-m'
[%3] PID 1535 Started
    set -m; ble/bin/sleep 10 & pid3=$!; set +m
                                            ^
lib/test-util.sh:1704: 'set' got invalid flag '-m'
  ble/function#push/0:ble/util/idle/IS_IDLE
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:ble/util/idle/IS_IDLE' not found (OILS-ERR-100)
  ble/function#push/0:ble/util/.test-utf8-locale
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:ble/util/.test-utf8-locale' not found (OILS-ERR-100)
real	53.215
user	0.578
sys	0.121
real	0.591
user	0.086
sys	0.009
</STDERR>

lib/test-util.sh:1696: ble/util/conditional-sync 'ble/bin/sleep 10' '((time<1000))' 100 progressive-weight
--- 1515.stdout.expect	2025-03-01 12:33:04.347133667 +0000
+++ 1515.stdout.result	2025-03-01 12:33:04.347133667 +0000
@@ -1,16 +1 @@
 1
-3
-7
-15
-31
-63
-127
-227
-327
-427
-527
-627
-727
-827
-927
-1027
<STDERR>
[%1] PID 1522 Started
[%1] PID 1522 Done
</STDERR>

lib/test-util.sh:1698: ble/util/conditional-sync 'ble/bin/sleep 10' 'true' 100 timeout=10
--- 1515.exit.expect	2025-03-01 12:33:14.402019796 +0000
+++ 1515.exit.result	2025-03-01 12:33:14.403019785 +0000
@@ -1 +1 @@
-142
+0
<STDERR>
[%1] PID 1527 Started
[%1] PID 1527 Done
</STDERR>

lib/test-util.sh:1713: kill -0 "$pid1"
--- 1515.exit.expect	2025-03-01 12:33:14.545018237 +0000
+++ 1515.exit.result	2025-03-01 12:33:14.546018226 +0000
@@ -1 +1 @@
-1
+0

lib/test-util.sh:1714: kill -0 "$pid2"
--- 1515.exit.expect	2025-03-01 12:33:14.583017823 +0000
+++ 1515.exit.result	2025-03-01 12:33:14.584017812 +0000
@@ -1 +1 @@
-1
+0

lib/test-util.sh:1715: kill -0 "$pid3"
--- 1515.exit.expect	2025-03-01 12:33:14.621017408 +0000
+++ 1515.exit.result	2025-03-01 12:33:14.622017398 +0000
@@ -1 +1 @@
-1
+0

lib/test-util.sh:1740: ble/util/get-pager ret
--- 1569.ret.expect	2025-03-01 12:33:14.876014629 +0000
+++ 1569.ret.result	2025-03-01 12:33:14.877014618 +0000
@@ -1 +1 @@
-less
+pager

lib/test-util.sh:1763: ble/util/buffer.flush
--- 1574.stdout.expect	2025-03-01 12:33:14.956013757 +0000
+++ 1574.stdout.result	2025-03-01 12:33:14.957013746 +0000
@@ -1 +1 @@
-helloworld
+

lib/test-util.sh:1767: ble/util/buffer.flush
--- 1574.stdout.expect	2025-03-01 12:33:15.001013266 +0000
+++ 1574.stdout.result	2025-03-01 12:33:15.001013266 +0000
@@ -1,2 +1 @@
-hello
-world
+

lib/test-util.sh:2016: ble/util/c2s 956; [[ $ret != μ ]]
--- 1587.exit.expect	2025-03-01 12:33:16.500996914 +0000
+++ 1587.exit.result	2025-03-01 12:33:16.500996914 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:2017: ble/util/c2s 12354; [[ $ret != あ ]]
--- 1587.exit.expect	2025-03-01 12:33:16.533996554 +0000
+++ 1587.exit.result	2025-03-01 12:33:16.533996554 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:2047: ble/util/chars2s
--- 1593.ret.expect	2025-03-01 12:33:16.831993305 +0000
+++ 1593.ret.result	2025-03-01 12:33:16.832993295 +0000
@@ -1 +1 @@
-
+12354
<STDERR>
  \\U%08x
        ^
[ printf arg at line 11674 of out/ble.osh ]:1
</STDERR>

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-@c'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 12:33:17.870981979 +0000
+++ 1596.ret.result	2025-03-01 12:33:17.871981968 +0000
@@ -1 +1 @@
-98 0 99
+98 0

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-ac'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 12:33:17.973980856 +0000
+++ 1596.ret.result	2025-03-01 12:33:17.974980845 +0000
@@ -1 +1 @@
-98 1 99
+98 1

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-zc'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 12:33:18.076979733 +0000
+++ 1596.ret.result	2025-03-01 12:33:18.077979722 +0000
@@ -1 +1 @@
-98 26 99
+98 26

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-]c'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 12:33:18.178978621 +0000
+++ 1596.ret.result	2025-03-01 12:33:18.178978621 +0000
@@ -1 +1 @@
-98 29 99
+98 29

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-^c'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 12:33:18.279977520 +0000
+++ 1596.ret.result	2025-03-01 12:33:18.279977520 +0000
@@ -1 +1 @@
-98 30 99
+98 30

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-_c'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 12:33:18.381976408 +0000
+++ 1596.ret.result	2025-03-01 12:33:18.381976408 +0000
@@ -1 +1 @@
-98 31 99
+98 31

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\M-\C-@c'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 12:33:18.487975253 +0000
+++ 1596.ret.result	2025-03-01 12:33:18.487975253 +0000
@@ -1 +1 @@
-98 27 0 99
+98 27 0

 91.3% [section] ble/util: 1129/1236 (107 fail, 0 crash, 8 skip)

DONE Running lib/test-util.sh


Running lib/test-decode.sh

100.0% [section] ble/decode: 33/33 (0 fail, 0 crash, 0 skip)

DONE Running lib/test-decode.sh

~/oil
DONE