graphql 0.0.1-test.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/NotSupportedTSVersion.d.ts +1 -0
- package/README.md +158 -0
- package/error/GraphQLError.d.ts +142 -0
- package/error/GraphQLError.js +267 -0
- package/error/GraphQLError.mjs +253 -0
- package/error/index.d.ts +7 -0
- package/error/index.js +41 -0
- package/error/index.mjs +3 -0
- package/error/locatedError.d.ts +13 -0
- package/error/locatedError.js +40 -0
- package/error/locatedError.mjs +32 -0
- package/error/syntaxError.d.ts +11 -0
- package/error/syntaxError.js +21 -0
- package/error/syntaxError.mjs +11 -0
- package/execution/collectFields.d.ts +45 -0
- package/execution/collectFields.js +229 -0
- package/execution/collectFields.mjs +213 -0
- package/execution/execute.d.ts +185 -0
- package/execution/execute.js +1016 -0
- package/execution/execute.mjs +988 -0
- package/execution/index.d.ts +14 -0
- package/execution/index.js +67 -0
- package/execution/index.mjs +9 -0
- package/execution/mapAsyncIterator.d.ts +9 -0
- package/execution/mapAsyncIterator.js +68 -0
- package/execution/mapAsyncIterator.mjs +61 -0
- package/execution/subscribe.d.ts +68 -0
- package/execution/subscribe.js +261 -0
- package/execution/subscribe.mjs +239 -0
- package/execution/values.d.ts +81 -0
- package/execution/values.js +292 -0
- package/execution/values.mjs +255 -0
- package/graphql.d.ts +67 -0
- package/graphql.js +96 -0
- package/graphql.mjs +122 -0
- package/index.d.ts +411 -0
- package/index.js +1263 -0
- package/index.mjs +254 -0
- package/jsutils/Maybe.d.ts +2 -0
- package/jsutils/Maybe.js +5 -0
- package/jsutils/Maybe.mjs +1 -0
- package/jsutils/ObjMap.d.ts +16 -0
- package/jsutils/ObjMap.js +5 -0
- package/jsutils/ObjMap.mjs +1 -0
- package/jsutils/Path.d.ts +20 -0
- package/jsutils/Path.js +33 -0
- package/jsutils/Path.mjs +25 -0
- package/jsutils/PromiseOrValue.d.ts +1 -0
- package/jsutils/PromiseOrValue.js +5 -0
- package/jsutils/PromiseOrValue.mjs +1 -0
- package/jsutils/devAssert.d.ts +1 -0
- package/jsutils/devAssert.js +14 -0
- package/jsutils/devAssert.mjs +7 -0
- package/jsutils/didYouMean.d.ts +8 -0
- package/jsutils/didYouMean.js +38 -0
- package/jsutils/didYouMean.mjs +32 -0
- package/jsutils/groupBy.d.ts +7 -0
- package/jsutils/groupBy.js +26 -0
- package/jsutils/groupBy.mjs +19 -0
- package/jsutils/identityFunc.d.ts +4 -0
- package/jsutils/identityFunc.js +13 -0
- package/jsutils/identityFunc.mjs +6 -0
- package/jsutils/inspect.d.ts +4 -0
- package/jsutils/inspect.js +121 -0
- package/jsutils/inspect.mjs +115 -0
- package/jsutils/instanceOf.d.ts +16 -0
- package/jsutils/instanceOf.js +60 -0
- package/jsutils/instanceOf.mjs +52 -0
- package/jsutils/invariant.d.ts +4 -0
- package/jsutils/invariant.js +16 -0
- package/jsutils/invariant.mjs +9 -0
- package/jsutils/isAsyncIterable.d.ts +7 -0
- package/jsutils/isAsyncIterable.js +18 -0
- package/jsutils/isAsyncIterable.mjs +11 -0
- package/jsutils/isIterableObject.d.ts +20 -0
- package/jsutils/isIterableObject.js +32 -0
- package/jsutils/isIterableObject.mjs +25 -0
- package/jsutils/isObjectLike.d.ts +7 -0
- package/jsutils/isObjectLike.js +14 -0
- package/jsutils/isObjectLike.mjs +7 -0
- package/jsutils/isPromise.d.ts +5 -0
- package/jsutils/isPromise.js +17 -0
- package/jsutils/isPromise.mjs +10 -0
- package/jsutils/keyMap.d.ts +32 -0
- package/jsutils/keyMap.js +43 -0
- package/jsutils/keyMap.mjs +36 -0
- package/jsutils/keyValMap.d.ts +23 -0
- package/jsutils/keyValMap.js +33 -0
- package/jsutils/keyValMap.mjs +26 -0
- package/jsutils/mapValue.d.ts +9 -0
- package/jsutils/mapValue.js +20 -0
- package/jsutils/mapValue.mjs +13 -0
- package/jsutils/memoize3.d.ts +9 -0
- package/jsutils/memoize3.js +41 -0
- package/jsutils/memoize3.mjs +34 -0
- package/jsutils/naturalCompare.d.ts +8 -0
- package/jsutils/naturalCompare.js +69 -0
- package/jsutils/naturalCompare.mjs +61 -0
- package/jsutils/printPathArray.d.ts +6 -0
- package/jsutils/printPathArray.js +17 -0
- package/jsutils/printPathArray.mjs +10 -0
- package/jsutils/promiseForObject.d.ts +11 -0
- package/jsutils/promiseForObject.js +25 -0
- package/jsutils/promiseForObject.mjs +18 -0
- package/jsutils/promiseReduce.d.ts +13 -0
- package/jsutils/promiseReduce.js +27 -0
- package/jsutils/promiseReduce.mjs +20 -0
- package/jsutils/suggestionList.d.ts +8 -0
- package/jsutils/suggestionList.js +139 -0
- package/jsutils/suggestionList.mjs +130 -0
- package/jsutils/toError.d.ts +4 -0
- package/jsutils/toError.js +25 -0
- package/jsutils/toError.mjs +18 -0
- package/jsutils/toObjMap.d.ts +5 -0
- package/jsutils/toObjMap.js +24 -0
- package/jsutils/toObjMap.mjs +17 -0
- package/language/ast.d.ts +536 -0
- package/language/ast.js +224 -0
- package/language/ast.mjs +206 -0
- package/language/blockString.d.ts +28 -0
- package/language/blockString.js +195 -0
- package/language/blockString.mjs +178 -0
- package/language/characterClasses.d.ts +47 -0
- package/language/characterClasses.js +75 -0
- package/language/characterClasses.mjs +64 -0
- package/language/directiveLocation.d.ts +32 -0
- package/language/directiveLocation.js +40 -0
- package/language/directiveLocation.mjs +31 -0
- package/language/index.d.ts +97 -0
- package/language/index.js +215 -0
- package/language/index.mjs +29 -0
- package/language/kinds.d.ts +65 -0
- package/language/kinds.js +64 -0
- package/language/kinds.mjs +55 -0
- package/language/lexer.d.ts +45 -0
- package/language/lexer.js +1006 -0
- package/language/lexer.mjs +902 -0
- package/language/location.d.ts +16 -0
- package/language/location.js +38 -0
- package/language/location.mjs +30 -0
- package/language/parser.d.ts +554 -0
- package/language/parser.js +1567 -0
- package/language/parser.mjs +1524 -0
- package/language/predicates.d.ts +33 -0
- package/language/predicates.js +109 -0
- package/language/predicates.mjs +81 -0
- package/language/printLocation.d.ts +14 -0
- package/language/printLocation.js +74 -0
- package/language/printLocation.mjs +66 -0
- package/language/printString.d.ts +5 -0
- package/language/printString.js +183 -0
- package/language/printString.mjs +176 -0
- package/language/printer.d.ts +6 -0
- package/language/printer.js +351 -0
- package/language/printer.mjs +339 -0
- package/language/source.d.ts +25 -0
- package/language/source.js +65 -0
- package/language/source.mjs +50 -0
- package/language/tokenKind.d.ts +34 -0
- package/language/tokenKind.js +44 -0
- package/language/tokenKind.mjs +35 -0
- package/language/visitor.d.ts +194 -0
- package/language/visitor.js +377 -0
- package/language/visitor.mjs +361 -0
- package/package.json +40 -0
- package/subscription/index.d.ts +19 -0
- package/subscription/index.js +19 -0
- package/subscription/index.mjs +19 -0
- package/type/assertName.d.ts +10 -0
- package/type/assertName.js +59 -0
- package/type/assertName.mjs +44 -0
- package/type/definition.d.ts +917 -0
- package/type/definition.js +1329 -0
- package/type/definition.mjs +1167 -0
- package/type/directives.d.ts +86 -0
- package/type/directives.js +224 -0
- package/type/directives.mjs +190 -0
- package/type/index.d.ts +150 -0
- package/type/index.js +547 -0
- package/type/index.mjs +103 -0
- package/type/introspection.d.ts +29 -0
- package/type/introspection.js +617 -0
- package/type/introspection.mjs +550 -0
- package/type/scalars.d.ts +19 -0
- package/type/scalars.js +359 -0
- package/type/scalars.mjs +299 -0
- package/type/schema.d.ts +170 -0
- package/type/schema.js +402 -0
- package/type/schema.mjs +381 -0
- package/type/validate.d.ts +17 -0
- package/type/validate.js +672 -0
- package/type/validate.mjs +647 -0
- package/utilities/TypeInfo.d.ts +67 -0
- package/utilities/TypeInfo.js +418 -0
- package/utilities/TypeInfo.mjs +395 -0
- package/utilities/assertValidName.d.ts +13 -0
- package/utilities/assertValidName.js +51 -0
- package/utilities/assertValidName.mjs +40 -0
- package/utilities/astFromValue.d.ts +28 -0
- package/utilities/astFromValue.js +190 -0
- package/utilities/astFromValue.mjs +177 -0
- package/utilities/buildASTSchema.d.ts +35 -0
- package/utilities/buildASTSchema.js +115 -0
- package/utilities/buildASTSchema.mjs +97 -0
- package/utilities/buildClientSchema.d.ts +19 -0
- package/utilities/buildClientSchema.js +386 -0
- package/utilities/buildClientSchema.mjs +363 -0
- package/utilities/coerceInputValue.d.ts +16 -0
- package/utilities/coerceInputValue.js +191 -0
- package/utilities/coerceInputValue.mjs +172 -0
- package/utilities/concatAST.d.ts +9 -0
- package/utilities/concatAST.js +26 -0
- package/utilities/concatAST.mjs +19 -0
- package/utilities/extendSchema.d.ts +40 -0
- package/utilities/extendSchema.js +798 -0
- package/utilities/extendSchema.mjs +789 -0
- package/utilities/findBreakingChanges.d.ts +51 -0
- package/utilities/findBreakingChanges.js +547 -0
- package/utilities/findBreakingChanges.mjs +516 -0
- package/utilities/getIntrospectionQuery.d.ts +182 -0
- package/utilities/getIntrospectionQuery.js +134 -0
- package/utilities/getIntrospectionQuery.mjs +127 -0
- package/utilities/getOperationAST.d.ts +11 -0
- package/utilities/getOperationAST.js +43 -0
- package/utilities/getOperationAST.mjs +36 -0
- package/utilities/getOperationRootType.d.ts +15 -0
- package/utilities/getOperationRootType.js +59 -0
- package/utilities/getOperationRootType.mjs +52 -0
- package/utilities/index.d.ts +61 -0
- package/utilities/index.js +233 -0
- package/utilities/index.mjs +55 -0
- package/utilities/introspectionFromSchema.d.ts +18 -0
- package/utilities/introspectionFromSchema.js +42 -0
- package/utilities/introspectionFromSchema.mjs +30 -0
- package/utilities/lexicographicSortSchema.d.ts +9 -0
- package/utilities/lexicographicSortSchema.js +177 -0
- package/utilities/lexicographicSortSchema.mjs +172 -0
- package/utilities/printSchema.d.ts +5 -0
- package/utilities/printSchema.js +333 -0
- package/utilities/printSchema.mjs +309 -0
- package/utilities/separateOperations.d.ts +11 -0
- package/utilities/separateOperations.js +88 -0
- package/utilities/separateOperations.mjs +80 -0
- package/utilities/sortValueNode.d.ts +9 -0
- package/utilities/sortValueNode.js +47 -0
- package/utilities/sortValueNode.mjs +39 -0
- package/utilities/stripIgnoredCharacters.d.ts +62 -0
- package/utilities/stripIgnoredCharacters.js +121 -0
- package/utilities/stripIgnoredCharacters.mjs +104 -0
- package/utilities/typeComparators.d.ts +32 -0
- package/utilities/typeComparators.js +116 -0
- package/utilities/typeComparators.mjs +106 -0
- package/utilities/typeFromAST.d.ts +32 -0
- package/utilities/typeFromAST.js +27 -0
- package/utilities/typeFromAST.mjs +18 -0
- package/utilities/typedQueryDocumentNode.d.ts +22 -0
- package/utilities/typedQueryDocumentNode.js +5 -0
- package/utilities/typedQueryDocumentNode.mjs +1 -0
- package/utilities/valueFromAST.d.ts +29 -0
- package/utilities/valueFromAST.js +185 -0
- package/utilities/valueFromAST.mjs +172 -0
- package/utilities/valueFromASTUntyped.d.ts +23 -0
- package/utilities/valueFromASTUntyped.js +61 -0
- package/utilities/valueFromASTUntyped.mjs +53 -0
- package/validation/ValidationContext.d.ts +95 -0
- package/validation/ValidationContext.js +232 -0
- package/validation/ValidationContext.mjs +212 -0
- package/validation/index.d.ts +40 -0
- package/validation/index.js +317 -0
- package/validation/index.mjs +68 -0
- package/validation/rules/ExecutableDefinitionsRule.d.ts +13 -0
- package/validation/rules/ExecutableDefinitionsRule.js +44 -0
- package/validation/rules/ExecutableDefinitionsRule.mjs +35 -0
- package/validation/rules/FieldsOnCorrectTypeRule.d.ts +13 -0
- package/validation/rules/FieldsOnCorrectTypeRule.js +143 -0
- package/validation/rules/FieldsOnCorrectTypeRule.mjs +125 -0
- package/validation/rules/FragmentsOnCompositeTypesRule.d.ts +14 -0
- package/validation/rules/FragmentsOnCompositeTypesRule.js +65 -0
- package/validation/rules/FragmentsOnCompositeTypesRule.mjs +49 -0
- package/validation/rules/KnownArgumentNamesRule.d.ts +23 -0
- package/validation/rules/KnownArgumentNamesRule.js +116 -0
- package/validation/rules/KnownArgumentNamesRule.mjs +98 -0
- package/validation/rules/KnownDirectivesRule.d.ts +16 -0
- package/validation/rules/KnownDirectivesRule.js +163 -0
- package/validation/rules/KnownDirectivesRule.mjs +146 -0
- package/validation/rules/KnownFragmentNamesRule.d.ts +13 -0
- package/validation/rules/KnownFragmentNamesRule.js +34 -0
- package/validation/rules/KnownFragmentNamesRule.mjs +24 -0
- package/validation/rules/KnownTypeNamesRule.d.ts +16 -0
- package/validation/rules/KnownTypeNamesRule.js +87 -0
- package/validation/rules/KnownTypeNamesRule.mjs +75 -0
- package/validation/rules/LoneAnonymousOperationRule.d.ts +13 -0
- package/validation/rules/LoneAnonymousOperationRule.js +40 -0
- package/validation/rules/LoneAnonymousOperationRule.mjs +32 -0
- package/validation/rules/LoneSchemaDefinitionRule.d.ts +10 -0
- package/validation/rules/LoneSchemaDefinitionRule.js +63 -0
- package/validation/rules/LoneSchemaDefinitionRule.mjs +53 -0
- package/validation/rules/NoFragmentCyclesRule.d.ts +13 -0
- package/validation/rules/NoFragmentCyclesRule.js +83 -0
- package/validation/rules/NoFragmentCyclesRule.mjs +76 -0
- package/validation/rules/NoUndefinedVariablesRule.d.ts +13 -0
- package/validation/rules/NoUndefinedVariablesRule.js +50 -0
- package/validation/rules/NoUndefinedVariablesRule.mjs +43 -0
- package/validation/rules/NoUnusedFragmentsRule.d.ts +13 -0
- package/validation/rules/NoUnusedFragmentsRule.js +59 -0
- package/validation/rules/NoUnusedFragmentsRule.mjs +52 -0
- package/validation/rules/NoUnusedVariablesRule.d.ts +13 -0
- package/validation/rules/NoUnusedVariablesRule.js +55 -0
- package/validation/rules/NoUnusedVariablesRule.mjs +48 -0
- package/validation/rules/OverlappingFieldsCanBeMergedRule-old.js +805 -0
- package/validation/rules/OverlappingFieldsCanBeMergedRule-old.mjs +788 -0
- package/validation/rules/OverlappingFieldsCanBeMergedRule.d.ts +14 -0
- package/validation/rules/OverlappingFieldsCanBeMergedRule.js +805 -0
- package/validation/rules/OverlappingFieldsCanBeMergedRule.mjs +788 -0
- package/validation/rules/PossibleFragmentSpreadsRule.d.ts +12 -0
- package/validation/rules/PossibleFragmentSpreadsRule.js +91 -0
- package/validation/rules/PossibleFragmentSpreadsRule.mjs +69 -0
- package/validation/rules/PossibleTypeExtensionsRule.d.ts +10 -0
- package/validation/rules/PossibleTypeExtensionsRule.js +167 -0
- package/validation/rules/PossibleTypeExtensionsRule.mjs +147 -0
- package/validation/rules/ProvidedRequiredArgumentsRule.d.ts +20 -0
- package/validation/rules/ProvidedRequiredArgumentsRule.js +158 -0
- package/validation/rules/ProvidedRequiredArgumentsRule.mjs +138 -0
- package/validation/rules/ScalarLeafsRule.d.ts +9 -0
- package/validation/rules/ScalarLeafsRule.js +51 -0
- package/validation/rules/ScalarLeafsRule.mjs +42 -0
- package/validation/rules/SingleFieldSubscriptionsRule.d.ts +13 -0
- package/validation/rules/SingleFieldSubscriptionsRule.js +82 -0
- package/validation/rules/SingleFieldSubscriptionsRule.mjs +73 -0
- package/validation/rules/UniqueArgumentDefinitionNamesRule.d.ts +11 -0
- package/validation/rules/UniqueArgumentDefinitionNamesRule.js +90 -0
- package/validation/rules/UniqueArgumentDefinitionNamesRule.mjs +79 -0
- package/validation/rules/UniqueArgumentNamesRule.d.ts +13 -0
- package/validation/rules/UniqueArgumentNamesRule.js +53 -0
- package/validation/rules/UniqueArgumentNamesRule.mjs +42 -0
- package/validation/rules/UniqueDirectiveNamesRule.d.ts +10 -0
- package/validation/rules/UniqueDirectiveNamesRule.js +50 -0
- package/validation/rules/UniqueDirectiveNamesRule.mjs +43 -0
- package/validation/rules/UniqueDirectivesPerLocationRule.d.ts +16 -0
- package/validation/rules/UniqueDirectivesPerLocationRule.js +93 -0
- package/validation/rules/UniqueDirectivesPerLocationRule.mjs +83 -0
- package/validation/rules/UniqueEnumValueNamesRule.d.ts +10 -0
- package/validation/rules/UniqueEnumValueNamesRule.js +71 -0
- package/validation/rules/UniqueEnumValueNamesRule.mjs +60 -0
- package/validation/rules/UniqueFieldDefinitionNamesRule.d.ts +10 -0
- package/validation/rules/UniqueFieldDefinitionNamesRule.js +83 -0
- package/validation/rules/UniqueFieldDefinitionNamesRule.mjs +75 -0
- package/validation/rules/UniqueFragmentNamesRule.d.ts +12 -0
- package/validation/rules/UniqueFragmentNamesRule.js +39 -0
- package/validation/rules/UniqueFragmentNamesRule.mjs +32 -0
- package/validation/rules/UniqueInputFieldNamesRule.d.ts +13 -0
- package/validation/rules/UniqueInputFieldNamesRule.js +52 -0
- package/validation/rules/UniqueInputFieldNamesRule.mjs +44 -0
- package/validation/rules/UniqueOperationNamesRule.d.ts +12 -0
- package/validation/rules/UniqueOperationNamesRule.js +41 -0
- package/validation/rules/UniqueOperationNamesRule.mjs +34 -0
- package/validation/rules/UniqueOperationTypesRule.d.ts +10 -0
- package/validation/rules/UniqueOperationTypesRule.js +67 -0
- package/validation/rules/UniqueOperationTypesRule.mjs +60 -0
- package/validation/rules/UniqueTypeNamesRule.d.ts +10 -0
- package/validation/rules/UniqueTypeNamesRule.js +53 -0
- package/validation/rules/UniqueTypeNamesRule.mjs +46 -0
- package/validation/rules/UniqueVariableNamesRule.d.ts +10 -0
- package/validation/rules/UniqueVariableNamesRule.js +47 -0
- package/validation/rules/UniqueVariableNamesRule.mjs +39 -0
- package/validation/rules/ValuesOfCorrectTypeRule.d.ts +13 -0
- package/validation/rules/ValuesOfCorrectTypeRule.js +183 -0
- package/validation/rules/ValuesOfCorrectTypeRule.mjs +164 -0
- package/validation/rules/VariablesAreInputTypesRule.d.ts +13 -0
- package/validation/rules/VariablesAreInputTypesRule.js +44 -0
- package/validation/rules/VariablesAreInputTypesRule.mjs +31 -0
- package/validation/rules/VariablesInAllowedPositionRule.d.ts +12 -0
- package/validation/rules/VariablesInAllowedPositionRule.js +114 -0
- package/validation/rules/VariablesInAllowedPositionRule.mjs +95 -0
- package/validation/rules/custom/NoDeprecatedCustomRule.d.ts +15 -0
- package/validation/rules/custom/NoDeprecatedCustomRule.js +121 -0
- package/validation/rules/custom/NoDeprecatedCustomRule.mjs +107 -0
- package/validation/rules/custom/NoSchemaIntrospectionCustomRule.d.ts +15 -0
- package/validation/rules/custom/NoSchemaIntrospectionCustomRule.js +39 -0
- package/validation/rules/custom/NoSchemaIntrospectionCustomRule.mjs +30 -0
- package/validation/specifiedRules.d.ts +12 -0
- package/validation/specifiedRules.js +160 -0
- package/validation/specifiedRules.mjs +123 -0
- package/validation/validate.d.ts +61 -0
- package/validation/validate.js +151 -0
- package/validation/validate.mjs +133 -0
- package/version.d.ts +13 -0
- package/version.js +25 -0
- package/version.mjs +17 -0
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', {
|
|
4
|
+
value: true,
|
|
5
|
+
});
|
|
6
|
+
exports.suggestionList = suggestionList;
|
|
7
|
+
|
|
8
|
+
var _naturalCompare = require('./naturalCompare.js');
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Given an invalid input string and a list of valid options, returns a filtered
|
|
12
|
+
* list of valid options sorted based on their similarity with the input.
|
|
13
|
+
*/
|
|
14
|
+
function suggestionList(input, options) {
|
|
15
|
+
const optionsByDistance = Object.create(null);
|
|
16
|
+
const lexicalDistance = new LexicalDistance(input);
|
|
17
|
+
const threshold = Math.floor(input.length * 0.4) + 1;
|
|
18
|
+
|
|
19
|
+
for (const option of options) {
|
|
20
|
+
const distance = lexicalDistance.measure(option, threshold);
|
|
21
|
+
|
|
22
|
+
if (distance !== undefined) {
|
|
23
|
+
optionsByDistance[option] = distance;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
return Object.keys(optionsByDistance).sort((a, b) => {
|
|
28
|
+
const distanceDiff = optionsByDistance[a] - optionsByDistance[b];
|
|
29
|
+
return distanceDiff !== 0
|
|
30
|
+
? distanceDiff
|
|
31
|
+
: (0, _naturalCompare.naturalCompare)(a, b);
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Computes the lexical distance between strings A and B.
|
|
36
|
+
*
|
|
37
|
+
* The "distance" between two strings is given by counting the minimum number
|
|
38
|
+
* of edits needed to transform string A into string B. An edit can be an
|
|
39
|
+
* insertion, deletion, or substitution of a single character, or a swap of two
|
|
40
|
+
* adjacent characters.
|
|
41
|
+
*
|
|
42
|
+
* Includes a custom alteration from Damerau-Levenshtein to treat case changes
|
|
43
|
+
* as a single edit which helps identify mis-cased values with an edit distance
|
|
44
|
+
* of 1.
|
|
45
|
+
*
|
|
46
|
+
* This distance can be useful for detecting typos in input or sorting
|
|
47
|
+
*/
|
|
48
|
+
|
|
49
|
+
class LexicalDistance {
|
|
50
|
+
constructor(input) {
|
|
51
|
+
this._input = input;
|
|
52
|
+
this._inputLowerCase = input.toLowerCase();
|
|
53
|
+
this._inputArray = stringToArray(this._inputLowerCase);
|
|
54
|
+
this._rows = [
|
|
55
|
+
new Array(input.length + 1).fill(0),
|
|
56
|
+
new Array(input.length + 1).fill(0),
|
|
57
|
+
new Array(input.length + 1).fill(0),
|
|
58
|
+
];
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
measure(option, threshold) {
|
|
62
|
+
if (this._input === option) {
|
|
63
|
+
return 0;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
const optionLowerCase = option.toLowerCase(); // Any case change counts as a single edit
|
|
67
|
+
|
|
68
|
+
if (this._inputLowerCase === optionLowerCase) {
|
|
69
|
+
return 1;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
let a = stringToArray(optionLowerCase);
|
|
73
|
+
let b = this._inputArray;
|
|
74
|
+
|
|
75
|
+
if (a.length < b.length) {
|
|
76
|
+
const tmp = a;
|
|
77
|
+
a = b;
|
|
78
|
+
b = tmp;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const aLength = a.length;
|
|
82
|
+
const bLength = b.length;
|
|
83
|
+
|
|
84
|
+
if (aLength - bLength > threshold) {
|
|
85
|
+
return undefined;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
const rows = this._rows;
|
|
89
|
+
|
|
90
|
+
for (let j = 0; j <= bLength; j++) {
|
|
91
|
+
rows[0][j] = j;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
for (let i = 1; i <= aLength; i++) {
|
|
95
|
+
const upRow = rows[(i - 1) % 3];
|
|
96
|
+
const currentRow = rows[i % 3];
|
|
97
|
+
let smallestCell = (currentRow[0] = i);
|
|
98
|
+
|
|
99
|
+
for (let j = 1; j <= bLength; j++) {
|
|
100
|
+
const cost = a[i - 1] === b[j - 1] ? 0 : 1;
|
|
101
|
+
let currentCell = Math.min(
|
|
102
|
+
upRow[j] + 1, // delete
|
|
103
|
+
currentRow[j - 1] + 1, // insert
|
|
104
|
+
upRow[j - 1] + cost, // substitute
|
|
105
|
+
);
|
|
106
|
+
|
|
107
|
+
if (i > 1 && j > 1 && a[i - 1] === b[j - 2] && a[i - 2] === b[j - 1]) {
|
|
108
|
+
// transposition
|
|
109
|
+
const doubleDiagonalCell = rows[(i - 2) % 3][j - 2];
|
|
110
|
+
currentCell = Math.min(currentCell, doubleDiagonalCell + 1);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
if (currentCell < smallestCell) {
|
|
114
|
+
smallestCell = currentCell;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
currentRow[j] = currentCell;
|
|
118
|
+
} // Early exit, since distance can't go smaller than smallest element of the previous row.
|
|
119
|
+
|
|
120
|
+
if (smallestCell > threshold) {
|
|
121
|
+
return undefined;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
const distance = rows[aLength % 3][bLength];
|
|
126
|
+
return distance <= threshold ? distance : undefined;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
function stringToArray(str) {
|
|
131
|
+
const strLength = str.length;
|
|
132
|
+
const array = new Array(strLength);
|
|
133
|
+
|
|
134
|
+
for (let i = 0; i < strLength; ++i) {
|
|
135
|
+
array[i] = str.charCodeAt(i);
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
return array;
|
|
139
|
+
}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { naturalCompare } from './naturalCompare.mjs';
|
|
2
|
+
/**
|
|
3
|
+
* Given an invalid input string and a list of valid options, returns a filtered
|
|
4
|
+
* list of valid options sorted based on their similarity with the input.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
export function suggestionList(input, options) {
|
|
8
|
+
const optionsByDistance = Object.create(null);
|
|
9
|
+
const lexicalDistance = new LexicalDistance(input);
|
|
10
|
+
const threshold = Math.floor(input.length * 0.4) + 1;
|
|
11
|
+
|
|
12
|
+
for (const option of options) {
|
|
13
|
+
const distance = lexicalDistance.measure(option, threshold);
|
|
14
|
+
|
|
15
|
+
if (distance !== undefined) {
|
|
16
|
+
optionsByDistance[option] = distance;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
return Object.keys(optionsByDistance).sort((a, b) => {
|
|
21
|
+
const distanceDiff = optionsByDistance[a] - optionsByDistance[b];
|
|
22
|
+
return distanceDiff !== 0 ? distanceDiff : naturalCompare(a, b);
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Computes the lexical distance between strings A and B.
|
|
27
|
+
*
|
|
28
|
+
* The "distance" between two strings is given by counting the minimum number
|
|
29
|
+
* of edits needed to transform string A into string B. An edit can be an
|
|
30
|
+
* insertion, deletion, or substitution of a single character, or a swap of two
|
|
31
|
+
* adjacent characters.
|
|
32
|
+
*
|
|
33
|
+
* Includes a custom alteration from Damerau-Levenshtein to treat case changes
|
|
34
|
+
* as a single edit which helps identify mis-cased values with an edit distance
|
|
35
|
+
* of 1.
|
|
36
|
+
*
|
|
37
|
+
* This distance can be useful for detecting typos in input or sorting
|
|
38
|
+
*/
|
|
39
|
+
|
|
40
|
+
class LexicalDistance {
|
|
41
|
+
constructor(input) {
|
|
42
|
+
this._input = input;
|
|
43
|
+
this._inputLowerCase = input.toLowerCase();
|
|
44
|
+
this._inputArray = stringToArray(this._inputLowerCase);
|
|
45
|
+
this._rows = [
|
|
46
|
+
new Array(input.length + 1).fill(0),
|
|
47
|
+
new Array(input.length + 1).fill(0),
|
|
48
|
+
new Array(input.length + 1).fill(0),
|
|
49
|
+
];
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
measure(option, threshold) {
|
|
53
|
+
if (this._input === option) {
|
|
54
|
+
return 0;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
const optionLowerCase = option.toLowerCase(); // Any case change counts as a single edit
|
|
58
|
+
|
|
59
|
+
if (this._inputLowerCase === optionLowerCase) {
|
|
60
|
+
return 1;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
let a = stringToArray(optionLowerCase);
|
|
64
|
+
let b = this._inputArray;
|
|
65
|
+
|
|
66
|
+
if (a.length < b.length) {
|
|
67
|
+
const tmp = a;
|
|
68
|
+
a = b;
|
|
69
|
+
b = tmp;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const aLength = a.length;
|
|
73
|
+
const bLength = b.length;
|
|
74
|
+
|
|
75
|
+
if (aLength - bLength > threshold) {
|
|
76
|
+
return undefined;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
const rows = this._rows;
|
|
80
|
+
|
|
81
|
+
for (let j = 0; j <= bLength; j++) {
|
|
82
|
+
rows[0][j] = j;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
for (let i = 1; i <= aLength; i++) {
|
|
86
|
+
const upRow = rows[(i - 1) % 3];
|
|
87
|
+
const currentRow = rows[i % 3];
|
|
88
|
+
let smallestCell = (currentRow[0] = i);
|
|
89
|
+
|
|
90
|
+
for (let j = 1; j <= bLength; j++) {
|
|
91
|
+
const cost = a[i - 1] === b[j - 1] ? 0 : 1;
|
|
92
|
+
let currentCell = Math.min(
|
|
93
|
+
upRow[j] + 1, // delete
|
|
94
|
+
currentRow[j - 1] + 1, // insert
|
|
95
|
+
upRow[j - 1] + cost, // substitute
|
|
96
|
+
);
|
|
97
|
+
|
|
98
|
+
if (i > 1 && j > 1 && a[i - 1] === b[j - 2] && a[i - 2] === b[j - 1]) {
|
|
99
|
+
// transposition
|
|
100
|
+
const doubleDiagonalCell = rows[(i - 2) % 3][j - 2];
|
|
101
|
+
currentCell = Math.min(currentCell, doubleDiagonalCell + 1);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
if (currentCell < smallestCell) {
|
|
105
|
+
smallestCell = currentCell;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
currentRow[j] = currentCell;
|
|
109
|
+
} // Early exit, since distance can't go smaller than smallest element of the previous row.
|
|
110
|
+
|
|
111
|
+
if (smallestCell > threshold) {
|
|
112
|
+
return undefined;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
const distance = rows[aLength % 3][bLength];
|
|
117
|
+
return distance <= threshold ? distance : undefined;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
function stringToArray(str) {
|
|
122
|
+
const strLength = str.length;
|
|
123
|
+
const array = new Array(strLength);
|
|
124
|
+
|
|
125
|
+
for (let i = 0; i < strLength; ++i) {
|
|
126
|
+
array[i] = str.charCodeAt(i);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
return array;
|
|
130
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', {
|
|
4
|
+
value: true,
|
|
5
|
+
});
|
|
6
|
+
exports.toError = toError;
|
|
7
|
+
|
|
8
|
+
var _inspect = require('./inspect.js');
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Sometimes a non-error is thrown, wrap it as an Error instance to ensure a consistent Error interface.
|
|
12
|
+
*/
|
|
13
|
+
function toError(thrownValue) {
|
|
14
|
+
return thrownValue instanceof Error
|
|
15
|
+
? thrownValue
|
|
16
|
+
: new NonErrorThrown(thrownValue);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
class NonErrorThrown extends Error {
|
|
20
|
+
constructor(thrownValue) {
|
|
21
|
+
super('Unexpected error value: ' + (0, _inspect.inspect)(thrownValue));
|
|
22
|
+
this.name = 'NonErrorThrown';
|
|
23
|
+
this.thrownValue = thrownValue;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { inspect } from './inspect.mjs';
|
|
2
|
+
/**
|
|
3
|
+
* Sometimes a non-error is thrown, wrap it as an Error instance to ensure a consistent Error interface.
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
export function toError(thrownValue) {
|
|
7
|
+
return thrownValue instanceof Error
|
|
8
|
+
? thrownValue
|
|
9
|
+
: new NonErrorThrown(thrownValue);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
class NonErrorThrown extends Error {
|
|
13
|
+
constructor(thrownValue) {
|
|
14
|
+
super('Unexpected error value: ' + inspect(thrownValue));
|
|
15
|
+
this.name = 'NonErrorThrown';
|
|
16
|
+
this.thrownValue = thrownValue;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', {
|
|
4
|
+
value: true,
|
|
5
|
+
});
|
|
6
|
+
exports.toObjMap = toObjMap;
|
|
7
|
+
|
|
8
|
+
function toObjMap(obj) {
|
|
9
|
+
if (obj == null) {
|
|
10
|
+
return Object.create(null);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
if (Object.getPrototypeOf(obj) === null) {
|
|
14
|
+
return obj;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
const map = Object.create(null);
|
|
18
|
+
|
|
19
|
+
for (const [key, value] of Object.entries(obj)) {
|
|
20
|
+
map[key] = value;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
return map;
|
|
24
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export function toObjMap(obj) {
|
|
2
|
+
if (obj == null) {
|
|
3
|
+
return Object.create(null);
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
if (Object.getPrototypeOf(obj) === null) {
|
|
7
|
+
return obj;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
const map = Object.create(null);
|
|
11
|
+
|
|
12
|
+
for (const [key, value] of Object.entries(obj)) {
|
|
13
|
+
map[key] = value;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
return map;
|
|
17
|
+
}
|