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