Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@kizahasi/flocon-core

Package Overview
Dependencies
Maintainers
1
Versions
74
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@kizahasi/flocon-core - npm Package Compare versions

Comparing version 0.14.0 to 0.14.1

7

dist/cjs/internal/toml.js

@@ -28,2 +28,3 @@ "use strict";

const expression_1 = require("./expression");
const util_1 = require("@kizahasi/util");
const dateTime = new t.Type('DateTime', (obj) => true, (input, context) => {

@@ -77,3 +78,3 @@ if (input == null) {

for (const key of path) {
if (typeof current !== 'object') {
if (current == null || typeof current !== 'object') {
return result_1.Result.ok(undefined);

@@ -104,3 +105,3 @@ }

const exactChatPalette = t.strict({
var: t.UnknownRecord,
var: util_1.maybe(t.UnknownRecord),
// textではなくわざわざ冗長なtext.valueにしたのは、[var]→チャットパレットの文字列 の順で書けるようにするため。

@@ -169,2 +170,2 @@ // また、将来的に例えばtext.typeに何かをセットして…という拡張もできる余地がある。

exports.isValidChatPalette = isValidChatPalette;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toml.js","sourceRoot":"","sources":["../../../src/internal/toml.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,oDAAoD;AACpD,yCAA2B;AAC3B,wCAMqB;AACrB,6CAA0C;AAC1C,6CAA8C;AAG9C,MAAM,QAAQ,GAAG,IAAI,CAAC,CAAC,IAAI,CACvB,UAAU,EACV,CAAC,GAAG,EAAuB,EAAE,CAAC,IAAI,EAClC,CAAC,KAAU,EAAE,OAAO,EAAE,EAAE;IACpB,IAAI,KAAK,IAAI,IAAI,EAAE;QACf,OAAO,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;KACpC;IACD,IAAI,OAAO,KAAK,CAAC,MAAM,KAAK,UAAU,EAAE;QACpC,OAAO,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;KACpC;IACD,OAAO,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AAC5B,CAAC,EACD,CAAC,CAAC,QAAQ,CACb,CAAC;AAEF,MAAM,cAAc,GAAG,CAAC,MAAgB,EAAU,EAAE;;IAChD,OAAO,MAAA,MAAA,MAAM,CAAC,CAAC,CAAC,0CAAE,OAAO,mCAAI,eAAe,CAAC;AACjD,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,CAAC,IAAY,EAAE,EAAE;IACnC,IAAI,MAAM,CAAC;IACX,IAAI;QACA,MAAM,GAAG,cAAS,CAAC,IAAI,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;KAChD;IAAC,OAAO,KAAK,EAAE;QACZ,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC3B,OAAO,eAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;SAC9B;QACD,IAAI,KAAK,YAAY,KAAK,EAAE;YACxB,OAAO,eAAM,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;SACtC;QACD,MAAM,KAAK,CAAC;KACf;IACD,OAAO,eAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;AAC7B,CAAC,CAAC;AAEK,MAAM,SAAS,GAAG,CAAC,IAAY,EAAE,EAAE;IACtC,MAAM,IAAI,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;IACjC,IAAI,IAAI,CAAC,OAAO,EAAE;QACd,OAAO,IAAI,CAAC;KACf;IACD,OAAO,eAAM,CAAC,EAAE,CAAC,IAAI,CAAC,KAAgB,CAAC,CAAC;AAC5C,CAAC,CAAC;AANW,QAAA,SAAS,aAMpB;AAEK,MAAM,cAAc,GAAG,CAAC,IAAY,EAAqB,EAAE;IAC9D,MAAM,MAAM,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;IACnC,IAAI,MAAM,CAAC,OAAO,EAAE;QAChB,OAAO,MAAM,CAAC;KACjB;IACD,OAAO,eAAM,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC;AAChC,CAAC,CAAC;AANW,QAAA,cAAc,kBAMzB;AAEK,MAAM,4BAA4B,GAAG,CAAC,UAAmB,EAAE,IAA2B,EAAE,EAAE;IAC7F,IAAI,OAAO,GAAQ,UAAU,CAAC;IAC9B,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;QACpB,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;YAC7B,OAAO,eAAM,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC;SAC/B;QACD,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;QAC1B,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,aAAa,CAAC,IAAI,KAAK,OAAO,EAAE;YAChC,OAAO,eAAM,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;SACzC;QACD,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;KAC1B;IACD,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC/C,IAAI,aAAa,CAAC,IAAI,KAAK,OAAO,EAAE;QAChC,OAAO,eAAM,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;KACzC;IACD,QAAQ,OAAO,OAAO,EAAE;QACpB,KAAK,SAAS,CAAC;QACf,KAAK,QAAQ,CAAC;QACd,KAAK,QAAQ,CAAC;QACd,KAAK,WAAW;YACZ,OAAO,eAAM,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;QAC9B;YACI,OAAO,eAAM,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC;KACnC;AACL,CAAC,CAAC;AA1BW,QAAA,4BAA4B,gCA0BvC;AAEF,MAAM,gBAAgB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC9B,GAAG,EAAE,CAAC,CAAC,aAAa;IAEpB,mEAAmE;IACnE,+CAA+C;IAC/C,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC;QACX,KAAK,EAAE,CAAC,CAAC,MAAM;KAClB,CAAC;CACL,CAAC,CAAC;AAEH,gFAAgF;AACzE,MAAM,mBAAmB,GAAG,CAAC,IAAY,EAAoB,EAAE;IAClE,8BAA8B;IAC9B,MAAM,MAAM,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;IACnC,IAAI,MAAM,CAAC,OAAO,EAAE;QAChB,OAAO,MAAM,CAAC;KACjB;IACD,MAAM,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACtD,IAAI,OAAO,CAAC,IAAI,KAAK,MAAM,EAAE;QACzB,OAAO,eAAM,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;KACrD;IAED,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QACtE,MAAM,aAAa,GAAG,oBAAO,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,aAAa,CAAC,OAAO,EAAE;YACvB,OAAO,IAAI,CAAC;SACf;QACD,OAAO,aAAa,CAAC,KAAK;aACrB,GAAG,CAAC,IAAI,CAAC,EAAE;YACR,QAAQ,IAAI,CAAC,IAAI,EAAE;gBACf,KAAK,kBAAK,CAAC,CAAC;oBACR,MAAM,QAAQ,GAAG,oCAA4B,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC5E,IAAI,QAAQ,CAAC,OAAO,EAAE;wBAClB,OAAO,IAAI,CAAC,GAAG,CAAC;qBACnB;oBACD,8CAA8C;oBAC9C,QAAQ,OAAO,QAAQ,CAAC,KAAK,EAAE;wBAC3B,KAAK,QAAQ,CAAC;wBACd,KAAK,QAAQ,CAAC;wBACd,KAAK,SAAS;4BACV,OAAO,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;wBACrC;4BACI,OAAO,EAAE,CAAC;qBACjB;iBACJ;gBACD,OAAO,CAAC,CAAC;oBACL,OAAO,IAAI,CAAC,IAAI,CAAC;iBACpB;aACJ;QACL,CAAC,CAAC;aACD,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,GAAG,IAAI,EAAE,EAAE,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,OAAO,eAAM,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;AAC5B,CAAC,CAAC;AA3CW,QAAA,mBAAmB,uBA2C9B;AAEK,MAAM,kBAAkB,GAAG,CAAC,IAAY,EAAqB,EAAE;IAClE,8BAA8B;IAC9B,MAAM,MAAM,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;IACnC,IAAI,MAAM,CAAC,OAAO,EAAE;QAChB,OAAO,MAAM,CAAC;KACjB;IACD,MAAM,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACtD,IAAI,OAAO,CAAC,IAAI,KAAK,MAAM,EAAE;QACzB,OAAO,eAAM,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;KACrD;IACD,OAAO,eAAM,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC;AAChC,CAAC,CAAC;AAXW,QAAA,kBAAkB,sBAW7B","sourcesContent":["/* eslint-disable @typescript-eslint/no-namespace */\r\nimport * as t from 'io-ts';\r\nimport {\r\n    parse as parseCore,\r\n    LocalDate as TomlLocalDate,\r\n    LocalDateTime as TomlLocalDateTime,\r\n    LocalTime as TomlLocalTime,\r\n    OffsetDateTime as TomlOffsetDateTime,\r\n} from '@ltd/j-toml';\r\nimport { Result } from '@kizahasi/result';\r\nimport { analyze, expr1 } from './expression';\r\n\r\ntype TomlDateTime = TomlLocalDate | TomlLocalDateTime | TomlLocalTime | TomlOffsetDateTime;\r\nconst dateTime = new t.Type<TomlDateTime>(\r\n    'DateTime',\r\n    (obj): obj is TomlDateTime => true,\r\n    (input: any, context) => {\r\n        if (input == null) {\r\n            return t.failure(input, context);\r\n        }\r\n        if (typeof input.toJSON !== 'function') {\r\n            return t.failure(input, context);\r\n        }\r\n        return t.success(input);\r\n    },\r\n    t.identity\r\n);\r\n\r\nconst errorToMessage = (source: t.Errors): string => {\r\n    return source[0]?.message ?? '不明なエラーが発生しました';\r\n};\r\n\r\nconst parseTomlCore = (toml: string) => {\r\n    let object;\r\n    try {\r\n        object = parseCore(toml, 1.0, '\\r\\n', false);\r\n    } catch (error) {\r\n        if (typeof error === 'string') {\r\n            return Result.error(error);\r\n        }\r\n        if (error instanceof Error) {\r\n            return Result.error(error.message);\r\n        }\r\n        throw error;\r\n    }\r\n    return Result.ok(object);\r\n};\r\n\r\nexport const parseToml = (toml: string) => {\r\n    const core = parseTomlCore(toml);\r\n    if (core.isError) {\r\n        return core;\r\n    }\r\n    return Result.ok(core.value as unknown);\r\n};\r\n\r\nexport const isValidVarToml = (toml: string): Result<undefined> => {\r\n    const parsed = parseTomlCore(toml);\r\n    if (parsed.isError) {\r\n        return parsed;\r\n    }\r\n    return Result.ok(undefined);\r\n};\r\n\r\nexport const getVariableFromVarTomlObject = (tomlObject: unknown, path: ReadonlyArray<string>) => {\r\n    let current: any = tomlObject;\r\n    for (const key of path) {\r\n        if (typeof current !== 'object') {\r\n            return Result.ok(undefined);\r\n        }\r\n        const next = current[key];\r\n        const dateTimeValue = dateTime.decode(next);\r\n        if (dateTimeValue._tag === 'Right') {\r\n            return Result.ok(dateTimeValue.right);\r\n        }\r\n        current = current[key];\r\n    }\r\n    const dateTimeValue = dateTime.decode(current);\r\n    if (dateTimeValue._tag === 'Right') {\r\n        return Result.ok(dateTimeValue.right);\r\n    }\r\n    switch (typeof current) {\r\n        case 'boolean':\r\n        case 'number':\r\n        case 'string':\r\n        case 'undefined':\r\n            return Result.ok(current);\r\n        default:\r\n            return Result.ok(undefined);\r\n    }\r\n};\r\n\r\nconst exactChatPalette = t.strict({\r\n    var: t.UnknownRecord,\r\n\r\n    // textではなくわざわざ冗長なtext.valueにしたのは、[var]→チャットパレットの文字列 の順で書けるようにするため。\r\n    // また、将来的に例えばtext.typeに何かをセットして…という拡張もできる余地がある。\r\n    text: t.strict({\r\n        value: t.string,\r\n    }),\r\n});\r\n\r\n// text.valueに例えば {foo} のような文字列が含まれている場合、varで定義されていればそれに置き換える。定義が見つからなければそのまま残す。\r\nexport const generateChatPalette = (toml: string): Result<string[]> => {\r\n    // CONSIDER: TOMLのDateTimeに未対応\r\n    const object = parseTomlCore(toml);\r\n    if (object.isError) {\r\n        return object;\r\n    }\r\n    const decoded = exactChatPalette.decode(object.value);\r\n    if (decoded._tag === 'Left') {\r\n        return Result.error(errorToMessage(decoded.left));\r\n    }\r\n\r\n    const lines = decoded.right.text.value.split(/(?:\\r\\n|\\r|\\n)/).map(line => {\r\n        const analyzeResult = analyze(line);\r\n        if (analyzeResult.isError) {\r\n            return line;\r\n        }\r\n        return analyzeResult.value\r\n            .map(expr => {\r\n                switch (expr.type) {\r\n                    case expr1: {\r\n                        const replaced = getVariableFromVarTomlObject(decoded.right.var, expr.path);\r\n                        if (replaced.isError) {\r\n                            return expr.raw;\r\n                        }\r\n                        // TODO: replaced.valueがstring以外のときの処理の仕様が今は曖昧\r\n                        switch (typeof replaced.value) {\r\n                            case 'string':\r\n                            case 'number':\r\n                            case 'boolean':\r\n                                return replaced.value.toString();\r\n                            default:\r\n                                return '';\r\n                        }\r\n                    }\r\n                    default: {\r\n                        return expr.text;\r\n                    }\r\n                }\r\n            })\r\n            .reduce((seed, elem) => seed + elem, '');\r\n    });\r\n\r\n    return Result.ok(lines);\r\n};\r\n\r\nexport const isValidChatPalette = (toml: string): Result<undefined> => {\r\n    // CONSIDER: TOMLのDateTimeに未対応\r\n    const object = parseTomlCore(toml);\r\n    if (object.isError) {\r\n        return object;\r\n    }\r\n    const decoded = exactChatPalette.decode(object.value);\r\n    if (decoded._tag === 'Left') {\r\n        return Result.error(errorToMessage(decoded.left));\r\n    }\r\n    return Result.ok(undefined);\r\n};\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toml.js","sourceRoot":"","sources":["../../../src/internal/toml.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-namespace */\r\nimport * as t from 'io-ts';\r\nimport {\r\n    parse as parseCore,\r\n    LocalDate as TomlLocalDate,\r\n    LocalDateTime as TomlLocalDateTime,\r\n    LocalTime as TomlLocalTime,\r\n    OffsetDateTime as TomlOffsetDateTime,\r\n} from '@ltd/j-toml';\r\nimport { Result } from '@kizahasi/result';\r\nimport { analyze, expr1 } from './expression';\r\nimport { maybe } from '@kizahasi/util';\r\n\r\ntype TomlDateTime = TomlLocalDate | TomlLocalDateTime | TomlLocalTime | TomlOffsetDateTime;\r\nconst dateTime = new t.Type<TomlDateTime>(\r\n    'DateTime',\r\n    (obj): obj is TomlDateTime => true,\r\n    (input: any, context) => {\r\n        if (input == null) {\r\n            return t.failure(input, context);\r\n        }\r\n        if (typeof input.toJSON !== 'function') {\r\n            return t.failure(input, context);\r\n        }\r\n        return t.success(input);\r\n    },\r\n    t.identity\r\n);\r\n\r\nconst errorToMessage = (source: t.Errors): string => {\r\n    return source[0]?.message ?? '不明なエラーが発生しました';\r\n};\r\n\r\nconst parseTomlCore = (toml: string) => {\r\n    let object;\r\n    try {\r\n        object = parseCore(toml, 1.0, '\\r\\n', false);\r\n    } catch (error) {\r\n        if (typeof error === 'string') {\r\n            return Result.error(error);\r\n        }\r\n        if (error instanceof Error) {\r\n            return Result.error(error.message);\r\n        }\r\n        throw error;\r\n    }\r\n    return Result.ok(object);\r\n};\r\n\r\nexport const parseToml = (toml: string) => {\r\n    const core = parseTomlCore(toml);\r\n    if (core.isError) {\r\n        return core;\r\n    }\r\n    return Result.ok(core.value as unknown);\r\n};\r\n\r\nexport const isValidVarToml = (toml: string): Result<undefined> => {\r\n    const parsed = parseTomlCore(toml);\r\n    if (parsed.isError) {\r\n        return parsed;\r\n    }\r\n    return Result.ok(undefined);\r\n};\r\n\r\nexport const getVariableFromVarTomlObject = (tomlObject: unknown, path: ReadonlyArray<string>) => {\r\n    let current: any = tomlObject;\r\n    for (const key of path) {\r\n        if (current == null || typeof current !== 'object') {\r\n            return Result.ok(undefined);\r\n        }\r\n        const next = current[key];\r\n        const dateTimeValue = dateTime.decode(next);\r\n        if (dateTimeValue._tag === 'Right') {\r\n            return Result.ok(dateTimeValue.right);\r\n        }\r\n        current = current[key];\r\n    }\r\n    const dateTimeValue = dateTime.decode(current);\r\n    if (dateTimeValue._tag === 'Right') {\r\n        return Result.ok(dateTimeValue.right);\r\n    }\r\n    switch (typeof current) {\r\n        case 'boolean':\r\n        case 'number':\r\n        case 'string':\r\n        case 'undefined':\r\n            return Result.ok(current);\r\n        default:\r\n            return Result.ok(undefined);\r\n    }\r\n};\r\n\r\nconst exactChatPalette = t.strict({\r\n    var: maybe(t.UnknownRecord),\r\n\r\n    // textではなくわざわざ冗長なtext.valueにしたのは、[var]→チャットパレットの文字列 の順で書けるようにするため。\r\n    // また、将来的に例えばtext.typeに何かをセットして…という拡張もできる余地がある。\r\n    text: t.strict({\r\n        value: t.string,\r\n    }),\r\n});\r\n\r\n// text.valueに例えば {foo} のような文字列が含まれている場合、varで定義されていればそれに置き換える。定義が見つからなければそのまま残す。\r\nexport const generateChatPalette = (toml: string): Result<string[]> => {\r\n    // CONSIDER: TOMLのDateTimeに未対応\r\n    const object = parseTomlCore(toml);\r\n    if (object.isError) {\r\n        return object;\r\n    }\r\n    const decoded = exactChatPalette.decode(object.value);\r\n    if (decoded._tag === 'Left') {\r\n        return Result.error(errorToMessage(decoded.left));\r\n    }\r\n\r\n    const lines = decoded.right.text.value.split(/(?:\\r\\n|\\r|\\n)/).map(line => {\r\n        const analyzeResult = analyze(line);\r\n        if (analyzeResult.isError) {\r\n            return line;\r\n        }\r\n        return analyzeResult.value\r\n            .map(expr => {\r\n                switch (expr.type) {\r\n                    case expr1: {\r\n                        const replaced = getVariableFromVarTomlObject(decoded.right.var, expr.path);\r\n                        if (replaced.isError) {\r\n                            return expr.raw;\r\n                        }\r\n                        // TODO: replaced.valueがstring以外のときの処理の仕様が今は曖昧\r\n                        switch (typeof replaced.value) {\r\n                            case 'string':\r\n                            case 'number':\r\n                            case 'boolean':\r\n                                return replaced.value.toString();\r\n                            default:\r\n                                return '';\r\n                        }\r\n                    }\r\n                    default: {\r\n                        return expr.text;\r\n                    }\r\n                }\r\n            })\r\n            .reduce((seed, elem) => seed + elem, '');\r\n    });\r\n\r\n    return Result.ok(lines);\r\n};\r\n\r\nexport const isValidChatPalette = (toml: string): Result<undefined> => {\r\n    // CONSIDER: TOMLのDateTimeに未対応\r\n    const object = parseTomlCore(toml);\r\n    if (object.isError) {\r\n        return object;\r\n    }\r\n    const decoded = exactChatPalette.decode(object.value);\r\n    if (decoded._tag === 'Left') {\r\n        return Result.error(errorToMessage(decoded.left));\r\n    }\r\n    return Result.ok(undefined);\r\n};\r\n"]}

@@ -6,2 +6,3 @@ /* eslint-disable @typescript-eslint/no-namespace */

import { analyze, expr1 } from './expression';
import { maybe } from '@kizahasi/util';
const dateTime = new t.Type('DateTime', (obj) => true, (input, context) => {

@@ -53,3 +54,3 @@ if (input == null) {

for (const key of path) {
if (typeof current !== 'object') {
if (current == null || typeof current !== 'object') {
return Result.ok(undefined);

@@ -79,3 +80,3 @@ }

const exactChatPalette = t.strict({
var: t.UnknownRecord,
var: maybe(t.UnknownRecord),
// textではなくわざわざ冗長なtext.valueにしたのは、[var]→チャットパレットの文字列 の順で書けるようにするため。

@@ -142,2 +143,2 @@ // また、将来的に例えばtext.typeに何かをセットして…という拡張もできる余地がある。

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toml.js","sourceRoot":"","sources":["../../../src/internal/toml.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-namespace */\r\nimport * as t from 'io-ts';\r\nimport {\r\n    parse as parseCore,\r\n    LocalDate as TomlLocalDate,\r\n    LocalDateTime as TomlLocalDateTime,\r\n    LocalTime as TomlLocalTime,\r\n    OffsetDateTime as TomlOffsetDateTime,\r\n} from '@ltd/j-toml';\r\nimport { Result } from '@kizahasi/result';\r\nimport { analyze, expr1 } from './expression';\r\n\r\ntype TomlDateTime = TomlLocalDate | TomlLocalDateTime | TomlLocalTime | TomlOffsetDateTime;\r\nconst dateTime = new t.Type<TomlDateTime>(\r\n    'DateTime',\r\n    (obj): obj is TomlDateTime => true,\r\n    (input: any, context) => {\r\n        if (input == null) {\r\n            return t.failure(input, context);\r\n        }\r\n        if (typeof input.toJSON !== 'function') {\r\n            return t.failure(input, context);\r\n        }\r\n        return t.success(input);\r\n    },\r\n    t.identity\r\n);\r\n\r\nconst errorToMessage = (source: t.Errors): string => {\r\n    return source[0]?.message ?? '不明なエラーが発生しました';\r\n};\r\n\r\nconst parseTomlCore = (toml: string) => {\r\n    let object;\r\n    try {\r\n        object = parseCore(toml, 1.0, '\\r\\n', false);\r\n    } catch (error) {\r\n        if (typeof error === 'string') {\r\n            return Result.error(error);\r\n        }\r\n        if (error instanceof Error) {\r\n            return Result.error(error.message);\r\n        }\r\n        throw error;\r\n    }\r\n    return Result.ok(object);\r\n};\r\n\r\nexport const parseToml = (toml: string) => {\r\n    const core = parseTomlCore(toml);\r\n    if (core.isError) {\r\n        return core;\r\n    }\r\n    return Result.ok(core.value as unknown);\r\n};\r\n\r\nexport const isValidVarToml = (toml: string): Result<undefined> => {\r\n    const parsed = parseTomlCore(toml);\r\n    if (parsed.isError) {\r\n        return parsed;\r\n    }\r\n    return Result.ok(undefined);\r\n};\r\n\r\nexport const getVariableFromVarTomlObject = (tomlObject: unknown, path: ReadonlyArray<string>) => {\r\n    let current: any = tomlObject;\r\n    for (const key of path) {\r\n        if (typeof current !== 'object') {\r\n            return Result.ok(undefined);\r\n        }\r\n        const next = current[key];\r\n        const dateTimeValue = dateTime.decode(next);\r\n        if (dateTimeValue._tag === 'Right') {\r\n            return Result.ok(dateTimeValue.right);\r\n        }\r\n        current = current[key];\r\n    }\r\n    const dateTimeValue = dateTime.decode(current);\r\n    if (dateTimeValue._tag === 'Right') {\r\n        return Result.ok(dateTimeValue.right);\r\n    }\r\n    switch (typeof current) {\r\n        case 'boolean':\r\n        case 'number':\r\n        case 'string':\r\n        case 'undefined':\r\n            return Result.ok(current);\r\n        default:\r\n            return Result.ok(undefined);\r\n    }\r\n};\r\n\r\nconst exactChatPalette = t.strict({\r\n    var: t.UnknownRecord,\r\n\r\n    // textではなくわざわざ冗長なtext.valueにしたのは、[var]→チャットパレットの文字列 の順で書けるようにするため。\r\n    // また、将来的に例えばtext.typeに何かをセットして…という拡張もできる余地がある。\r\n    text: t.strict({\r\n        value: t.string,\r\n    }),\r\n});\r\n\r\n// text.valueに例えば {foo} のような文字列が含まれている場合、varで定義されていればそれに置き換える。定義が見つからなければそのまま残す。\r\nexport const generateChatPalette = (toml: string): Result<string[]> => {\r\n    // CONSIDER: TOMLのDateTimeに未対応\r\n    const object = parseTomlCore(toml);\r\n    if (object.isError) {\r\n        return object;\r\n    }\r\n    const decoded = exactChatPalette.decode(object.value);\r\n    if (decoded._tag === 'Left') {\r\n        return Result.error(errorToMessage(decoded.left));\r\n    }\r\n\r\n    const lines = decoded.right.text.value.split(/(?:\\r\\n|\\r|\\n)/).map(line => {\r\n        const analyzeResult = analyze(line);\r\n        if (analyzeResult.isError) {\r\n            return line;\r\n        }\r\n        return analyzeResult.value\r\n            .map(expr => {\r\n                switch (expr.type) {\r\n                    case expr1: {\r\n                        const replaced = getVariableFromVarTomlObject(decoded.right.var, expr.path);\r\n                        if (replaced.isError) {\r\n                            return expr.raw;\r\n                        }\r\n                        // TODO: replaced.valueがstring以外のときの処理の仕様が今は曖昧\r\n                        switch (typeof replaced.value) {\r\n                            case 'string':\r\n                            case 'number':\r\n                            case 'boolean':\r\n                                return replaced.value.toString();\r\n                            default:\r\n                                return '';\r\n                        }\r\n                    }\r\n                    default: {\r\n                        return expr.text;\r\n                    }\r\n                }\r\n            })\r\n            .reduce((seed, elem) => seed + elem, '');\r\n    });\r\n\r\n    return Result.ok(lines);\r\n};\r\n\r\nexport const isValidChatPalette = (toml: string): Result<undefined> => {\r\n    // CONSIDER: TOMLのDateTimeに未対応\r\n    const object = parseTomlCore(toml);\r\n    if (object.isError) {\r\n        return object;\r\n    }\r\n    const decoded = exactChatPalette.decode(object.value);\r\n    if (decoded._tag === 'Left') {\r\n        return Result.error(errorToMessage(decoded.left));\r\n    }\r\n    return Result.ok(undefined);\r\n};\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toml.js","sourceRoot":"","sources":["../../../src/internal/toml.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-namespace */\r\nimport * as t from 'io-ts';\r\nimport {\r\n    parse as parseCore,\r\n    LocalDate as TomlLocalDate,\r\n    LocalDateTime as TomlLocalDateTime,\r\n    LocalTime as TomlLocalTime,\r\n    OffsetDateTime as TomlOffsetDateTime,\r\n} from '@ltd/j-toml';\r\nimport { Result } from '@kizahasi/result';\r\nimport { analyze, expr1 } from './expression';\r\nimport { maybe } from '@kizahasi/util';\r\n\r\ntype TomlDateTime = TomlLocalDate | TomlLocalDateTime | TomlLocalTime | TomlOffsetDateTime;\r\nconst dateTime = new t.Type<TomlDateTime>(\r\n    'DateTime',\r\n    (obj): obj is TomlDateTime => true,\r\n    (input: any, context) => {\r\n        if (input == null) {\r\n            return t.failure(input, context);\r\n        }\r\n        if (typeof input.toJSON !== 'function') {\r\n            return t.failure(input, context);\r\n        }\r\n        return t.success(input);\r\n    },\r\n    t.identity\r\n);\r\n\r\nconst errorToMessage = (source: t.Errors): string => {\r\n    return source[0]?.message ?? '不明なエラーが発生しました';\r\n};\r\n\r\nconst parseTomlCore = (toml: string) => {\r\n    let object;\r\n    try {\r\n        object = parseCore(toml, 1.0, '\\r\\n', false);\r\n    } catch (error) {\r\n        if (typeof error === 'string') {\r\n            return Result.error(error);\r\n        }\r\n        if (error instanceof Error) {\r\n            return Result.error(error.message);\r\n        }\r\n        throw error;\r\n    }\r\n    return Result.ok(object);\r\n};\r\n\r\nexport const parseToml = (toml: string) => {\r\n    const core = parseTomlCore(toml);\r\n    if (core.isError) {\r\n        return core;\r\n    }\r\n    return Result.ok(core.value as unknown);\r\n};\r\n\r\nexport const isValidVarToml = (toml: string): Result<undefined> => {\r\n    const parsed = parseTomlCore(toml);\r\n    if (parsed.isError) {\r\n        return parsed;\r\n    }\r\n    return Result.ok(undefined);\r\n};\r\n\r\nexport const getVariableFromVarTomlObject = (tomlObject: unknown, path: ReadonlyArray<string>) => {\r\n    let current: any = tomlObject;\r\n    for (const key of path) {\r\n        if (current == null || typeof current !== 'object') {\r\n            return Result.ok(undefined);\r\n        }\r\n        const next = current[key];\r\n        const dateTimeValue = dateTime.decode(next);\r\n        if (dateTimeValue._tag === 'Right') {\r\n            return Result.ok(dateTimeValue.right);\r\n        }\r\n        current = current[key];\r\n    }\r\n    const dateTimeValue = dateTime.decode(current);\r\n    if (dateTimeValue._tag === 'Right') {\r\n        return Result.ok(dateTimeValue.right);\r\n    }\r\n    switch (typeof current) {\r\n        case 'boolean':\r\n        case 'number':\r\n        case 'string':\r\n        case 'undefined':\r\n            return Result.ok(current);\r\n        default:\r\n            return Result.ok(undefined);\r\n    }\r\n};\r\n\r\nconst exactChatPalette = t.strict({\r\n    var: maybe(t.UnknownRecord),\r\n\r\n    // textではなくわざわざ冗長なtext.valueにしたのは、[var]→チャットパレットの文字列 の順で書けるようにするため。\r\n    // また、将来的に例えばtext.typeに何かをセットして…という拡張もできる余地がある。\r\n    text: t.strict({\r\n        value: t.string,\r\n    }),\r\n});\r\n\r\n// text.valueに例えば {foo} のような文字列が含まれている場合、varで定義されていればそれに置き換える。定義が見つからなければそのまま残す。\r\nexport const generateChatPalette = (toml: string): Result<string[]> => {\r\n    // CONSIDER: TOMLのDateTimeに未対応\r\n    const object = parseTomlCore(toml);\r\n    if (object.isError) {\r\n        return object;\r\n    }\r\n    const decoded = exactChatPalette.decode(object.value);\r\n    if (decoded._tag === 'Left') {\r\n        return Result.error(errorToMessage(decoded.left));\r\n    }\r\n\r\n    const lines = decoded.right.text.value.split(/(?:\\r\\n|\\r|\\n)/).map(line => {\r\n        const analyzeResult = analyze(line);\r\n        if (analyzeResult.isError) {\r\n            return line;\r\n        }\r\n        return analyzeResult.value\r\n            .map(expr => {\r\n                switch (expr.type) {\r\n                    case expr1: {\r\n                        const replaced = getVariableFromVarTomlObject(decoded.right.var, expr.path);\r\n                        if (replaced.isError) {\r\n                            return expr.raw;\r\n                        }\r\n                        // TODO: replaced.valueがstring以外のときの処理の仕様が今は曖昧\r\n                        switch (typeof replaced.value) {\r\n                            case 'string':\r\n                            case 'number':\r\n                            case 'boolean':\r\n                                return replaced.value.toString();\r\n                            default:\r\n                                return '';\r\n                        }\r\n                    }\r\n                    default: {\r\n                        return expr.text;\r\n                    }\r\n                }\r\n            })\r\n            .reduce((seed, elem) => seed + elem, '');\r\n    });\r\n\r\n    return Result.ok(lines);\r\n};\r\n\r\nexport const isValidChatPalette = (toml: string): Result<undefined> => {\r\n    // CONSIDER: TOMLのDateTimeに未対応\r\n    const object = parseTomlCore(toml);\r\n    if (object.isError) {\r\n        return object;\r\n    }\r\n    const decoded = exactChatPalette.decode(object.value);\r\n    if (decoded._tag === 'Left') {\r\n        return Result.error(errorToMessage(decoded.left));\r\n    }\r\n    return Result.ok(undefined);\r\n};\r\n"]}
{
"version": "0.14.0",
"version": "0.14.1",
"license": "MIT",

@@ -4,0 +4,0 @@ "main": "dist/cjs/index.js",

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc