lua: add dump lua stack function and extract flb_lua_arraylength #7826
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
I need a debug function to add new feature for flb_lua to fix issue 7708.
This patch is to
flb_lua_dump_stack
flb_lua_arraylength
to be able to pass index of stackflb_lua_absindex
flb_lua_dump_stack
is to dump lua stack for debug.It needs to modify
flb_lua_arraylength
since the function expects an array should be on the top of the stack.flb_lua_dump_stack
needs to dump an array in the middle of the stack.This patch also supports
flb_lua_absindex
.In some cases, we use negative index to point from a top of the stack. e.g.
lua_next(l, -2)
offlb_lua_arraylength
.It can cause an error when the top of stack is added/deleted.
flb_lua_absindex
is to prevent it since it returns a positive index from the bottom of the stack.Enter
[N/A]
in the box, if an item is not applicable to your change.Testing
Before we can approve your change; please submit the following in a comment:
If this is a change to packaging of containers or native binaries then please confirm it works for all targets.
ok-package-test
label to test for all targets (requires maintainer to do).Documentation
Backporting
Debug/Valgrind output
Fluent Bit is licensed under Apache 2.0, by submitting this pull request I understand that this code will be released under the terms of that license.