Commit graph

31 commits

Author SHA1 Message Date
Kim Alvefur
9bbfb849b1 util.format: Restore "freeze" serialization behavior in logging
This was implied with the "debug" preset and does nice things like turn
util.set objects into "set{a,b,c}" instead of the quite verbose thing
you get otherwise.
2023-03-26 00:33:20 +01:00
Kim Alvefur
328447c2b1 util.format: Tweak serialization of %q formatted entries
Improves serialization of function references especially, the built-in
default handling of that in util.serialization is not the most
informative.  Now, along with the function metatable from util.startup,
the actual function can be found by filename and line number.
2023-03-26 00:18:05 +01:00
Kim Alvefur
43531740f9 util: Prefix module imports with prosody namespace 2023-03-17 16:23:16 +01:00
Kim Alvefur
e64c5e30c2 util.startup: Provide a common Lua 5.3+ math.type() for Lua 5.2
Code deduplication
2022-10-19 16:25:05 +02:00
Kim Alvefur
f8e73eba98 compat: Use table.pack (there since Lua 5.2) over our util.table
Added in d278a770eddc avoid having to deal with its absence in Lua 5.1.
No longer needed when Lua 5.1 support is dropped.
2022-07-11 19:15:24 +02:00
Kim Alvefur
5251c9b686 compat: Remove handling of Lua 5.1 location of 'unpack' function 2022-07-11 19:07:38 +02:00
Kim Alvefur
49a9a1e76a util: Remove various Lua 5.1 compatibility hacks
Part of #1600
2022-07-02 17:31:14 +02:00
Kim Alvefur
c6e9692a00 util.format: Fix typo in comment [codespell] 2022-02-04 16:40:38 +01:00
Kim Alvefur
dccab4e10f util.format: Expand explanation of purpose in comments 2022-01-27 21:40:13 +01:00
Kim Alvefur
c551d3d8dd util.format: Skip control code escaping when doing full serialization
Fixes that a multi-line string ended up "like\
\9this" instead of "like\nthis" as can be demonstrated by somehow
initiating a connection to a HTTP server.
2022-01-27 21:14:22 +01:00
Kim Alvefur
0e997ab3f9 util.format: Optimize most common integer format
A search for log formats in use points to %s being the most common,
followed by %d, so worth having a fast path for that. %g works well with
most numbers and is what Lua 5.1 and 5.2 used
2021-12-13 16:38:33 +01:00
Kim Alvefur
58c9115351 util.format: Ensure metatable __tostring results are also sanitized 2021-12-13 16:34:55 +01:00
Kim Alvefur
d482ece962 util.format: Fix some formats expecting positive numbers in Lua 5.2
Amazing how string.format behaves differently under each Lua version
2021-12-11 20:54:37 +01:00
Kim Alvefur
db41cd8e4d util.format: Fix Lua 5.1 quirks thanks to ALL THE TESTS 2021-12-11 20:40:23 +01:00
Kim Alvefur
0ddd204a27 util.format: Also handle the %p format added in Lua 5.4 2021-12-11 13:39:58 +01:00
Kim Alvefur
1eca4e8870 util.format: Ensure sanitation of strings passed to wrong format
Ie. log("debug", "%d", "\1\2\3") should not result in garbage.

Also optimizing for the common case of ASCII string passed to %s and
early returns everywhere.

Returning nil from a gsub callback keeps the original substring.
2021-12-11 13:30:34 +01:00
Kim Alvefur
d4c1451794 util.format: Escape invalid UTF-8 by passing trough serialization
Should prevent invalid UTF-8 from making it into the logs, which can
cause trouble with terminals or log viewers or other tools, such as when
grep determines that log files are binary.
2021-12-10 22:48:45 +01:00
Kim Alvefur
130f74381c util.format: Escape ASCII control characters also in extra arguments 2021-07-03 04:35:29 +02:00
Kim Alvefur
7e09f662cb util.format: Allow newlines but ensure following lines are indented
This should a) prevent injection of text that looks like legitimate log
lines and b) not mangle tracebacks.
2021-07-03 04:29:25 +02:00
Kim Alvefur
f179b18e2b util.format: Fix missing backslash in pattern
Made the pattern match a longer range than intended, but with no effect
since those characters are not present in the 'control_symbols' table.
2021-07-03 04:24:13 +02:00
Kim Alvefur
6e037dc045 util.format: Change formatting of nil values to avoid looking like XML 2021-06-29 16:18:31 +02:00
Kim Alvefur
3f1d93bb4e util.format: Escape ASCII control characters in output
This should offer some protection against doing evil things to
terminals. Doesn't protect against pure broken UTF-8 garbage however.

See #734
2021-06-15 23:24:23 +02:00
Kim Alvefur
2661a6f5a3 util.format: Handle integer formats the same way on Lua versions without integer support 2019-05-30 13:54:11 +02:00
Kim Alvefur
236abc4afe util.format: Handle formats expecting an integer in Lua 5.3+ (fixes #1371) 2019-05-30 13:41:05 +02:00
Kim Alvefur
177420df39 util.format: Serialize values for the %q format
Improves eg debug logs
2018-10-12 01:29:34 +02:00
Kim Alvefur
01deb521fd util.format: Use pack from util.table 2018-12-08 16:35:39 +01:00
Kim Alvefur
d007771f8d util.format: Tweak how nil values are handled
Because [<nil>] seems exsessive
2018-11-28 20:36:53 +01:00
Kim Alvefur
2facc56274 util.format: Import unpack from table lib in Lua 5.2+ 2017-11-23 20:55:21 +01:00
Kim Alvefur
0c4ad0fdbc util.format: Move tests to spec/ 2017-11-10 05:46:39 +01:00
Kim Alvefur
1438a38845 util: Various minor changes to please [luacheck] 2017-11-10 05:42:32 +01:00
Waqas Hussain
347f3ab6a3 util.format: A string.format wrapper that gracefully handles invalid arguments 2017-09-10 12:42:05 -04:00