@vcollab/yaml-language-server-tag-validation 1.22.0

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.
Files changed (865) hide show
  1. package/CHANGELOG.md +712 -0
  2. package/CONTRIBUTING.md +8 -0
  3. package/DCO +37 -0
  4. package/Dockerfile +11 -0
  5. package/LICENSE +21 -0
  6. package/README.md +475 -0
  7. package/bin/yaml-language-server +27 -0
  8. package/docs/scalaruri-custom-tags.md +269 -0
  9. package/l10n/bundle.l10n.de.json +62 -0
  10. package/l10n/bundle.l10n.fr.json +62 -0
  11. package/l10n/bundle.l10n.ja.json +62 -0
  12. package/l10n/bundle.l10n.json +61 -0
  13. package/l10n/bundle.l10n.ko.json +62 -0
  14. package/l10n/bundle.l10n.zh-cn.json +62 -0
  15. package/l10n/bundle.l10n.zh-tw.json +62 -0
  16. package/lib/esm/commands.d.ts +3 -0
  17. package/lib/esm/commands.js +9 -0
  18. package/lib/esm/commands.js.map +1 -0
  19. package/lib/esm/index.d.ts +3 -0
  20. package/lib/esm/index.js +4 -0
  21. package/lib/esm/index.js.map +1 -0
  22. package/lib/esm/languageserver/commandExecutor.d.ts +10 -0
  23. package/lib/esm/languageserver/commandExecutor.js +21 -0
  24. package/lib/esm/languageserver/commandExecutor.js.map +1 -0
  25. package/lib/esm/languageserver/handlers/languageHandlers.d.ts +61 -0
  26. package/lib/esm/languageserver/handlers/languageHandlers.js +236 -0
  27. package/lib/esm/languageserver/handlers/languageHandlers.js.map +1 -0
  28. package/lib/esm/languageserver/handlers/notificationHandlers.d.ts +29 -0
  29. package/lib/esm/languageserver/handlers/notificationHandlers.js +46 -0
  30. package/lib/esm/languageserver/handlers/notificationHandlers.js.map +1 -0
  31. package/lib/esm/languageserver/handlers/requestHandlers.d.ts +9 -0
  32. package/lib/esm/languageserver/handlers/requestHandlers.js +23 -0
  33. package/lib/esm/languageserver/handlers/requestHandlers.js.map +1 -0
  34. package/lib/esm/languageserver/handlers/schemaSelectionHandlers.d.ts +13 -0
  35. package/lib/esm/languageserver/handlers/schemaSelectionHandlers.js +72 -0
  36. package/lib/esm/languageserver/handlers/schemaSelectionHandlers.js.map +1 -0
  37. package/lib/esm/languageserver/handlers/settingsHandlers.d.ts +42 -0
  38. package/lib/esm/languageserver/handlers/settingsHandlers.js +316 -0
  39. package/lib/esm/languageserver/handlers/settingsHandlers.js.map +1 -0
  40. package/lib/esm/languageserver/handlers/validationHandlers.d.ts +15 -0
  41. package/lib/esm/languageserver/handlers/validationHandlers.js +108 -0
  42. package/lib/esm/languageserver/handlers/validationHandlers.js.map +1 -0
  43. package/lib/esm/languageserver/handlers/workspaceHandlers.d.ts +9 -0
  44. package/lib/esm/languageserver/handlers/workspaceHandlers.js +17 -0
  45. package/lib/esm/languageserver/handlers/workspaceHandlers.js.map +1 -0
  46. package/lib/esm/languageserver/telemetry.d.ts +9 -0
  47. package/lib/esm/languageserver/telemetry.js +20 -0
  48. package/lib/esm/languageserver/telemetry.js.map +1 -0
  49. package/lib/esm/languageservice/jsonASTTypes.d.ts +49 -0
  50. package/lib/esm/languageservice/jsonASTTypes.js +6 -0
  51. package/lib/esm/languageservice/jsonASTTypes.js.map +1 -0
  52. package/lib/esm/languageservice/jsonSchema.d.ts +103 -0
  53. package/lib/esm/languageservice/jsonSchema.js +12 -0
  54. package/lib/esm/languageservice/jsonSchema.js.map +1 -0
  55. package/lib/esm/languageservice/parser/ast-converter.d.ts +11 -0
  56. package/lib/esm/languageservice/parser/ast-converter.js +176 -0
  57. package/lib/esm/languageservice/parser/ast-converter.js.map +1 -0
  58. package/lib/esm/languageservice/parser/astNodeUtils.d.ts +4 -0
  59. package/lib/esm/languageservice/parser/astNodeUtils.js +48 -0
  60. package/lib/esm/languageservice/parser/astNodeUtils.js.map +1 -0
  61. package/lib/esm/languageservice/parser/custom-tag-provider.d.ts +7 -0
  62. package/lib/esm/languageservice/parser/custom-tag-provider.js +58 -0
  63. package/lib/esm/languageservice/parser/custom-tag-provider.js.map +1 -0
  64. package/lib/esm/languageservice/parser/isKubernetes.d.ts +4 -0
  65. package/lib/esm/languageservice/parser/isKubernetes.js +17 -0
  66. package/lib/esm/languageservice/parser/isKubernetes.js.map +1 -0
  67. package/lib/esm/languageservice/parser/jsonDocument.d.ts +83 -0
  68. package/lib/esm/languageservice/parser/jsonDocument.js +171 -0
  69. package/lib/esm/languageservice/parser/jsonDocument.js.map +1 -0
  70. package/lib/esm/languageservice/parser/scalar-type.d.ts +8 -0
  71. package/lib/esm/languageservice/parser/scalar-type.js +17 -0
  72. package/lib/esm/languageservice/parser/scalar-type.js.map +1 -0
  73. package/lib/esm/languageservice/parser/schemaValidation/baseValidator.d.ts +124 -0
  74. package/lib/esm/languageservice/parser/schemaValidation/baseValidator.js +1254 -0
  75. package/lib/esm/languageservice/parser/schemaValidation/baseValidator.js.map +1 -0
  76. package/lib/esm/languageservice/parser/schemaValidation/draft04Validator.d.ts +17 -0
  77. package/lib/esm/languageservice/parser/schemaValidation/draft04Validator.js +30 -0
  78. package/lib/esm/languageservice/parser/schemaValidation/draft04Validator.js.map +1 -0
  79. package/lib/esm/languageservice/parser/schemaValidation/draft07Validator.d.ts +15 -0
  80. package/lib/esm/languageservice/parser/schemaValidation/draft07Validator.js +28 -0
  81. package/lib/esm/languageservice/parser/schemaValidation/draft07Validator.js.map +1 -0
  82. package/lib/esm/languageservice/parser/schemaValidation/draft2019Validator.d.ts +28 -0
  83. package/lib/esm/languageservice/parser/schemaValidation/draft2019Validator.js +224 -0
  84. package/lib/esm/languageservice/parser/schemaValidation/draft2019Validator.js.map +1 -0
  85. package/lib/esm/languageservice/parser/schemaValidation/draft2020Validator.d.ts +17 -0
  86. package/lib/esm/languageservice/parser/schemaValidation/draft2020Validator.js +126 -0
  87. package/lib/esm/languageservice/parser/schemaValidation/draft2020Validator.js.map +1 -0
  88. package/lib/esm/languageservice/parser/schemaValidation/validatorFactory.d.ts +3 -0
  89. package/lib/esm/languageservice/parser/schemaValidation/validatorFactory.js +24 -0
  90. package/lib/esm/languageservice/parser/schemaValidation/validatorFactory.js.map +1 -0
  91. package/lib/esm/languageservice/parser/yaml-documents.d.ts +71 -0
  92. package/lib/esm/languageservice/parser/yaml-documents.js +258 -0
  93. package/lib/esm/languageservice/parser/yaml-documents.js.map +1 -0
  94. package/lib/esm/languageservice/parser/yamlParser07.d.ts +15 -0
  95. package/lib/esm/languageservice/parser/yamlParser07.js +50 -0
  96. package/lib/esm/languageservice/parser/yamlParser07.js.map +1 -0
  97. package/lib/esm/languageservice/services/crdUtil.d.ts +23 -0
  98. package/lib/esm/languageservice/services/crdUtil.js +74 -0
  99. package/lib/esm/languageservice/services/crdUtil.js.map +1 -0
  100. package/lib/esm/languageservice/services/documentSymbols.d.ts +12 -0
  101. package/lib/esm/languageservice/services/documentSymbols.js +67 -0
  102. package/lib/esm/languageservice/services/documentSymbols.js.map +1 -0
  103. package/lib/esm/languageservice/services/modelineUtil.d.ts +9 -0
  104. package/lib/esm/languageservice/services/modelineUtil.js +29 -0
  105. package/lib/esm/languageservice/services/modelineUtil.js.map +1 -0
  106. package/lib/esm/languageservice/services/schemaRequestHandler.d.ts +12 -0
  107. package/lib/esm/languageservice/services/schemaRequestHandler.js +84 -0
  108. package/lib/esm/languageservice/services/schemaRequestHandler.js.map +1 -0
  109. package/lib/esm/languageservice/services/validation/map-key-order.d.ts +7 -0
  110. package/lib/esm/languageservice/services/validation/map-key-order.js +35 -0
  111. package/lib/esm/languageservice/services/validation/map-key-order.js.map +1 -0
  112. package/lib/esm/languageservice/services/validation/types.d.ts +6 -0
  113. package/lib/esm/languageservice/services/validation/types.js +6 -0
  114. package/lib/esm/languageservice/services/validation/types.js.map +1 -0
  115. package/lib/esm/languageservice/services/validation/unused-anchors.d.ts +8 -0
  116. package/lib/esm/languageservice/services/validation/unused-anchors.js +91 -0
  117. package/lib/esm/languageservice/services/validation/unused-anchors.js.map +1 -0
  118. package/lib/esm/languageservice/services/validation/yaml-style.d.ts +12 -0
  119. package/lib/esm/languageservice/services/validation/yaml-style.js +28 -0
  120. package/lib/esm/languageservice/services/validation/yaml-style.js.map +1 -0
  121. package/lib/esm/languageservice/services/yamlCodeActions.d.ts +25 -0
  122. package/lib/esm/languageservice/services/yamlCodeActions.js +342 -0
  123. package/lib/esm/languageservice/services/yamlCodeActions.js.map +1 -0
  124. package/lib/esm/languageservice/services/yamlCodeLens.d.ts +11 -0
  125. package/lib/esm/languageservice/services/yamlCodeLens.js +46 -0
  126. package/lib/esm/languageservice/services/yamlCodeLens.js.map +1 -0
  127. package/lib/esm/languageservice/services/yamlCommands.d.ts +3 -0
  128. package/lib/esm/languageservice/services/yamlCommands.js +46 -0
  129. package/lib/esm/languageservice/services/yamlCommands.js.map +1 -0
  130. package/lib/esm/languageservice/services/yamlCompletion.d.ts +77 -0
  131. package/lib/esm/languageservice/services/yamlCompletion.js +1501 -0
  132. package/lib/esm/languageservice/services/yamlCompletion.js.map +1 -0
  133. package/lib/esm/languageservice/services/yamlDefinition.d.ts +9 -0
  134. package/lib/esm/languageservice/services/yamlDefinition.js +37 -0
  135. package/lib/esm/languageservice/services/yamlDefinition.js.map +1 -0
  136. package/lib/esm/languageservice/services/yamlFolding.d.ts +4 -0
  137. package/lib/esm/languageservice/services/yamlFolding.js +62 -0
  138. package/lib/esm/languageservice/services/yamlFolding.js.map +1 -0
  139. package/lib/esm/languageservice/services/yamlFormatter.d.ts +8 -0
  140. package/lib/esm/languageservice/services/yamlFormatter.js +46 -0
  141. package/lib/esm/languageservice/services/yamlFormatter.js.map +1 -0
  142. package/lib/esm/languageservice/services/yamlHover.d.ts +47 -0
  143. package/lib/esm/languageservice/services/yamlHover.js +366 -0
  144. package/lib/esm/languageservice/services/yamlHover.js.map +1 -0
  145. package/lib/esm/languageservice/services/yamlLinks.d.ts +8 -0
  146. package/lib/esm/languageservice/services/yamlLinks.js +27 -0
  147. package/lib/esm/languageservice/services/yamlLinks.js.map +1 -0
  148. package/lib/esm/languageservice/services/yamlOnTypeFormatting.d.ts +4 -0
  149. package/lib/esm/languageservice/services/yamlOnTypeFormatting.js +43 -0
  150. package/lib/esm/languageservice/services/yamlOnTypeFormatting.js.map +1 -0
  151. package/lib/esm/languageservice/services/yamlRename.d.ts +18 -0
  152. package/lib/esm/languageservice/services/yamlRename.js +184 -0
  153. package/lib/esm/languageservice/services/yamlRename.js.map +1 -0
  154. package/lib/esm/languageservice/services/yamlSchemaService.d.ts +99 -0
  155. package/lib/esm/languageservice/services/yamlSchemaService.js +1110 -0
  156. package/lib/esm/languageservice/services/yamlSchemaService.js.map +1 -0
  157. package/lib/esm/languageservice/services/yamlSelectionRanges.d.ts +3 -0
  158. package/lib/esm/languageservice/services/yamlSelectionRanges.js +130 -0
  159. package/lib/esm/languageservice/services/yamlSelectionRanges.js.map +1 -0
  160. package/lib/esm/languageservice/services/yamlValidation.d.ts +26 -0
  161. package/lib/esm/languageservice/services/yamlValidation.js +135 -0
  162. package/lib/esm/languageservice/services/yamlValidation.js.map +1 -0
  163. package/lib/esm/languageservice/telemetry.d.ts +16 -0
  164. package/lib/esm/languageservice/telemetry.js +6 -0
  165. package/lib/esm/languageservice/telemetry.js.map +1 -0
  166. package/lib/esm/languageservice/utils/arrUtils.d.ts +6 -0
  167. package/lib/esm/languageservice/utils/arrUtils.js +81 -0
  168. package/lib/esm/languageservice/utils/arrUtils.js.map +1 -0
  169. package/lib/esm/languageservice/utils/block-string-rewriter.d.ts +8 -0
  170. package/lib/esm/languageservice/utils/block-string-rewriter.js +215 -0
  171. package/lib/esm/languageservice/utils/block-string-rewriter.js.map +1 -0
  172. package/lib/esm/languageservice/utils/charCode.d.ts +415 -0
  173. package/lib/esm/languageservice/utils/charCode.js +6 -0
  174. package/lib/esm/languageservice/utils/charCode.js.map +1 -0
  175. package/lib/esm/languageservice/utils/diagnostic-filter.d.ts +50 -0
  176. package/lib/esm/languageservice/utils/diagnostic-filter.js +82 -0
  177. package/lib/esm/languageservice/utils/diagnostic-filter.js.map +1 -0
  178. package/lib/esm/languageservice/utils/documentPositionCalculator.d.ts +5 -0
  179. package/lib/esm/languageservice/utils/documentPositionCalculator.js +56 -0
  180. package/lib/esm/languageservice/utils/documentPositionCalculator.js.map +1 -0
  181. package/lib/esm/languageservice/utils/filePatternAssociation.d.ts +8 -0
  182. package/lib/esm/languageservice/utils/filePatternAssociation.js +23 -0
  183. package/lib/esm/languageservice/utils/filePatternAssociation.js.map +1 -0
  184. package/lib/esm/languageservice/utils/flow-style-rewriter.d.ts +6 -0
  185. package/lib/esm/languageservice/utils/flow-style-rewriter.js +53 -0
  186. package/lib/esm/languageservice/utils/flow-style-rewriter.js.map +1 -0
  187. package/lib/esm/languageservice/utils/indentationGuesser.d.ts +15 -0
  188. package/lib/esm/languageservice/utils/indentationGuesser.js +176 -0
  189. package/lib/esm/languageservice/utils/indentationGuesser.js.map +1 -0
  190. package/lib/esm/languageservice/utils/json.d.ts +11 -0
  191. package/lib/esm/languageservice/utils/json.js +79 -0
  192. package/lib/esm/languageservice/utils/json.js.map +1 -0
  193. package/lib/esm/languageservice/utils/math.d.ts +1 -0
  194. package/lib/esm/languageservice/utils/math.js +9 -0
  195. package/lib/esm/languageservice/utils/math.js.map +1 -0
  196. package/lib/esm/languageservice/utils/objects.d.ts +16 -0
  197. package/lib/esm/languageservice/utils/objects.js +92 -0
  198. package/lib/esm/languageservice/utils/objects.js.map +1 -0
  199. package/lib/esm/languageservice/utils/parseUtils.d.ts +17 -0
  200. package/lib/esm/languageservice/utils/parseUtils.js +2 -0
  201. package/lib/esm/languageservice/utils/parseUtils.js.map +1 -0
  202. package/lib/esm/languageservice/utils/paths.d.ts +5 -0
  203. package/lib/esm/languageservice/utils/paths.js +42 -0
  204. package/lib/esm/languageservice/utils/paths.js.map +1 -0
  205. package/lib/esm/languageservice/utils/schemaUrls.d.ts +14 -0
  206. package/lib/esm/languageservice/utils/schemaUrls.js +59 -0
  207. package/lib/esm/languageservice/utils/schemaUrls.js.map +1 -0
  208. package/lib/esm/languageservice/utils/schemaUtils.d.ts +19 -0
  209. package/lib/esm/languageservice/utils/schemaUtils.js +62 -0
  210. package/lib/esm/languageservice/utils/schemaUtils.js.map +1 -0
  211. package/lib/esm/languageservice/utils/strings.d.ts +10 -0
  212. package/lib/esm/languageservice/utils/strings.js +79 -0
  213. package/lib/esm/languageservice/utils/strings.js.map +1 -0
  214. package/lib/esm/languageservice/utils/textBuffer.d.ts +12 -0
  215. package/lib/esm/languageservice/utils/textBuffer.js +45 -0
  216. package/lib/esm/languageservice/utils/textBuffer.js.map +1 -0
  217. package/lib/esm/languageservice/utils/yamlAstUtils.d.ts +13 -0
  218. package/lib/esm/languageservice/utils/yamlAstUtils.js +108 -0
  219. package/lib/esm/languageservice/utils/yamlAstUtils.js.map +1 -0
  220. package/lib/esm/languageservice/utils/yamlScalar.d.ts +1 -0
  221. package/lib/esm/languageservice/utils/yamlScalar.js +69 -0
  222. package/lib/esm/languageservice/utils/yamlScalar.js.map +1 -0
  223. package/lib/esm/languageservice/yamlLanguageService.d.ts +135 -0
  224. package/lib/esm/languageservice/yamlLanguageService.js +101 -0
  225. package/lib/esm/languageservice/yamlLanguageService.js.map +1 -0
  226. package/lib/esm/languageservice/yamlTypes.d.ts +18 -0
  227. package/lib/esm/languageservice/yamlTypes.js +6 -0
  228. package/lib/esm/languageservice/yamlTypes.js.map +1 -0
  229. package/lib/esm/nodeTranslationSetup.d.ts +9 -0
  230. package/lib/esm/nodeTranslationSetup.js +34 -0
  231. package/lib/esm/nodeTranslationSetup.js.map +1 -0
  232. package/lib/esm/requestTypes.d.ts +63 -0
  233. package/lib/esm/requestTypes.js +46 -0
  234. package/lib/esm/requestTypes.js.map +1 -0
  235. package/lib/esm/server.d.ts +1 -0
  236. package/lib/esm/server.js +55 -0
  237. package/lib/esm/server.js.map +1 -0
  238. package/lib/esm/webworker/yamlServerMain.d.ts +1 -0
  239. package/lib/esm/webworker/yamlServerMain.js +40 -0
  240. package/lib/esm/webworker/yamlServerMain.js.map +1 -0
  241. package/lib/esm/yamlServerInit.d.ts +23 -0
  242. package/lib/esm/yamlServerInit.js +123 -0
  243. package/lib/esm/yamlServerInit.js.map +1 -0
  244. package/lib/esm/yamlSettings.d.ts +112 -0
  245. package/lib/esm/yamlSettings.js +69 -0
  246. package/lib/esm/yamlSettings.js.map +1 -0
  247. package/lib/umd/commands.d.ts +3 -0
  248. package/lib/umd/commands.js +22 -0
  249. package/lib/umd/commands.js.map +1 -0
  250. package/lib/umd/index.d.ts +3 -0
  251. package/lib/umd/index.js +32 -0
  252. package/lib/umd/index.js.map +1 -0
  253. package/lib/umd/languageserver/commandExecutor.d.ts +10 -0
  254. package/lib/umd/languageserver/commandExecutor.js +35 -0
  255. package/lib/umd/languageserver/commandExecutor.js.map +1 -0
  256. package/lib/umd/languageserver/handlers/languageHandlers.d.ts +61 -0
  257. package/lib/umd/languageserver/handlers/languageHandlers.js +250 -0
  258. package/lib/umd/languageserver/handlers/languageHandlers.js.map +1 -0
  259. package/lib/umd/languageserver/handlers/notificationHandlers.d.ts +29 -0
  260. package/lib/umd/languageserver/handlers/notificationHandlers.js +60 -0
  261. package/lib/umd/languageserver/handlers/notificationHandlers.js.map +1 -0
  262. package/lib/umd/languageserver/handlers/requestHandlers.d.ts +9 -0
  263. package/lib/umd/languageserver/handlers/requestHandlers.js +37 -0
  264. package/lib/umd/languageserver/handlers/requestHandlers.js.map +1 -0
  265. package/lib/umd/languageserver/handlers/schemaSelectionHandlers.d.ts +13 -0
  266. package/lib/umd/languageserver/handlers/schemaSelectionHandlers.js +86 -0
  267. package/lib/umd/languageserver/handlers/schemaSelectionHandlers.js.map +1 -0
  268. package/lib/umd/languageserver/handlers/settingsHandlers.d.ts +42 -0
  269. package/lib/umd/languageserver/handlers/settingsHandlers.js +330 -0
  270. package/lib/umd/languageserver/handlers/settingsHandlers.js.map +1 -0
  271. package/lib/umd/languageserver/handlers/validationHandlers.d.ts +15 -0
  272. package/lib/umd/languageserver/handlers/validationHandlers.js +122 -0
  273. package/lib/umd/languageserver/handlers/validationHandlers.js.map +1 -0
  274. package/lib/umd/languageserver/handlers/workspaceHandlers.d.ts +9 -0
  275. package/lib/umd/languageserver/handlers/workspaceHandlers.js +31 -0
  276. package/lib/umd/languageserver/handlers/workspaceHandlers.js.map +1 -0
  277. package/lib/umd/languageserver/telemetry.d.ts +9 -0
  278. package/lib/umd/languageserver/telemetry.js +34 -0
  279. package/lib/umd/languageserver/telemetry.js.map +1 -0
  280. package/lib/umd/languageservice/jsonASTTypes.d.ts +49 -0
  281. package/lib/umd/languageservice/jsonASTTypes.js +17 -0
  282. package/lib/umd/languageservice/jsonASTTypes.js.map +1 -0
  283. package/lib/umd/languageservice/jsonSchema.d.ts +103 -0
  284. package/lib/umd/languageservice/jsonSchema.js +25 -0
  285. package/lib/umd/languageservice/jsonSchema.js.map +1 -0
  286. package/lib/umd/languageservice/parser/ast-converter.d.ts +11 -0
  287. package/lib/umd/languageservice/parser/ast-converter.js +191 -0
  288. package/lib/umd/languageservice/parser/ast-converter.js.map +1 -0
  289. package/lib/umd/languageservice/parser/astNodeUtils.d.ts +4 -0
  290. package/lib/umd/languageservice/parser/astNodeUtils.js +64 -0
  291. package/lib/umd/languageservice/parser/astNodeUtils.js.map +1 -0
  292. package/lib/umd/languageservice/parser/custom-tag-provider.d.ts +7 -0
  293. package/lib/umd/languageservice/parser/custom-tag-provider.js +72 -0
  294. package/lib/umd/languageservice/parser/custom-tag-provider.js.map +1 -0
  295. package/lib/umd/languageservice/parser/isKubernetes.d.ts +4 -0
  296. package/lib/umd/languageservice/parser/isKubernetes.js +32 -0
  297. package/lib/umd/languageservice/parser/isKubernetes.js.map +1 -0
  298. package/lib/umd/languageservice/parser/jsonDocument.d.ts +83 -0
  299. package/lib/umd/languageservice/parser/jsonDocument.js +193 -0
  300. package/lib/umd/languageservice/parser/jsonDocument.js.map +1 -0
  301. package/lib/umd/languageservice/parser/scalar-type.d.ts +8 -0
  302. package/lib/umd/languageservice/parser/scalar-type.js +31 -0
  303. package/lib/umd/languageservice/parser/scalar-type.js.map +1 -0
  304. package/lib/umd/languageservice/parser/schemaValidation/baseValidator.d.ts +124 -0
  305. package/lib/umd/languageservice/parser/schemaValidation/baseValidator.js +1270 -0
  306. package/lib/umd/languageservice/parser/schemaValidation/baseValidator.js.map +1 -0
  307. package/lib/umd/languageservice/parser/schemaValidation/draft04Validator.d.ts +17 -0
  308. package/lib/umd/languageservice/parser/schemaValidation/draft04Validator.js +44 -0
  309. package/lib/umd/languageservice/parser/schemaValidation/draft04Validator.js.map +1 -0
  310. package/lib/umd/languageservice/parser/schemaValidation/draft07Validator.d.ts +15 -0
  311. package/lib/umd/languageservice/parser/schemaValidation/draft07Validator.js +42 -0
  312. package/lib/umd/languageservice/parser/schemaValidation/draft07Validator.js.map +1 -0
  313. package/lib/umd/languageservice/parser/schemaValidation/draft2019Validator.d.ts +28 -0
  314. package/lib/umd/languageservice/parser/schemaValidation/draft2019Validator.js +238 -0
  315. package/lib/umd/languageservice/parser/schemaValidation/draft2019Validator.js.map +1 -0
  316. package/lib/umd/languageservice/parser/schemaValidation/draft2020Validator.d.ts +17 -0
  317. package/lib/umd/languageservice/parser/schemaValidation/draft2020Validator.js +140 -0
  318. package/lib/umd/languageservice/parser/schemaValidation/draft2020Validator.js.map +1 -0
  319. package/lib/umd/languageservice/parser/schemaValidation/validatorFactory.d.ts +3 -0
  320. package/lib/umd/languageservice/parser/schemaValidation/validatorFactory.js +38 -0
  321. package/lib/umd/languageservice/parser/schemaValidation/validatorFactory.js.map +1 -0
  322. package/lib/umd/languageservice/parser/yaml-documents.d.ts +71 -0
  323. package/lib/umd/languageservice/parser/yaml-documents.js +274 -0
  324. package/lib/umd/languageservice/parser/yaml-documents.js.map +1 -0
  325. package/lib/umd/languageservice/parser/yamlParser07.d.ts +15 -0
  326. package/lib/umd/languageservice/parser/yamlParser07.js +65 -0
  327. package/lib/umd/languageservice/parser/yamlParser07.js.map +1 -0
  328. package/lib/umd/languageservice/services/crdUtil.d.ts +23 -0
  329. package/lib/umd/languageservice/services/crdUtil.js +89 -0
  330. package/lib/umd/languageservice/services/crdUtil.js.map +1 -0
  331. package/lib/umd/languageservice/services/documentSymbols.d.ts +12 -0
  332. package/lib/umd/languageservice/services/documentSymbols.js +81 -0
  333. package/lib/umd/languageservice/services/documentSymbols.js.map +1 -0
  334. package/lib/umd/languageservice/services/modelineUtil.d.ts +9 -0
  335. package/lib/umd/languageservice/services/modelineUtil.js +44 -0
  336. package/lib/umd/languageservice/services/modelineUtil.js.map +1 -0
  337. package/lib/umd/languageservice/services/schemaRequestHandler.d.ts +12 -0
  338. package/lib/umd/languageservice/services/schemaRequestHandler.js +98 -0
  339. package/lib/umd/languageservice/services/schemaRequestHandler.js.map +1 -0
  340. package/lib/umd/languageservice/services/validation/map-key-order.d.ts +7 -0
  341. package/lib/umd/languageservice/services/validation/map-key-order.js +49 -0
  342. package/lib/umd/languageservice/services/validation/map-key-order.js.map +1 -0
  343. package/lib/umd/languageservice/services/validation/types.d.ts +6 -0
  344. package/lib/umd/languageservice/services/validation/types.js +17 -0
  345. package/lib/umd/languageservice/services/validation/types.js.map +1 -0
  346. package/lib/umd/languageservice/services/validation/unused-anchors.d.ts +8 -0
  347. package/lib/umd/languageservice/services/validation/unused-anchors.js +105 -0
  348. package/lib/umd/languageservice/services/validation/unused-anchors.js.map +1 -0
  349. package/lib/umd/languageservice/services/validation/yaml-style.d.ts +12 -0
  350. package/lib/umd/languageservice/services/validation/yaml-style.js +42 -0
  351. package/lib/umd/languageservice/services/validation/yaml-style.js.map +1 -0
  352. package/lib/umd/languageservice/services/yamlCodeActions.d.ts +25 -0
  353. package/lib/umd/languageservice/services/yamlCodeActions.js +356 -0
  354. package/lib/umd/languageservice/services/yamlCodeActions.js.map +1 -0
  355. package/lib/umd/languageservice/services/yamlCodeLens.d.ts +11 -0
  356. package/lib/umd/languageservice/services/yamlCodeLens.js +60 -0
  357. package/lib/umd/languageservice/services/yamlCodeLens.js.map +1 -0
  358. package/lib/umd/languageservice/services/yamlCommands.d.ts +3 -0
  359. package/lib/umd/languageservice/services/yamlCommands.js +60 -0
  360. package/lib/umd/languageservice/services/yamlCommands.js.map +1 -0
  361. package/lib/umd/languageservice/services/yamlCompletion.d.ts +77 -0
  362. package/lib/umd/languageservice/services/yamlCompletion.js +1515 -0
  363. package/lib/umd/languageservice/services/yamlCompletion.js.map +1 -0
  364. package/lib/umd/languageservice/services/yamlDefinition.d.ts +9 -0
  365. package/lib/umd/languageservice/services/yamlDefinition.js +51 -0
  366. package/lib/umd/languageservice/services/yamlDefinition.js.map +1 -0
  367. package/lib/umd/languageservice/services/yamlFolding.d.ts +4 -0
  368. package/lib/umd/languageservice/services/yamlFolding.js +76 -0
  369. package/lib/umd/languageservice/services/yamlFolding.js.map +1 -0
  370. package/lib/umd/languageservice/services/yamlFormatter.d.ts +8 -0
  371. package/lib/umd/languageservice/services/yamlFormatter.js +60 -0
  372. package/lib/umd/languageservice/services/yamlFormatter.js.map +1 -0
  373. package/lib/umd/languageservice/services/yamlHover.d.ts +47 -0
  374. package/lib/umd/languageservice/services/yamlHover.js +380 -0
  375. package/lib/umd/languageservice/services/yamlHover.js.map +1 -0
  376. package/lib/umd/languageservice/services/yamlLinks.d.ts +8 -0
  377. package/lib/umd/languageservice/services/yamlLinks.js +41 -0
  378. package/lib/umd/languageservice/services/yamlLinks.js.map +1 -0
  379. package/lib/umd/languageservice/services/yamlOnTypeFormatting.d.ts +4 -0
  380. package/lib/umd/languageservice/services/yamlOnTypeFormatting.js +57 -0
  381. package/lib/umd/languageservice/services/yamlOnTypeFormatting.js.map +1 -0
  382. package/lib/umd/languageservice/services/yamlRename.d.ts +18 -0
  383. package/lib/umd/languageservice/services/yamlRename.js +198 -0
  384. package/lib/umd/languageservice/services/yamlRename.js.map +1 -0
  385. package/lib/umd/languageservice/services/yamlSchemaService.d.ts +99 -0
  386. package/lib/umd/languageservice/services/yamlSchemaService.js +1124 -0
  387. package/lib/umd/languageservice/services/yamlSchemaService.js.map +1 -0
  388. package/lib/umd/languageservice/services/yamlSelectionRanges.d.ts +3 -0
  389. package/lib/umd/languageservice/services/yamlSelectionRanges.js +144 -0
  390. package/lib/umd/languageservice/services/yamlSelectionRanges.js.map +1 -0
  391. package/lib/umd/languageservice/services/yamlValidation.d.ts +26 -0
  392. package/lib/umd/languageservice/services/yamlValidation.js +150 -0
  393. package/lib/umd/languageservice/services/yamlValidation.js.map +1 -0
  394. package/lib/umd/languageservice/telemetry.d.ts +16 -0
  395. package/lib/umd/languageservice/telemetry.js +17 -0
  396. package/lib/umd/languageservice/telemetry.js.map +1 -0
  397. package/lib/umd/languageservice/utils/arrUtils.d.ts +6 -0
  398. package/lib/umd/languageservice/utils/arrUtils.js +99 -0
  399. package/lib/umd/languageservice/utils/arrUtils.js.map +1 -0
  400. package/lib/umd/languageservice/utils/block-string-rewriter.d.ts +8 -0
  401. package/lib/umd/languageservice/utils/block-string-rewriter.js +229 -0
  402. package/lib/umd/languageservice/utils/block-string-rewriter.js.map +1 -0
  403. package/lib/umd/languageservice/utils/charCode.d.ts +415 -0
  404. package/lib/umd/languageservice/utils/charCode.js +17 -0
  405. package/lib/umd/languageservice/utils/charCode.js.map +1 -0
  406. package/lib/umd/languageservice/utils/diagnostic-filter.d.ts +50 -0
  407. package/lib/umd/languageservice/utils/diagnostic-filter.js +98 -0
  408. package/lib/umd/languageservice/utils/diagnostic-filter.js.map +1 -0
  409. package/lib/umd/languageservice/utils/documentPositionCalculator.d.ts +5 -0
  410. package/lib/umd/languageservice/utils/documentPositionCalculator.js +73 -0
  411. package/lib/umd/languageservice/utils/documentPositionCalculator.js.map +1 -0
  412. package/lib/umd/languageservice/utils/filePatternAssociation.d.ts +8 -0
  413. package/lib/umd/languageservice/utils/filePatternAssociation.js +37 -0
  414. package/lib/umd/languageservice/utils/filePatternAssociation.js.map +1 -0
  415. package/lib/umd/languageservice/utils/flow-style-rewriter.d.ts +6 -0
  416. package/lib/umd/languageservice/utils/flow-style-rewriter.js +67 -0
  417. package/lib/umd/languageservice/utils/flow-style-rewriter.js.map +1 -0
  418. package/lib/umd/languageservice/utils/indentationGuesser.d.ts +15 -0
  419. package/lib/umd/languageservice/utils/indentationGuesser.js +190 -0
  420. package/lib/umd/languageservice/utils/indentationGuesser.js.map +1 -0
  421. package/lib/umd/languageservice/utils/json.d.ts +11 -0
  422. package/lib/umd/languageservice/utils/json.js +93 -0
  423. package/lib/umd/languageservice/utils/json.js.map +1 -0
  424. package/lib/umd/languageservice/utils/math.d.ts +1 -0
  425. package/lib/umd/languageservice/utils/math.js +23 -0
  426. package/lib/umd/languageservice/utils/math.js.map +1 -0
  427. package/lib/umd/languageservice/utils/objects.d.ts +16 -0
  428. package/lib/umd/languageservice/utils/objects.js +112 -0
  429. package/lib/umd/languageservice/utils/objects.js.map +1 -0
  430. package/lib/umd/languageservice/utils/parseUtils.d.ts +17 -0
  431. package/lib/umd/languageservice/utils/parseUtils.js +15 -0
  432. package/lib/umd/languageservice/utils/parseUtils.js.map +1 -0
  433. package/lib/umd/languageservice/utils/paths.d.ts +5 -0
  434. package/lib/umd/languageservice/utils/paths.js +58 -0
  435. package/lib/umd/languageservice/utils/paths.js.map +1 -0
  436. package/lib/umd/languageservice/utils/schemaUrls.d.ts +14 -0
  437. package/lib/umd/languageservice/utils/schemaUrls.js +74 -0
  438. package/lib/umd/languageservice/utils/schemaUrls.js.map +1 -0
  439. package/lib/umd/languageservice/utils/schemaUtils.d.ts +19 -0
  440. package/lib/umd/languageservice/utils/schemaUtils.js +80 -0
  441. package/lib/umd/languageservice/utils/schemaUtils.js.map +1 -0
  442. package/lib/umd/languageservice/utils/strings.d.ts +10 -0
  443. package/lib/umd/languageservice/utils/strings.js +99 -0
  444. package/lib/umd/languageservice/utils/strings.js.map +1 -0
  445. package/lib/umd/languageservice/utils/textBuffer.d.ts +12 -0
  446. package/lib/umd/languageservice/utils/textBuffer.js +59 -0
  447. package/lib/umd/languageservice/utils/textBuffer.js.map +1 -0
  448. package/lib/umd/languageservice/utils/yamlAstUtils.d.ts +13 -0
  449. package/lib/umd/languageservice/utils/yamlAstUtils.js +126 -0
  450. package/lib/umd/languageservice/utils/yamlAstUtils.js.map +1 -0
  451. package/lib/umd/languageservice/utils/yamlScalar.d.ts +1 -0
  452. package/lib/umd/languageservice/utils/yamlScalar.js +83 -0
  453. package/lib/umd/languageservice/utils/yamlScalar.js.map +1 -0
  454. package/lib/umd/languageservice/yamlLanguageService.d.ts +135 -0
  455. package/lib/umd/languageservice/yamlLanguageService.js +115 -0
  456. package/lib/umd/languageservice/yamlLanguageService.js.map +1 -0
  457. package/lib/umd/languageservice/yamlTypes.d.ts +18 -0
  458. package/lib/umd/languageservice/yamlTypes.js +17 -0
  459. package/lib/umd/languageservice/yamlTypes.js.map +1 -0
  460. package/lib/umd/nodeTranslationSetup.d.ts +9 -0
  461. package/lib/umd/nodeTranslationSetup.js +48 -0
  462. package/lib/umd/nodeTranslationSetup.js.map +1 -0
  463. package/lib/umd/requestTypes.d.ts +63 -0
  464. package/lib/umd/requestTypes.js +59 -0
  465. package/lib/umd/requestTypes.js.map +1 -0
  466. package/lib/umd/server.d.ts +1 -0
  467. package/lib/umd/server.js +67 -0
  468. package/lib/umd/server.js.map +1 -0
  469. package/lib/umd/webworker/yamlServerMain.d.ts +1 -0
  470. package/lib/umd/webworker/yamlServerMain.js +52 -0
  471. package/lib/umd/webworker/yamlServerMain.js.map +1 -0
  472. package/lib/umd/yamlServerInit.d.ts +23 -0
  473. package/lib/umd/yamlServerInit.js +137 -0
  474. package/lib/umd/yamlServerInit.js.map +1 -0
  475. package/lib/umd/yamlSettings.d.ts +112 -0
  476. package/lib/umd/yamlSettings.js +84 -0
  477. package/lib/umd/yamlSettings.js.map +1 -0
  478. package/out/server/src/commands.d.ts +3 -0
  479. package/out/server/src/commands.js +12 -0
  480. package/out/server/src/commands.js.map +1 -0
  481. package/out/server/src/index.d.ts +3 -0
  482. package/out/server/src/index.js +22 -0
  483. package/out/server/src/index.js.map +1 -0
  484. package/out/server/src/languageserver/commandExecutor.d.ts +10 -0
  485. package/out/server/src/languageserver/commandExecutor.js +25 -0
  486. package/out/server/src/languageserver/commandExecutor.js.map +1 -0
  487. package/out/server/src/languageserver/handlers/languageHandlers.d.ts +61 -0
  488. package/out/server/src/languageserver/handlers/languageHandlers.js +240 -0
  489. package/out/server/src/languageserver/handlers/languageHandlers.js.map +1 -0
  490. package/out/server/src/languageserver/handlers/notificationHandlers.d.ts +29 -0
  491. package/out/server/src/languageserver/handlers/notificationHandlers.js +50 -0
  492. package/out/server/src/languageserver/handlers/notificationHandlers.js.map +1 -0
  493. package/out/server/src/languageserver/handlers/requestHandlers.d.ts +9 -0
  494. package/out/server/src/languageserver/handlers/requestHandlers.js +27 -0
  495. package/out/server/src/languageserver/handlers/requestHandlers.js.map +1 -0
  496. package/out/server/src/languageserver/handlers/schemaSelectionHandlers.d.ts +13 -0
  497. package/out/server/src/languageserver/handlers/schemaSelectionHandlers.js +76 -0
  498. package/out/server/src/languageserver/handlers/schemaSelectionHandlers.js.map +1 -0
  499. package/out/server/src/languageserver/handlers/settingsHandlers.d.ts +42 -0
  500. package/out/server/src/languageserver/handlers/settingsHandlers.js +320 -0
  501. package/out/server/src/languageserver/handlers/settingsHandlers.js.map +1 -0
  502. package/out/server/src/languageserver/handlers/validationHandlers.d.ts +15 -0
  503. package/out/server/src/languageserver/handlers/validationHandlers.js +112 -0
  504. package/out/server/src/languageserver/handlers/validationHandlers.js.map +1 -0
  505. package/out/server/src/languageserver/handlers/workspaceHandlers.d.ts +9 -0
  506. package/out/server/src/languageserver/handlers/workspaceHandlers.js +21 -0
  507. package/out/server/src/languageserver/handlers/workspaceHandlers.js.map +1 -0
  508. package/out/server/src/languageserver/telemetry.d.ts +9 -0
  509. package/out/server/src/languageserver/telemetry.js +24 -0
  510. package/out/server/src/languageserver/telemetry.js.map +1 -0
  511. package/out/server/src/languageservice/jsonASTTypes.d.ts +49 -0
  512. package/out/server/src/languageservice/jsonASTTypes.js +7 -0
  513. package/out/server/src/languageservice/jsonASTTypes.js.map +1 -0
  514. package/out/server/src/languageservice/jsonSchema.d.ts +103 -0
  515. package/out/server/src/languageservice/jsonSchema.js +15 -0
  516. package/out/server/src/languageservice/jsonSchema.js.map +1 -0
  517. package/out/server/src/languageservice/parser/ast-converter.d.ts +11 -0
  518. package/out/server/src/languageservice/parser/ast-converter.js +181 -0
  519. package/out/server/src/languageservice/parser/ast-converter.js.map +1 -0
  520. package/out/server/src/languageservice/parser/astNodeUtils.d.ts +4 -0
  521. package/out/server/src/languageservice/parser/astNodeUtils.js +54 -0
  522. package/out/server/src/languageservice/parser/astNodeUtils.js.map +1 -0
  523. package/out/server/src/languageservice/parser/custom-tag-provider.d.ts +7 -0
  524. package/out/server/src/languageservice/parser/custom-tag-provider.js +62 -0
  525. package/out/server/src/languageservice/parser/custom-tag-provider.js.map +1 -0
  526. package/out/server/src/languageservice/parser/isKubernetes.d.ts +4 -0
  527. package/out/server/src/languageservice/parser/isKubernetes.js +22 -0
  528. package/out/server/src/languageservice/parser/isKubernetes.js.map +1 -0
  529. package/out/server/src/languageservice/parser/jsonDocument.d.ts +83 -0
  530. package/out/server/src/languageservice/parser/jsonDocument.js +183 -0
  531. package/out/server/src/languageservice/parser/jsonDocument.js.map +1 -0
  532. package/out/server/src/languageservice/parser/scalar-type.d.ts +8 -0
  533. package/out/server/src/languageservice/parser/scalar-type.js +21 -0
  534. package/out/server/src/languageservice/parser/scalar-type.js.map +1 -0
  535. package/out/server/src/languageservice/parser/schemaValidation/baseValidator.d.ts +124 -0
  536. package/out/server/src/languageservice/parser/schemaValidation/baseValidator.js +1260 -0
  537. package/out/server/src/languageservice/parser/schemaValidation/baseValidator.js.map +1 -0
  538. package/out/server/src/languageservice/parser/schemaValidation/draft04Validator.d.ts +17 -0
  539. package/out/server/src/languageservice/parser/schemaValidation/draft04Validator.js +34 -0
  540. package/out/server/src/languageservice/parser/schemaValidation/draft04Validator.js.map +1 -0
  541. package/out/server/src/languageservice/parser/schemaValidation/draft07Validator.d.ts +15 -0
  542. package/out/server/src/languageservice/parser/schemaValidation/draft07Validator.js +32 -0
  543. package/out/server/src/languageservice/parser/schemaValidation/draft07Validator.js.map +1 -0
  544. package/out/server/src/languageservice/parser/schemaValidation/draft2019Validator.d.ts +28 -0
  545. package/out/server/src/languageservice/parser/schemaValidation/draft2019Validator.js +228 -0
  546. package/out/server/src/languageservice/parser/schemaValidation/draft2019Validator.js.map +1 -0
  547. package/out/server/src/languageservice/parser/schemaValidation/draft2020Validator.d.ts +17 -0
  548. package/out/server/src/languageservice/parser/schemaValidation/draft2020Validator.js +130 -0
  549. package/out/server/src/languageservice/parser/schemaValidation/draft2020Validator.js.map +1 -0
  550. package/out/server/src/languageservice/parser/schemaValidation/validatorFactory.d.ts +3 -0
  551. package/out/server/src/languageservice/parser/schemaValidation/validatorFactory.js +28 -0
  552. package/out/server/src/languageservice/parser/schemaValidation/validatorFactory.js.map +1 -0
  553. package/out/server/src/languageservice/parser/yaml-documents.d.ts +71 -0
  554. package/out/server/src/languageservice/parser/yaml-documents.js +264 -0
  555. package/out/server/src/languageservice/parser/yaml-documents.js.map +1 -0
  556. package/out/server/src/languageservice/parser/yamlParser07.d.ts +15 -0
  557. package/out/server/src/languageservice/parser/yamlParser07.js +55 -0
  558. package/out/server/src/languageservice/parser/yamlParser07.js.map +1 -0
  559. package/out/server/src/languageservice/services/crdUtil.d.ts +23 -0
  560. package/out/server/src/languageservice/services/crdUtil.js +79 -0
  561. package/out/server/src/languageservice/services/crdUtil.js.map +1 -0
  562. package/out/server/src/languageservice/services/documentSymbols.d.ts +12 -0
  563. package/out/server/src/languageservice/services/documentSymbols.js +71 -0
  564. package/out/server/src/languageservice/services/documentSymbols.js.map +1 -0
  565. package/out/server/src/languageservice/services/modelineUtil.d.ts +9 -0
  566. package/out/server/src/languageservice/services/modelineUtil.js +34 -0
  567. package/out/server/src/languageservice/services/modelineUtil.js.map +1 -0
  568. package/out/server/src/languageservice/services/schemaRequestHandler.d.ts +12 -0
  569. package/out/server/src/languageservice/services/schemaRequestHandler.js +88 -0
  570. package/out/server/src/languageservice/services/schemaRequestHandler.js.map +1 -0
  571. package/out/server/src/languageservice/services/validation/map-key-order.d.ts +7 -0
  572. package/out/server/src/languageservice/services/validation/map-key-order.js +39 -0
  573. package/out/server/src/languageservice/services/validation/map-key-order.js.map +1 -0
  574. package/out/server/src/languageservice/services/validation/types.d.ts +6 -0
  575. package/out/server/src/languageservice/services/validation/types.js +7 -0
  576. package/out/server/src/languageservice/services/validation/types.js.map +1 -0
  577. package/out/server/src/languageservice/services/validation/unused-anchors.d.ts +8 -0
  578. package/out/server/src/languageservice/services/validation/unused-anchors.js +95 -0
  579. package/out/server/src/languageservice/services/validation/unused-anchors.js.map +1 -0
  580. package/out/server/src/languageservice/services/validation/yaml-style.d.ts +12 -0
  581. package/out/server/src/languageservice/services/validation/yaml-style.js +32 -0
  582. package/out/server/src/languageservice/services/validation/yaml-style.js.map +1 -0
  583. package/out/server/src/languageservice/services/yamlCodeActions.d.ts +25 -0
  584. package/out/server/src/languageservice/services/yamlCodeActions.js +346 -0
  585. package/out/server/src/languageservice/services/yamlCodeActions.js.map +1 -0
  586. package/out/server/src/languageservice/services/yamlCodeLens.d.ts +11 -0
  587. package/out/server/src/languageservice/services/yamlCodeLens.js +50 -0
  588. package/out/server/src/languageservice/services/yamlCodeLens.js.map +1 -0
  589. package/out/server/src/languageservice/services/yamlCommands.d.ts +3 -0
  590. package/out/server/src/languageservice/services/yamlCommands.js +50 -0
  591. package/out/server/src/languageservice/services/yamlCommands.js.map +1 -0
  592. package/out/server/src/languageservice/services/yamlCompletion.d.ts +77 -0
  593. package/out/server/src/languageservice/services/yamlCompletion.js +1505 -0
  594. package/out/server/src/languageservice/services/yamlCompletion.js.map +1 -0
  595. package/out/server/src/languageservice/services/yamlDefinition.d.ts +9 -0
  596. package/out/server/src/languageservice/services/yamlDefinition.js +41 -0
  597. package/out/server/src/languageservice/services/yamlDefinition.js.map +1 -0
  598. package/out/server/src/languageservice/services/yamlFolding.d.ts +4 -0
  599. package/out/server/src/languageservice/services/yamlFolding.js +66 -0
  600. package/out/server/src/languageservice/services/yamlFolding.js.map +1 -0
  601. package/out/server/src/languageservice/services/yamlFormatter.d.ts +8 -0
  602. package/out/server/src/languageservice/services/yamlFormatter.js +50 -0
  603. package/out/server/src/languageservice/services/yamlFormatter.js.map +1 -0
  604. package/out/server/src/languageservice/services/yamlHover.d.ts +47 -0
  605. package/out/server/src/languageservice/services/yamlHover.js +370 -0
  606. package/out/server/src/languageservice/services/yamlHover.js.map +1 -0
  607. package/out/server/src/languageservice/services/yamlLinks.d.ts +8 -0
  608. package/out/server/src/languageservice/services/yamlLinks.js +31 -0
  609. package/out/server/src/languageservice/services/yamlLinks.js.map +1 -0
  610. package/out/server/src/languageservice/services/yamlOnTypeFormatting.d.ts +4 -0
  611. package/out/server/src/languageservice/services/yamlOnTypeFormatting.js +47 -0
  612. package/out/server/src/languageservice/services/yamlOnTypeFormatting.js.map +1 -0
  613. package/out/server/src/languageservice/services/yamlRename.d.ts +18 -0
  614. package/out/server/src/languageservice/services/yamlRename.js +188 -0
  615. package/out/server/src/languageservice/services/yamlRename.js.map +1 -0
  616. package/out/server/src/languageservice/services/yamlSchemaService.d.ts +99 -0
  617. package/out/server/src/languageservice/services/yamlSchemaService.js +1114 -0
  618. package/out/server/src/languageservice/services/yamlSchemaService.js.map +1 -0
  619. package/out/server/src/languageservice/services/yamlSelectionRanges.d.ts +3 -0
  620. package/out/server/src/languageservice/services/yamlSelectionRanges.js +134 -0
  621. package/out/server/src/languageservice/services/yamlSelectionRanges.js.map +1 -0
  622. package/out/server/src/languageservice/services/yamlValidation.d.ts +26 -0
  623. package/out/server/src/languageservice/services/yamlValidation.js +140 -0
  624. package/out/server/src/languageservice/services/yamlValidation.js.map +1 -0
  625. package/out/server/src/languageservice/telemetry.d.ts +16 -0
  626. package/out/server/src/languageservice/telemetry.js +7 -0
  627. package/out/server/src/languageservice/telemetry.js.map +1 -0
  628. package/out/server/src/languageservice/utils/arrUtils.d.ts +6 -0
  629. package/out/server/src/languageservice/utils/arrUtils.js +89 -0
  630. package/out/server/src/languageservice/utils/arrUtils.js.map +1 -0
  631. package/out/server/src/languageservice/utils/block-string-rewriter.d.ts +8 -0
  632. package/out/server/src/languageservice/utils/block-string-rewriter.js +219 -0
  633. package/out/server/src/languageservice/utils/block-string-rewriter.js.map +1 -0
  634. package/out/server/src/languageservice/utils/charCode.d.ts +415 -0
  635. package/out/server/src/languageservice/utils/charCode.js +7 -0
  636. package/out/server/src/languageservice/utils/charCode.js.map +1 -0
  637. package/out/server/src/languageservice/utils/diagnostic-filter.d.ts +50 -0
  638. package/out/server/src/languageservice/utils/diagnostic-filter.js +88 -0
  639. package/out/server/src/languageservice/utils/diagnostic-filter.js.map +1 -0
  640. package/out/server/src/languageservice/utils/documentPositionCalculator.d.ts +5 -0
  641. package/out/server/src/languageservice/utils/documentPositionCalculator.js +63 -0
  642. package/out/server/src/languageservice/utils/documentPositionCalculator.js.map +1 -0
  643. package/out/server/src/languageservice/utils/filePatternAssociation.d.ts +8 -0
  644. package/out/server/src/languageservice/utils/filePatternAssociation.js +27 -0
  645. package/out/server/src/languageservice/utils/filePatternAssociation.js.map +1 -0
  646. package/out/server/src/languageservice/utils/flow-style-rewriter.d.ts +6 -0
  647. package/out/server/src/languageservice/utils/flow-style-rewriter.js +57 -0
  648. package/out/server/src/languageservice/utils/flow-style-rewriter.js.map +1 -0
  649. package/out/server/src/languageservice/utils/indentationGuesser.d.ts +15 -0
  650. package/out/server/src/languageservice/utils/indentationGuesser.js +180 -0
  651. package/out/server/src/languageservice/utils/indentationGuesser.js.map +1 -0
  652. package/out/server/src/languageservice/utils/json.d.ts +11 -0
  653. package/out/server/src/languageservice/utils/json.js +83 -0
  654. package/out/server/src/languageservice/utils/json.js.map +1 -0
  655. package/out/server/src/languageservice/utils/math.d.ts +1 -0
  656. package/out/server/src/languageservice/utils/math.js +13 -0
  657. package/out/server/src/languageservice/utils/math.js.map +1 -0
  658. package/out/server/src/languageservice/utils/objects.d.ts +16 -0
  659. package/out/server/src/languageservice/utils/objects.js +102 -0
  660. package/out/server/src/languageservice/utils/objects.js.map +1 -0
  661. package/out/server/src/languageservice/utils/parseUtils.d.ts +17 -0
  662. package/out/server/src/languageservice/utils/parseUtils.js +5 -0
  663. package/out/server/src/languageservice/utils/parseUtils.js.map +1 -0
  664. package/out/server/src/languageservice/utils/paths.d.ts +5 -0
  665. package/out/server/src/languageservice/utils/paths.js +48 -0
  666. package/out/server/src/languageservice/utils/paths.js.map +1 -0
  667. package/out/server/src/languageservice/utils/schemaUrls.d.ts +14 -0
  668. package/out/server/src/languageservice/utils/schemaUrls.js +64 -0
  669. package/out/server/src/languageservice/utils/schemaUrls.js.map +1 -0
  670. package/out/server/src/languageservice/utils/schemaUtils.d.ts +19 -0
  671. package/out/server/src/languageservice/utils/schemaUtils.js +70 -0
  672. package/out/server/src/languageservice/utils/schemaUtils.js.map +1 -0
  673. package/out/server/src/languageservice/utils/strings.d.ts +10 -0
  674. package/out/server/src/languageservice/utils/strings.js +89 -0
  675. package/out/server/src/languageservice/utils/strings.js.map +1 -0
  676. package/out/server/src/languageservice/utils/textBuffer.d.ts +12 -0
  677. package/out/server/src/languageservice/utils/textBuffer.js +49 -0
  678. package/out/server/src/languageservice/utils/textBuffer.js.map +1 -0
  679. package/out/server/src/languageservice/utils/yamlAstUtils.d.ts +13 -0
  680. package/out/server/src/languageservice/utils/yamlAstUtils.js +116 -0
  681. package/out/server/src/languageservice/utils/yamlAstUtils.js.map +1 -0
  682. package/out/server/src/languageservice/utils/yamlScalar.d.ts +1 -0
  683. package/out/server/src/languageservice/utils/yamlScalar.js +73 -0
  684. package/out/server/src/languageservice/utils/yamlScalar.js.map +1 -0
  685. package/out/server/src/languageservice/yamlLanguageService.d.ts +135 -0
  686. package/out/server/src/languageservice/yamlLanguageService.js +105 -0
  687. package/out/server/src/languageservice/yamlLanguageService.js.map +1 -0
  688. package/out/server/src/languageservice/yamlTypes.d.ts +18 -0
  689. package/out/server/src/languageservice/yamlTypes.js +7 -0
  690. package/out/server/src/languageservice/yamlTypes.js.map +1 -0
  691. package/out/server/src/nodeTranslationSetup.d.ts +9 -0
  692. package/out/server/src/nodeTranslationSetup.js +38 -0
  693. package/out/server/src/nodeTranslationSetup.js.map +1 -0
  694. package/out/server/src/requestTypes.d.ts +63 -0
  695. package/out/server/src/requestTypes.js +49 -0
  696. package/out/server/src/requestTypes.js.map +1 -0
  697. package/out/server/src/server.d.ts +1 -0
  698. package/out/server/src/server.js +57 -0
  699. package/out/server/src/server.js.map +1 -0
  700. package/out/server/src/webworker/yamlServerMain.d.ts +1 -0
  701. package/out/server/src/webworker/yamlServerMain.js +42 -0
  702. package/out/server/src/webworker/yamlServerMain.js.map +1 -0
  703. package/out/server/src/yamlServerInit.d.ts +23 -0
  704. package/out/server/src/yamlServerInit.js +127 -0
  705. package/out/server/src/yamlServerInit.js.map +1 -0
  706. package/out/server/src/yamlSettings.d.ts +112 -0
  707. package/out/server/src/yamlSettings.js +74 -0
  708. package/out/server/src/yamlSettings.js.map +1 -0
  709. package/out/server/test/arrUtils.test.d.ts +1 -0
  710. package/out/server/test/arrUtils.test.js +60 -0
  711. package/out/server/test/arrUtils.test.js.map +1 -0
  712. package/out/server/test/astUtils.test.d.ts +1 -0
  713. package/out/server/test/astUtils.test.js +79 -0
  714. package/out/server/test/astUtils.test.js.map +1 -0
  715. package/out/server/test/autoCompletion.test.d.ts +1 -0
  716. package/out/server/test/autoCompletion.test.js +2832 -0
  717. package/out/server/test/autoCompletion.test.js.map +1 -0
  718. package/out/server/test/autoCompletionFix.test.d.ts +1 -0
  719. package/out/server/test/autoCompletionFix.test.js +1591 -0
  720. package/out/server/test/autoCompletionFix.test.js.map +1 -0
  721. package/out/server/test/bundlel10n.test.d.ts +1 -0
  722. package/out/server/test/bundlel10n.test.js +73 -0
  723. package/out/server/test/bundlel10n.test.js.map +1 -0
  724. package/out/server/test/code-action-schema.test.d.ts +1 -0
  725. package/out/server/test/code-action-schema.test.js +89 -0
  726. package/out/server/test/code-action-schema.test.js.map +1 -0
  727. package/out/server/test/customTags.test.d.ts +1 -0
  728. package/out/server/test/customTags.test.js +88 -0
  729. package/out/server/test/customTags.test.js.map +1 -0
  730. package/out/server/test/defaultSnippets.test.d.ts +1 -0
  731. package/out/server/test/defaultSnippets.test.js +384 -0
  732. package/out/server/test/defaultSnippets.test.js.map +1 -0
  733. package/out/server/test/diagnostic-filter.test.d.ts +1 -0
  734. package/out/server/test/diagnostic-filter.test.js +161 -0
  735. package/out/server/test/diagnostic-filter.test.js.map +1 -0
  736. package/out/server/test/documentPositionCalculator.test.d.ts +1 -0
  737. package/out/server/test/documentPositionCalculator.test.js +69 -0
  738. package/out/server/test/documentPositionCalculator.test.js.map +1 -0
  739. package/out/server/test/documentSymbols.test.d.ts +1 -0
  740. package/out/server/test/documentSymbols.test.js +267 -0
  741. package/out/server/test/documentSymbols.test.js.map +1 -0
  742. package/out/server/test/findLinks.test.d.ts +1 -0
  743. package/out/server/test/findLinks.test.js +58 -0
  744. package/out/server/test/findLinks.test.js.map +1 -0
  745. package/out/server/test/flow-style-rewriter.test.d.ts +1 -0
  746. package/out/server/test/flow-style-rewriter.test.js +79 -0
  747. package/out/server/test/flow-style-rewriter.test.js.map +1 -0
  748. package/out/server/test/formatter.test.d.ts +1 -0
  749. package/out/server/test/formatter.test.js +170 -0
  750. package/out/server/test/formatter.test.js.map +1 -0
  751. package/out/server/test/hover.test.d.ts +1 -0
  752. package/out/server/test/hover.test.js +1056 -0
  753. package/out/server/test/hover.test.js.map +1 -0
  754. package/out/server/test/integration.test.d.ts +1 -0
  755. package/out/server/test/integration.test.js +293 -0
  756. package/out/server/test/integration.test.js.map +1 -0
  757. package/out/server/test/invalid-metaschema.test.d.ts +1 -0
  758. package/out/server/test/invalid-metaschema.test.js +43 -0
  759. package/out/server/test/invalid-metaschema.test.js.map +1 -0
  760. package/out/server/test/jsonParser.test.d.ts +1 -0
  761. package/out/server/test/jsonParser.test.js +1682 -0
  762. package/out/server/test/jsonParser.test.js.map +1 -0
  763. package/out/server/test/multipleDocuments.test.d.ts +1 -0
  764. package/out/server/test/multipleDocuments.test.js +117 -0
  765. package/out/server/test/multipleDocuments.test.js.map +1 -0
  766. package/out/server/test/objects.test.d.ts +1 -0
  767. package/out/server/test/objects.test.js +110 -0
  768. package/out/server/test/objects.test.js.map +1 -0
  769. package/out/server/test/paths.test.d.ts +1 -0
  770. package/out/server/test/paths.test.js +223 -0
  771. package/out/server/test/paths.test.js.map +1 -0
  772. package/out/server/test/scalaruri.test.d.ts +1 -0
  773. package/out/server/test/scalaruri.test.js +363 -0
  774. package/out/server/test/scalaruri.test.js.map +1 -0
  775. package/out/server/test/schema.test.d.ts +1 -0
  776. package/out/server/test/schema.test.js +952 -0
  777. package/out/server/test/schema.test.js.map +1 -0
  778. package/out/server/test/schema2019Validation.test.d.ts +1 -0
  779. package/out/server/test/schema2019Validation.test.js +3630 -0
  780. package/out/server/test/schema2019Validation.test.js.map +1 -0
  781. package/out/server/test/schema2020Validation.test.d.ts +1 -0
  782. package/out/server/test/schema2020Validation.test.js +2037 -0
  783. package/out/server/test/schema2020Validation.test.js.map +1 -0
  784. package/out/server/test/schemaRequestHandler.test.d.ts +1 -0
  785. package/out/server/test/schemaRequestHandler.test.js +48 -0
  786. package/out/server/test/schemaRequestHandler.test.js.map +1 -0
  787. package/out/server/test/schemaSelectionHandlers.test.d.ts +1 -0
  788. package/out/server/test/schemaSelectionHandlers.test.js +99 -0
  789. package/out/server/test/schemaSelectionHandlers.test.js.map +1 -0
  790. package/out/server/test/schemaValidation.test.d.ts +1 -0
  791. package/out/server/test/schemaValidation.test.js +2269 -0
  792. package/out/server/test/schemaValidation.test.js.map +1 -0
  793. package/out/server/test/settingsHandlers.test.d.ts +1 -0
  794. package/out/server/test/settingsHandlers.test.js +299 -0
  795. package/out/server/test/settingsHandlers.test.js.map +1 -0
  796. package/out/server/test/strings.test.d.ts +1 -0
  797. package/out/server/test/strings.test.js +92 -0
  798. package/out/server/test/strings.test.js.map +1 -0
  799. package/out/server/test/telemetry.test.d.ts +1 -0
  800. package/out/server/test/telemetry.test.js +36 -0
  801. package/out/server/test/telemetry.test.js.map +1 -0
  802. package/out/server/test/textBuffer.test.d.ts +1 -0
  803. package/out/server/test/textBuffer.test.js +41 -0
  804. package/out/server/test/textBuffer.test.js.map +1 -0
  805. package/out/server/test/utils/errorMessages.d.ts +27 -0
  806. package/out/server/test/utils/errorMessages.js +38 -0
  807. package/out/server/test/utils/errorMessages.js.map +1 -0
  808. package/out/server/test/utils/serviceSetup.d.ts +17 -0
  809. package/out/server/test/utils/serviceSetup.js +74 -0
  810. package/out/server/test/utils/serviceSetup.js.map +1 -0
  811. package/out/server/test/utils/testHelper.d.ts +78 -0
  812. package/out/server/test/utils/testHelper.js +202 -0
  813. package/out/server/test/utils/testHelper.js.map +1 -0
  814. package/out/server/test/utils/testsTypes.d.ts +29 -0
  815. package/out/server/test/utils/testsTypes.js +61 -0
  816. package/out/server/test/utils/testsTypes.js.map +1 -0
  817. package/out/server/test/utils/verifyError.d.ts +8 -0
  818. package/out/server/test/utils/verifyError.js +82 -0
  819. package/out/server/test/utils/verifyError.js.map +1 -0
  820. package/out/server/test/yaml-documents.test.d.ts +1 -0
  821. package/out/server/test/yaml-documents.test.js +198 -0
  822. package/out/server/test/yaml-documents.test.js.map +1 -0
  823. package/out/server/test/yamlCodeActions.test.d.ts +1 -0
  824. package/out/server/test/yamlCodeActions.test.js +864 -0
  825. package/out/server/test/yamlCodeActions.test.js.map +1 -0
  826. package/out/server/test/yamlCodeLens.test.d.ts +1 -0
  827. package/out/server/test/yamlCodeLens.test.js +165 -0
  828. package/out/server/test/yamlCodeLens.test.js.map +1 -0
  829. package/out/server/test/yamlCommands.test.d.ts +1 -0
  830. package/out/server/test/yamlCommands.test.js +89 -0
  831. package/out/server/test/yamlCommands.test.js.map +1 -0
  832. package/out/server/test/yamlDefinition.test.d.ts +1 -0
  833. package/out/server/test/yamlDefinition.test.js +30 -0
  834. package/out/server/test/yamlDefinition.test.js.map +1 -0
  835. package/out/server/test/yamlFolding.test.d.ts +1 -0
  836. package/out/server/test/yamlFolding.test.js +142 -0
  837. package/out/server/test/yamlFolding.test.js.map +1 -0
  838. package/out/server/test/yamlLanguageService.test.d.ts +1 -0
  839. package/out/server/test/yamlLanguageService.test.js +90 -0
  840. package/out/server/test/yamlLanguageService.test.js.map +1 -0
  841. package/out/server/test/yamlOnTypeFormatting.test.d.ts +1 -0
  842. package/out/server/test/yamlOnTypeFormatting.test.js +69 -0
  843. package/out/server/test/yamlOnTypeFormatting.test.js.map +1 -0
  844. package/out/server/test/yamlParser.test.d.ts +1 -0
  845. package/out/server/test/yamlParser.test.js +242 -0
  846. package/out/server/test/yamlParser.test.js.map +1 -0
  847. package/out/server/test/yamlRename.test.d.ts +1 -0
  848. package/out/server/test/yamlRename.test.js +106 -0
  849. package/out/server/test/yamlRename.test.js.map +1 -0
  850. package/out/server/test/yamlSchema.test.d.ts +1 -0
  851. package/out/server/test/yamlSchema.test.js +62 -0
  852. package/out/server/test/yamlSchema.test.js.map +1 -0
  853. package/out/server/test/yamlSchemaService.test.d.ts +1 -0
  854. package/out/server/test/yamlSchemaService.test.js +403 -0
  855. package/out/server/test/yamlSchemaService.test.js.map +1 -0
  856. package/out/server/test/yamlSelectionRanges.test.d.ts +1 -0
  857. package/out/server/test/yamlSelectionRanges.test.js +248 -0
  858. package/out/server/test/yamlSelectionRanges.test.js.map +1 -0
  859. package/out/server/test/yamlValidation.test.d.ts +1 -0
  860. package/out/server/test/yamlValidation.test.js +303 -0
  861. package/out/server/test/yamlValidation.test.js.map +1 -0
  862. package/package.json +106 -0
  863. package/scripts/check-dependencies.js +21 -0
  864. package/tsconfig.esm.json +15 -0
  865. package/tsconfig.umd.json +14 -0
@@ -0,0 +1,1270 @@
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Red Hat, Inc. All rights reserved.
3
+ * Copyright (c) Microsoft Corporation. All rights reserved.
4
+ * Licensed under the MIT License. See License.txt in the project root for license information.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ (function (factory) {
7
+ if (typeof module === "object" && typeof module.exports === "object") {
8
+ var v = factory(require, exports);
9
+ if (v !== undefined) module.exports = v;
10
+ }
11
+ else if (typeof define === "function" && define.amd) {
12
+ define(["require", "exports", "../../utils/objects", "../../utils/schemaUtils", "../../utils/arrUtils", "../../utils/strings", "../../utils/filePatternAssociation", "../../utils/math", "vscode-json-languageservice", "@vscode/l10n", "vscode-uri", "vscode-languageserver-types", "../astNodeUtils", "./validatorFactory"], factory);
13
+ }
14
+ })(function (require, exports) {
15
+ "use strict";
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.asSchema = exports.BaseValidator = exports.ValidationResult = exports.formats = exports.ProblemTypeMessages = exports.ProblemType = exports.YAML_SOURCE = void 0;
18
+ const objects_1 = require("../../utils/objects");
19
+ const schemaUtils_1 = require("../../utils/schemaUtils");
20
+ const arrUtils_1 = require("../../utils/arrUtils");
21
+ const strings_1 = require("../../utils/strings");
22
+ const filePatternAssociation_1 = require("../../utils/filePatternAssociation");
23
+ const math_1 = require("../../utils/math");
24
+ const vscode_json_languageservice_1 = require("vscode-json-languageservice");
25
+ const l10n = require("@vscode/l10n");
26
+ const vscode_uri_1 = require("vscode-uri");
27
+ const vscode_languageserver_types_1 = require("vscode-languageserver-types");
28
+ const astNodeUtils_1 = require("../astNodeUtils");
29
+ const validatorFactory_1 = require("./validatorFactory");
30
+ exports.YAML_SOURCE = 'YAML';
31
+ const YAML_SCHEMA_PREFIX = 'yaml-schema: ';
32
+ var ProblemType;
33
+ (function (ProblemType) {
34
+ ProblemType["missingRequiredPropWarning"] = "missingRequiredPropWarning";
35
+ ProblemType["typeMismatchWarning"] = "typeMismatchWarning";
36
+ ProblemType["constWarning"] = "constWarning";
37
+ })(ProblemType = exports.ProblemType || (exports.ProblemType = {}));
38
+ exports.ProblemTypeMessages = {
39
+ [ProblemType.missingRequiredPropWarning]: 'Missing property "{0}".',
40
+ [ProblemType.typeMismatchWarning]: 'Incorrect type. Expected "{0}".',
41
+ [ProblemType.constWarning]: 'Value must be {0}.',
42
+ };
43
+ class SchemaCollector {
44
+ constructor(focusOffset = -1, exclude = null) {
45
+ this.focusOffset = focusOffset;
46
+ this.exclude = exclude;
47
+ this.schemas = [];
48
+ }
49
+ add(schema) {
50
+ this.schemas.push(schema);
51
+ }
52
+ merge(other) {
53
+ this.schemas.push(...other.schemas);
54
+ }
55
+ include(node) {
56
+ return (this.focusOffset === -1 || (0, astNodeUtils_1.contains)(node, this.focusOffset)) && node !== this.exclude;
57
+ }
58
+ newSub() {
59
+ return new SchemaCollector(-1, this.exclude);
60
+ }
61
+ }
62
+ class NoOpSchemaCollector {
63
+ constructor() {
64
+ // ignore
65
+ }
66
+ get schemas() {
67
+ return [];
68
+ }
69
+ add() {
70
+ // ignore
71
+ }
72
+ merge() {
73
+ // ignore
74
+ }
75
+ include() {
76
+ return true;
77
+ }
78
+ newSub() {
79
+ return this;
80
+ }
81
+ }
82
+ NoOpSchemaCollector.instance = new NoOpSchemaCollector();
83
+ exports.formats = {
84
+ 'color-hex': {
85
+ errorMessage: l10n.t('Invalid color format. Use #RGB, #RGBA, #RRGGBB or #RRGGBBAA.'),
86
+ pattern: /^#([0-9A-Fa-f]{3,4}|([0-9A-Fa-f]{2}){3,4})$/,
87
+ },
88
+ 'date-time': {
89
+ errorMessage: l10n.t('String is not a RFC3339 date-time.'),
90
+ pattern: /^(\d{4})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])T([01][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9]|60)(\.[0-9]+)?(Z|(\+|-)([01][0-9]|2[0-3]):([0-5][0-9]))$/i,
91
+ },
92
+ date: {
93
+ errorMessage: l10n.t('String is not a RFC3339 date.'),
94
+ pattern: /^(\d{4})-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])$/i,
95
+ },
96
+ time: {
97
+ errorMessage: l10n.t('String is not a RFC3339 time.'),
98
+ pattern: /^([01][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9]|60)(\.[0-9]+)?(Z|(\+|-)([01][0-9]|2[0-3]):([0-5][0-9]))$/i,
99
+ },
100
+ email: {
101
+ errorMessage: l10n.t('String is not an e-mail address.'),
102
+ pattern: /^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,
103
+ },
104
+ ipv4: {
105
+ errorMessage: l10n.t('String does not match IPv4 format.'),
106
+ pattern: /^((25[0-5]|(2[0-4]|1\d|[1-9]|)\d)\.?\b){4}$/,
107
+ },
108
+ ipv6: {
109
+ errorMessage: l10n.t('String does not match IPv6 format.'),
110
+ pattern: /^([0-9a-f]|:){1,4}(:([0-9a-f]{0,4})*){1,7}$/i,
111
+ },
112
+ };
113
+ class ValidationResult {
114
+ constructor(isKubernetes) {
115
+ this.problems = [];
116
+ this.propertiesMatches = 0;
117
+ this.propertiesValueMatches = 0;
118
+ this.primaryValueMatches = 0;
119
+ this.enumValueMatch = false;
120
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
121
+ this.enumValues = null;
122
+ if (isKubernetes)
123
+ this.enumValues = [];
124
+ }
125
+ getEvaluatedItems(node) {
126
+ this.evaluatedItemsByNode ?? (this.evaluatedItemsByNode = new Map());
127
+ let evaluated = this.evaluatedItemsByNode.get(node);
128
+ if (!evaluated) {
129
+ evaluated = new Set();
130
+ this.evaluatedItemsByNode.set(node, evaluated);
131
+ }
132
+ return evaluated;
133
+ }
134
+ hasProblems() {
135
+ return this.problems.length > 0;
136
+ }
137
+ merge(other) {
138
+ this.problems = this.problems.concat(other.problems);
139
+ // Merge evaluatedProperties/evaluatedItems if present (needed for unevaluatedProperties/unevaluatedItems)
140
+ if (other.evaluatedProperties) {
141
+ this.evaluatedProperties ?? (this.evaluatedProperties = new Set());
142
+ for (const p of other.evaluatedProperties)
143
+ this.evaluatedProperties.add(p);
144
+ }
145
+ if (other.evaluatedItemsByNode) {
146
+ this.evaluatedItemsByNode ?? (this.evaluatedItemsByNode = new Map());
147
+ for (const [node, set] of other.evaluatedItemsByNode) {
148
+ const target = this.evaluatedItemsByNode.get(node);
149
+ if (target) {
150
+ for (const i of set)
151
+ target.add(i);
152
+ }
153
+ else {
154
+ this.evaluatedItemsByNode.set(node, new Set(set));
155
+ }
156
+ }
157
+ }
158
+ }
159
+ mergeEnumValues(other) {
160
+ if (!this.enumValueMatch && !other.enumValueMatch && this.enumValues && other.enumValues) {
161
+ this.enumValues = this.enumValues.concat(other.enumValues);
162
+ for (const err of this.problems) {
163
+ if (err.code === vscode_json_languageservice_1.ErrorCode.EnumValueMismatch) {
164
+ err.message = l10n.t('Value is not accepted. Valid values: {0}.', [...new Set(this.enumValues)].map((v) => JSON.stringify(v)).join(', '));
165
+ }
166
+ }
167
+ }
168
+ }
169
+ mergeWarningGeneric(sub, problemTypesToMerge) {
170
+ if (!this.problems?.length)
171
+ return;
172
+ for (const problemType of problemTypesToMerge) {
173
+ const bestResults = this.problems.filter((p) => p.problemType === problemType);
174
+ for (const bestResult of bestResults) {
175
+ const mergingResult = sub.problems?.find((p) => p.problemType === problemType &&
176
+ bestResult.location.offset === p.location.offset &&
177
+ (problemType !== ProblemType.missingRequiredPropWarning || (0, arrUtils_1.isArrayEqual)(p.problemArgs, bestResult.problemArgs)));
178
+ if (!mergingResult)
179
+ continue;
180
+ if (mergingResult.problemArgs?.length) {
181
+ mergingResult.problemArgs
182
+ .filter((p) => !bestResult.problemArgs.includes(p))
183
+ .forEach((p) => bestResult.problemArgs.push(p));
184
+ if (bestResult.problemType) {
185
+ bestResult.message = getWarningMessage(bestResult.problemType, bestResult.problemArgs ?? []);
186
+ }
187
+ }
188
+ this.mergeSources(mergingResult, bestResult);
189
+ }
190
+ }
191
+ }
192
+ mergePropertyMatch(propertyValidationResult, mergeEvaluated = true) {
193
+ if (mergeEvaluated) {
194
+ this.merge(propertyValidationResult);
195
+ }
196
+ else {
197
+ this.problems = this.problems.concat(propertyValidationResult.problems);
198
+ }
199
+ this.propertiesMatches++;
200
+ if (propertyValidationResult.enumValueMatch ||
201
+ (!propertyValidationResult.hasProblems() && propertyValidationResult.propertiesMatches)) {
202
+ this.propertiesValueMatches++;
203
+ }
204
+ if (propertyValidationResult.enumValueMatch && propertyValidationResult.enumValues) {
205
+ this.primaryValueMatches++;
206
+ }
207
+ }
208
+ mergeSources(mergingResult, bestResult) {
209
+ const mergingSource = (mergingResult.source ?? '').replace(YAML_SCHEMA_PREFIX, '');
210
+ if (mergingSource && bestResult.source && !bestResult.source.includes(mergingSource)) {
211
+ bestResult.source = bestResult.source + ' | ' + mergingSource;
212
+ }
213
+ if (bestResult.schemaUri && mergingResult.schemaUri && !bestResult.schemaUri.includes(mergingResult.schemaUri[0])) {
214
+ bestResult.schemaUri = bestResult.schemaUri.concat(mergingResult.schemaUri);
215
+ }
216
+ }
217
+ compareGeneric(other) {
218
+ const hasProblems = this.hasProblems();
219
+ if (hasProblems !== other.hasProblems())
220
+ return hasProblems ? -1 : 1;
221
+ if (this.enumValueMatch !== other.enumValueMatch)
222
+ return other.enumValueMatch ? -1 : 1;
223
+ if (this.propertiesValueMatches !== other.propertiesValueMatches)
224
+ return this.propertiesValueMatches - other.propertiesValueMatches;
225
+ if (this.primaryValueMatches !== other.primaryValueMatches)
226
+ return this.primaryValueMatches - other.primaryValueMatches;
227
+ return this.propertiesMatches - other.propertiesMatches;
228
+ }
229
+ compareKubernetes(other) {
230
+ const hasProblems = this.hasProblems();
231
+ if (this.propertiesMatches !== other.propertiesMatches)
232
+ return this.propertiesMatches - other.propertiesMatches;
233
+ if (this.enumValueMatch !== other.enumValueMatch)
234
+ return other.enumValueMatch ? -1 : 1;
235
+ if (this.primaryValueMatches !== other.primaryValueMatches)
236
+ return this.primaryValueMatches - other.primaryValueMatches;
237
+ if (this.propertiesValueMatches !== other.propertiesValueMatches)
238
+ return this.propertiesValueMatches - other.propertiesValueMatches;
239
+ if (hasProblems !== other.hasProblems())
240
+ return hasProblems ? -1 : 1;
241
+ return this.propertiesMatches - other.propertiesMatches;
242
+ }
243
+ }
244
+ exports.ValidationResult = ValidationResult;
245
+ class BaseValidator {
246
+ collectSeenKeys(node) {
247
+ const seenKeys = Object.create(null);
248
+ const unprocessedNodes = [...node.properties];
249
+ while (unprocessedNodes.length > 0) {
250
+ const propertyNode = unprocessedNodes.pop();
251
+ if (!propertyNode)
252
+ continue;
253
+ const key = propertyNode.keyNode.value;
254
+ // YAML merge key "<<"
255
+ if (key === '<<' && propertyNode.valueNode) {
256
+ const valueNode = propertyNode.valueNode;
257
+ switch (valueNode.type) {
258
+ case 'object':
259
+ unprocessedNodes.push(...valueNode.properties);
260
+ break;
261
+ case 'array':
262
+ valueNode.items.forEach((sequenceNode) => {
263
+ if (sequenceNode && sequenceNode.type === 'object' && (0, objects_1.isIterable)(sequenceNode.properties)) {
264
+ unprocessedNodes.push(...sequenceNode.properties);
265
+ }
266
+ });
267
+ break;
268
+ default:
269
+ break;
270
+ }
271
+ }
272
+ else {
273
+ seenKeys[key] = propertyNode.valueNode;
274
+ }
275
+ }
276
+ return seenKeys;
277
+ }
278
+ validateDocument(root, textDocument, schema, options) {
279
+ const validationResult = new ValidationResult(options.isKubernetes);
280
+ this.validateNode(root, schema, schema, validationResult, NoOpSchemaCollector.instance, options);
281
+ return validationResult.problems.map((p) => {
282
+ const range = vscode_languageserver_types_1.Range.create(textDocument.positionAt(p.location.offset), textDocument.positionAt(p.location.offset + p.location.length));
283
+ const diagnostic = vscode_languageserver_types_1.Diagnostic.create(range, p.message, p.severity, p.code ? p.code : vscode_json_languageservice_1.ErrorCode.Undefined, p.source);
284
+ diagnostic.data = { schemaUri: p.schemaUri, ...p.data };
285
+ return diagnostic;
286
+ });
287
+ }
288
+ getMatchingSchemas(root, schema, options, focusOffset, exclude) {
289
+ const matchingSchemas = new SchemaCollector(focusOffset, exclude);
290
+ this.validateNode(root, schema, schema, new ValidationResult(options.isKubernetes), matchingSchemas, options);
291
+ return matchingSchemas.schemas;
292
+ }
293
+ getNoOpCollector() {
294
+ return NoOpSchemaCollector.instance;
295
+ }
296
+ getSchemaSource(schema, originalSchema) {
297
+ let label;
298
+ if (schema.title) {
299
+ label = schema.title;
300
+ }
301
+ else if (schema.closestTitle) {
302
+ label = schema.closestTitle;
303
+ }
304
+ else if (originalSchema.closestTitle) {
305
+ label = originalSchema.closestTitle;
306
+ }
307
+ else {
308
+ const uriString = schema.url ?? originalSchema.url;
309
+ if (uriString)
310
+ label = vscode_uri_1.URI.parse(uriString).toString();
311
+ }
312
+ return label ? `${YAML_SCHEMA_PREFIX}${label}` : exports.YAML_SOURCE;
313
+ }
314
+ getSchemaUri(schema, originalSchema) {
315
+ const uriString = schema.url ?? originalSchema.url;
316
+ return uriString ? [uriString] : [];
317
+ }
318
+ // ---------------- core traversal ----------------
319
+ validateNode(node, schema, originalSchema, validationResult, matchingSchemas, options) {
320
+ if (!node)
321
+ return;
322
+ if (!schema || typeof schema !== 'object')
323
+ return;
324
+ // Draft 2020-12 Compound Schema Document behavior: check if this node explicitly declares a different dialect
325
+ if (schema._dialect) {
326
+ const subDialect = schema._dialect;
327
+ const currentDialect = this.getCurrentDialect();
328
+ if (subDialect !== currentDialect) {
329
+ const subValidator = (0, validatorFactory_1.getValidator)(subDialect);
330
+ subValidator.validateNode(node, schema, originalSchema, validationResult, matchingSchemas, options);
331
+ return;
332
+ }
333
+ }
334
+ if (!schema.url)
335
+ schema.url = originalSchema.url;
336
+ schema.closestTitle = schema.title || originalSchema.closestTitle;
337
+ switch (node.type) {
338
+ case 'object':
339
+ this.validateObjectNode(node, schema, originalSchema, validationResult, matchingSchemas, options);
340
+ break;
341
+ case 'array':
342
+ this.validateArrayNode(node, schema, originalSchema, validationResult, matchingSchemas, options);
343
+ break;
344
+ case 'string':
345
+ this.validateStringNode(node, schema, originalSchema, validationResult);
346
+ break;
347
+ case 'number':
348
+ this.validateNumberNode(node, schema, originalSchema, validationResult);
349
+ break;
350
+ case 'property':
351
+ this.validateNode(node.valueNode, schema, schema, validationResult, matchingSchemas, options);
352
+ break;
353
+ default:
354
+ break;
355
+ }
356
+ this.validateGenericNode(node, schema, originalSchema, validationResult, matchingSchemas, options);
357
+ // used by completion/hover schema collection
358
+ matchingSchemas.add({ node, schema });
359
+ // draft-specific post-processing hooks (no-op in base)
360
+ this.applyUnevaluatedItems(node, schema, originalSchema, validationResult, matchingSchemas, options);
361
+ // unevaluatedProperties must run AFTER validateGenericNode() (allOf/$ref/anyOf/oneOf/if/then/else/not)
362
+ if (node.type === 'object') {
363
+ const seenKeys = this.collectSeenKeys(node);
364
+ this.applyUnevaluatedProperties(node, schema, originalSchema, validationResult, matchingSchemas, options, seenKeys);
365
+ }
366
+ }
367
+ // ---------------- shared generic keywords ----------------
368
+ validateGenericNode(node, schema, originalSchema, validationResult, matchingSchemas, options) {
369
+ const { isKubernetes, callFromAutoComplete } = options;
370
+ const matchesType = (type) => {
371
+ return node.type === type || (type === 'integer' && node.type === 'number' && node.isInteger);
372
+ };
373
+ const mergeEvaluated = (target, source) => {
374
+ if (source.evaluatedProperties) {
375
+ target.evaluatedProperties ?? (target.evaluatedProperties = new Set());
376
+ for (const p of source.evaluatedProperties)
377
+ target.evaluatedProperties.add(p);
378
+ }
379
+ if (source.evaluatedItemsByNode) {
380
+ target.evaluatedItemsByNode ?? (target.evaluatedItemsByNode = new Map());
381
+ for (const [nodeRef, set] of source.evaluatedItemsByNode) {
382
+ const targetSet = target.evaluatedItemsByNode.get(nodeRef);
383
+ if (targetSet) {
384
+ for (const i of set)
385
+ targetSet.add(i);
386
+ }
387
+ else {
388
+ target.evaluatedItemsByNode.set(nodeRef, new Set(set));
389
+ }
390
+ }
391
+ }
392
+ };
393
+ // type
394
+ if (Array.isArray(schema.type)) {
395
+ if (!schema.type.some(matchesType)) {
396
+ validationResult.problems.push({
397
+ location: { offset: node.offset, length: node.length },
398
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
399
+ message: schema.errorMessage || l10n.t('Incorrect type. Expected one of {0}.', schema.type.join(', ')),
400
+ source: this.getSchemaSource(schema, originalSchema),
401
+ schemaUri: this.getSchemaUri(schema, originalSchema),
402
+ });
403
+ }
404
+ }
405
+ else if (schema.type) {
406
+ if (!matchesType(schema.type)) {
407
+ const schemaType = schema.type === 'object' ? (0, schemaUtils_1.getSchemaTypeName)(schema) : schema.type;
408
+ validationResult.problems.push({
409
+ location: { offset: node.offset, length: node.length },
410
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
411
+ message: schema.errorMessage || getWarningMessage(ProblemType.typeMismatchWarning, [schemaType]),
412
+ source: this.getSchemaSource(schema, originalSchema),
413
+ schemaUri: this.getSchemaUri(schema, originalSchema),
414
+ problemType: ProblemType.typeMismatchWarning,
415
+ problemArgs: [schemaType],
416
+ });
417
+ }
418
+ }
419
+ // allOf
420
+ if (Array.isArray(schema.allOf)) {
421
+ for (const subSchemaRef of schema.allOf) {
422
+ const subSchema = asSchema(subSchemaRef);
423
+ const subValidationResult = new ValidationResult(isKubernetes);
424
+ const subMatchingSchemas = matchingSchemas.newSub();
425
+ this.validateNode(node, subSchema, schema, subValidationResult, subMatchingSchemas, options);
426
+ validationResult.merge(subValidationResult);
427
+ validationResult.propertiesMatches += subValidationResult.propertiesMatches;
428
+ validationResult.propertiesValueMatches += subValidationResult.propertiesValueMatches;
429
+ matchingSchemas.merge(subMatchingSchemas);
430
+ }
431
+ }
432
+ // not
433
+ const notSchema = asSchema(schema.not);
434
+ if (notSchema) {
435
+ const subValidationResult = new ValidationResult(isKubernetes);
436
+ const subMatchingSchemas = matchingSchemas.newSub();
437
+ this.validateNode(node, notSchema, schema, subValidationResult, subMatchingSchemas, options);
438
+ if (!subValidationResult.hasProblems()) {
439
+ validationResult.problems.push({
440
+ location: { offset: node.offset, length: node.length },
441
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
442
+ message: l10n.t('Matches a schema that is not allowed.'),
443
+ source: this.getSchemaSource(schema, originalSchema),
444
+ schemaUri: this.getSchemaUri(schema, originalSchema),
445
+ });
446
+ }
447
+ for (const ms of subMatchingSchemas.schemas) {
448
+ ms.inverted = !ms.inverted;
449
+ matchingSchemas.add(ms);
450
+ }
451
+ }
452
+ const testAlternatives = (alternatives, maxOneMatch) => {
453
+ const subMatches = [];
454
+ const noPropertyMatches = [];
455
+ const validResults = [];
456
+ let bestMatch = null;
457
+ for (const subSchemaRef of alternatives) {
458
+ const subSchema = { ...asSchema(subSchemaRef) };
459
+ const subValidationResult = new ValidationResult(isKubernetes);
460
+ const subMatchingSchemas = matchingSchemas.newSub();
461
+ this.validateNode(node, subSchema, schema, subValidationResult, subMatchingSchemas, options);
462
+ if (!subValidationResult.hasProblems() || callFromAutoComplete) {
463
+ subMatches.push(subSchema);
464
+ if (subValidationResult.propertiesMatches === 0)
465
+ noPropertyMatches.push(subSchema);
466
+ if (subSchema.format)
467
+ subMatches.pop();
468
+ }
469
+ if (!subValidationResult.hasProblems()) {
470
+ validResults.push(subValidationResult);
471
+ }
472
+ if (!bestMatch) {
473
+ bestMatch = { schema: subSchema, validationResult: subValidationResult, matchingSchemas: subMatchingSchemas };
474
+ }
475
+ else if (isKubernetes) {
476
+ bestMatch = this.alternativeComparison(subValidationResult, bestMatch, subSchema, subMatchingSchemas);
477
+ }
478
+ else {
479
+ bestMatch = this.genericComparison(node, maxOneMatch, subValidationResult, bestMatch, subSchema, subMatchingSchemas);
480
+ }
481
+ }
482
+ if (subMatches.length > 1 && (subMatches.length > 1 || noPropertyMatches.length === 0) && maxOneMatch) {
483
+ validationResult.problems.push({
484
+ location: { offset: node.offset, length: 1 },
485
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
486
+ message: l10n.t('Matches multiple schemas when only one must validate.'),
487
+ source: this.getSchemaSource(schema, originalSchema),
488
+ schemaUri: this.getSchemaUri(schema, originalSchema),
489
+ });
490
+ }
491
+ if (bestMatch) {
492
+ validationResult.merge(bestMatch.validationResult);
493
+ validationResult.propertiesMatches += bestMatch.validationResult.propertiesMatches;
494
+ validationResult.propertiesValueMatches += bestMatch.validationResult.propertiesValueMatches;
495
+ validationResult.enumValueMatch = validationResult.enumValueMatch || bestMatch.validationResult.enumValueMatch;
496
+ if (bestMatch.validationResult.enumValues?.length) {
497
+ validationResult.enumValues = (validationResult.enumValues || []).concat(bestMatch.validationResult.enumValues);
498
+ }
499
+ matchingSchemas.merge(bestMatch.matchingSchemas);
500
+ }
501
+ if (validResults.length > 0) {
502
+ for (const result of validResults) {
503
+ mergeEvaluated(validationResult, result);
504
+ }
505
+ }
506
+ };
507
+ if (Array.isArray(schema.anyOf)) {
508
+ testAlternatives(schema.anyOf, false);
509
+ }
510
+ if (Array.isArray(schema.oneOf)) {
511
+ testAlternatives(schema.oneOf, true);
512
+ }
513
+ // if / then / else (plus filePatternAssociation extension)
514
+ const testBranch = (branchSchema, original) => {
515
+ const subValidationResult = new ValidationResult(isKubernetes);
516
+ const subMatchingSchemas = matchingSchemas.newSub();
517
+ this.validateNode(node, asSchema(branchSchema), original, subValidationResult, subMatchingSchemas, options);
518
+ validationResult.merge(subValidationResult);
519
+ validationResult.propertiesMatches += subValidationResult.propertiesMatches;
520
+ validationResult.propertiesValueMatches += subValidationResult.propertiesValueMatches;
521
+ matchingSchemas.merge(subMatchingSchemas);
522
+ };
523
+ const testCondition = (ifSchemaRef, original, thenSchema, elseSchema) => {
524
+ const subSchema = asSchema(ifSchemaRef);
525
+ const subValidationResult = new ValidationResult(isKubernetes);
526
+ const subMatchingSchemas = matchingSchemas.newSub();
527
+ this.validateNode(node, subSchema, original, subValidationResult, subMatchingSchemas, options);
528
+ matchingSchemas.merge(subMatchingSchemas);
529
+ const filePatternAssociation = subSchema?.filePatternAssociation;
530
+ if (filePatternAssociation) {
531
+ const association = new filePatternAssociation_1.FilePatternAssociation(filePatternAssociation);
532
+ if (!association.matchesPattern(options.uri)) {
533
+ subValidationResult.problems.push({
534
+ location: { offset: node.offset, length: node.length },
535
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
536
+ message: l10n.t("filePatternAssociation '{0}' does not match with doc uri '{1}'", filePatternAssociation, options.uri),
537
+ source: this.getSchemaSource(schema, originalSchema),
538
+ schemaUri: this.getSchemaUri(schema, originalSchema),
539
+ });
540
+ }
541
+ }
542
+ if (!subValidationResult.hasProblems()) {
543
+ mergeEvaluated(validationResult, subValidationResult);
544
+ if (thenSchema)
545
+ testBranch(thenSchema, original);
546
+ }
547
+ else if (elseSchema) {
548
+ testBranch(elseSchema, original);
549
+ }
550
+ };
551
+ const ifSchema = asSchema(schema.if);
552
+ if (ifSchema) {
553
+ testCondition(ifSchema, schema, asSchema(schema.then), asSchema(schema.else));
554
+ }
555
+ // enum
556
+ if (Array.isArray(schema.enum)) {
557
+ const val = (0, astNodeUtils_1.getNodeValue)(node);
558
+ let enumValueMatch = false;
559
+ for (const e of schema.enum) {
560
+ if ((0, objects_1.equals)(val, e, node.type) || isAutoCompleteEqualMaybe(callFromAutoComplete, node, val, e)) {
561
+ enumValueMatch = true;
562
+ break;
563
+ }
564
+ }
565
+ validationResult.enumValues = schema.enum;
566
+ validationResult.enumValueMatch = enumValueMatch;
567
+ if (!enumValueMatch) {
568
+ validationResult.problems.push({
569
+ location: { offset: node.offset, length: node.length },
570
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
571
+ code: vscode_json_languageservice_1.ErrorCode.EnumValueMismatch,
572
+ message: schema.errorMessage ||
573
+ l10n.t('Value is not accepted. Valid values: {0}.', (schema.enum ?? []).map((v) => JSON.stringify(v)).join(', ')),
574
+ source: this.getSchemaSource(schema, originalSchema),
575
+ schemaUri: this.getSchemaUri(schema, originalSchema),
576
+ data: { values: schema.enum },
577
+ });
578
+ }
579
+ }
580
+ // const
581
+ if ((0, objects_1.isDefined)(schema.const)) {
582
+ const val = (0, astNodeUtils_1.getNodeValue)(node);
583
+ const c = schema.const;
584
+ if (!(0, objects_1.equals)(val, c, node.type) && !isAutoCompleteEqualMaybe(callFromAutoComplete, node, val, c)) {
585
+ validationResult.problems.push({
586
+ location: { offset: node.offset, length: node.length },
587
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
588
+ code: vscode_json_languageservice_1.ErrorCode.EnumValueMismatch,
589
+ problemType: ProblemType.constWarning,
590
+ message: schema.errorMessage || getWarningMessage(ProblemType.constWarning, [JSON.stringify(c)]),
591
+ source: this.getSchemaSource(schema, originalSchema),
592
+ schemaUri: this.getSchemaUri(schema, originalSchema),
593
+ problemArgs: [JSON.stringify(c)],
594
+ data: { values: [c] },
595
+ });
596
+ validationResult.enumValueMatch = false;
597
+ }
598
+ else {
599
+ validationResult.enumValueMatch = true;
600
+ }
601
+ validationResult.enumValues = [c];
602
+ }
603
+ // deprecationMessage
604
+ if (schema.deprecationMessage && node.parent) {
605
+ validationResult.problems.push({
606
+ location: { offset: node.parent.offset, length: node.parent.length },
607
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
608
+ message: schema.deprecationMessage,
609
+ source: this.getSchemaSource(schema, originalSchema),
610
+ schemaUri: this.getSchemaUri(schema, originalSchema),
611
+ });
612
+ }
613
+ }
614
+ // ---------------- shared leaf validations ----------------
615
+ validateStringNode(node, schema, originalSchema, validationResult) {
616
+ const value = node.value;
617
+ if ((0, objects_1.isNumber)(schema.minLength) && value.length < (schema.minLength ?? 0)) {
618
+ validationResult.problems.push({
619
+ location: { offset: node.offset, length: node.length },
620
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
621
+ message: l10n.t('String is shorter than the minimum length of {0}.', schema.minLength),
622
+ source: this.getSchemaSource(schema, originalSchema),
623
+ schemaUri: this.getSchemaUri(schema, originalSchema),
624
+ });
625
+ }
626
+ if ((0, objects_1.isNumber)(schema.maxLength) && value.length > (schema.maxLength ?? 0)) {
627
+ validationResult.problems.push({
628
+ location: { offset: node.offset, length: node.length },
629
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
630
+ message: l10n.t('String is longer than the maximum length of {0}.', schema.maxLength),
631
+ source: this.getSchemaSource(schema, originalSchema),
632
+ schemaUri: this.getSchemaUri(schema, originalSchema),
633
+ });
634
+ }
635
+ if ((0, objects_1.isString)(schema.pattern)) {
636
+ const regex = (0, strings_1.safeCreateUnicodeRegExp)(schema.pattern);
637
+ if (!regex.test(value)) {
638
+ validationResult.problems.push({
639
+ location: { offset: node.offset, length: node.length },
640
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
641
+ message: schema.patternErrorMessage ||
642
+ schema.errorMessage ||
643
+ l10n.t('String does not match the pattern of "{0}".', schema.pattern),
644
+ source: this.getSchemaSource(schema, originalSchema),
645
+ schemaUri: this.getSchemaUri(schema, originalSchema),
646
+ });
647
+ }
648
+ }
649
+ if (schema.format) {
650
+ switch (schema.format) {
651
+ case 'uri':
652
+ case 'uri-reference': {
653
+ let errorMessage;
654
+ if (!value) {
655
+ errorMessage = l10n.t('URI expected.');
656
+ }
657
+ else {
658
+ try {
659
+ const uri = vscode_uri_1.URI.parse(value);
660
+ if (!uri.scheme && schema.format === 'uri') {
661
+ errorMessage = l10n.t('URI with a scheme is expected.');
662
+ }
663
+ }
664
+ catch (e) {
665
+ errorMessage = e instanceof Error ? e.message : String(e);
666
+ }
667
+ }
668
+ if (errorMessage) {
669
+ validationResult.problems.push({
670
+ location: { offset: node.offset, length: node.length },
671
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
672
+ message: schema.patternErrorMessage || schema.errorMessage || l10n.t('String is not a URI: {0}', errorMessage),
673
+ source: this.getSchemaSource(schema, originalSchema),
674
+ schemaUri: this.getSchemaUri(schema, originalSchema),
675
+ });
676
+ }
677
+ break;
678
+ }
679
+ case 'color-hex':
680
+ case 'date-time':
681
+ case 'date':
682
+ case 'time':
683
+ case 'email':
684
+ case 'ipv4':
685
+ case 'ipv6': {
686
+ const format = exports.formats[schema.format];
687
+ if (!value || !format.pattern.test(value)) {
688
+ validationResult.problems.push({
689
+ location: { offset: node.offset, length: node.length },
690
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
691
+ message: schema.patternErrorMessage || schema.errorMessage || l10n.t(format.errorMessage),
692
+ source: this.getSchemaSource(schema, originalSchema),
693
+ schemaUri: this.getSchemaUri(schema, originalSchema),
694
+ });
695
+ }
696
+ break;
697
+ }
698
+ default:
699
+ break;
700
+ }
701
+ }
702
+ }
703
+ validateNumberNode(node, schema, originalSchema, validationResult) {
704
+ const val = node.value;
705
+ if ((0, objects_1.isNumber)(schema.multipleOf)) {
706
+ if ((0, math_1.floatSafeRemainder)(val, schema.multipleOf ?? 0) !== 0) {
707
+ validationResult.problems.push({
708
+ location: { offset: node.offset, length: node.length },
709
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
710
+ message: l10n.t('Value is not divisible by {0}.', schema.multipleOf),
711
+ source: this.getSchemaSource(schema, originalSchema),
712
+ schemaUri: this.getSchemaUri(schema, originalSchema),
713
+ });
714
+ }
715
+ }
716
+ const limits = this.getNumberLimits(schema);
717
+ if ((0, objects_1.isNumber)(limits.exclusiveMinimum) && val <= limits.exclusiveMinimum) {
718
+ validationResult.problems.push({
719
+ location: { offset: node.offset, length: node.length },
720
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
721
+ message: l10n.t('Value is below the exclusive minimum of {0}.', limits.exclusiveMinimum),
722
+ source: this.getSchemaSource(schema, originalSchema),
723
+ schemaUri: this.getSchemaUri(schema, originalSchema),
724
+ });
725
+ }
726
+ if ((0, objects_1.isNumber)(limits.exclusiveMaximum) && val >= limits.exclusiveMaximum) {
727
+ validationResult.problems.push({
728
+ location: { offset: node.offset, length: node.length },
729
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
730
+ message: l10n.t('Value is above the exclusive maximum of {0}.', limits.exclusiveMaximum),
731
+ source: this.getSchemaSource(schema, originalSchema),
732
+ schemaUri: this.getSchemaUri(schema, originalSchema),
733
+ });
734
+ }
735
+ if ((0, objects_1.isNumber)(limits.minimum) && val < limits.minimum) {
736
+ validationResult.problems.push({
737
+ location: { offset: node.offset, length: node.length },
738
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
739
+ message: l10n.t('Value is below the minimum of {0}.', limits.minimum),
740
+ source: this.getSchemaSource(schema, originalSchema),
741
+ schemaUri: this.getSchemaUri(schema, originalSchema),
742
+ });
743
+ }
744
+ if ((0, objects_1.isNumber)(limits.maximum) && val > limits.maximum) {
745
+ validationResult.problems.push({
746
+ location: { offset: node.offset, length: node.length },
747
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
748
+ message: l10n.t('Value is above the maximum of {0}.', limits.maximum),
749
+ source: this.getSchemaSource(schema, originalSchema),
750
+ schemaUri: this.getSchemaUri(schema, originalSchema),
751
+ });
752
+ }
753
+ }
754
+ // ---------------- array validation (draft hotspot) ----------------
755
+ validateArrayNode(node, schema, originalSchema, validationResult, matchingSchemas, options) {
756
+ // Draft-07 default: tuple arrays via items: [] and additionalItems
757
+ const { isKubernetes } = options;
758
+ const items = node.items ?? [];
759
+ const evaluatedItems = schema.items ? validationResult.getEvaluatedItems(node) : undefined;
760
+ if (Array.isArray(schema.items)) {
761
+ const subSchemas = schema.items;
762
+ for (let index = 0; index < subSchemas.length; index++) {
763
+ const subSchema = asSchema(subSchemas[index]);
764
+ const itemValidationResult = new ValidationResult(isKubernetes);
765
+ const item = items[index];
766
+ if (item) {
767
+ this.validateNode(item, subSchema, schema, itemValidationResult, matchingSchemas, options);
768
+ validationResult.mergePropertyMatch(itemValidationResult, false);
769
+ validationResult.mergeEnumValues(itemValidationResult);
770
+ evaluatedItems?.add(index);
771
+ }
772
+ else if (items.length >= subSchemas.length) {
773
+ validationResult.propertiesValueMatches++;
774
+ }
775
+ }
776
+ if (items.length > subSchemas.length) {
777
+ const additional = schema.additionalItems;
778
+ if (additional === false) {
779
+ validationResult.problems.push({
780
+ location: { offset: node.offset, length: node.length },
781
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
782
+ message: l10n.t('Array has too many items according to schema. Expected {0} or fewer.', subSchemas.length),
783
+ source: this.getSchemaSource(schema, originalSchema),
784
+ schemaUri: this.getSchemaUri(schema, originalSchema),
785
+ });
786
+ for (let i = subSchemas.length; i < items.length; i++) {
787
+ evaluatedItems?.add(i);
788
+ }
789
+ }
790
+ else if (typeof additional === 'object') {
791
+ for (let i = subSchemas.length; i < items.length; i++) {
792
+ const itemValidationResult = new ValidationResult(isKubernetes);
793
+ this.validateNode(items[i], additional, schema, itemValidationResult, matchingSchemas, options);
794
+ validationResult.mergePropertyMatch(itemValidationResult, false);
795
+ validationResult.mergeEnumValues(itemValidationResult);
796
+ evaluatedItems?.add(i);
797
+ }
798
+ }
799
+ else if (additional === true) {
800
+ // additionalItems is true => allowed by default (treat as {}), so mark remaining as evaluated
801
+ for (let i = subSchemas.length; i < items.length; i++) {
802
+ evaluatedItems?.add(i);
803
+ }
804
+ }
805
+ }
806
+ }
807
+ else {
808
+ const itemSchema = asSchema(schema.items);
809
+ if (itemSchema) {
810
+ const currentEvaluatedItems = validationResult.getEvaluatedItems(node);
811
+ for (let i = 0; i < items.length; i++) {
812
+ const item = items[i];
813
+ const itemValidationResult = new ValidationResult(isKubernetes);
814
+ this.validateNode(item, itemSchema, schema, itemValidationResult, matchingSchemas, options);
815
+ validationResult.mergePropertyMatch(itemValidationResult, false);
816
+ validationResult.mergeEnumValues(itemValidationResult);
817
+ currentEvaluatedItems.add(i);
818
+ }
819
+ }
820
+ }
821
+ this.applyContains(node, schema, originalSchema, validationResult, matchingSchemas, options);
822
+ this.applyArrayLength(node, schema, originalSchema, validationResult, options);
823
+ this.applyUniqueItems(node, schema, originalSchema, validationResult);
824
+ }
825
+ applyContains(node, schema, originalSchema, validationResult, _matchingSchemas, options) {
826
+ // Draft-07 default: contains must match at least one item
827
+ const { isKubernetes } = options;
828
+ const containsSchema = asSchema(schema.contains);
829
+ if (!containsSchema)
830
+ return;
831
+ const doesContain = (node.items ?? []).some((item) => {
832
+ const itemValidationResult = new ValidationResult(isKubernetes);
833
+ this.validateNode(item, containsSchema, schema, itemValidationResult, NoOpSchemaCollector.instance, options);
834
+ return !itemValidationResult.hasProblems();
835
+ });
836
+ if (!doesContain) {
837
+ validationResult.problems.push({
838
+ location: { offset: node.offset, length: node.length },
839
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
840
+ message: schema.errorMessage || l10n.t('Array does not contain required item.'),
841
+ source: this.getSchemaSource(schema, originalSchema),
842
+ schemaUri: this.getSchemaUri(schema, originalSchema),
843
+ });
844
+ }
845
+ }
846
+ applyArrayLength(node, schema, originalSchema, validationResult,
847
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
848
+ _options) {
849
+ if ((0, objects_1.isNumber)(schema.minItems) && node.items.length < (schema.minItems ?? 0)) {
850
+ validationResult.problems.push({
851
+ location: { offset: node.offset, length: node.length },
852
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
853
+ message: l10n.t('Array has too few items. Expected {0} or more.', schema.minItems),
854
+ source: this.getSchemaSource(schema, originalSchema),
855
+ schemaUri: this.getSchemaUri(schema, originalSchema),
856
+ });
857
+ }
858
+ if ((0, objects_1.isNumber)(schema.maxItems) && node.items.length > (schema.maxItems ?? 0)) {
859
+ validationResult.problems.push({
860
+ location: { offset: node.offset, length: node.length },
861
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
862
+ message: l10n.t('Array has too many items. Expected {0} or fewer.', schema.maxItems),
863
+ source: this.getSchemaSource(schema, originalSchema),
864
+ schemaUri: this.getSchemaUri(schema, originalSchema),
865
+ });
866
+ }
867
+ }
868
+ applyUniqueItems(node, schema, originalSchema, validationResult) {
869
+ if (schema.uniqueItems === true) {
870
+ const values = (0, astNodeUtils_1.getNodeValue)(node);
871
+ const duplicates = Array.isArray(values) && values.some((v, i) => i !== values.lastIndexOf(v));
872
+ if (duplicates) {
873
+ validationResult.problems.push({
874
+ location: { offset: node.offset, length: node.length },
875
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
876
+ message: l10n.t('Array has duplicate items.'),
877
+ source: this.getSchemaSource(schema, originalSchema),
878
+ schemaUri: this.getSchemaUri(schema, originalSchema),
879
+ });
880
+ }
881
+ }
882
+ }
883
+ // ---------------- object validation ----------------
884
+ validateObjectNode(node, schema, originalSchema, validationResult, matchingSchemas, options) {
885
+ const seenKeys = Object.create(null);
886
+ const unprocessedProperties = [];
887
+ const unprocessedNodes = [...node.properties];
888
+ while (unprocessedNodes.length > 0) {
889
+ const propertyNode = unprocessedNodes.pop();
890
+ if (!propertyNode)
891
+ continue;
892
+ const key = propertyNode.keyNode.value;
893
+ // YAML merge key "<<"
894
+ if (key === '<<' && propertyNode.valueNode) {
895
+ switch (propertyNode.valueNode.type) {
896
+ case 'object':
897
+ unprocessedNodes.push(...propertyNode.valueNode.properties);
898
+ break;
899
+ case 'array':
900
+ propertyNode.valueNode.items.forEach((sequenceNode) => {
901
+ if (sequenceNode && sequenceNode.type === 'object' && (0, objects_1.isIterable)(sequenceNode.properties)) {
902
+ unprocessedNodes.push(...sequenceNode.properties);
903
+ }
904
+ });
905
+ break;
906
+ default:
907
+ break;
908
+ }
909
+ }
910
+ else {
911
+ seenKeys[key] = propertyNode.valueNode;
912
+ unprocessedProperties.push(key);
913
+ }
914
+ }
915
+ const propertyProcessed = (prop) => {
916
+ let index = unprocessedProperties.indexOf(prop);
917
+ while (index >= 0) {
918
+ unprocessedProperties.splice(index, 1);
919
+ index = unprocessedProperties.indexOf(prop);
920
+ }
921
+ };
922
+ this.applyRequired(node, schema, originalSchema, validationResult, options, seenKeys);
923
+ this.applyProperties(node, schema, originalSchema, validationResult, matchingSchemas, options, seenKeys, unprocessedProperties, propertyProcessed);
924
+ this.applyPatternProperties(node, schema, originalSchema, validationResult, matchingSchemas, options, seenKeys, unprocessedProperties, propertyProcessed);
925
+ this.applyAdditionalProperties(node, schema, originalSchema, validationResult, matchingSchemas, options, seenKeys, unprocessedProperties);
926
+ this.applyPropertyCount(node, schema, originalSchema, validationResult);
927
+ this.applyDependencies(node, schema, originalSchema, validationResult, matchingSchemas, options, seenKeys);
928
+ this.applyPropertyNames(node, schema, validationResult, options);
929
+ }
930
+ applyRequired(node, schema, originalSchema, validationResult, _options, seenKeys) {
931
+ if (Array.isArray(schema.required)) {
932
+ for (const propertyName of schema.required) {
933
+ if (seenKeys[propertyName] === undefined) {
934
+ const keyNode = node.parent && node.parent.type === 'property' && node.parent.keyNode;
935
+ const location = keyNode ? { offset: keyNode.offset, length: keyNode.length } : { offset: node.offset, length: 1 };
936
+ validationResult.problems.push({
937
+ location,
938
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
939
+ message: schema.errorMessage || getWarningMessage(ProblemType.missingRequiredPropWarning, [propertyName]),
940
+ source: this.getSchemaSource(schema, originalSchema),
941
+ schemaUri: this.getSchemaUri(schema, originalSchema),
942
+ problemArgs: [propertyName],
943
+ problemType: ProblemType.missingRequiredPropWarning,
944
+ });
945
+ }
946
+ }
947
+ }
948
+ }
949
+ applyProperties(_node, schema, originalSchema, validationResult, matchingSchemas, options, seenKeys, _unprocessedProperties, propertyProcessed) {
950
+ const { isKubernetes } = options;
951
+ const props = schema.properties;
952
+ if (!props)
953
+ return;
954
+ for (const propertyName of Object.keys(props)) {
955
+ propertyProcessed(propertyName);
956
+ const propertySchemaRef = props[propertyName];
957
+ const child = seenKeys[propertyName];
958
+ if (!child)
959
+ continue;
960
+ validationResult.evaluatedProperties ?? (validationResult.evaluatedProperties = new Set());
961
+ validationResult.evaluatedProperties.add(propertyName);
962
+ if ((0, objects_1.isBoolean)(propertySchemaRef)) {
963
+ if (!propertySchemaRef) {
964
+ const propertyNode = child.parent;
965
+ validationResult.problems.push({
966
+ location: { offset: propertyNode.keyNode.offset, length: propertyNode.keyNode.length },
967
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
968
+ message: schema.errorMessage || l10n.t('Property {0} is not allowed.', propertyName),
969
+ source: this.getSchemaSource(schema, originalSchema),
970
+ schemaUri: this.getSchemaUri(schema, originalSchema),
971
+ });
972
+ }
973
+ else {
974
+ validationResult.propertiesMatches++;
975
+ validationResult.propertiesValueMatches++;
976
+ }
977
+ }
978
+ else {
979
+ propertySchemaRef.url = schema.url ?? originalSchema.url;
980
+ const propertyValidationResult = new ValidationResult(isKubernetes);
981
+ this.validateNode(child, propertySchemaRef, schema, propertyValidationResult, matchingSchemas, options);
982
+ validationResult.mergePropertyMatch(propertyValidationResult, false);
983
+ validationResult.mergeEnumValues(propertyValidationResult);
984
+ }
985
+ }
986
+ }
987
+ applyPatternProperties(_node, schema, originalSchema, validationResult, matchingSchemas, options, seenKeys, unprocessedProperties, propertyProcessed) {
988
+ const { isKubernetes } = options;
989
+ const patternProps = schema.patternProperties;
990
+ if (!patternProps)
991
+ return;
992
+ for (const propertyPattern of Object.keys(patternProps)) {
993
+ const regex = (0, strings_1.safeCreateUnicodeRegExp)(propertyPattern);
994
+ for (const propertyName of unprocessedProperties.slice(0)) {
995
+ if (!regex.test(propertyName))
996
+ continue;
997
+ propertyProcessed(propertyName);
998
+ const child = seenKeys[propertyName];
999
+ if (!child)
1000
+ continue;
1001
+ validationResult.evaluatedProperties ?? (validationResult.evaluatedProperties = new Set());
1002
+ validationResult.evaluatedProperties.add(propertyName);
1003
+ const propertySchemaRef = patternProps[propertyPattern];
1004
+ if ((0, objects_1.isBoolean)(propertySchemaRef)) {
1005
+ if (!propertySchemaRef) {
1006
+ const propertyNode = child.parent;
1007
+ validationResult.problems.push({
1008
+ location: { offset: propertyNode.keyNode.offset, length: propertyNode.keyNode.length },
1009
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
1010
+ message: schema.errorMessage || l10n.t('Property {0} is not allowed.', propertyName),
1011
+ source: this.getSchemaSource(schema, originalSchema),
1012
+ schemaUri: this.getSchemaUri(schema, originalSchema),
1013
+ });
1014
+ }
1015
+ else {
1016
+ validationResult.propertiesMatches++;
1017
+ validationResult.propertiesValueMatches++;
1018
+ }
1019
+ }
1020
+ else {
1021
+ const propertyValidationResult = new ValidationResult(isKubernetes);
1022
+ this.validateNode(child, propertySchemaRef, schema, propertyValidationResult, matchingSchemas, options);
1023
+ validationResult.mergePropertyMatch(propertyValidationResult, false);
1024
+ validationResult.mergeEnumValues(propertyValidationResult);
1025
+ }
1026
+ }
1027
+ }
1028
+ }
1029
+ applyAdditionalProperties(_node, schema, originalSchema, validationResult, matchingSchemas, options, seenKeys, unprocessedProperties) {
1030
+ const { isKubernetes } = options;
1031
+ const additional = schema.additionalProperties;
1032
+ if (typeof additional === 'object') {
1033
+ for (const propertyName of unprocessedProperties) {
1034
+ const child = seenKeys[propertyName];
1035
+ if (!child)
1036
+ continue;
1037
+ validationResult.evaluatedProperties ?? (validationResult.evaluatedProperties = new Set());
1038
+ validationResult.evaluatedProperties.add(propertyName);
1039
+ const propertyValidationResult = new ValidationResult(isKubernetes);
1040
+ this.validateNode(child, additional, schema, propertyValidationResult, matchingSchemas, options);
1041
+ validationResult.mergePropertyMatch(propertyValidationResult, false);
1042
+ validationResult.mergeEnumValues(propertyValidationResult);
1043
+ }
1044
+ return;
1045
+ }
1046
+ if (additional === true) {
1047
+ if (unprocessedProperties.length > 0) {
1048
+ validationResult.evaluatedProperties ?? (validationResult.evaluatedProperties = new Set());
1049
+ for (const propertyName of unprocessedProperties) {
1050
+ if (seenKeys[propertyName]) {
1051
+ validationResult.evaluatedProperties.add(propertyName);
1052
+ }
1053
+ }
1054
+ }
1055
+ return;
1056
+ }
1057
+ const forbidExtra = additional === false ||
1058
+ (schema.type === 'object' && additional === undefined && options.disableAdditionalProperties === true);
1059
+ if (!forbidExtra)
1060
+ return;
1061
+ if (unprocessedProperties.length === 0)
1062
+ return;
1063
+ const possibleProperties = schema.properties &&
1064
+ Object.entries(schema.properties)
1065
+ .filter(([key, property]) => {
1066
+ if (seenKeys[key])
1067
+ return false;
1068
+ if (property && typeof property === 'object' && (property.doNotSuggest || property.deprecationMessage))
1069
+ return false;
1070
+ return true;
1071
+ })
1072
+ .map(([key]) => key);
1073
+ for (const propertyName of unprocessedProperties) {
1074
+ const child = seenKeys[propertyName];
1075
+ if (!child)
1076
+ continue;
1077
+ let propertyNode = child.type === 'property' ? child : (child.parent ?? child);
1078
+ if (propertyNode.type === 'object') {
1079
+ propertyNode = propertyNode.properties[0] ?? propertyNode;
1080
+ }
1081
+ const keyNode = propertyNode.type === 'property' ? propertyNode.keyNode : propertyNode;
1082
+ const problem = {
1083
+ location: { offset: keyNode.offset, length: keyNode.length },
1084
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
1085
+ code: vscode_json_languageservice_1.ErrorCode.PropertyExpected,
1086
+ message: schema.errorMessage || l10n.t('Property {0} is not allowed.', propertyName),
1087
+ source: this.getSchemaSource(schema, originalSchema),
1088
+ schemaUri: this.getSchemaUri(schema, originalSchema),
1089
+ };
1090
+ if (possibleProperties?.length)
1091
+ problem.data = { properties: possibleProperties };
1092
+ validationResult.problems.push(problem);
1093
+ }
1094
+ }
1095
+ applyPropertyCount(node, schema, originalSchema, validationResult) {
1096
+ if ((0, objects_1.isNumber)(schema.maxProperties) && node.properties.length > (schema.maxProperties ?? 0)) {
1097
+ validationResult.problems.push({
1098
+ location: { offset: node.offset, length: node.length },
1099
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
1100
+ message: l10n.t('Object has more properties than limit of {0}.', schema.maxProperties),
1101
+ source: this.getSchemaSource(schema, originalSchema),
1102
+ schemaUri: this.getSchemaUri(schema, originalSchema),
1103
+ });
1104
+ }
1105
+ if ((0, objects_1.isNumber)(schema.minProperties) && node.properties.length < (schema.minProperties ?? 0)) {
1106
+ validationResult.problems.push({
1107
+ location: { offset: node.offset, length: node.length },
1108
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
1109
+ message: l10n.t('Object has fewer properties than the required number of {0}', schema.minProperties),
1110
+ source: this.getSchemaSource(schema, originalSchema),
1111
+ schemaUri: this.getSchemaUri(schema, originalSchema),
1112
+ });
1113
+ }
1114
+ }
1115
+ applyDependencies(node, schema, originalSchema, validationResult, matchingSchemas, options, seenKeys) {
1116
+ // Draft-07 behavior: dependencies keyword
1117
+ const { isKubernetes } = options;
1118
+ const deps = schema.dependencies;
1119
+ if (!deps)
1120
+ return;
1121
+ for (const key of Object.keys(deps)) {
1122
+ const prop = seenKeys[key];
1123
+ if (!prop)
1124
+ continue;
1125
+ const propertyDep = deps[key];
1126
+ if (Array.isArray(propertyDep)) {
1127
+ for (const requiredProp of propertyDep) {
1128
+ if (!seenKeys[requiredProp]) {
1129
+ validationResult.problems.push({
1130
+ location: { offset: node.offset, length: node.length },
1131
+ severity: vscode_languageserver_types_1.DiagnosticSeverity.Warning,
1132
+ message: l10n.t('Object is missing property {0} required by property {1}.', requiredProp, key),
1133
+ source: this.getSchemaSource(schema, originalSchema),
1134
+ schemaUri: this.getSchemaUri(schema, originalSchema),
1135
+ });
1136
+ }
1137
+ else {
1138
+ validationResult.propertiesValueMatches++;
1139
+ }
1140
+ }
1141
+ }
1142
+ else {
1143
+ const propertySchema = asSchema(propertyDep);
1144
+ if (propertySchema) {
1145
+ const propertyValidationResult = new ValidationResult(isKubernetes);
1146
+ this.validateNode(node, propertySchema, schema, propertyValidationResult, matchingSchemas, options);
1147
+ validationResult.mergePropertyMatch(propertyValidationResult);
1148
+ validationResult.mergeEnumValues(propertyValidationResult);
1149
+ }
1150
+ }
1151
+ }
1152
+ }
1153
+ applyPropertyNames(node, schema, validationResult, options) {
1154
+ const propertyNames = asSchema(schema.propertyNames);
1155
+ if (!propertyNames)
1156
+ return;
1157
+ for (const f of node.properties) {
1158
+ const key = f.keyNode;
1159
+ if (key) {
1160
+ this.validateNode(key, propertyNames, schema, validationResult, NoOpSchemaCollector.instance, options);
1161
+ }
1162
+ }
1163
+ }
1164
+ // ---------------- unevaluated hooks (2019/2020) ----------------
1165
+ applyUnevaluatedProperties(
1166
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1167
+ _node,
1168
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1169
+ _schema,
1170
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1171
+ _originalSchema,
1172
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1173
+ _validationResult,
1174
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1175
+ _matchingSchemas,
1176
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1177
+ _options,
1178
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1179
+ _seenKeys,
1180
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1181
+ _unprocessedProperties) {
1182
+ // no-op in draft-07
1183
+ }
1184
+ applyUnevaluatedItems(
1185
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1186
+ _node,
1187
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1188
+ _schema,
1189
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1190
+ _originalSchema,
1191
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1192
+ _validationResult,
1193
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1194
+ _matchingSchemas,
1195
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1196
+ _options) {
1197
+ // no-op in draft-07
1198
+ }
1199
+ // ---------------- best-match helpers ----------------
1200
+ alternativeComparison(subValidationResult, bestMatch, subSchema, subMatchingSchemas) {
1201
+ const compareResult = subValidationResult.compareKubernetes(bestMatch.validationResult);
1202
+ if (compareResult > 0) {
1203
+ return { schema: subSchema, validationResult: subValidationResult, matchingSchemas: subMatchingSchemas };
1204
+ }
1205
+ if (compareResult === 0) {
1206
+ bestMatch.matchingSchemas.merge(subMatchingSchemas);
1207
+ bestMatch.validationResult.mergeEnumValues(subValidationResult);
1208
+ }
1209
+ return bestMatch;
1210
+ }
1211
+ genericComparison(node, maxOneMatch, subValidationResult, bestMatch, subSchema, subMatchingSchemas) {
1212
+ if (!maxOneMatch && !subValidationResult.hasProblems() && !bestMatch.validationResult.hasProblems()) {
1213
+ bestMatch.matchingSchemas.merge(subMatchingSchemas);
1214
+ bestMatch.validationResult.propertiesMatches += subValidationResult.propertiesMatches;
1215
+ bestMatch.validationResult.propertiesValueMatches += subValidationResult.propertiesValueMatches;
1216
+ }
1217
+ else {
1218
+ const compareResult = subValidationResult.compareGeneric(bestMatch.validationResult);
1219
+ if (compareResult > 0 ||
1220
+ (compareResult === 0 &&
1221
+ maxOneMatch &&
1222
+ bestMatch.schema.type === 'object' &&
1223
+ node.type !== 'null' &&
1224
+ node.type !== bestMatch.schema.type)) {
1225
+ bestMatch = { schema: subSchema, validationResult: subValidationResult, matchingSchemas: subMatchingSchemas };
1226
+ }
1227
+ else if (compareResult === 0 || ((node.value === null || node.type === 'null') && node.length === 0)) {
1228
+ this.mergeValidationMatches(bestMatch, subMatchingSchemas, subValidationResult);
1229
+ }
1230
+ }
1231
+ return bestMatch;
1232
+ }
1233
+ mergeValidationMatches(bestMatch, subMatchingSchemas, subValidationResult) {
1234
+ bestMatch.matchingSchemas.merge(subMatchingSchemas);
1235
+ bestMatch.validationResult.mergeEnumValues(subValidationResult);
1236
+ bestMatch.validationResult.mergeWarningGeneric(subValidationResult, [
1237
+ ProblemType.missingRequiredPropWarning,
1238
+ ProblemType.typeMismatchWarning,
1239
+ ProblemType.constWarning,
1240
+ ]);
1241
+ }
1242
+ }
1243
+ exports.BaseValidator = BaseValidator;
1244
+ function asSchema(schema) {
1245
+ if (schema === undefined)
1246
+ return undefined;
1247
+ if ((0, objects_1.isBoolean)(schema))
1248
+ return schema ? {} : { not: {} };
1249
+ if (typeof schema !== 'object') {
1250
+ // Keep legacy behavior: warn and coerce
1251
+ // eslint-disable-next-line no-console
1252
+ console.warn(`Wrong schema: ${JSON.stringify(schema)}, it MUST be an Object or Boolean`);
1253
+ return { type: schema };
1254
+ }
1255
+ return schema;
1256
+ }
1257
+ exports.asSchema = asSchema;
1258
+ function getWarningMessage(problemType, args) {
1259
+ return l10n.t(exports.ProblemTypeMessages[problemType], args.join(' | '));
1260
+ }
1261
+ function isAutoCompleteEqualMaybe(callFromAutoComplete, node, nodeValue, schemaValue) {
1262
+ if (!callFromAutoComplete)
1263
+ return false;
1264
+ const isWithoutValue = nodeValue === null && node.length === 0; // allows `prop: ` but ignore `prop: null`
1265
+ if (isWithoutValue)
1266
+ return true;
1267
+ return (0, objects_1.isString)(nodeValue) && (0, objects_1.isString)(schemaValue) && schemaValue.startsWith(nodeValue);
1268
+ }
1269
+ });
1270
+ //# sourceMappingURL=baseValidator.js.map