lua: string.format width/zero-pad/hex/octal/char/precision +6 tests
Some checks failed
Test, Build, and Deploy / test-build-deploy (push) Has been cancelled

This commit is contained in:
2026-04-25 00:24:05 +00:00
parent d170d5fbae
commit fd32bcf547
5 changed files with 183 additions and 66 deletions

View File

@@ -1145,6 +1145,39 @@
((= (type-of n) "number") (str (floor n)))
(else (str n)))))
(define
lua-fmt-pad
(fn (s width left-align zero-pad)
(let ((diff (- width (len s))))
(cond
((<= diff 0) s)
(else
(let ((pad (lua-string-rep (if (and zero-pad (not left-align)) "0" " ") diff)))
(if left-align (str s pad) (str pad s))))))))
(define
lua-fmt-int-base
(fn (n base upper)
(cond
((= n 0) "0")
(else
(let ((sign "") (v n) (out ""))
(begin
(when (< v 0) (begin (set! sign "-") (set! v (- 0 v))))
(set! v (floor v))
(define
ib-loop
(fn ()
(when (> v 0)
(let ((d (- v (* base (floor (/ v base))))))
(let ((c (cond
((< d 10) (char-at "0123456789" d))
(upper (char-at "ABCDEFGHIJKLMNOP" (- d 10)))
(else (char-at "abcdefghijklmnop" (- d 10))))))
(begin (set! out (str c out)) (set! v (floor (/ v base))) (ib-loop)))))))
(ib-loop)
(str sign out)))))))
(define
lua-string-format
(fn (&rest args)
@@ -1158,24 +1191,90 @@
(let ((c (char-at fmt i)))
(cond
((and (= c "%") (< (+ i 1) (len fmt)))
(let ((spec (char-at fmt (+ i 1))))
(cond
((= spec "%")
(begin (set! out (str out "%")) (set! i (+ i 2)) (loop)))
((= spec "s")
(let ((j (+ i 1)) (left-align false) (zero-pad false) (width 0) (prec -1))
(begin
(when (and (< j (len fmt)) (= (char-at fmt j) "-"))
(begin (set! left-align true) (set! j (+ j 1))))
(when (and (< j (len fmt)) (= (char-at fmt j) "0"))
(begin (set! zero-pad true) (set! j (+ j 1))))
(define
wd-loop
(fn ()
(when (and (< j (len fmt)) (>= (char-at fmt j) "0") (<= (char-at fmt j) "9"))
(begin
(set! width (+ (* width 10) (- (char-code (char-at fmt j)) (char-code "0"))))
(set! j (+ j 1))
(wd-loop)))))
(wd-loop)
(when (and (< j (len fmt)) (= (char-at fmt j) "."))
(begin
(set! out (str out (lua-concat-coerce (nth vals vi))))
(set! vi (+ vi 1)) (set! i (+ i 2)) (loop)))
((= spec "d")
(begin
(set! out (str out (lua-format-int (nth vals vi))))
(set! vi (+ vi 1)) (set! i (+ i 2)) (loop)))
((= spec "f")
(begin
(set! out (str out (str (nth vals vi))))
(set! vi (+ vi 1)) (set! i (+ i 2)) (loop)))
(else
(begin (set! out (str out c)) (set! i (+ i 1)) (loop))))))
(set! prec 0)
(set! j (+ j 1))
(define
pr-loop
(fn ()
(when (and (< j (len fmt)) (>= (char-at fmt j) "0") (<= (char-at fmt j) "9"))
(begin
(set! prec (+ (* prec 10) (- (char-code (char-at fmt j)) (char-code "0"))))
(set! j (+ j 1))
(pr-loop)))))
(pr-loop)))
(when (< j (len fmt))
(let ((spec (char-at fmt j)))
(cond
((= spec "%")
(begin (set! out (str out "%")) (set! i (+ j 1))))
((= spec "s")
(let ((v (lua-concat-coerce (nth vals vi))))
(let ((vt (if (and (>= prec 0) (< prec (len v))) (substring v 0 prec) v)))
(begin
(set! out (str out (lua-fmt-pad vt width left-align false)))
(set! vi (+ vi 1))
(set! i (+ j 1))))))
((= spec "d")
(let ((v (lua-fmt-int-base (lua-to-number (nth vals vi)) 10 false)))
(begin
(set! out (str out (lua-fmt-pad v width left-align zero-pad)))
(set! vi (+ vi 1))
(set! i (+ j 1)))))
((= spec "x")
(let ((v (lua-fmt-int-base (lua-to-number (nth vals vi)) 16 false)))
(begin
(set! out (str out (lua-fmt-pad v width left-align zero-pad)))
(set! vi (+ vi 1))
(set! i (+ j 1)))))
((= spec "X")
(let ((v (lua-fmt-int-base (lua-to-number (nth vals vi)) 16 true)))
(begin
(set! out (str out (lua-fmt-pad v width left-align zero-pad)))
(set! vi (+ vi 1))
(set! i (+ j 1)))))
((= spec "o")
(let ((v (lua-fmt-int-base (lua-to-number (nth vals vi)) 8 false)))
(begin
(set! out (str out (lua-fmt-pad v width left-align zero-pad)))
(set! vi (+ vi 1))
(set! i (+ j 1)))))
((= spec "f")
(let ((v (str (lua-to-number (nth vals vi)))))
(begin
(set! out (str out (lua-fmt-pad v width left-align zero-pad)))
(set! vi (+ vi 1))
(set! i (+ j 1)))))
((= spec "c")
(let ((v (lua-char-one (lua-to-number (nth vals vi)))))
(begin
(set! out (str out v))
(set! vi (+ vi 1))
(set! i (+ j 1)))))
((= spec "q")
(let ((v (str "\"" (lua-concat-coerce (nth vals vi)) "\"")))
(begin
(set! out (str out v))
(set! vi (+ vi 1))
(set! i (+ j 1)))))
(else (begin (set! out (str out c)) (set! i (+ i 1)))))))
(loop))))
(else
(begin (set! out (str out c)) (set! i (+ i 1)) (loop))))))))
(loop)

View File

@@ -1,8 +1,8 @@
{
"totals": {
"pass": 1,
"fail": 11,
"timeout": 4,
"fail": 7,
"timeout": 8,
"skip": 8,
"total": 24,
"runnable": 16,
@@ -10,11 +10,11 @@
},
"top_failure_modes": [
[
"other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"assertion failed!\\\\\\\"\\",
7
"timeout",
8
],
[
"timeout",
"other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"assertion failed!\\\\\\\"\\",
4
],
[
@@ -24,10 +24,6 @@
[
"undefined symbol: fat\\",
1
],
[
"other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"lua: attempt to compare incompat",
1
]
],
"results": [
@@ -47,7 +43,7 @@
"name": "attrib.lua",
"status": "timeout",
"reason": "per-test timeout",
"ms": 8008
"ms": 8000
},
{
"name": "big.lua",
@@ -59,7 +55,7 @@
"name": "calls.lua",
"status": "fail",
"reason": "undefined symbol: fat\\",
"ms": 6184
"ms": 6732
},
{
"name": "checktable.lua",
@@ -71,7 +67,7 @@
"name": "closure.lua",
"status": "timeout",
"reason": "per-test timeout",
"ms": 8001
"ms": 8005
},
{
"name": "code.lua",
@@ -81,9 +77,9 @@
},
{
"name": "constructs.lua",
"status": "fail",
"reason": "other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"lua: attempt to compare incompat",
"ms": 7870
"status": "timeout",
"reason": "per-test timeout",
"ms": 8007
},
{
"name": "db.lua",
@@ -95,13 +91,13 @@
"name": "errors.lua",
"status": "fail",
"reason": "other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"assertion failed!\\\\\\\"\\",
"ms": 3808
"ms": 4579
},
{
"name": "events.lua",
"status": "fail",
"reason": "other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"assertion failed!\\\\\\\"\\",
"ms": 7990
"status": "timeout",
"reason": "per-test timeout",
"ms": 8007
},
{
"name": "files.lua",
@@ -119,13 +115,13 @@
"name": "literals.lua",
"status": "fail",
"reason": "other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"assertion failed!\\\\\\\"\\",
"ms": 2085
"ms": 2829
},
{
"name": "locals.lua",
"status": "fail",
"reason": "other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"lua: attempt to call non-functio",
"ms": 1811
"ms": 2598
},
{
"name": "main.lua",
@@ -137,19 +133,19 @@
"name": "math.lua",
"status": "fail",
"reason": "other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"lua: attempt to call non-functio",
"ms": 4436
"ms": 6606
},
{
"name": "nextvar.lua",
"status": "fail",
"reason": "other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"assertion failed!\\\\\\\"\\",
"ms": 7759
"status": "timeout",
"reason": "per-test timeout",
"ms": 8008
},
{
"name": "pm.lua",
"status": "fail",
"reason": "other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"assertion failed!\\\\\\\"\\",
"ms": 6473
"status": "timeout",
"reason": "per-test timeout",
"ms": 8009
},
{
"name": "sort.lua",
@@ -161,19 +157,19 @@
"name": "strings.lua",
"status": "fail",
"reason": "other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"assertion failed!\\\\\\\"\\",
"ms": 4366
"ms": 6228
},
{
"name": "vararg.lua",
"status": "fail",
"reason": "other: Unhandled exception: \\\"Unhandled exception: \\\\\\\"assertion failed!\\\\\\\"\\",
"ms": 2422
"ms": 3087
},
{
"name": "verybig.lua",
"status": "pass",
"reason": "",
"ms": 1077
"ms": 1058
}
]
}

View File

@@ -1,15 +1,14 @@
# Lua-on-SX conformance scoreboard
**Pass rate:** 1/16 runnable (6.2%)
fail=11 timeout=4 skip=8 total=24
fail=7 timeout=8 skip=8 total=24
## Top failure modes
- **7x** other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\
- **4x** timeout
- **8x** timeout
- **4x** other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\
- **2x** other: Unhandled exception: \"Unhandled exception: \\\"lua: attempt to call non-functio
- **1x** undefined symbol: fat\
- **1x** other: Unhandled exception: \"Unhandled exception: \\\"lua: attempt to compare incompat
## Per-test results
@@ -17,25 +16,25 @@ fail=11 timeout=4 skip=8 total=24
|---|---|---|---:|
| all.lua | skip | driver uses dofile to chain other tests | 0 |
| api.lua | skip | requires testC (C debug library) | 0 |
| attrib.lua | timeout | per-test timeout | 8008 |
| attrib.lua | timeout | per-test timeout | 8000 |
| big.lua | timeout | per-test timeout | 8007 |
| calls.lua | fail | undefined symbol: fat\ | 6184 |
| calls.lua | fail | undefined symbol: fat\ | 6732 |
| checktable.lua | skip | internal debug helpers | 0 |
| closure.lua | timeout | per-test timeout | 8001 |
| closure.lua | timeout | per-test timeout | 8005 |
| code.lua | skip | bytecode inspection via debug library | 0 |
| constructs.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"lua: attempt to compare incompat | 7870 |
| constructs.lua | timeout | per-test timeout | 8007 |
| db.lua | skip | debug library | 0 |
| errors.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 3808 |
| events.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 7990 |
| errors.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 4579 |
| events.lua | timeout | per-test timeout | 8007 |
| files.lua | skip | io library | 0 |
| gc.lua | skip | collectgarbage / finalisers | 0 |
| literals.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 2085 |
| locals.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"lua: attempt to call non-functio | 1811 |
| literals.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 2829 |
| locals.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"lua: attempt to call non-functio | 2598 |
| main.lua | skip | standalone interpreter driver | 0 |
| math.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"lua: attempt to call non-functio | 4436 |
| nextvar.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 7759 |
| pm.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 6473 |
| math.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"lua: attempt to call non-functio | 6606 |
| nextvar.lua | timeout | per-test timeout | 8008 |
| pm.lua | timeout | per-test timeout | 8009 |
| sort.lua | timeout | per-test timeout | 8007 |
| strings.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 4366 |
| vararg.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 2422 |
| verybig.lua | pass | - | 1077 |
| strings.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 6228 |
| vararg.lua | fail | other: Unhandled exception: \"Unhandled exception: \\\"assertion failed!\\\"\ | 3087 |
| verybig.lua | pass | - | 1058 |

View File

@@ -994,6 +994,20 @@ cat > "$TMPFILE" << 'EPOCHS'
(epoch 1912)
(eval "(lua-eval-ast \"return string.match(\\\"abc\\\", \\\"[^a]+\\\")\")")
;; ── string.format width/precision/hex/octal/char ─────────────
(epoch 1920)
(eval "(lua-eval-ast \"return string.format('%5d', 42)\")")
(epoch 1921)
(eval "(lua-eval-ast \"return string.format('%05d', 42)\")")
(epoch 1922)
(eval "(lua-eval-ast \"return string.format('%x', 255)\")")
(epoch 1923)
(eval "(lua-eval-ast \"return string.format('%X', 255)\")")
(epoch 1924)
(eval "(lua-eval-ast \"return string.format('%c', 65)\")")
(epoch 1925)
(eval "(lua-eval-ast \"return string.format('%.3s', 'hello')\")")
EPOCHS
OUTPUT=$(timeout 60 "$SX_SERVER" < "$TMPFILE" 2>/dev/null)
@@ -1508,6 +1522,14 @@ check 1910 "[a-z]+ on hello123" '"hello"'
check 1911 "[0-9]+ on hello123" '"123"'
check 1912 "[^a]+ on abc" '"bc"'
# ── string.format width/precision/hex/octal/char ────────────
check 1920 "%5d width" '" 42"'
check 1921 "%05d zero-pad" '"00042"'
check 1922 "%x hex" '"ff"'
check 1923 "%X HEX" '"FF"'
check 1924 "%c char" '"A"'
check 1925 "%.3s precision" '"hel"'
TOTAL=$((PASS + FAIL))
if [ $FAIL -eq 0 ]; then
echo "ok $PASS/$TOTAL Lua-on-SX tests passed"