win: fix incomplete VSCEIP, location scripts

This commit improves the validation logic in parser, corrects Windows
collection files to adhere to expected structure. This validation helps
catch errors that previously led to incomplete generated code in scripts
for disabling VSCEIP and location settings.

Changes:

- Add type validation for function call structures in the
  parser/compiler. This helps prevent runtime errors by ensuring that
  only correctly structured data is processed.
- Fix scripts in the Windows collection that previoulsy had incomplete
  `code` or `revertCode` values. These corrections ensure that the
  scripts function as intended.
- Refactor related logic within the compiler/parser to improve
  testability and maintainability.
This commit is contained in:
undergroundwires
2024-06-18 17:59:32 +02:00
parent dc03bff324
commit 48761f62a2
14 changed files with 646 additions and 329 deletions

View File

@@ -0,0 +1,30 @@
import type { FunctionCall } from '@/application/Parser/Executable/Script/Compiler/Function/Call/FunctionCall';
import type { FunctionCallsParser } from '@/application/Parser/Executable/Script/Compiler/Function/Call/FunctionCallsParser';
import type { FunctionCallsData } from '@/application/collections/';
import { FunctionCallStub } from './FunctionCallStub';
export function createFunctionCallsParserStub() {
const setupResults = new Map<FunctionCallsData, FunctionCall[]>();
const parser: FunctionCallsParser = (rawData) => {
if (setupResults.size === 0) {
return [
new FunctionCallStub().withFunctionName('function created by parser stub'),
];
}
const setupResult = setupResults.get(rawData);
if (setupResult === undefined) {
throw new Error(`Stub error: Expected pre-configured input data was not found.\n
Received input: ${JSON.stringify(rawData, null, 2)}\n
Number of configurations available: ${setupResults.size}\n
Available configurations: ${JSON.stringify([...setupResults.keys()].map((key) => JSON.stringify(key, null, 2)), null, 2)}`);
}
return setupResult;
};
const setup = (rawData: FunctionCallsData, parsedData: FunctionCall[]) => {
setupResults.set(rawData, parsedData);
};
return {
parser,
setup,
};
}

View File

@@ -1,40 +1,51 @@
import type { FunctionData } from '@/application/collections/';
import { sequenceEqual } from '@/application/Common/Array';
import type { ISharedFunctionCollection } from '@/application/Parser/Executable/Script/Compiler/Function/ISharedFunctionCollection';
import type { ISharedFunctionsParser } from '@/application/Parser/Executable/Script/Compiler/Function/ISharedFunctionsParser';
import type { SharedFunctionsParser } from '@/application/Parser/Executable/Script/Compiler/Function/SharedFunctionsParser';
import type { ILanguageSyntax } from '@/application/Parser/Executable/Script/Validation/Syntax/ILanguageSyntax';
import { SharedFunctionCollectionStub } from './SharedFunctionCollectionStub';
export class SharedFunctionsParserStub implements ISharedFunctionsParser {
public callHistory = new Array<{
functions: readonly FunctionData[],
syntax: ILanguageSyntax,
export function createSharedFunctionsParserStub() {
const callHistory = new Array<{
readonly functions: readonly FunctionData[],
readonly syntax: ILanguageSyntax,
}>();
private setupResults = new Array<{
functions: readonly FunctionData[],
result: ISharedFunctionCollection,
const setupResults = new Array<{
readonly functions: readonly FunctionData[],
readonly result: ISharedFunctionCollection,
}>();
public setup(functions: readonly FunctionData[], result: ISharedFunctionCollection) {
this.setupResults.push({ functions, result });
}
const findResult = (
functions: readonly FunctionData[],
): ISharedFunctionCollection | undefined => {
return setupResults
.find((result) => sequenceEqual(result.functions, functions))
?.result;
};
public parseFunctions(
const parser: SharedFunctionsParser = (
functions: readonly FunctionData[],
syntax: ILanguageSyntax,
): ISharedFunctionCollection {
this.callHistory.push({
) => {
callHistory.push({
functions: Array.from(functions),
syntax,
});
const result = this.findResult(functions);
const result = findResult(functions);
return result || new SharedFunctionCollectionStub();
}
};
private findResult(functions: readonly FunctionData[]): ISharedFunctionCollection | undefined {
return this.setupResults
.find((result) => sequenceEqual(result.functions, functions))
?.result;
}
const setup = (
functions: readonly FunctionData[],
result: ISharedFunctionCollection,
) => {
setupResults.push({ functions, result });
};
return {
parser,
setup,
callHistory,
};
}