Replace YAML parser

pull/596/head
Zef Hemel 2023-11-29 16:51:28 +01:00
parent 62e98b1fd8
commit 1d5c6f9277
9 changed files with 55 additions and 12 deletions

View File

@ -15,7 +15,7 @@ export type { Completion, CompletionResult } from "@codemirror/autocomplete";
export { styleTags, Tag, tagHighlighter, tags } from "@lezer/highlight";
export * as YAML from "https://deno.land/std@0.189.0/yaml/mod.ts";
export * as YAML from "https://esm.sh/js-yaml@4.1.0";
export * as path from "https://deno.land/std@0.189.0/path/mod.ts";
export type {

View File

@ -1,15 +1,48 @@
import { SysCallMapping } from "../../plugos/system.ts";
import { YAML } from "../../web/deps.ts";
type YamlStringifyOptions = {
/** indentation width to use (in spaces). */
indent?: number;
/** when true, will not add an indentation level to array elements */
noArrayIndent?: boolean;
/** do not throw on invalid types (like function in the safe schema) and skip pairs and single values with such types. */
skipInvalid?: boolean;
/** specifies level of nesting, when to switch from block to flow style for collections. -1 means block style everwhere */
flowLevel?: number;
/** if true, sort keys when dumping YAML. If a function, use the function to sort the keys. (default: false) */
sortKeys?: boolean;
/** set max line width. (default: 80) */
lineWidth?: number;
/** if true, don't convert duplicate objects into references (default: false) */
noRefs?: boolean;
/** if true don't try to be compatible with older yaml versions. Currently: don't quote "yes", "no" and so on, as required for YAML 1.1 (default: false) */
noCompatMode?: boolean;
/**
* if true flow sequences will be condensed, omitting the space between `key: value` or `a, b`. Eg. `'[a,b]'` or `{a:{b:c}}`.
* Can be useful when using yaml for pretty URL query params as spaces are %-encoded. (default: false).
*/
condenseFlow?: boolean;
/** strings will be quoted using this quoting style. If you specify single quotes, double quotes will still be used for non-printable characters. (default: `'`) */
quotingType?: "'" | '"';
/** if true, all non-key strings will be quoted even if they normally don't need to. (default: false) */
forceQuotes?: boolean;
};
export function yamlSyscalls(): SysCallMapping {
return {
"yaml.parse": (_ctx, text: string): any => {
return YAML.parse(text);
return YAML.load(text);
},
"yaml.stringify": (_ctx, obj: any): string => {
return YAML.stringify(obj, {
noArrayIndent: true,
"yaml.stringify": (
_ctx,
obj: any,
options: YamlStringifyOptions = {},
): string => {
return YAML.dump(obj, {
quotingType: '"',
noCompatMode: true,
...options,
});
},
};

View File

@ -24,7 +24,7 @@ export function parseYamlSettings(settingsMarkdown: string): {
}
const yaml = match[1];
try {
return YAML.parse(yaml) as {
return YAML.load(yaml) as {
[key: string]: any;
};
} catch (e: any) {

View File

@ -41,7 +41,7 @@ export type IndexTreeEvent = {
};
export type PublishEvent = {
uri: string;
uri?: string;
// Page name
name: string;
};

View File

@ -4,7 +4,7 @@ import {
replaceNodesMatchingAsync,
} from "$sb/lib/tree.ts";
import { YAML } from "$sb/plugos-syscall/mod.ts";
import { YAML } from "$sb/syscalls.ts";
/**
* Extracts attributes from a tree, optionally cleaning them out of the tree.

View File

@ -3,7 +3,7 @@ import { YAML } from "../../common/deps.ts";
globalThis.syscall = (name: string, ...args: readonly any[]) => {
switch (name) {
case "yaml.parse":
return Promise.resolve(YAML.parse(args[0]));
return Promise.resolve(YAML.load(args[0]));
default:
throw Error(`Not implemented in tests: ${name}`);
}

View File

@ -51,7 +51,7 @@ export async function lintYAML({ tree }: LintEvent): Promise<LintDiagnostic[]> {
return diagnostics;
}
const errorRegex = /at line (\d+),? column (\d+)/;
const errorRegex = /\((\d+):(\d+)\)/;
async function lintYaml(
yamlText: string,

View File

@ -25,6 +25,9 @@ export async function publishCommand() {
}
async function publish(pageName: string, uris: string[]) {
const broadcastResults = await events.dispatchEvent(`share:_`, {
name: pageName,
} as PublishEvent);
for (const uri of uris) {
const publisher = uri.split(":")[0];
const results = await events.dispatchEvent(
@ -34,7 +37,7 @@ async function publish(pageName: string, uris: string[]) {
name: pageName,
} as PublishEvent,
);
if (results.length === 0) {
if (broadcastResults.length === 0 && results.length === 0) {
throw new Error(`Unsupported publisher: ${publisher} for URI: ${uri}`);
}
}

View File

@ -505,7 +505,6 @@ export class HttpServer {
return next();
}
}
console.log("Requested path to proxy", url, request.method);
if (url.startsWith("localhost")) {
url = `http://${url}`;
} else {
@ -574,3 +573,11 @@ function utcDateString(mtime: number): string {
function authCookieName(host: string) {
return `auth:${host}`;
}
function headersToJson(headers: Headers) {
let headersObj: any = {};
for (const [key, value] of headers.entries()) {
headersObj[key] = value;
}
return JSON.stringify(headersObj);
}