From 13e9048835646c4d254d3bfc97ef8dad61335b74 Mon Sep 17 00:00:00 2001 From: Alex Wilson Date: Sat, 12 Aug 2023 12:04:00 +0100 Subject: [PATCH 1/2] Expose the names of a module's defined function via `modulemeta` This reuses the existing `block_list_funcs` capability and adds an extra field on the `modulemeta` output, called `defs`, containing that list of functions. --- src/linker.c | 1 + tests/jq.test | 10 +++++++--- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/src/linker.c b/src/linker.c index 32a8f032b1..e86c2b4e77 100644 --- a/src/linker.c +++ b/src/linker.c @@ -390,6 +390,7 @@ jv load_module_meta(jq_state *jq, jv mod_relpath) { if (jv_get_kind(meta) == JV_KIND_NULL) meta = jv_object(); meta = jv_object_set(meta, jv_string("deps"), block_take_imports(&program)); + meta = jv_object_set(meta, jv_string("defs"), block_list_funcs(program, 0)); } locfile_free(src); block_free(program); diff --git a/tests/jq.test b/tests/jq.test index 94dec3fb8f..eff15e0009 100644 --- a/tests/jq.test +++ b/tests/jq.test @@ -1624,11 +1624,15 @@ jq: error: Import path must be constant at , line 1: modulemeta "c" -{"whatever":null,"deps":[{"as":"foo","is_data":false,"relpath":"a"},{"search":"./","as":"d","is_data":false,"relpath":"d"},{"search":"./","as":"d2","is_data":false,"relpath":"d"},{"search":"./../lib/jq","as":"e","is_data":false,"relpath":"e"},{"search":"./../lib/jq","as":"f","is_data":false,"relpath":"f"},{"as":"d","is_data":true,"relpath":"data"}]} +{"whatever":null,"deps":[{"as":"foo","is_data":false,"relpath":"a"},{"search":"./","as":"d","is_data":false,"relpath":"d"},{"search":"./","as":"d2","is_data":false,"relpath":"d"},{"search":"./../lib/jq","as":"e","is_data":false,"relpath":"e"},{"search":"./../lib/jq","as":"f","is_data":false,"relpath":"f"},{"as":"d","is_data":true,"relpath":"data"}],"defs":["a/0","c/0"]} -modulemeta | .deps |= length +modulemeta | .deps | length "c" -{"whatever":null,"deps":6} +6 + +modulemeta | .defs | length +"c" +2 %%FAIL IGNORE MSG import "syntaxerror" as e; . From 91315d3e7dab416d5550ccaeb4c76fb7a1be5ada Mon Sep 17 00:00:00 2001 From: Alex Wilson Date: Sat, 12 Aug 2023 12:04:27 +0100 Subject: [PATCH 2/2] Update documentation to reflect new `defs` field on `modulemeta` --- docs/content/manual/manual.yml | 3 ++- jq.1.prebuilt | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/docs/content/manual/manual.yml b/docs/content/manual/manual.yml index d5e625c16c..b1da59441d 100644 --- a/docs/content/manual/manual.yml +++ b/docs/content/manual/manual.yml @@ -3633,7 +3633,8 @@ sections: Takes a module name as input and outputs the module's metadata as an object, with the module's imports (including metadata) - as an array value for the `deps` key. + as an array value for the `deps` key and the module's defined + functions as an array value for the `defs` key. Programs can use this to query a module's metadata, which they could then use to, for example, search for, download, and diff --git a/jq.1.prebuilt b/jq.1.prebuilt index 99c35dbede..285d80bfe3 100644 --- a/jq.1.prebuilt +++ b/jq.1.prebuilt @@ -4011,7 +4011,7 @@ This directive is entirely optional\. It\'s not required for proper operation\. The metadata must be a constant jq expression\. It should be an object with keys like \fBhomepage\fR\. At this time jq doesn\'t use this metadata, but it is made available to users via the \fBmodulemeta\fR builtin\. . .SS "modulemeta" -Takes a module name as input and outputs the module\'s metadata as an object, with the module\'s imports (including metadata) as an array value for the \fBdeps\fR key\. +Takes a module name as input and outputs the module\'s metadata as an object, with the module\'s imports (including metadata) as an array value for the \fBdeps\fR key and the module\'s defined functions as an array value for the \fBdefs\fR key\. . .P Programs can use this to query a module\'s metadata, which they could then use to, for example, search for, download, and install missing dependencies\.