Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Extract the scripting engine code from the functions unit #1312

Draft
wants to merge 26 commits into
base: unstable
Choose a base branch
from

Conversation

rjd15372
Copy link
Contributor

NOTE: this PR is on top of #1277, please ignore the common commits. I'll keep this PR in draft mode until #1277 is merged

This commit creates a new unit for the scripting engine code by extracting the existing code from the functions unit.

We're doing this refactor to prepare the code for runnning the EVAL command using different scripting engines.

Signed-off-by: Ricardo Dias [email protected]

This commit extends the module API to support the addition of different
scripting engines to run user defined functions.

The scripting engine can be implemented as a Valkey module, and can be
dynamically loaded with the `loadmodule` config directive, or with
the `MODULE LOAD` command.

The current module API support, only allows to load scripting engines to
run functions using `FCALL` command.

In a follow up PR, we will move the Lua scripting engine implmentation
into its own module.

Signed-off-by: Ricardo Dias <[email protected]>
This commit adds a module with a very simple stack based scripting
language implementation to test the new module API that allows to
implement new scripting engines as modules.

Signed-off-by: Ricardo Dias <[email protected]>
Signed-off-by: Ricardo Dias <[email protected]>
@rjd15372 rjd15372 force-pushed the refactor-engine-1261 branch from 40bcded to e8db485 Compare November 15, 2024 09:47
Copy link

codecov bot commented Nov 15, 2024

Codecov Report

Attention: Patch coverage is 81.87500% with 58 lines in your changes missing coverage. Please review.

Project coverage is 70.85%. Comparing base (a401e37) to head (1ae23e8).

Files with missing lines Patch % Lines
src/engine.c 74.44% 23 Missing ⚠️
src/module.c 10.00% 18 Missing ⚠️
src/functions.c 89.38% 12 Missing ⚠️
src/rdb.c 50.00% 3 Missing ⚠️
src/function_lua.c 98.41% 1 Missing ⚠️
src/server.c 50.00% 1 Missing ⚠️
Additional details and impacted files
@@             Coverage Diff              @@
##           unstable    #1312      +/-   ##
============================================
+ Coverage     70.69%   70.85%   +0.16%     
============================================
  Files           118      119       +1     
  Lines         63549    63734     +185     
============================================
+ Hits          44924    45161     +237     
+ Misses        18625    18573      -52     
Files with missing lines Coverage Δ
src/script_lua.c 89.92% <100.00%> (-0.51%) ⬇️
src/util.c 71.89% <100.00%> (+0.42%) ⬆️
src/function_lua.c 98.87% <98.41%> (-0.32%) ⬇️
src/server.c 87.40% <50.00%> (+<0.01%) ⬆️
src/rdb.c 76.40% <50.00%> (-0.41%) ⬇️
src/functions.c 94.27% <89.38%> (-1.28%) ⬇️
src/module.c 9.64% <10.00%> (+<0.01%) ⬆️
src/engine.c 74.44% <74.44%> (ø)

... and 12 files with indirect coverage changes

@hpatro
Copy link
Contributor

hpatro commented Nov 15, 2024

@rjd15372 You could point the merge branch as your initial branch. It will show only the diff then.

@rjd15372
Copy link
Contributor Author

rjd15372 commented Nov 15, 2024

@hpatro

@rjd15372 You could point the merge branch as your initial branch. It will show only the diff then.

I don't know if that is possible because the branch that I used to open #1277 is from my own fork of the valkey repo.

@rjd15372 rjd15372 force-pushed the refactor-engine-1261 branch 2 times, most recently from 0cad7ff to 6af7c63 Compare November 25, 2024 15:41
… functionLibInfo in most places

Signed-off-by: Ricardo Dias <[email protected]>
- Removed the `ValkeyModuleScriptingEngineFunctionLibrary` structure.
- Changed a few structure and parameters names.

Signed-off-by: Ricardo Dias <[email protected]>
Signed-off-by: Ricardo Dias <[email protected]>
Signed-off-by: Ricardo Dias <[email protected]>
@rjd15372 rjd15372 force-pushed the refactor-engine-1261 branch 3 times, most recently from 990447a to 54eb99f Compare November 27, 2024 14:52
Signed-off-by: Ricardo Dias <[email protected]>
@rjd15372 rjd15372 force-pushed the refactor-engine-1261 branch from 54eb99f to 1ae23e8 Compare December 5, 2024 12:24
This commit creates a new unit for the scripting engine code by
extracting the existing code from the functions unit.

We're doing this refactor to prepare the code for runnning the `EVAL`
command using different scripting engines.

Signed-off-by: Ricardo Dias <[email protected]>
@rjd15372 rjd15372 force-pushed the refactor-engine-1261 branch from 1ae23e8 to d095057 Compare December 16, 2024 14:57
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants