fix(scraper): extract_section_functions coupling
Before this fix, the `extract_section_functions` function had issues with how the elements were discovered. There are some scenarios where selected nodes weren't from the same function definition. It causes the generated teal to mix up the function's parameters.
This commit is contained in:
parent
8127e457d4
commit
4b4af7416c
|
@ -115,28 +115,44 @@ end
|
||||||
|
|
||||||
local function extract_section_functions(dl: string): { Function_Info.Function_Info }
|
local function extract_section_functions(dl: string): { Function_Info.Function_Info }
|
||||||
local query_selectors = {
|
local query_selectors = {
|
||||||
function_name = "dt a",
|
header = "dt",
|
||||||
function_parameters = "dd table",
|
body = "dd",
|
||||||
function_return_type = "dd ol",
|
parameters = "table",
|
||||||
|
return_types = "ol",
|
||||||
}
|
}
|
||||||
|
|
||||||
return scraper_utils.scrape_tuples(
|
return scraper_utils.scrape_tuples(
|
||||||
dl,
|
dl,
|
||||||
{ query_selectors.function_name, query_selectors.function_parameters, query_selectors.function_return_type },
|
{ query_selectors.header, query_selectors.body },
|
||||||
function(nodes: { string : scan.HTMLNode | nil }): Function_Info.Function_Info
|
function(nodes: { string : scan.HTMLNode | nil }): Function_Info.Function_Info
|
||||||
local function_info = Function_Info()
|
if not nodes[query_selectors.header] or not nodes[query_selectors.body] then
|
||||||
|
log:warn(
|
||||||
function_info.name =
|
logger.message_with_metadata(
|
||||||
extract_item_name(nodes[query_selectors.function_name])
|
"Missing header or body",
|
||||||
function_info.parameters =
|
{ nodes = nodes }
|
||||||
List(extract_function_parameters(nodes[query_selectors.function_parameters]))
|
|
||||||
function_info.return_types = List(
|
|
||||||
extract_function_return_types(
|
|
||||||
nodes[query_selectors.function_return_type]
|
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
error("Missing header or body")
|
||||||
return function_info
|
end
|
||||||
|
local header = nodes[query_selectors.header] as scan.HTMLNode
|
||||||
|
local body = nodes[query_selectors.body] as scan.HTMLNode
|
||||||
|
local body_elements = scraper_utils.extract_nodes(
|
||||||
|
body:outer_html(),
|
||||||
|
{ query_selectors.parameters, query_selectors.return_types }
|
||||||
|
)
|
||||||
|
return {
|
||||||
|
name = scraper_utils.scrape(
|
||||||
|
header:outer_html(),
|
||||||
|
"a",
|
||||||
|
extract_item_name
|
||||||
|
)[1],
|
||||||
|
parameters = #body_elements:get(query_selectors.parameters) ~= 0 and
|
||||||
|
List(extract_function_parameters(body_elements:get(query_selectors.parameters)[1])) or
|
||||||
|
(List() as List<Function_Info.Parameter>),
|
||||||
|
return_types = #body_elements:get(query_selectors.return_types) ~= 0 and
|
||||||
|
List(extract_function_return_types(body_elements:get(query_selectors.return_types)[1])) or
|
||||||
|
(List() as List<string>),
|
||||||
|
}
|
||||||
end
|
end
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue