Skip to content

Commit

Permalink
Fixes issues with Roku doc scraper and adds missing components (#736)
Browse files Browse the repository at this point in the history
* Fixes issues with Roku doc scraper and adds missing components

* Fix failed tests

Co-authored-by: Bronley Plumb <[email protected]>
  • Loading branch information
markwpearce and TwitchBronBron authored Nov 4, 2022
1 parent 8a9fa80 commit 414568f
Show file tree
Hide file tree
Showing 5 changed files with 5,700 additions and 9,818 deletions.
4 changes: 3 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,9 @@
"dep-graph": "madge --image graph.svg --extensions ts ./src/parser",
"docs": "ts-node scripts/compile-doc-examples.ts",
"benchmark": "node ./benchmarks/index.js",
"scrape-roku-docs": "ts-node scripts/scrape-roku-docs.ts"
"scrape-roku-docs": "ts-node scripts/scrape-roku-docs.ts",
"rescrape-roku-docs": "rm scripts/.cache.json && ts-node scripts/scrape-roku-docs.ts"

},
"mocha": {
"spec": "src/**/*.spec.ts",
Expand Down
2 changes: 1 addition & 1 deletion scripts/.cache.json

Large diffs are not rendered by default.

57 changes: 39 additions & 18 deletions scripts/scrape-roku-docs.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
import * as phin from 'phin';
import * as fsExtra from 'fs-extra';
import { standardizePath as s } from '../src/util';
import { Parser } from '../src/parser/Parser';
import { ParseMode, Parser } from '../src/parser/Parser';
import type { CallExpression, LiteralExpression } from '../src/parser/Expression';
import type { ExpressionStatement, FunctionStatement } from '../src/parser/Statement';
import TurndownService = require('turndown');
Expand All @@ -15,6 +15,7 @@ import { marked } from 'marked';
import * as he from 'he';
import * as deepmerge from 'deepmerge';
import { NodeHtmlMarkdown } from 'node-html-markdown';
import { isVariableExpression } from '../src/astUtils/reflection';

type Token = marked.Token;

Expand Down Expand Up @@ -273,7 +274,7 @@ class Runner {
if (/this object is created with no parameters/.exec(manager.html)) {
component.constructors.push({
params: [],
returnType: name,
returnType: component.name,
returnDescription: undefined
});
} else {
Expand All @@ -282,20 +283,25 @@ class Runner {
const regexp = /CreateObject\((.*?)\)/g;
let match;
while (match = regexp.exec(manager.markdown)) {

const { statements, diagnostics } = Parser.parse(match[0]);
if (statements.length > 0) {
if (diagnostics.length === 0) {
const signature = {
params: [],
returnType: name
returnType: component.name
} as Signature;
const call = (statements[0] as ExpressionStatement).expression as CallExpression;
//only scan createObject calls for our own name
if ((call.args[0] as LiteralExpression)?.token?.text === `"${name}"`) {
if ((call.args[0] as LiteralExpression)?.token?.text === `"${component.name}"`) {
//skip the first arg because that's the name of the component
for (let i = 1; i < call.args.length; i++) {
const arg = call.args[i];
let paramName = `param${i}`;
if (isVariableExpression(arg)) {
paramName = arg.getName(ParseMode.BrightScript)
}
signature.params.push({
name: `param${i}`,
name: paramName,
default: undefined,
isRequired: true,
type: (arg as any).type?.toString() ?? 'dynamic',
Expand All @@ -305,18 +311,9 @@ class Runner {
component.constructors.push(signature);
}
} else if (match[1]) {
const foundParamTexts = match[1].split(',').map(x => x.replace(/['"]+/g, '').trim());

if (foundParamTexts[0].toLowerCase() === component.name.toLowerCase()) {
const signature = {
params: [],
returnType: name
} as Signature;
const signature = this.getConstructorSignature(name, match[1])

for (let i = 1; i < foundParamTexts.length; i++) {
const foundParam = foundParamTexts[i];
signature.params.push(this.getParamFromMarkdown(foundParam, `param${i}`));
}
if (signature) {
component.constructors.push(signature);
}
}
Expand All @@ -330,7 +327,31 @@ class Runner {
this[name](component, manager);
}

this.result.components[name?.toLowerCase()] = component;
this.result.components[component?.name?.toLowerCase()] = component;
}
}

private getConstructorSignature(componentName: string, sourceCode: string) {
const foundParamTexts = this.findParamTexts(sourceCode)

if (foundParamTexts && foundParamTexts[0].toLowerCase() === componentName.toLowerCase()) {
const signature = {
params: [],
returnType: componentName
} as Signature;

for (let i = 1; i < foundParamTexts.length; i++) {
const foundParam = foundParamTexts[i];
signature.params.push(this.getParamFromMarkdown(foundParam, `param${i}`));
}
return signature;
}
}


private findParamTexts(sourceCode: string): string[] {
if (!sourceCode.includes('{') && !sourceCode.includes('}')) {
return sourceCode.split(',').map(x => x.replace(/['"]+/g, '').trim());
}
}

Expand Down
10 changes: 4 additions & 6 deletions src/Scope.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -516,7 +516,7 @@ describe('Scope', () => {
DiagnosticMessages.unknownBrightScriptComponent('roDateTime_FAKE'),
DiagnosticMessages.mismatchCreateObjectArgumentCount('roDateTime', [1, 1], 2),
DiagnosticMessages.unknownRoSGNode('Rectangle_FAKE'),
DiagnosticMessages.deprecatedBrightScriptComponent('roFontMetrics').code
DiagnosticMessages.unknownBrightScriptComponent('roFontMetrics')
]);
});

Expand Down Expand Up @@ -601,11 +601,9 @@ describe('Scope', () => {
`);
program.validate();
// only care about code and `roFontMetrics` match
const diagnostics = program.getDiagnostics();
const expectedDiag = DiagnosticMessages.deprecatedBrightScriptComponent('roFontMetrics');
expect(diagnostics.length).to.eql(1);
expect(diagnostics[0].code).to.eql(expectedDiag.code);
expect(diagnostics[0].message).to.contain(expectedDiag.message);
expectDiagnostics(program, [
DiagnosticMessages.unknownBrightScriptComponent('roFontMetrics')
]);
});
});

Expand Down
Loading

0 comments on commit 414568f

Please sign in to comment.