@sitevision/api 2023.2.1 → 2023.2.2-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (936) hide show
  1. package/common/router/index.js +1 -0
  2. package/package.json +5 -5
  3. package/server/AliasUtil/index.d.ts +6 -5
  4. package/server/ArchiveUtil/index.d.ts +24 -23
  5. package/server/ArraysInstance/index.d.ts +302 -246
  6. package/server/ArticleUtil/index.d.ts +181 -179
  7. package/server/AuthenticationUtil/index.d.ts +22 -11
  8. package/server/BookmarkUtil/index.d.ts +18 -16
  9. package/server/BuddyIconRenderer/index.d.ts +86 -85
  10. package/server/BuddyIconRenderer.BuddyIconSize/index.d.ts +15 -15
  11. package/server/BuddyIconRenderer.BuddyIconSize/index.js +16 -16
  12. package/server/ClientUtil/index.d.ts +10 -8
  13. package/server/CollaborationFactory/index.d.ts +6 -6
  14. package/server/CollaborationGroupFolderUtil/index.d.ts +12 -11
  15. package/server/CollaborationGroupState/index.d.ts +15 -15
  16. package/server/CollaborationGroupState/index.js +2 -2
  17. package/server/CollaborationGroupTemplateUtil/index.d.ts +26 -24
  18. package/server/CollaborationGroupType/index.d.ts +15 -15
  19. package/server/CollaborationGroupType/index.js +3 -3
  20. package/server/CollaborationGroupUtil/index.d.ts +52 -52
  21. package/server/CollectionsInstance/index.d.ts +145 -105
  22. package/server/ColorUtil/index.d.ts +12 -8
  23. package/server/CompoundAndFilterBuilder/index.d.ts +21 -21
  24. package/server/CompoundComparatorBuilder/index.d.ts +22 -21
  25. package/server/CompoundOrFilterBuilder/index.d.ts +20 -20
  26. package/server/ContentNodeUtil/index.d.ts +30 -30
  27. package/server/CurrencyFactory/index.d.ts +55 -53
  28. package/server/DateUtil/index.d.ts +55 -47
  29. package/server/DecorationUtil/index.d.ts +6 -5
  30. package/server/DeviceUtil/index.d.ts +8 -8
  31. package/server/DimensionMode/index.d.ts +4 -4
  32. package/server/DimensionMode/index.js +3 -3
  33. package/server/DirectoryUtil/index.d.ts +40 -37
  34. package/server/DocType/index.d.ts +15 -15
  35. package/server/DocType/index.js +5 -5
  36. package/server/DocTypeUtil/index.d.ts +4 -4
  37. package/server/EndecUtil/index.d.ts +222 -214
  38. package/server/ExtendedDismaxParserBuilder/index.d.ts +127 -125
  39. package/server/FileIconRenderer/index.d.ts +167 -163
  40. package/server/FileUtil/index.d.ts +157 -150
  41. package/server/FilterBuilder/index.d.ts +67 -66
  42. package/server/FolderUtil/index.d.ts +51 -50
  43. package/server/FontUtil/index.d.ts +9 -8
  44. package/server/FormatterBuilderFactory/index.d.ts +35 -34
  45. package/server/HighlightBuilder/index.d.ts +93 -91
  46. package/server/IconUtil/index.d.ts +8 -7
  47. package/server/ImageLinkRenderer/index.d.ts +79 -78
  48. package/server/ImageRenderer/index.d.ts +327 -218
  49. package/server/ImageRenderer/index.js +6 -0
  50. package/server/ImageUtil/index.d.ts +155 -148
  51. package/server/IndexUtil/index.d.ts +24 -23
  52. package/server/IndexUtil.IndexType/index.d.ts +15 -15
  53. package/server/IndexUtil.IndexType/index.js +4 -4
  54. package/server/IndexingUtil/index.d.ts +38 -38
  55. package/server/InstanceCreatorUtil/index.d.ts +192 -183
  56. package/server/InstanceTypeUtil/index.d.ts +7 -5
  57. package/server/JwtUtil/index.d.ts +79 -78
  58. package/server/LandingPageUtil/index.d.ts +5 -5
  59. package/server/LinkPageUtil/index.d.ts +211 -206
  60. package/server/LinkRenderer/index.d.ts +428 -419
  61. package/server/LinkTargetBuilder/index.d.ts +61 -60
  62. package/server/LinkValueBuilder/index.d.ts +59 -58
  63. package/server/ListWrapper/index.d.ts +73 -67
  64. package/server/LocaleUtil/index.d.ts +328 -324
  65. package/server/LogUtil/index.d.ts +30 -26
  66. package/server/MailBuilder/index.d.ts +112 -109
  67. package/server/MailUtil/index.d.ts +23 -22
  68. package/server/MathInstance/index.d.ts +28 -28
  69. package/server/MessageDigesterFactory/index.d.ts +11 -11
  70. package/server/MetadataDefinitionUtil/index.d.ts +53 -51
  71. package/server/MetadataUtil/index.d.ts +197 -181
  72. package/server/MimeTypeUtil/index.d.ts +117 -112
  73. package/server/MonitorBuilder/index.d.ts +21 -21
  74. package/server/NodeComparatorUtil/index.d.ts +172 -164
  75. package/server/NodeFactoryUtil/index.d.ts +5 -5
  76. package/server/NodeFilterUtil/index.d.ts +290 -256
  77. package/server/NodeIteratorUtil/index.d.ts +113 -110
  78. package/server/NodeResolverUtil/index.d.ts +324 -324
  79. package/server/NodeTreeUtil/index.d.ts +132 -130
  80. package/server/NodeTypeUtil/index.d.ts +71 -70
  81. package/server/OfflineVersionPropertyUtil/index.d.ts +16 -18
  82. package/server/OnlineVersionPropertyUtil/index.d.ts +16 -18
  83. package/server/OutputUtil/index.d.ts +240 -231
  84. package/server/PageUtil/index.d.ts +145 -143
  85. package/server/PermissionUtil/index.d.ts +200 -200
  86. package/server/PermissionUtil.Permission/index.d.ts +15 -15
  87. package/server/PermissionUtil.Permission/index.js +29 -29
  88. package/server/PortletContextUtil/index.d.ts +35 -33
  89. package/server/PortletUtil/index.d.ts +9 -9
  90. package/server/PrincipalUtil/index.d.ts +15 -11
  91. package/server/Properties/index.d.ts +113 -104
  92. package/server/PropertyUtil/index.d.ts +1018 -995
  93. package/server/PublishingUtil/index.d.ts +140 -142
  94. package/server/QueryStringUtil/index.d.ts +333 -319
  95. package/server/RedirectUtil/index.d.ts +32 -28
  96. package/server/RelatedValueBuilder/index.d.ts +40 -40
  97. package/server/Requester/index.d.ts +303 -302
  98. package/server/ResourceLocatorUtil/index.d.ts +101 -99
  99. package/server/RestApi/index.d.ts +82 -81
  100. package/server/RestAppInvokerFactory/index.d.ts +34 -33
  101. package/server/RoleAssignmentBuilder/index.d.ts +12 -12
  102. package/server/RoleMatcherBuilder/index.d.ts +12 -12
  103. package/server/RoleUtil/index.d.ts +6 -6
  104. package/server/ScriptUtil/index.d.ts +226 -208
  105. package/server/SearchFactory/index.d.ts +11 -6
  106. package/server/SearchUtil/index.d.ts +84 -81
  107. package/server/SearcherBuilder/index.d.ts +111 -111
  108. package/server/Session/index.d.ts +123 -120
  109. package/server/SimpleUserUtil/index.d.ts +22 -17
  110. package/server/SiteCookieUtil/index.d.ts +24 -22
  111. package/server/SortBuilder/index.d.ts +70 -69
  112. package/server/SourceSetMode/index.js +3 -3
  113. package/server/SpellCheckBuilder/index.d.ts +31 -28
  114. package/server/StandardParserBuilder/index.d.ts +65 -64
  115. package/server/StructureUtil/index.d.ts +149 -67
  116. package/server/SubscriberUtil/index.d.ts +54 -43
  117. package/server/SubscriptionUtil/index.d.ts +64 -62
  118. package/server/SystemUserUtil/index.d.ts +75 -75
  119. package/server/TagUtil/index.d.ts +66 -63
  120. package/server/TemplateUtil/index.d.ts +89 -85
  121. package/server/TemporaryFileNodeBuilder/index.d.ts +25 -23
  122. package/server/TemporaryNodeBuilder/index.d.ts +74 -54
  123. package/server/TextModuleRendererBuilder/index.d.ts +37 -37
  124. package/server/TimestampUtil/index.d.ts +32 -21
  125. package/server/TranslationUtil/index.d.ts +63 -60
  126. package/server/TrashcanUtil/index.d.ts +76 -75
  127. package/server/UserDataUtil/index.d.ts +76 -70
  128. package/server/UserFactory/index.d.ts +5 -5
  129. package/server/UserFieldRenderer/index.d.ts +116 -114
  130. package/server/UserIdentityUtil/index.d.ts +26 -26
  131. package/server/UserUtil/index.d.ts +36 -36
  132. package/server/Utils/index.d.ts +83 -83
  133. package/server/VelocityRenderer/index.d.ts +141 -138
  134. package/server/VersionUtil/index.d.ts +5 -5
  135. package/server/WebContentUtil/index.d.ts +320 -317
  136. package/server/WebResourceFactory/index.d.ts +5 -5
  137. package/server/XSLTUtil/index.d.ts +35 -32
  138. package/server/XmlParserUtil/index.d.ts +61 -60
  139. package/server/appResource/index.d.ts +1 -1
  140. package/types/java/io/Closeable/index.d.ts +23 -0
  141. package/types/{senselogic/sitevision/api/base/Requireable/ScriptEngine → java/io/Closeable}/index.js +1 -2
  142. package/types/java/io/File/index.d.ts +1023 -0
  143. package/types/java/io/File/index.js +52 -0
  144. package/types/java/io/FileFilter/index.d.ts +19 -0
  145. package/types/java/io/FileFilter/index.js +10 -0
  146. package/types/java/io/FilenameFilter/index.d.ts +25 -0
  147. package/types/java/io/FilenameFilter/index.js +10 -0
  148. package/types/java/io/FilterOutputStream/index.d.ts +93 -0
  149. package/types/java/io/FilterOutputStream/index.js +12 -0
  150. package/types/java/io/Flushable/index.d.ts +14 -0
  151. package/types/java/io/Flushable/index.js +10 -0
  152. package/types/java/io/InputStream/index.d.ts +255 -0
  153. package/types/java/io/InputStream/index.js +16 -0
  154. package/types/java/io/OutputStream/index.d.ts +106 -0
  155. package/types/java/io/OutputStream/index.js +12 -0
  156. package/types/java/io/PrintStream/index.d.ts +408 -0
  157. package/types/java/io/PrintStream/index.js +20 -0
  158. package/types/java/io/PrintWriter/index.d.ts +401 -0
  159. package/types/java/io/PrintWriter/index.js +20 -0
  160. package/types/java/io/Reader/index.d.ts +125 -0
  161. package/types/java/io/Reader/index.js +16 -0
  162. package/types/java/io/Serializable/index.d.ts +141 -0
  163. package/types/java/io/Serializable/index.js +8 -0
  164. package/types/java/io/Writer/index.d.ts +154 -0
  165. package/types/java/io/Writer/index.js +13 -0
  166. package/types/java/lang/Appendable/index.d.ts +63 -0
  167. package/types/java/lang/Appendable/index.js +10 -0
  168. package/types/java/lang/AutoCloseable/index.d.ts +59 -0
  169. package/types/java/lang/AutoCloseable/index.js +10 -0
  170. package/types/java/lang/Boolean/index.d.ts +208 -0
  171. package/types/java/lang/Boolean/index.js +21 -0
  172. package/types/java/lang/CharSequence/index.d.ts +97 -0
  173. package/types/java/lang/CharSequence/index.js +15 -0
  174. package/types/java/lang/Class/index.d.ts +1320 -0
  175. package/types/java/lang/Class/index.js +72 -0
  176. package/types/java/lang/ClassLoader/index.d.ts +710 -0
  177. package/types/java/lang/ClassLoader/index.js +36 -0
  178. package/types/java/lang/Cloneable/index.d.ts +25 -0
  179. package/types/java/lang/Cloneable/index.js +8 -0
  180. package/types/java/lang/Comparable/index.d.ts +103 -0
  181. package/types/java/lang/Comparable/index.js +10 -0
  182. package/types/java/lang/Double/index.d.ts +814 -0
  183. package/types/java/lang/Double/index.js +32 -0
  184. package/types/java/lang/Enum/index.d.ts +141 -0
  185. package/types/java/lang/Enum/index.js +19 -0
  186. package/types/java/lang/Exception/index.d.ts +19 -0
  187. package/types/java/lang/Exception/index.js +8 -0
  188. package/types/java/lang/Float/index.d.ts +752 -0
  189. package/types/java/lang/Float/index.js +32 -0
  190. package/types/java/lang/Integer/index.d.ts +922 -0
  191. package/types/java/lang/Integer/index.js +46 -0
  192. package/types/java/lang/Iterable/index.d.ts +46 -0
  193. package/types/java/lang/Iterable/index.js +12 -0
  194. package/types/java/lang/Long/index.d.ts +936 -0
  195. package/types/java/lang/Long/index.js +45 -0
  196. package/types/java/lang/Number/index.d.ts +81 -0
  197. package/types/java/lang/Number/index.js +15 -0
  198. package/types/java/lang/Object/index.d.ts +467 -0
  199. package/types/java/lang/Object/index.js +18 -0
  200. package/types/java/lang/Package/index.d.ts +216 -0
  201. package/types/java/lang/Package/index.js +29 -0
  202. package/types/java/lang/Readable/index.d.ts +20 -0
  203. package/types/java/lang/Readable/index.js +10 -0
  204. package/types/java/lang/Runnable/index.d.ts +39 -0
  205. package/types/java/lang/Runnable/index.js +10 -0
  206. package/types/java/lang/RuntimeException/index.d.ts +17 -0
  207. package/types/java/lang/RuntimeException/index.js +8 -0
  208. package/types/java/lang/StackTraceElement/index.d.ts +116 -0
  209. package/types/java/lang/StackTraceElement/index.js +17 -0
  210. package/types/java/lang/String/index.d.ts +1427 -0
  211. package/types/java/lang/String/index.js +48 -0
  212. package/types/java/lang/StringBuffer/index.d.ts +232 -0
  213. package/types/java/lang/StringBuffer/index.js +33 -0
  214. package/types/java/lang/Throwable/index.d.ts +462 -0
  215. package/types/java/lang/Throwable/index.js +20 -0
  216. package/types/java/lang/annotation/Annotation/index.d.ts +109 -0
  217. package/types/java/lang/annotation/Annotation/index.js +13 -0
  218. package/types/java/lang/reflect/AccessibleObject/index.d.ts +106 -0
  219. package/types/java/lang/reflect/AccessibleObject/index.js +18 -0
  220. package/types/java/lang/reflect/AnnotatedElement/index.d.ts +322 -0
  221. package/types/java/lang/reflect/AnnotatedElement/index.js +16 -0
  222. package/types/java/lang/reflect/AnnotatedType/index.d.ts +17 -0
  223. package/types/java/lang/reflect/AnnotatedType/index.js +10 -0
  224. package/types/java/lang/reflect/Constructor/index.d.ts +236 -0
  225. package/types/java/lang/reflect/Constructor/index.js +30 -0
  226. package/types/java/lang/reflect/Executable/index.d.ts +255 -0
  227. package/types/java/lang/reflect/Executable/index.js +30 -0
  228. package/types/java/lang/reflect/Field/index.d.ts +506 -0
  229. package/types/java/lang/reflect/Field/index.js +42 -0
  230. package/types/java/lang/reflect/GenericDeclaration/index.d.ts +19 -0
  231. package/types/java/lang/reflect/GenericDeclaration/index.js +10 -0
  232. package/types/java/lang/reflect/Member/index.d.ts +60 -0
  233. package/types/java/lang/reflect/Member/index.js +13 -0
  234. package/types/java/lang/reflect/Method/index.d.ts +308 -0
  235. package/types/java/lang/reflect/Method/index.js +34 -0
  236. package/types/java/lang/reflect/Parameter/index.d.ts +155 -0
  237. package/types/java/lang/reflect/Parameter/index.js +28 -0
  238. package/types/java/lang/reflect/Type/index.d.ts +18 -0
  239. package/types/java/lang/reflect/Type/index.js +10 -0
  240. package/types/java/lang/reflect/TypeVariable/index.d.ts +70 -0
  241. package/types/java/lang/reflect/TypeVariable/index.js +13 -0
  242. package/types/java/math/BigDecimal/index.d.ts +1317 -0
  243. package/types/java/math/BigDecimal/index.js +50 -0
  244. package/types/java/math/BigInteger/index.d.ts +592 -0
  245. package/types/java/math/BigInteger/index.js +56 -0
  246. package/types/java/math/MathContext/index.d.ts +136 -0
  247. package/types/java/math/MathContext/index.js +14 -0
  248. package/types/java/math/RoundingMode/index.d.ts +71 -0
  249. package/types/java/math/RoundingMode/index.js +17 -0
  250. package/types/java/net/ContentHandler/index.d.ts +70 -0
  251. package/types/java/net/ContentHandler/index.js +10 -0
  252. package/types/java/net/ContentHandlerFactory/index.d.ts +26 -0
  253. package/types/java/net/ContentHandlerFactory/index.js +10 -0
  254. package/types/java/net/FileNameMap/index.d.ts +16 -0
  255. package/types/java/net/FileNameMap/index.js +10 -0
  256. package/types/java/net/InetAddress/index.d.ts +490 -0
  257. package/types/java/net/InetAddress/index.js +32 -0
  258. package/types/java/net/NetworkInterface/index.d.ts +222 -0
  259. package/types/java/net/NetworkInterface/index.js +30 -0
  260. package/types/java/net/Proxy/index.d.ts +68 -0
  261. package/types/java/net/Proxy/index.js +14 -0
  262. package/types/java/net/Proxy.Type/index.d.ts +9 -0
  263. package/types/java/net/Proxy.Type/index.js +12 -0
  264. package/types/java/net/SocketAddress/index.d.ts +15 -0
  265. package/types/java/net/SocketAddress/index.js +8 -0
  266. package/types/java/net/URI/index.d.ts +956 -0
  267. package/types/java/net/URI/index.js +37 -0
  268. package/types/java/net/URL/index.d.ts +378 -0
  269. package/types/java/net/URL/index.js +29 -0
  270. package/types/java/net/URLConnection/index.d.ts +773 -0
  271. package/types/java/net/URLConnection/index.js +58 -0
  272. package/types/java/net/URLStreamHandler/index.d.ts +199 -0
  273. package/types/java/net/URLStreamHandler/index.js +19 -0
  274. package/types/java/net/URLStreamHandlerFactory/index.d.ts +24 -0
  275. package/types/java/net/URLStreamHandlerFactory/index.js +10 -0
  276. package/types/java/nio/MappedByteBuffer/index.d.ts +80 -0
  277. package/types/java/nio/MappedByteBuffer/index.js +12 -0
  278. package/types/java/nio/channels/AsynchronousChannel/index.d.ts +82 -0
  279. package/types/java/nio/channels/AsynchronousChannel/index.js +10 -0
  280. package/types/java/nio/channels/AsynchronousFileChannel/index.d.ts +546 -0
  281. package/types/java/nio/channels/AsynchronousFileChannel/index.js +17 -0
  282. package/types/java/nio/channels/ByteChannel/index.d.ts +12 -0
  283. package/types/java/nio/channels/ByteChannel/index.js +8 -0
  284. package/types/java/nio/channels/Channel/index.d.ts +48 -0
  285. package/types/java/nio/channels/Channel/index.js +11 -0
  286. package/types/java/nio/channels/CompletionHandler/index.d.ts +31 -0
  287. package/types/java/nio/channels/CompletionHandler/index.js +11 -0
  288. package/types/java/nio/channels/FileChannel/index.d.ts +756 -0
  289. package/types/java/nio/channels/FileChannel/index.js +21 -0
  290. package/types/java/nio/channels/FileChannel.MapMode/index.d.ts +33 -0
  291. package/types/java/nio/channels/FileChannel.MapMode/index.js +10 -0
  292. package/types/java/nio/channels/FileLock/index.d.ts +180 -0
  293. package/types/java/nio/channels/FileLock/index.js +19 -0
  294. package/types/java/nio/channels/GatheringByteChannel/index.d.ts +83 -0
  295. package/types/java/nio/channels/GatheringByteChannel/index.js +10 -0
  296. package/types/java/nio/channels/InterruptibleChannel/index.d.ts +43 -0
  297. package/types/java/nio/channels/InterruptibleChannel/index.js +10 -0
  298. package/types/java/nio/channels/ReadableByteChannel/index.d.ts +56 -0
  299. package/types/java/nio/channels/ReadableByteChannel/index.js +10 -0
  300. package/types/java/nio/channels/ScatteringByteChannel/index.d.ts +78 -0
  301. package/types/java/nio/channels/ScatteringByteChannel/index.js +10 -0
  302. package/types/java/nio/channels/SeekableByteChannel/index.d.ts +110 -0
  303. package/types/java/nio/channels/SeekableByteChannel/index.js +14 -0
  304. package/types/java/nio/channels/WritableByteChannel/index.d.ts +52 -0
  305. package/types/java/nio/channels/WritableByteChannel/index.js +10 -0
  306. package/types/java/nio/channels/spi/AbstractInterruptibleChannel/index.d.ts +104 -0
  307. package/types/java/nio/channels/spi/AbstractInterruptibleChannel/index.js +14 -0
  308. package/types/java/nio/charset/Charset/index.d.ts +472 -0
  309. package/types/java/nio/charset/Charset/index.js +27 -0
  310. package/types/java/nio/file/AccessMode/index.d.ts +9 -0
  311. package/types/java/nio/file/AccessMode/index.js +12 -0
  312. package/types/java/nio/file/CopyOption/index.d.ts +15 -0
  313. package/types/java/nio/file/CopyOption/index.js +8 -0
  314. package/types/java/nio/file/DirectoryStream/index.d.ts +97 -0
  315. package/types/java/nio/file/DirectoryStream/index.js +10 -0
  316. package/types/java/nio/file/DirectoryStream.Filter/index.d.ts +18 -0
  317. package/types/java/nio/file/DirectoryStream.Filter/index.js +10 -0
  318. package/types/java/nio/file/FileStore/index.d.ts +154 -0
  319. package/types/java/nio/file/FileStore/index.js +18 -0
  320. package/types/java/nio/file/FileSystem/index.d.ts +402 -0
  321. package/types/java/nio/file/FileSystem/index.js +21 -0
  322. package/types/java/nio/file/LinkOption/index.d.ts +7 -0
  323. package/types/java/nio/file/LinkOption/index.js +10 -0
  324. package/types/java/nio/file/OpenOption/index.d.ts +15 -0
  325. package/types/java/nio/file/OpenOption/index.js +8 -0
  326. package/types/java/nio/file/Path/index.d.ts +617 -0
  327. package/types/java/nio/file/Path/index.js +33 -0
  328. package/types/java/nio/file/PathMatcher/index.d.ts +17 -0
  329. package/types/java/nio/file/PathMatcher/index.js +10 -0
  330. package/types/java/nio/file/WatchEvent.Kind/index.d.ts +21 -0
  331. package/types/java/nio/file/WatchEvent.Kind/index.js +11 -0
  332. package/types/java/nio/file/WatchEvent.Modifier/index.d.ts +17 -0
  333. package/types/java/nio/file/WatchEvent.Modifier/index.js +10 -0
  334. package/types/java/nio/file/WatchKey/index.d.ts +117 -0
  335. package/types/java/nio/file/WatchKey/index.js +14 -0
  336. package/types/java/nio/file/WatchService/index.d.ts +121 -0
  337. package/types/java/nio/file/WatchService/index.js +12 -0
  338. package/types/java/nio/file/Watchable/index.d.ts +71 -0
  339. package/types/java/nio/file/Watchable/index.js +10 -0
  340. package/types/java/nio/file/attribute/FileAttribute/index.d.ts +24 -0
  341. package/types/java/nio/file/attribute/FileAttribute/index.js +11 -0
  342. package/types/java/nio/file/attribute/GroupPrincipal/index.d.ts +14 -0
  343. package/types/java/nio/file/attribute/GroupPrincipal/index.js +8 -0
  344. package/types/java/nio/file/attribute/UserPrincipal/index.d.ts +25 -0
  345. package/types/java/nio/file/attribute/UserPrincipal/index.js +8 -0
  346. package/types/java/nio/file/attribute/UserPrincipalLookupService/index.d.ts +52 -0
  347. package/types/java/nio/file/attribute/UserPrincipalLookupService/index.js +11 -0
  348. package/types/java/nio/file/spi/FileSystemProvider/index.d.ts +583 -0
  349. package/types/java/nio/file/spi/FileSystemProvider/index.js +35 -0
  350. package/types/java/security/CodeSigner/index.d.ts +52 -0
  351. package/types/java/security/CodeSigner/index.js +14 -0
  352. package/types/java/security/CodeSource/index.d.ts +143 -0
  353. package/types/java/security/CodeSource/index.js +16 -0
  354. package/types/java/security/Guard/index.d.ts +24 -0
  355. package/types/java/security/Guard/index.js +10 -0
  356. package/types/java/security/Key/index.d.ts +120 -0
  357. package/types/java/security/Key/index.js +12 -0
  358. package/types/java/security/Permission/index.d.ts +153 -0
  359. package/types/java/security/Permission/index.js +17 -0
  360. package/types/java/security/PermissionCollection/index.d.ts +132 -0
  361. package/types/java/security/PermissionCollection/index.js +15 -0
  362. package/types/java/security/Principal/index.d.ts +54 -0
  363. package/types/java/security/Principal/index.js +14 -0
  364. package/types/java/security/PrivilegedExceptionAction/index.d.ts +24 -0
  365. package/types/java/security/PrivilegedExceptionAction/index.js +10 -0
  366. package/types/java/security/ProtectionDomain/index.d.ts +88 -0
  367. package/types/java/security/ProtectionDomain/index.js +15 -0
  368. package/types/java/security/Provider/index.d.ts +383 -0
  369. package/types/java/security/Provider/index.js +38 -0
  370. package/types/java/security/Provider.Service/index.d.ts +116 -0
  371. package/types/java/security/Provider.Service/index.js +17 -0
  372. package/types/java/security/PublicKey/index.d.ts +25 -0
  373. package/types/java/security/PublicKey/index.js +8 -0
  374. package/types/java/security/Timestamp/index.d.ts +53 -0
  375. package/types/java/security/Timestamp/index.js +14 -0
  376. package/types/java/security/cert/CertPath/index.d.ts +181 -0
  377. package/types/java/security/cert/CertPath/index.js +17 -0
  378. package/types/java/security/cert/Certificate/index.d.ts +133 -0
  379. package/types/java/security/cert/Certificate/index.js +17 -0
  380. package/types/java/text/AttributedCharacterIterator/index.d.ts +127 -0
  381. package/types/java/text/AttributedCharacterIterator/index.js +14 -0
  382. package/types/java/text/AttributedCharacterIterator.Attribute/index.d.ts +76 -0
  383. package/types/java/text/AttributedCharacterIterator.Attribute/index.js +14 -0
  384. package/types/java/text/CharacterIterator/index.d.ts +144 -0
  385. package/types/java/text/CharacterIterator/index.js +19 -0
  386. package/types/java/text/DateFormat/index.d.ts +600 -0
  387. package/types/java/text/DateFormat/index.js +28 -0
  388. package/types/java/text/DateFormatSymbols/index.d.ts +290 -0
  389. package/types/java/text/DateFormatSymbols/index.js +30 -0
  390. package/types/java/text/FieldPosition/index.d.ts +98 -0
  391. package/types/java/text/FieldPosition/index.js +18 -0
  392. package/types/java/text/Format/index.d.ts +190 -0
  393. package/types/java/text/Format/index.js +13 -0
  394. package/types/java/text/Format.Field/index.d.ts +10 -0
  395. package/types/java/text/Format.Field/index.js +8 -0
  396. package/types/java/text/NumberFormat/index.d.ts +586 -0
  397. package/types/java/text/NumberFormat/index.js +37 -0
  398. package/types/java/text/ParsePosition/index.d.ts +67 -0
  399. package/types/java/text/ParsePosition/index.js +16 -0
  400. package/types/java/text/SimpleDateFormat/index.d.ts +521 -0
  401. package/types/java/text/SimpleDateFormat/index.js +23 -0
  402. package/types/java/time/Clock/index.d.ts +272 -0
  403. package/types/java/time/Clock/index.js +23 -0
  404. package/types/java/time/DayOfWeek/index.d.ts +34 -0
  405. package/types/java/time/DayOfWeek/index.js +16 -0
  406. package/types/java/time/Duration/index.d.ts +729 -0
  407. package/types/java/time/Duration/index.js +56 -0
  408. package/types/java/time/Instant/index.d.ts +877 -0
  409. package/types/java/time/Instant/index.js +42 -0
  410. package/types/java/time/LocalDate/index.d.ts +1306 -0
  411. package/types/java/time/LocalDate/index.js +59 -0
  412. package/types/java/time/LocalDateTime/index.d.ts +1394 -0
  413. package/types/java/time/LocalDateTime/index.js +72 -0
  414. package/types/java/time/LocalTime/index.d.ts +966 -0
  415. package/types/java/time/LocalTime/index.js +53 -0
  416. package/types/java/time/Month/index.d.ts +35 -0
  417. package/types/java/time/Month/index.js +21 -0
  418. package/types/java/time/OffsetDateTime/index.d.ts +1384 -0
  419. package/types/java/time/OffsetDateTime/index.js +80 -0
  420. package/types/java/time/OffsetTime/index.d.ts +960 -0
  421. package/types/java/time/OffsetTime/index.js +54 -0
  422. package/types/java/time/Period/index.d.ts +602 -0
  423. package/types/java/time/Period/index.js +45 -0
  424. package/types/java/time/ZoneId/index.d.ts +343 -0
  425. package/types/java/time/ZoneId/index.js +21 -0
  426. package/types/java/time/ZoneOffset/index.d.ts +384 -0
  427. package/types/java/time/ZoneOffset/index.js +28 -0
  428. package/types/java/time/ZonedDateTime/index.d.ts +1580 -0
  429. package/types/java/time/ZonedDateTime/index.js +75 -0
  430. package/types/java/time/chrono/AbstractChronology/index.d.ts +153 -0
  431. package/types/java/time/chrono/AbstractChronology/index.js +14 -0
  432. package/types/java/time/chrono/ChronoLocalDate/index.d.ts +593 -0
  433. package/types/java/time/chrono/ChronoLocalDate/index.js +33 -0
  434. package/types/java/time/chrono/ChronoLocalDateTime/index.d.ts +409 -0
  435. package/types/java/time/chrono/ChronoLocalDateTime/index.js +31 -0
  436. package/types/java/time/chrono/ChronoPeriod/index.d.ts +246 -0
  437. package/types/java/time/chrono/ChronoPeriod/index.js +25 -0
  438. package/types/java/time/chrono/ChronoZonedDateTime/index.d.ts +439 -0
  439. package/types/java/time/chrono/ChronoZonedDateTime/index.js +39 -0
  440. package/types/java/time/chrono/Chronology/index.d.ts +556 -0
  441. package/types/java/time/chrono/Chronology/index.js +33 -0
  442. package/types/java/time/chrono/Era/index.d.ts +202 -0
  443. package/types/java/time/chrono/Era/index.js +17 -0
  444. package/types/java/time/chrono/IsoChronology/index.d.ts +345 -0
  445. package/types/java/time/chrono/IsoChronology/index.js +24 -0
  446. package/types/java/time/chrono/IsoEra/index.d.ts +40 -0
  447. package/types/java/time/chrono/IsoEra/index.js +11 -0
  448. package/types/java/time/format/DateTimeFormatter/index.d.ts +1478 -0
  449. package/types/java/time/format/DateTimeFormatter/index.js +34 -0
  450. package/types/java/time/format/DecimalStyle/index.d.ts +150 -0
  451. package/types/java/time/format/DecimalStyle/index.js +23 -0
  452. package/types/java/time/format/FormatStyle/index.d.ts +14 -0
  453. package/types/java/time/format/FormatStyle/index.js +13 -0
  454. package/types/java/time/format/ResolverStyle/index.d.ts +15 -0
  455. package/types/java/time/format/ResolverStyle/index.js +12 -0
  456. package/types/java/time/format/TextStyle/index.d.ts +26 -0
  457. package/types/java/time/format/TextStyle/index.js +15 -0
  458. package/types/java/time/temporal/ChronoField/index.d.ts +45 -0
  459. package/types/java/time/temporal/ChronoField/index.js +39 -0
  460. package/types/java/time/temporal/Temporal/index.d.ts +259 -0
  461. package/types/java/time/temporal/Temporal/index.js +14 -0
  462. package/types/java/time/temporal/TemporalAccessor/index.d.ts +126 -0
  463. package/types/java/time/temporal/TemporalAccessor/index.js +14 -0
  464. package/types/java/time/temporal/TemporalAdjuster/index.d.ts +64 -0
  465. package/types/java/time/temporal/TemporalAdjuster/index.js +10 -0
  466. package/types/java/time/temporal/TemporalAmount/index.d.ts +105 -0
  467. package/types/java/time/temporal/TemporalAmount/index.js +13 -0
  468. package/types/java/time/temporal/TemporalField/index.d.ts +257 -0
  469. package/types/java/time/temporal/TemporalField/index.js +21 -0
  470. package/types/java/time/temporal/TemporalQuery/index.d.ts +60 -0
  471. package/types/java/time/temporal/TemporalQuery/index.js +10 -0
  472. package/types/java/time/temporal/TemporalUnit/index.d.ts +182 -0
  473. package/types/java/time/temporal/TemporalUnit/index.js +17 -0
  474. package/types/java/time/temporal/ValueRange/index.d.ts +198 -0
  475. package/types/java/time/temporal/ValueRange/index.js +23 -0
  476. package/types/java/time/zone/ZoneOffsetTransition/index.d.ts +178 -0
  477. package/types/java/time/zone/ZoneOffsetTransition/index.js +24 -0
  478. package/types/java/time/zone/ZoneRules/index.d.ts +321 -0
  479. package/types/java/time/zone/ZoneRules/index.js +25 -0
  480. package/types/java/util/AbstractCollection/index.d.ts +250 -0
  481. package/types/java/util/AbstractCollection/index.js +22 -0
  482. package/types/java/util/AbstractList/index.d.ts +313 -0
  483. package/types/java/util/AbstractList/index.js +23 -0
  484. package/types/java/util/ArrayList/index.d.ts +403 -0
  485. package/types/java/util/ArrayList/index.js +35 -0
  486. package/types/java/util/Calendar/index.d.ts +1495 -0
  487. package/types/java/util/Calendar/index.js +55 -0
  488. package/types/java/util/Collection/index.d.ts +436 -0
  489. package/types/java/util/Collection/index.js +27 -0
  490. package/types/java/util/Comparator/index.d.ts +369 -0
  491. package/types/java/util/Comparator/index.js +24 -0
  492. package/types/java/util/Currency/index.d.ts +173 -0
  493. package/types/java/util/Currency/index.js +17 -0
  494. package/types/java/util/Date/index.d.ts +609 -0
  495. package/types/java/util/Date/index.js +38 -0
  496. package/types/java/util/Deque/index.d.ts +467 -0
  497. package/types/java/util/Deque/index.js +35 -0
  498. package/types/java/util/Dictionary/index.d.ts +107 -0
  499. package/types/java/util/Dictionary/index.js +16 -0
  500. package/types/java/util/DoubleSummaryStatistics/index.d.ts +121 -0
  501. package/types/java/util/DoubleSummaryStatistics/index.js +17 -0
  502. package/types/java/util/Enumeration/index.d.ts +46 -0
  503. package/types/java/util/Enumeration/index.js +11 -0
  504. package/types/java/util/Hashtable/index.d.ts +356 -0
  505. package/types/java/util/Hashtable/index.js +38 -0
  506. package/types/java/util/IntSummaryStatistics/index.d.ts +82 -0
  507. package/types/java/util/IntSummaryStatistics/index.js +17 -0
  508. package/types/java/util/Iterator/index.d.ts +65 -0
  509. package/types/java/util/Iterator/index.js +13 -0
  510. package/types/java/util/List/index.d.ts +503 -0
  511. package/types/java/util/List/index.js +32 -0
  512. package/types/java/util/ListIterator/index.d.ts +134 -0
  513. package/types/java/util/ListIterator/index.js +18 -0
  514. package/types/java/util/Locale/index.d.ts +1360 -0
  515. package/types/java/util/Locale/index.js +42 -0
  516. package/types/java/util/Locale.Category/index.d.ts +12 -0
  517. package/types/java/util/Locale.Category/index.js +11 -0
  518. package/types/java/util/Locale.FilteringMode/index.d.ts +97 -0
  519. package/types/java/util/Locale.FilteringMode/index.js +14 -0
  520. package/types/java/util/LongSummaryStatistics/index.d.ts +91 -0
  521. package/types/java/util/LongSummaryStatistics/index.js +17 -0
  522. package/types/java/util/Map/index.d.ts +515 -0
  523. package/types/java/util/Map/index.js +32 -0
  524. package/types/java/util/Map.Entry/index.d.ts +137 -0
  525. package/types/java/util/Map.Entry/index.js +16 -0
  526. package/types/java/util/NavigableMap/index.d.ts +314 -0
  527. package/types/java/util/NavigableMap/index.js +27 -0
  528. package/types/java/util/NavigableSet/index.d.ts +228 -0
  529. package/types/java/util/NavigableSet/index.js +21 -0
  530. package/types/java/util/Optional/index.d.ts +170 -0
  531. package/types/java/util/Optional/index.js +24 -0
  532. package/types/java/util/OptionalDouble/index.d.ts +123 -0
  533. package/types/java/util/OptionalDouble/index.js +20 -0
  534. package/types/java/util/OptionalInt/index.d.ts +122 -0
  535. package/types/java/util/OptionalInt/index.js +20 -0
  536. package/types/java/util/OptionalLong/index.d.ts +123 -0
  537. package/types/java/util/OptionalLong/index.js +20 -0
  538. package/types/java/util/PrimitiveIterator/index.d.ts +38 -0
  539. package/types/java/util/PrimitiveIterator/index.js +10 -0
  540. package/types/java/util/PrimitiveIterator.OfDouble/index.d.ts +41 -0
  541. package/types/java/util/PrimitiveIterator.OfDouble/index.js +12 -0
  542. package/types/java/util/PrimitiveIterator.OfInt/index.d.ts +41 -0
  543. package/types/java/util/PrimitiveIterator.OfInt/index.js +12 -0
  544. package/types/java/util/PrimitiveIterator.OfLong/index.d.ts +41 -0
  545. package/types/java/util/PrimitiveIterator.OfLong/index.js +12 -0
  546. package/types/java/util/Properties/index.d.ts +513 -0
  547. package/types/java/util/Properties/index.js +19 -0
  548. package/types/java/util/Queue/index.d.ts +168 -0
  549. package/types/java/util/Queue/index.js +15 -0
  550. package/types/java/util/Random/index.d.ts +605 -0
  551. package/types/java/util/Random/index.js +21 -0
  552. package/types/java/util/RandomAccess/index.d.ts +39 -0
  553. package/types/java/util/RandomAccess/index.js +8 -0
  554. package/types/java/util/Set/index.d.ts +303 -0
  555. package/types/java/util/Set/index.js +24 -0
  556. package/types/java/util/SortedMap/index.d.ts +218 -0
  557. package/types/java/util/SortedMap/index.js +18 -0
  558. package/types/java/util/SortedSet/index.d.ts +179 -0
  559. package/types/java/util/SortedSet/index.js +16 -0
  560. package/types/java/util/Spliterator/index.d.ts +317 -0
  561. package/types/java/util/Spliterator/index.js +17 -0
  562. package/types/java/util/Spliterator.OfDouble/index.d.ts +28 -0
  563. package/types/java/util/Spliterator.OfDouble/index.js +12 -0
  564. package/types/java/util/Spliterator.OfInt/index.d.ts +28 -0
  565. package/types/java/util/Spliterator.OfInt/index.js +12 -0
  566. package/types/java/util/Spliterator.OfLong/index.d.ts +28 -0
  567. package/types/java/util/Spliterator.OfLong/index.js +12 -0
  568. package/types/java/util/Spliterator.OfPrimitive/index.d.ts +39 -0
  569. package/types/java/util/Spliterator.OfPrimitive/index.js +12 -0
  570. package/types/java/util/TimeZone/index.d.ts +435 -0
  571. package/types/java/util/TimeZone/index.js +26 -0
  572. package/types/java/util/concurrent/Callable/index.d.ts +26 -0
  573. package/types/java/util/concurrent/Callable/index.js +10 -0
  574. package/types/java/util/concurrent/Executor/index.d.ts +102 -0
  575. package/types/java/util/concurrent/Executor/index.js +10 -0
  576. package/types/java/util/concurrent/ExecutorService/index.d.ts +296 -0
  577. package/types/java/util/concurrent/ExecutorService/index.js +17 -0
  578. package/types/java/util/concurrent/Future/index.d.ts +118 -0
  579. package/types/java/util/concurrent/Future/index.js +13 -0
  580. package/types/java/util/concurrent/TimeUnit/index.d.ts +41 -0
  581. package/types/java/util/concurrent/TimeUnit/index.js +16 -0
  582. package/types/java/util/function/BiConsumer/index.d.ts +33 -0
  583. package/types/java/util/function/BiConsumer/index.js +11 -0
  584. package/types/java/util/function/BiFunction/index.d.ts +35 -0
  585. package/types/java/util/function/BiFunction/index.js +11 -0
  586. package/types/java/util/function/BinaryOperator/index.d.ts +37 -0
  587. package/types/java/util/function/BinaryOperator/index.js +11 -0
  588. package/types/java/util/function/Consumer/index.d.ts +29 -0
  589. package/types/java/util/function/Consumer/index.js +11 -0
  590. package/types/java/util/function/DoubleBinaryOperator/index.d.ts +20 -0
  591. package/types/java/util/function/DoubleBinaryOperator/index.js +10 -0
  592. package/types/java/util/function/DoubleConsumer/index.d.ts +30 -0
  593. package/types/java/util/function/DoubleConsumer/index.js +11 -0
  594. package/types/java/util/function/DoubleFunction/index.d.ts +19 -0
  595. package/types/java/util/function/DoubleFunction/index.js +10 -0
  596. package/types/java/util/function/DoublePredicate/index.d.ts +55 -0
  597. package/types/java/util/function/DoublePredicate/index.js +13 -0
  598. package/types/java/util/function/DoubleSupplier/index.d.ts +19 -0
  599. package/types/java/util/function/DoubleSupplier/index.js +10 -0
  600. package/types/java/util/function/DoubleToIntFunction/index.d.ts +18 -0
  601. package/types/java/util/function/DoubleToIntFunction/index.js +10 -0
  602. package/types/java/util/function/DoubleToLongFunction/index.d.ts +18 -0
  603. package/types/java/util/function/DoubleToLongFunction/index.js +10 -0
  604. package/types/java/util/function/DoubleUnaryOperator/index.d.ts +48 -0
  605. package/types/java/util/function/DoubleUnaryOperator/index.js +13 -0
  606. package/types/java/util/function/Function/index.d.ts +50 -0
  607. package/types/java/util/function/Function/index.js +13 -0
  608. package/types/java/util/function/IntBinaryOperator/index.d.ts +20 -0
  609. package/types/java/util/function/IntBinaryOperator/index.js +10 -0
  610. package/types/java/util/function/IntConsumer/index.d.ts +30 -0
  611. package/types/java/util/function/IntConsumer/index.js +11 -0
  612. package/types/java/util/function/IntFunction/index.d.ts +19 -0
  613. package/types/java/util/function/IntFunction/index.js +10 -0
  614. package/types/java/util/function/IntPredicate/index.d.ts +55 -0
  615. package/types/java/util/function/IntPredicate/index.js +13 -0
  616. package/types/java/util/function/IntSupplier/index.d.ts +19 -0
  617. package/types/java/util/function/IntSupplier/index.js +10 -0
  618. package/types/java/util/function/IntToDoubleFunction/index.d.ts +18 -0
  619. package/types/java/util/function/IntToDoubleFunction/index.js +10 -0
  620. package/types/java/util/function/IntToLongFunction/index.d.ts +18 -0
  621. package/types/java/util/function/IntToLongFunction/index.js +10 -0
  622. package/types/java/util/function/IntUnaryOperator/index.d.ts +48 -0
  623. package/types/java/util/function/IntUnaryOperator/index.js +13 -0
  624. package/types/java/util/function/LongBinaryOperator/index.d.ts +20 -0
  625. package/types/java/util/function/LongBinaryOperator/index.js +10 -0
  626. package/types/java/util/function/LongConsumer/index.d.ts +30 -0
  627. package/types/java/util/function/LongConsumer/index.js +11 -0
  628. package/types/java/util/function/LongFunction/index.d.ts +19 -0
  629. package/types/java/util/function/LongFunction/index.js +10 -0
  630. package/types/java/util/function/LongPredicate/index.d.ts +55 -0
  631. package/types/java/util/function/LongPredicate/index.js +13 -0
  632. package/types/java/util/function/LongSupplier/index.d.ts +19 -0
  633. package/types/java/util/function/LongSupplier/index.js +10 -0
  634. package/types/java/util/function/LongToDoubleFunction/index.d.ts +18 -0
  635. package/types/java/util/function/LongToDoubleFunction/index.js +10 -0
  636. package/types/java/util/function/LongToIntFunction/index.d.ts +18 -0
  637. package/types/java/util/function/LongToIntFunction/index.js +10 -0
  638. package/types/java/util/function/LongUnaryOperator/index.d.ts +48 -0
  639. package/types/java/util/function/LongUnaryOperator/index.js +13 -0
  640. package/types/java/util/function/ObjDoubleConsumer/index.d.ts +21 -0
  641. package/types/java/util/function/ObjDoubleConsumer/index.js +10 -0
  642. package/types/java/util/function/ObjIntConsumer/index.d.ts +21 -0
  643. package/types/java/util/function/ObjIntConsumer/index.js +10 -0
  644. package/types/java/util/function/ObjLongConsumer/index.d.ts +21 -0
  645. package/types/java/util/function/ObjLongConsumer/index.js +10 -0
  646. package/types/java/util/function/Predicate/index.d.ts +64 -0
  647. package/types/java/util/function/Predicate/index.js +14 -0
  648. package/types/java/util/function/Supplier/index.d.ts +18 -0
  649. package/types/java/util/function/Supplier/index.js +10 -0
  650. package/types/java/util/function/ToDoubleFunction/index.d.ts +18 -0
  651. package/types/java/util/function/ToDoubleFunction/index.js +10 -0
  652. package/types/java/util/function/ToIntFunction/index.d.ts +18 -0
  653. package/types/java/util/function/ToIntFunction/index.js +10 -0
  654. package/types/java/util/function/ToLongFunction/index.d.ts +18 -0
  655. package/types/java/util/function/ToLongFunction/index.js +10 -0
  656. package/types/java/util/function/UnaryOperator/index.d.ts +21 -0
  657. package/types/java/util/function/UnaryOperator/index.js +10 -0
  658. package/types/java/util/stream/BaseStream/index.d.ts +120 -0
  659. package/types/java/util/stream/BaseStream/index.js +17 -0
  660. package/types/java/util/stream/Collector/index.d.ts +213 -0
  661. package/types/java/util/stream/Collector/index.js +15 -0
  662. package/types/java/util/stream/Collector.Characteristics/index.d.ts +10 -0
  663. package/types/java/util/stream/Collector.Characteristics/index.js +12 -0
  664. package/types/java/util/stream/DoubleStream/index.d.ts +603 -0
  665. package/types/java/util/stream/DoubleStream/index.js +47 -0
  666. package/types/java/util/stream/DoubleStream.Builder/index.d.ts +41 -0
  667. package/types/java/util/stream/DoubleStream.Builder/index.js +12 -0
  668. package/types/java/util/stream/IntStream/index.d.ts +597 -0
  669. package/types/java/util/stream/IntStream/index.js +51 -0
  670. package/types/java/util/stream/IntStream.Builder/index.d.ts +41 -0
  671. package/types/java/util/stream/IntStream.Builder/index.js +12 -0
  672. package/types/java/util/stream/LongStream/index.d.ts +587 -0
  673. package/types/java/util/stream/LongStream/index.js +50 -0
  674. package/types/java/util/stream/LongStream.Builder/index.d.ts +41 -0
  675. package/types/java/util/stream/LongStream.Builder/index.js +12 -0
  676. package/types/java/util/stream/Stream/index.d.ts +753 -0
  677. package/types/java/util/stream/Stream/index.js +42 -0
  678. package/types/java/util/stream/Stream.Builder/index.d.ts +44 -0
  679. package/types/java/util/stream/Stream.Builder/index.js +12 -0
  680. package/types/javax/jcr/AccessDeniedException/index.d.ts +7 -0
  681. package/types/javax/jcr/AccessDeniedException/index.js +8 -0
  682. package/types/javax/jcr/Binary/index.d.ts +20 -18
  683. package/types/javax/jcr/Credentials/index.d.ts +7 -7
  684. package/types/javax/jcr/GuestCredentials/index.d.ts +14 -0
  685. package/types/javax/jcr/GuestCredentials/index.js +8 -0
  686. package/types/javax/jcr/ImportUUIDBehavior/index.d.ts +4 -22
  687. package/types/javax/jcr/InvalidItemStateException/index.d.ts +12 -0
  688. package/types/javax/jcr/InvalidItemStateException/index.js +8 -0
  689. package/types/javax/jcr/InvalidLifecycleTransitionException/index.d.ts +7 -0
  690. package/types/javax/jcr/InvalidLifecycleTransitionException/index.js +8 -0
  691. package/types/javax/jcr/InvalidSerializedDataException/index.d.ts +8 -0
  692. package/types/javax/jcr/InvalidSerializedDataException/index.js +8 -0
  693. package/types/javax/jcr/Item/index.d.ts +65 -63
  694. package/types/javax/jcr/ItemExistsException/index.d.ts +8 -0
  695. package/types/javax/jcr/ItemExistsException/index.js +8 -0
  696. package/types/javax/jcr/ItemNotFoundException/index.d.ts +8 -0
  697. package/types/javax/jcr/ItemNotFoundException/index.js +8 -0
  698. package/types/javax/jcr/ItemVisitor/index.d.ts +14 -14
  699. package/types/javax/jcr/LoginException/index.d.ts +9 -0
  700. package/types/javax/jcr/LoginException/index.js +8 -0
  701. package/types/javax/jcr/MergeException/index.d.ts +7 -0
  702. package/types/javax/jcr/MergeException/index.js +8 -0
  703. package/types/javax/jcr/NamespaceException/index.d.ts +9 -0
  704. package/types/javax/jcr/NamespaceException/index.js +8 -0
  705. package/types/javax/jcr/NamespaceRegistry/index.d.ts +16 -14
  706. package/types/javax/jcr/NoSuchWorkspaceException/index.d.ts +8 -0
  707. package/types/javax/jcr/NoSuchWorkspaceException/index.js +8 -0
  708. package/types/javax/jcr/Node/index.d.ts +170 -160
  709. package/types/javax/jcr/NodeIterator/index.d.ts +3 -3
  710. package/types/javax/jcr/PathNotFoundException/index.d.ts +9 -0
  711. package/types/javax/jcr/PathNotFoundException/index.js +8 -0
  712. package/types/javax/jcr/Property/index.d.ts +216 -211
  713. package/types/javax/jcr/PropertyIterator/index.d.ts +2 -2
  714. package/types/javax/jcr/PropertyType/index.d.ts +211 -0
  715. package/types/javax/jcr/PropertyType/index.js +11 -0
  716. package/types/javax/jcr/RangeIterator/index.d.ts +6 -4
  717. package/types/javax/jcr/ReferentialIntegrityException/index.d.ts +7 -0
  718. package/types/javax/jcr/ReferentialIntegrityException/index.js +8 -0
  719. package/types/javax/jcr/Repository/index.d.ts +129 -131
  720. package/types/javax/jcr/RepositoryException/index.d.ts +8 -0
  721. package/types/javax/jcr/RepositoryException/index.js +8 -0
  722. package/types/javax/jcr/RepositoryFactory/index.d.ts +64 -63
  723. package/types/javax/jcr/SimpleCredentials/index.d.ts +57 -0
  724. package/types/javax/jcr/SimpleCredentials/index.js +15 -0
  725. package/types/javax/jcr/UnsupportedRepositoryOperationException/index.d.ts +7 -0
  726. package/types/javax/jcr/UnsupportedRepositoryOperationException/index.js +8 -0
  727. package/types/javax/jcr/Value/index.d.ts +81 -76
  728. package/types/javax/jcr/ValueFactory/index.d.ts +20 -15
  729. package/types/javax/jcr/ValueFormatException/index.d.ts +10 -0
  730. package/types/javax/jcr/ValueFormatException/index.js +8 -0
  731. package/types/javax/jcr/Workspace/index.d.ts +35 -32
  732. package/types/javax/jcr/lock/Lock/index.d.ts +41 -39
  733. package/types/javax/jcr/lock/LockException/index.d.ts +16 -0
  734. package/types/javax/jcr/lock/LockException/index.js +10 -0
  735. package/types/javax/jcr/lock/LockManager/index.d.ts +89 -87
  736. package/types/javax/jcr/nodetype/ConstraintViolationException/index.d.ts +9 -0
  737. package/types/javax/jcr/nodetype/ConstraintViolationException/index.js +8 -0
  738. package/types/javax/jcr/nodetype/InvalidNodeTypeDefinitionException/index.d.ts +8 -0
  739. package/types/javax/jcr/nodetype/InvalidNodeTypeDefinitionException/index.js +8 -0
  740. package/types/javax/jcr/nodetype/ItemDefinition/index.d.ts +15 -14
  741. package/types/javax/jcr/nodetype/NoSuchNodeTypeException/index.d.ts +7 -0
  742. package/types/javax/jcr/nodetype/NoSuchNodeTypeException/index.js +8 -0
  743. package/types/javax/jcr/nodetype/NodeDefinition/index.d.ts +59 -58
  744. package/types/javax/jcr/nodetype/NodeDefinitionTemplate/index.d.ts +21 -19
  745. package/types/javax/jcr/nodetype/NodeType/index.d.ts +119 -118
  746. package/types/javax/jcr/nodetype/NodeTypeDefinition/index.d.ts +32 -30
  747. package/types/javax/jcr/nodetype/NodeTypeExistsException/index.d.ts +8 -0
  748. package/types/javax/jcr/nodetype/NodeTypeExistsException/index.js +8 -0
  749. package/types/javax/jcr/nodetype/NodeTypeIterator/index.d.ts +1 -1
  750. package/types/javax/jcr/nodetype/NodeTypeManager/index.d.ts +7 -6
  751. package/types/javax/jcr/nodetype/NodeTypeTemplate/index.d.ts +36 -33
  752. package/types/javax/jcr/nodetype/PropertyDefinition/index.d.ts +12 -11
  753. package/types/javax/jcr/nodetype/PropertyDefinitionTemplate/index.d.ts +22 -20
  754. package/types/javax/jcr/observation/Event/index.d.ts +63 -60
  755. package/types/javax/jcr/observation/EventIterator/index.d.ts +5 -5
  756. package/types/javax/jcr/observation/EventJournal/index.d.ts +6 -6
  757. package/types/javax/jcr/observation/EventListener/index.d.ts +8 -8
  758. package/types/javax/jcr/observation/EventListenerIterator/index.d.ts +5 -5
  759. package/types/javax/jcr/observation/ObservationManager/index.d.ts +87 -85
  760. package/types/javax/jcr/query/InvalidQueryException/index.d.ts +7 -0
  761. package/types/javax/jcr/query/InvalidQueryException/index.js +8 -0
  762. package/types/javax/jcr/query/Query/index.d.ts +71 -70
  763. package/types/javax/jcr/query/QueryManager/index.d.ts +21 -20
  764. package/types/javax/jcr/query/QueryResult/index.d.ts +11 -10
  765. package/types/javax/jcr/query/Row/index.d.ts +54 -54
  766. package/types/javax/jcr/query/RowIterator/index.d.ts +5 -5
  767. package/types/javax/jcr/query/qom/And/index.d.ts +4 -4
  768. package/types/javax/jcr/query/qom/BindVariableValue/index.d.ts +2 -1
  769. package/types/javax/jcr/query/qom/ChildNode/index.d.ts +8 -7
  770. package/types/javax/jcr/query/qom/ChildNodeJoinCondition/index.d.ts +8 -7
  771. package/types/javax/jcr/query/qom/Column/index.d.ts +16 -14
  772. package/types/javax/jcr/query/qom/Comparison/index.d.ts +55 -55
  773. package/types/javax/jcr/query/qom/Constraint/index.d.ts +6 -8
  774. package/types/javax/jcr/query/qom/DescendantNode/index.d.ts +12 -11
  775. package/types/javax/jcr/query/qom/DescendantNodeJoinCondition/index.d.ts +10 -9
  776. package/types/javax/jcr/query/qom/DynamicOperand/index.d.ts +2 -4
  777. package/types/javax/jcr/query/qom/EquiJoinCondition/index.d.ts +10 -9
  778. package/types/javax/jcr/query/qom/FullTextSearch/index.d.ts +63 -62
  779. package/types/javax/jcr/query/qom/FullTextSearchScore/index.d.ts +11 -10
  780. package/types/javax/jcr/query/qom/Join/index.d.ts +3 -3
  781. package/types/javax/jcr/query/qom/JoinCondition/index.d.ts +2 -4
  782. package/types/javax/jcr/query/qom/Length/index.d.ts +8 -8
  783. package/types/javax/jcr/query/qom/Literal/index.d.ts +1 -1
  784. package/types/javax/jcr/query/qom/LowerCase/index.d.ts +10 -10
  785. package/types/javax/jcr/query/qom/NodeLocalName/index.d.ts +3 -2
  786. package/types/javax/jcr/query/qom/NodeName/index.d.ts +3 -2
  787. package/types/javax/jcr/query/qom/Not/index.d.ts +4 -4
  788. package/types/javax/jcr/query/qom/Operand/index.d.ts +2 -4
  789. package/types/javax/jcr/query/qom/Or/index.d.ts +8 -8
  790. package/types/javax/jcr/query/qom/Ordering/index.d.ts +33 -32
  791. package/types/javax/jcr/query/qom/PropertyExistence/index.d.ts +5 -4
  792. package/types/javax/jcr/query/qom/PropertyValue/index.d.ts +6 -5
  793. package/types/javax/jcr/query/qom/QueryObjectModel/index.d.ts +27 -27
  794. package/types/javax/jcr/query/qom/QueryObjectModelConstants/index.d.ts +3 -3
  795. package/types/javax/jcr/query/qom/QueryObjectModelFactory/index.d.ts +220 -211
  796. package/types/javax/jcr/query/qom/SameNode/index.d.ts +8 -7
  797. package/types/javax/jcr/query/qom/SameNodeJoinCondition/index.d.ts +11 -10
  798. package/types/javax/jcr/query/qom/Selector/index.d.ts +13 -12
  799. package/types/javax/jcr/query/qom/Source/index.d.ts +2 -4
  800. package/types/javax/jcr/query/qom/StaticOperand/index.d.ts +3 -5
  801. package/types/javax/jcr/query/qom/UpperCase/index.d.ts +10 -10
  802. package/types/javax/jcr/retention/Hold/index.d.ts +10 -8
  803. package/types/javax/jcr/retention/RetentionManager/index.d.ts +91 -83
  804. package/types/javax/jcr/retention/RetentionPolicy/index.d.ts +4 -2
  805. package/types/javax/jcr/security/AccessControlEntry/index.d.ts +4 -3
  806. package/types/javax/jcr/security/AccessControlException/index.d.ts +9 -0
  807. package/types/javax/jcr/security/AccessControlException/index.js +8 -0
  808. package/types/javax/jcr/security/AccessControlList/index.d.ts +35 -35
  809. package/types/javax/jcr/security/AccessControlManager/index.d.ts +130 -129
  810. package/types/javax/jcr/security/AccessControlPolicy/index.d.ts +4 -6
  811. package/types/javax/jcr/security/AccessControlPolicyIterator/index.d.ts +4 -4
  812. package/types/javax/jcr/security/NamedAccessControlPolicy/index.d.ts +6 -5
  813. package/types/javax/jcr/security/Privilege/index.d.ts +73 -71
  814. package/types/javax/jcr/util/TraversingItemVisitor/index.d.ts +87 -0
  815. package/types/javax/jcr/util/TraversingItemVisitor/index.js +12 -0
  816. package/types/javax/jcr/util/TraversingItemVisitor.Default/index.d.ts +19 -0
  817. package/types/javax/jcr/util/TraversingItemVisitor.Default/index.js +11 -0
  818. package/types/javax/jcr/version/ActivityViolationException/index.d.ts +14 -0
  819. package/types/javax/jcr/version/ActivityViolationException/index.js +8 -0
  820. package/types/javax/jcr/version/LabelExistsVersionException/index.d.ts +9 -0
  821. package/types/javax/jcr/version/LabelExistsVersionException/index.js +8 -0
  822. package/types/javax/jcr/version/OnParentVersionAction/index.d.ts +71 -0
  823. package/types/javax/jcr/version/OnParentVersionAction/index.js +11 -0
  824. package/types/javax/jcr/version/Version/index.d.ts +36 -36
  825. package/types/javax/jcr/version/VersionException/index.d.ts +8 -0
  826. package/types/javax/jcr/version/VersionException/index.js +8 -0
  827. package/types/javax/jcr/version/VersionHistory/index.d.ts +116 -111
  828. package/types/javax/jcr/version/VersionIterator/index.d.ts +5 -5
  829. package/types/javax/jcr/version/VersionManager/index.d.ts +498 -489
  830. package/types/senselogic/sitevision/api/base/Builder/index.d.ts +83 -83
  831. package/types/senselogic/sitevision/api/base/Filter/index.d.ts +8 -8
  832. package/types/senselogic/sitevision/api/base/FilterSplit/index.d.ts +18 -17
  833. package/types/senselogic/sitevision/api/base/Loadable/index.d.ts +3 -1
  834. package/types/senselogic/sitevision/api/base/Requireable.ScriptEngine/index.js +11 -0
  835. package/types/senselogic/sitevision/api/base/Resolver/index.d.ts +13 -13
  836. package/types/senselogic/sitevision/api/base/Wrapper/index.d.ts +9 -9
  837. package/types/senselogic/sitevision/api/collaboration/CollaborationGroupWrapper/index.d.ts +124 -122
  838. package/types/senselogic/sitevision/api/format/NumericFormatter/index.d.ts +22 -17
  839. package/types/senselogic/sitevision/api/format/NumericFormatterBuilder/index.d.ts +22 -22
  840. package/types/senselogic/sitevision/api/i18n/Currency/index.d.ts +47 -44
  841. package/types/senselogic/sitevision/api/link/CustomLinkProcessor/index.d.ts +12 -10
  842. package/types/senselogic/sitevision/api/link/CustomLinkRenderData/index.d.ts +26 -24
  843. package/types/senselogic/sitevision/api/mail/Mail/index.d.ts +7 -7
  844. package/types/senselogic/sitevision/api/message/MessageTextLinker/index.d.ts +3 -1
  845. package/types/senselogic/sitevision/api/metadata/value/LinkValue/index.d.ts +13 -15
  846. package/types/senselogic/sitevision/api/metadata/value/RelatedValue/index.d.ts +13 -15
  847. package/types/senselogic/sitevision/api/portlet/GenericConfigPortlet/index.d.ts +228 -0
  848. package/types/senselogic/sitevision/api/portlet/GenericConfigPortlet/index.js +14 -0
  849. package/types/senselogic/sitevision/api/portlet/GenericSiteVisionPortlet/index.d.ts +69 -0
  850. package/types/senselogic/sitevision/api/portlet/GenericSiteVisionPortlet/index.js +12 -0
  851. package/types/senselogic/sitevision/api/property/VersionedPropertyUtil/index.d.ts +288 -262
  852. package/types/senselogic/sitevision/api/render/BuddyIconRenderer.BuddyIconInfo/index.d.ts +21 -19
  853. package/types/senselogic/sitevision/api/render/ImageScaler/index.d.ts +14 -14
  854. package/types/senselogic/sitevision/api/render/TextModuleRenderer/index.d.ts +162 -160
  855. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess/index.d.ts +1 -3
  856. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.ArticleUtilConstants/index.d.ts +6 -4
  857. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.ExceptionSuppressingProxyConstants/index.d.ts +4 -4
  858. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.IndexingUtilConstants/index.d.ts +4 -4
  859. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.LinkPageUtilConstants/index.d.ts +6 -4
  860. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.MathInstanceConstants/index.d.ts +4 -4
  861. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.MimeTypeUtilConstants/index.d.ts +6 -4
  862. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.NodeTypeUtilConstants/index.d.ts +6 -4
  863. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.OutputUtilConstants/index.d.ts +4 -4
  864. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.PageUtilConstants/index.d.ts +6 -4
  865. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.PortletContextUtilConstants/index.d.ts +4 -4
  866. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.PortletUtilConstants/index.d.ts +4 -4
  867. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.QueryStringUtilConstants/index.d.ts +6 -4
  868. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.SearchHitConstants/index.d.ts +4 -4
  869. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.SearchResultConstants/index.d.ts +4 -4
  870. package/types/senselogic/sitevision/api/render/velocity/VelocityAccess.VersionUtilConstants/index.d.ts +4 -4
  871. package/types/senselogic/sitevision/api/render/velocity/VelocityContext/index.d.ts +12 -9
  872. package/types/senselogic/sitevision/api/render/velocity/VelocityEvaluator/index.d.ts +40 -38
  873. package/types/senselogic/sitevision/api/render/velocity/VelocityException/index.d.ts +9 -0
  874. package/types/senselogic/sitevision/api/render/velocity/VelocityException/index.js +8 -0
  875. package/types/senselogic/sitevision/api/script/RequesterChainable/index.d.ts +46 -46
  876. package/types/senselogic/sitevision/api/script/app/RestAppInvoker/index.d.ts +183 -155
  877. package/types/senselogic/sitevision/api/script/app/RestAppInvoker/index.js +2 -1
  878. package/types/senselogic/sitevision/api/script/factory/TypedArgument/index.d.ts +25 -22
  879. package/types/senselogic/sitevision/api/script/proxy/ExceptionSuppressingCollection/index.d.ts +77 -74
  880. package/types/senselogic/sitevision/api/script/proxy/ExceptionSuppressingIterator/index.d.ts +55 -53
  881. package/types/senselogic/sitevision/api/script/proxy/ExceptionSuppressingProxy/index.d.ts +58 -56
  882. package/types/senselogic/sitevision/api/search/SearchFieldUtil/index.d.ts +30 -22
  883. package/types/senselogic/sitevision/api/search/SearchHighlighter/index.d.ts +18 -17
  884. package/types/senselogic/sitevision/api/search/SearchHit/index.d.ts +471 -444
  885. package/types/senselogic/sitevision/api/search/SearchResult/index.d.ts +279 -272
  886. package/types/senselogic/sitevision/api/search/SearchSortField/index.d.ts +58 -0
  887. package/types/senselogic/sitevision/api/search/SearchSortField/index.js +12 -0
  888. package/types/senselogic/sitevision/api/search/facet/SearchFacetField/index.d.ts +4 -1
  889. package/types/senselogic/sitevision/api/search/facet/SearchFacetValue/index.d.ts +12 -10
  890. package/types/senselogic/sitevision/api/search/searcher/Searcher/index.d.ts +172 -170
  891. package/types/senselogic/sitevision/api/search/searcher/component/Filter/index.d.ts +16 -18
  892. package/types/senselogic/sitevision/api/search/searcher/component/Highlight/index.d.ts +19 -21
  893. package/types/senselogic/sitevision/api/search/searcher/component/Monitor/index.d.ts +16 -18
  894. package/types/senselogic/sitevision/api/search/searcher/component/Parser/index.d.ts +26 -28
  895. package/types/senselogic/sitevision/api/search/searcher/component/Sort/index.d.ts +16 -18
  896. package/types/senselogic/sitevision/api/search/searcher/component/SpellCheck/index.d.ts +19 -21
  897. package/types/senselogic/sitevision/api/search/sort/CustomSort/index.d.ts +17 -15
  898. package/types/senselogic/sitevision/api/search/suggestion/SearchSuggestion/index.d.ts +2 -0
  899. package/types/senselogic/sitevision/api/security/DirectoryAttributes/index.d.ts +41 -27
  900. package/types/senselogic/sitevision/api/security/JwtException/index.d.ts +9 -0
  901. package/types/senselogic/sitevision/api/security/JwtException/index.js +8 -0
  902. package/types/senselogic/sitevision/api/security/MessageDigester/index.d.ts +14 -12
  903. package/types/senselogic/sitevision/api/security/RoleAssignment/index.d.ts +16 -16
  904. package/types/senselogic/sitevision/api/security/RoleMatcher/index.d.ts +4 -4
  905. package/types/senselogic/sitevision/api/security/Secret/index.d.ts +37 -0
  906. package/types/senselogic/sitevision/api/security/Secret/index.js +13 -0
  907. package/types/senselogic/sitevision/api/security/SecretStore/index.d.ts +13 -13
  908. package/types/senselogic/sitevision/api/security/UserUtil/index.d.ts +5 -5
  909. package/types/senselogic/sitevision/api/security/jaas/callback/NodePrincipalCallback/index.d.ts +109 -0
  910. package/types/senselogic/sitevision/api/security/jaas/callback/NodePrincipalCallback/index.js +14 -0
  911. package/types/senselogic/sitevision/api/security/jaas/callback/RedirectCallback/index.d.ts +22 -0
  912. package/types/senselogic/sitevision/api/security/jaas/callback/RedirectCallback/index.js +10 -0
  913. package/types/senselogic/sitevision/api/security/jaas/callback/ServletCallback/index.d.ts +39 -0
  914. package/types/senselogic/sitevision/api/security/jaas/callback/ServletCallback/index.js +13 -0
  915. package/types/senselogic/sitevision/api/security/jaas/callback/SharedStateCallback/index.d.ts +35 -0
  916. package/types/senselogic/sitevision/api/security/jaas/callback/SharedStateCallback/index.js +12 -0
  917. package/types/senselogic/sitevision/api/security/jaas/callback/UserAttributeCallback/index.d.ts +48 -0
  918. package/types/senselogic/sitevision/api/security/jaas/callback/UserAttributeCallback/index.js +14 -0
  919. package/types/senselogic/sitevision/api/security/jaas/callback/UserPrincipalCallback/index.d.ts +36 -0
  920. package/types/senselogic/sitevision/api/security/jaas/callback/UserPrincipalCallback/index.js +12 -0
  921. package/types/senselogic/sitevision/api/security/jaas/credential/AuthTypeCredential/index.d.ts +35 -0
  922. package/types/senselogic/sitevision/api/security/jaas/credential/AuthTypeCredential/index.js +12 -0
  923. package/types/senselogic/sitevision/api/security/jaas/credential/InetAddressCredential/index.d.ts +35 -0
  924. package/types/senselogic/sitevision/api/security/jaas/credential/InetAddressCredential/index.js +12 -0
  925. package/types/senselogic/sitevision/api/security/jaas/credential/PasswordCredential/index.d.ts +34 -0
  926. package/types/senselogic/sitevision/api/security/jaas/credential/PasswordCredential/index.js +12 -0
  927. package/types/senselogic/sitevision/api/security/jaas/credential/VirtualGroupCredential/index.d.ts +34 -0
  928. package/types/senselogic/sitevision/api/security/jaas/credential/VirtualGroupCredential/index.js +12 -0
  929. package/types/senselogic/sitevision/api/security/jaas/filter/AuthenticationFilter/index.d.ts +12 -9
  930. package/types/senselogic/sitevision/api/security/jaas/filter/AuthenticationFilterChain/index.d.ts +10 -8
  931. package/types/senselogic/sitevision/api/user/UserIdentityWrapper/index.d.ts +178 -177
  932. package/types/senselogic/sitevision/api/webresource/LinkTarget/index.d.ts +10 -12
  933. package/types/senselogic/sitevision/api/xml/XmlElement/index.d.ts +9 -5
  934. package/types/senselogic/sitevision/api/xml/XmlParserException/index.d.ts +9 -0
  935. package/types/senselogic/sitevision/api/xml/XmlParserException/index.js +8 -0
  936. /package/types/senselogic/sitevision/api/base/{Requireable/ScriptEngine → Requireable.ScriptEngine}/index.d.ts +0 -0
@@ -0,0 +1,1317 @@
1
+ import type { MathContext } from "../MathContext";
2
+ import type { RoundingMode } from "../RoundingMode";
3
+ import type { BigInteger } from "../BigInteger";
4
+ import type { Object } from "../../lang/Object";
5
+
6
+ import type { String } from "../../lang/String";
7
+
8
+ import type { Number } from "../../lang/Number";
9
+ import type { Comparable } from "../../lang/Comparable";
10
+
11
+ /**
12
+ * Immutable, arbitrary-precision signed decimal numbers. A
13
+ * {@code BigDecimal} consists of an arbitrary precision integer
14
+ * <i>unscaled value</i> and a 32-bit integer <i>scale</i>. If zero
15
+ * or positive, the scale is the number of digits to the right of the
16
+ * decimal point. If negative, the unscaled value of the number is
17
+ * multiplied by ten to the power of the negation of the scale. The
18
+ * value of the number represented by the {@code BigDecimal} is
19
+ * therefore <tt>(unscaledValue &times; 10<sup>-scale</sup>)</tt>.
20
+ *
21
+ * <p>The {@code BigDecimal} class provides operations for
22
+ * arithmetic, scale manipulation, rounding, comparison, hashing, and
23
+ * format conversion. The {@link #toString} method provides a
24
+ * canonical representation of a {@code BigDecimal}.
25
+ *
26
+ * <p>The {@code BigDecimal} class gives its user complete control
27
+ * over rounding behavior. If no rounding mode is specified and the
28
+ * exact result cannot be represented, an exception is thrown;
29
+ * otherwise, calculations can be carried out to a chosen precision
30
+ * and rounding mode by supplying an appropriate {@link MathContext}
31
+ * object to the operation. In either case, eight <em>rounding
32
+ * modes</em> are provided for the control of rounding. Using the
33
+ * integer fields in this class (such as {@link #ROUND_HALF_UP}) to
34
+ * represent rounding mode is largely obsolete; the enumeration values
35
+ * of the {@code RoundingMode} {@code enum}, (such as {@link
36
+ * RoundingMode#HALF_UP}) should be used instead.
37
+ *
38
+ * <p>When a {@code MathContext} object is supplied with a precision
39
+ * setting of 0 (for example, {@link MathContext#UNLIMITED}),
40
+ * arithmetic operations are exact, as are the arithmetic methods
41
+ * which take no {@code MathContext} object. (This is the only
42
+ * behavior that was supported in releases prior to 5.) As a
43
+ * corollary of computing the exact result, the rounding mode setting
44
+ * of a {@code MathContext} object with a precision setting of 0 is
45
+ * not used and thus irrelevant. In the case of divide, the exact
46
+ * quotient could have an infinitely long decimal expansion; for
47
+ * example, 1 divided by 3. If the quotient has a nonterminating
48
+ * decimal expansion and the operation is specified to return an exact
49
+ * result, an {@code ArithmeticException} is thrown. Otherwise, the
50
+ * exact result of the division is returned, as done for other
51
+ * operations.
52
+ *
53
+ * <p>When the precision setting is not 0, the rules of
54
+ * {@code BigDecimal} arithmetic are broadly compatible with selected
55
+ * modes of operation of the arithmetic defined in ANSI X3.274-1996
56
+ * and ANSI X3.274-1996/AM 1-2000 (section 7.4). Unlike those
57
+ * standards, {@code BigDecimal} includes many rounding modes, which
58
+ * were mandatory for division in {@code BigDecimal} releases prior
59
+ * to 5. Any conflicts between these ANSI standards and the
60
+ * {@code BigDecimal} specification are resolved in favor of
61
+ * {@code BigDecimal}.
62
+ *
63
+ * <p>Since the same numerical value can have different
64
+ * representations (with different scales), the rules of arithmetic
65
+ * and rounding must specify both the numerical result and the scale
66
+ * used in the result's representation.
67
+ *
68
+ *
69
+ * <p>In general the rounding modes and precision setting determine
70
+ * how operations return results with a limited number of digits when
71
+ * the exact result has more digits (perhaps infinitely many in the
72
+ * case of division) than the number of digits returned.
73
+ *
74
+ * First, the
75
+ * total number of digits to return is specified by the
76
+ * {@code MathContext}'s {@code precision} setting; this determines
77
+ * the result's <i>precision</i>. The digit count starts from the
78
+ * leftmost nonzero digit of the exact result. The rounding mode
79
+ * determines how any discarded trailing digits affect the returned
80
+ * result.
81
+ *
82
+ * <p>For all arithmetic operators , the operation is carried out as
83
+ * though an exact intermediate result were first calculated and then
84
+ * rounded to the number of digits specified by the precision setting
85
+ * (if necessary), using the selected rounding mode. If the exact
86
+ * result is not returned, some digit positions of the exact result
87
+ * are discarded. When rounding increases the magnitude of the
88
+ * returned result, it is possible for a new digit position to be
89
+ * created by a carry propagating to a leading {@literal "9"} digit.
90
+ * For example, rounding the value 999.9 to three digits rounding up
91
+ * would be numerically equal to one thousand, represented as
92
+ * 100&times;10<sup>1</sup>. In such cases, the new {@literal "1"} is
93
+ * the leading digit position of the returned result.
94
+ *
95
+ * <p>Besides a logical exact result, each arithmetic operation has a
96
+ * preferred scale for representing a result. The preferred
97
+ * scale for each operation is listed in the table below.
98
+ *
99
+ * <table border>
100
+ * <caption><b>Preferred Scales for Results of Arithmetic Operations
101
+ * </b></caption>
102
+ * <tr><th>Operation</th><th>Preferred Scale of Result</th></tr>
103
+ * <tr><td>Add</td><td>max(addend.scale(), augend.scale())</td>
104
+ * <tr><td>Subtract</td><td>max(minuend.scale(), subtrahend.scale())</td>
105
+ * <tr><td>Multiply</td><td>multiplier.scale() + multiplicand.scale()</td>
106
+ * <tr><td>Divide</td><td>dividend.scale() - divisor.scale()</td>
107
+ * </table>
108
+ *
109
+ * These scales are the ones used by the methods which return exact
110
+ * arithmetic results; except that an exact divide may have to use a
111
+ * larger scale since the exact result may have more digits. For
112
+ * example, {@code 1/32} is {@code 0.03125}.
113
+ *
114
+ * <p>Before rounding, the scale of the logical exact intermediate
115
+ * result is the preferred scale for that operation. If the exact
116
+ * numerical result cannot be represented in {@code precision}
117
+ * digits, rounding selects the set of digits to return and the scale
118
+ * of the result is reduced from the scale of the intermediate result
119
+ * to the least scale which can represent the {@code precision}
120
+ * digits actually returned. If the exact result can be represented
121
+ * with at most {@code precision} digits, the representation
122
+ * of the result with the scale closest to the preferred scale is
123
+ * returned. In particular, an exactly representable quotient may be
124
+ * represented in fewer than {@code precision} digits by removing
125
+ * trailing zeros and decreasing the scale. For example, rounding to
126
+ * three digits using the {@linkplain RoundingMode#FLOOR floor}
127
+ * rounding mode, <br>
128
+ *
129
+ * {@code 19/100 = 0.19 // integer=19, scale=2} <br>
130
+ *
131
+ * but<br>
132
+ *
133
+ * {@code 21/110 = 0.190 // integer=190, scale=3} <br>
134
+ *
135
+ * <p>Note that for add, subtract, and multiply, the reduction in
136
+ * scale will equal the number of digit positions of the exact result
137
+ * which are discarded. If the rounding causes a carry propagation to
138
+ * create a new high-order digit position, an additional digit of the
139
+ * result is discarded than when no new digit position is created.
140
+ *
141
+ * <p>Other methods may have slightly different rounding semantics.
142
+ * For example, the result of the {@code pow} method using the
143
+ * {@linkplain #pow(int, MathContext) specified algorithm} can
144
+ * occasionally differ from the rounded mathematical result by more
145
+ * than one unit in the last place, one <i>{@linkplain #ulp() ulp}</i>.
146
+ *
147
+ * <p>Two types of operations are provided for manipulating the scale
148
+ * of a {@code BigDecimal}: scaling/rounding operations and decimal
149
+ * point motion operations. Scaling/rounding operations ({@link
150
+ * #setScale setScale} and {@link #round round}) return a
151
+ * {@code BigDecimal} whose value is approximately (or exactly) equal
152
+ * to that of the operand, but whose scale or precision is the
153
+ * specified value; that is, they increase or decrease the precision
154
+ * of the stored number with minimal effect on its value. Decimal
155
+ * point motion operations ({@link #movePointLeft movePointLeft} and
156
+ * {@link #movePointRight movePointRight}) return a
157
+ * {@code BigDecimal} created from the operand by moving the decimal
158
+ * point a specified distance in the specified direction.
159
+ *
160
+ * <p>For the sake of brevity and clarity, pseudo-code is used
161
+ * throughout the descriptions of {@code BigDecimal} methods. The
162
+ * pseudo-code expression {@code (i + j)} is shorthand for "a
163
+ * {@code BigDecimal} whose value is that of the {@code BigDecimal}
164
+ * {@code i} added to that of the {@code BigDecimal}
165
+ * {@code j}." The pseudo-code expression {@code (i == j)} is
166
+ * shorthand for "{@code true} if and only if the
167
+ * {@code BigDecimal} {@code i} represents the same value as the
168
+ * {@code BigDecimal} {@code j}." Other pseudo-code expressions
169
+ * are interpreted similarly. Square brackets are used to represent
170
+ * the particular {@code BigInteger} and scale pair defining a
171
+ * {@code BigDecimal} value; for example [19, 2] is the
172
+ * {@code BigDecimal} numerically equal to 0.19 having a scale of 2.
173
+ *
174
+ * <p>Note: care should be exercised if {@code BigDecimal} objects
175
+ * are used as keys in a {@link java.util.SortedMap SortedMap} or
176
+ * elements in a {@link java.util.SortedSet SortedSet} since
177
+ * {@code BigDecimal}'s <i>natural ordering</i> is <i>inconsistent
178
+ * with equals</i>. See {@link Comparable}, {@link
179
+ * java.util.SortedMap} or {@link java.util.SortedSet} for more
180
+ * information.
181
+ *
182
+ * <p>All methods and constructors for this class throw
183
+ * {@code NullPointerException} when passed a {@code null} object
184
+ * reference for any input parameter.
185
+ * @see BigInteger
186
+ * @see MathContext
187
+ * @see RoundingMode
188
+ * @see java.util.SortedMap
189
+ * @see java.util.SortedSet
190
+ * @author Josh Bloch
191
+ * @author Mike Cowlishaw
192
+ * @author Joseph D. Darcy
193
+ * @author Sergey V. Kuksenko
194
+ */
195
+ export type BigDecimal = Number &
196
+ Comparable & {
197
+ /**
198
+ * Translates a {@code long} unscaled value and an
199
+ * {@code int} scale into a {@code BigDecimal}. This
200
+ * {@literal "static factory method"} is provided in preference to
201
+ * a ({@code long}, {@code int}) constructor because it
202
+ * allows for reuse of frequently used {@code BigDecimal} values..
203
+ * @param unscaledVal unscaled value of the {@code BigDecimal}.
204
+ * @param scale scale of the {@code BigDecimal}.
205
+ * @return a {@code BigDecimal} whose value is&#xA; <tt>(unscaledVal &times; 10<sup>-scale</sup>)</tt>.
206
+ */
207
+ valueOf(unscaledVal: number, scale: number): BigDecimal;
208
+
209
+ /**
210
+ * Translates a {@code long} value into a {@code BigDecimal}
211
+ * with a scale of zero. This {@literal "static factory method"}
212
+ * is provided in preference to a ({@code long}) constructor
213
+ * because it allows for reuse of frequently used
214
+ * {@code BigDecimal} values.
215
+ * @param val value of the {@code BigDecimal}.
216
+ * @return a {@code BigDecimal} whose value is {@code val}.
217
+ */
218
+ valueOf(val: number): BigDecimal;
219
+
220
+ /**
221
+ * Translates a {@code double} into a {@code BigDecimal}, using
222
+ * the {@code double}'s canonical string representation provided
223
+ * by the {@link Double#toString(double)} method.
224
+ *
225
+ * <p><b>Note:</b> This is generally the preferred way to convert
226
+ * a {@code double} (or {@code float}) into a
227
+ * {@code BigDecimal}, as the value returned is equal to that
228
+ * resulting from constructing a {@code BigDecimal} from the
229
+ * result of using {@link Double#toString(double)}.
230
+ * @param val {@code double} to convert to a {@code BigDecimal}.
231
+ * @return a {@code BigDecimal} whose value is equal to or approximately&#xA; equal to the value of {@code val}.
232
+ * @throws NumberFormatException if {@code val} is infinite or NaN.
233
+ * @since 1.5
234
+ */
235
+ valueOf(val: number): BigDecimal;
236
+
237
+ /**
238
+ * Returns a {@code BigDecimal} whose value is {@code (this +
239
+ * augend)}, and whose scale is {@code max(this.scale(),
240
+ * augend.scale())}.
241
+ * @param augend value to be added to this {@code BigDecimal}.
242
+ * @return {@code this + augend}
243
+ */
244
+ add(augend: BigDecimal): BigDecimal;
245
+
246
+ /**
247
+ * Returns a {@code BigDecimal} whose value is {@code (this + augend)},
248
+ * with rounding according to the context settings.
249
+ *
250
+ * If either number is zero and the precision setting is nonzero then
251
+ * the other number, rounded if necessary, is used as the result.
252
+ * @param augend value to be added to this {@code BigDecimal}.
253
+ * @param mc the context to use.
254
+ * @return {@code this + augend}, rounded as necessary.
255
+ * @throws ArithmeticException if the result is inexact but the&#xA; rounding mode is {@code UNNECESSARY}.
256
+ * @since 1.5
257
+ */
258
+ add(augend: BigDecimal, mc: MathContext): BigDecimal;
259
+
260
+ /**
261
+ * Returns a {@code BigDecimal} whose value is {@code (this -
262
+ * subtrahend)}, and whose scale is {@code max(this.scale(),
263
+ * subtrahend.scale())}.
264
+ * @param subtrahend value to be subtracted from this {@code BigDecimal}.
265
+ * @return {@code this - subtrahend}
266
+ */
267
+ subtract(subtrahend: BigDecimal): BigDecimal;
268
+
269
+ /**
270
+ * Returns a {@code BigDecimal} whose value is {@code (this - subtrahend)},
271
+ * with rounding according to the context settings.
272
+ *
273
+ * If {@code subtrahend} is zero then this, rounded if necessary, is used as the
274
+ * result. If this is zero then the result is {@code subtrahend.negate(mc)}.
275
+ * @param subtrahend value to be subtracted from this {@code BigDecimal}.
276
+ * @param mc the context to use.
277
+ * @return {@code this - subtrahend}, rounded as necessary.
278
+ * @throws ArithmeticException if the result is inexact but the&#xA; rounding mode is {@code UNNECESSARY}.
279
+ * @since 1.5
280
+ */
281
+ subtract(subtrahend: BigDecimal, mc: MathContext): BigDecimal;
282
+
283
+ /**
284
+ * Returns a {@code BigDecimal} whose value is <tt>(this &times;
285
+ * multiplicand)</tt>, and whose scale is {@code (this.scale() +
286
+ * multiplicand.scale())}.
287
+ * @param multiplicand value to be multiplied by this {@code BigDecimal}.
288
+ * @return {@code this * multiplicand}
289
+ */
290
+ multiply(multiplicand: BigDecimal): BigDecimal;
291
+
292
+ /**
293
+ * Returns a {@code BigDecimal} whose value is <tt>(this &times;
294
+ * multiplicand)</tt>, with rounding according to the context settings.
295
+ * @param multiplicand value to be multiplied by this {@code BigDecimal}.
296
+ * @param mc the context to use.
297
+ * @return {@code this * multiplicand}, rounded as necessary.
298
+ * @throws ArithmeticException if the result is inexact but the&#xA; rounding mode is {@code UNNECESSARY}.
299
+ * @since 1.5
300
+ */
301
+ multiply(multiplicand: BigDecimal, mc: MathContext): BigDecimal;
302
+
303
+ /**
304
+ * Returns a {@code BigDecimal} whose value is {@code (this /
305
+ * divisor)}, and whose scale is as specified. If rounding must
306
+ * be performed to generate a result with the specified scale, the
307
+ * specified rounding mode is applied.
308
+ *
309
+ * <p>The new {@link #divide(BigDecimal, int, RoundingMode)} method
310
+ * should be used in preference to this legacy method.
311
+ * @param divisor value by which this {@code BigDecimal} is to be divided.
312
+ * @param scale scale of the {@code BigDecimal} quotient to be returned.
313
+ * @param roundingMode rounding mode to apply.
314
+ * @return {@code this / divisor}
315
+ * @throws ArithmeticException if {@code divisor} is zero,&#xA; {@code roundingMode==ROUND_UNNECESSARY} and&#xA; the specified scale is insufficient to represent the result&#xA; of the division exactly.
316
+ * @throws IllegalArgumentException if {@code roundingMode} does not&#xA; represent a valid rounding mode.
317
+ * @see #ROUND_UP
318
+ * @see #ROUND_DOWN
319
+ * @see #ROUND_CEILING
320
+ * @see #ROUND_FLOOR
321
+ * @see #ROUND_HALF_UP
322
+ * @see #ROUND_HALF_DOWN
323
+ * @see #ROUND_HALF_EVEN
324
+ * @see #ROUND_UNNECESSARY
325
+ */
326
+ divide(
327
+ divisor: BigDecimal,
328
+ scale: number,
329
+ roundingMode: number
330
+ ): BigDecimal;
331
+
332
+ /**
333
+ * Returns a {@code BigDecimal} whose value is {@code (this /
334
+ * divisor)}, and whose scale is as specified. If rounding must
335
+ * be performed to generate a result with the specified scale, the
336
+ * specified rounding mode is applied.
337
+ * @param divisor value by which this {@code BigDecimal} is to be divided.
338
+ * @param scale scale of the {@code BigDecimal} quotient to be returned.
339
+ * @param roundingMode rounding mode to apply.
340
+ * @return {@code this / divisor}
341
+ * @throws ArithmeticException if {@code divisor} is zero,&#xA; {@code roundingMode==RoundingMode.UNNECESSARY} and&#xA; the specified scale is insufficient to represent the result&#xA; of the division exactly.
342
+ * @since 1.5
343
+ */
344
+ divide(
345
+ divisor: BigDecimal,
346
+ scale: number,
347
+ roundingMode: RoundingMode
348
+ ): BigDecimal;
349
+
350
+ /**
351
+ * Returns a {@code BigDecimal} whose value is {@code (this /
352
+ * divisor)}, and whose scale is {@code this.scale()}. If
353
+ * rounding must be performed to generate a result with the given
354
+ * scale, the specified rounding mode is applied.
355
+ *
356
+ * <p>The new {@link #divide(BigDecimal, RoundingMode)} method
357
+ * should be used in preference to this legacy method.
358
+ * @param divisor value by which this {@code BigDecimal} is to be divided.
359
+ * @param roundingMode rounding mode to apply.
360
+ * @return {@code this / divisor}
361
+ * @throws ArithmeticException if {@code divisor==0}, or&#xA; {@code roundingMode==ROUND_UNNECESSARY} and&#xA; {@code this.scale()} is insufficient to represent the result&#xA; of the division exactly.
362
+ * @throws IllegalArgumentException if {@code roundingMode} does not&#xA; represent a valid rounding mode.
363
+ * @see #ROUND_UP
364
+ * @see #ROUND_DOWN
365
+ * @see #ROUND_CEILING
366
+ * @see #ROUND_FLOOR
367
+ * @see #ROUND_HALF_UP
368
+ * @see #ROUND_HALF_DOWN
369
+ * @see #ROUND_HALF_EVEN
370
+ * @see #ROUND_UNNECESSARY
371
+ */
372
+ divide(divisor: BigDecimal, roundingMode: number): BigDecimal;
373
+
374
+ /**
375
+ * Returns a {@code BigDecimal} whose value is {@code (this /
376
+ * divisor)}, and whose scale is {@code this.scale()}. If
377
+ * rounding must be performed to generate a result with the given
378
+ * scale, the specified rounding mode is applied.
379
+ * @param divisor value by which this {@code BigDecimal} is to be divided.
380
+ * @param roundingMode rounding mode to apply.
381
+ * @return {@code this / divisor}
382
+ * @throws ArithmeticException if {@code divisor==0}, or&#xA; {@code roundingMode==RoundingMode.UNNECESSARY} and&#xA; {@code this.scale()} is insufficient to represent the result&#xA; of the division exactly.
383
+ * @since 1.5
384
+ */
385
+ divide(divisor: BigDecimal, roundingMode: RoundingMode): BigDecimal;
386
+
387
+ /**
388
+ * Returns a {@code BigDecimal} whose value is {@code (this /
389
+ * divisor)}, and whose preferred scale is {@code (this.scale() -
390
+ * divisor.scale())}; if the exact quotient cannot be
391
+ * represented (because it has a non-terminating decimal
392
+ * expansion) an {@code ArithmeticException} is thrown.
393
+ * @param divisor value by which this {@code BigDecimal} is to be divided.
394
+ * @throws ArithmeticException if the exact quotient does not have a&#xA; terminating decimal expansion
395
+ * @return {@code this / divisor}
396
+ * @since 1.5
397
+ * @author Joseph D. Darcy
398
+ */
399
+ divide(divisor: BigDecimal): BigDecimal;
400
+
401
+ /**
402
+ * Returns a {@code BigDecimal} whose value is {@code (this /
403
+ * divisor)}, with rounding according to the context settings.
404
+ * @param divisor value by which this {@code BigDecimal} is to be divided.
405
+ * @param mc the context to use.
406
+ * @return {@code this / divisor}, rounded as necessary.
407
+ * @throws ArithmeticException if the result is inexact but the&#xA; rounding mode is {@code UNNECESSARY} or&#xA; {@code mc.precision == 0} and the quotient has a&#xA; non-terminating decimal expansion.
408
+ * @since 1.5
409
+ */
410
+ divide(divisor: BigDecimal, mc: MathContext): BigDecimal;
411
+
412
+ /**
413
+ * Returns a {@code BigDecimal} whose value is the integer part
414
+ * of the quotient {@code (this / divisor)} rounded down. The
415
+ * preferred scale of the result is {@code (this.scale() -
416
+ * divisor.scale())}.
417
+ * @param divisor value by which this {@code BigDecimal} is to be divided.
418
+ * @return The integer part of {@code this / divisor}.
419
+ * @throws ArithmeticException if {@code divisor==0}
420
+ * @since 1.5
421
+ */
422
+ divideToIntegralValue(divisor: BigDecimal): BigDecimal;
423
+
424
+ /**
425
+ * Returns a {@code BigDecimal} whose value is the integer part
426
+ * of {@code (this / divisor)}. Since the integer part of the
427
+ * exact quotient does not depend on the rounding mode, the
428
+ * rounding mode does not affect the values returned by this
429
+ * method. The preferred scale of the result is
430
+ * {@code (this.scale() - divisor.scale())}. An
431
+ * {@code ArithmeticException} is thrown if the integer part of
432
+ * the exact quotient needs more than {@code mc.precision}
433
+ * digits.
434
+ * @param divisor value by which this {@code BigDecimal} is to be divided.
435
+ * @param mc the context to use.
436
+ * @return The integer part of {@code this / divisor}.
437
+ * @throws ArithmeticException if {@code divisor==0}
438
+ * @throws ArithmeticException if {@code mc.precision} {@literal >} 0 and the result&#xA; requires a precision of more than {@code mc.precision} digits.
439
+ * @since 1.5
440
+ * @author Joseph D. Darcy
441
+ */
442
+ divideToIntegralValue(divisor: BigDecimal, mc: MathContext): BigDecimal;
443
+
444
+ /**
445
+ * Returns a {@code BigDecimal} whose value is {@code (this % divisor)}.
446
+ *
447
+ * <p>The remainder is given by
448
+ * {@code this.subtract(this.divideToIntegralValue(divisor).multiply(divisor))}.
449
+ * Note that this is not the modulo operation (the result can be
450
+ * negative).
451
+ * @param divisor value by which this {@code BigDecimal} is to be divided.
452
+ * @return {@code this % divisor}.
453
+ * @throws ArithmeticException if {@code divisor==0}
454
+ * @since 1.5
455
+ */
456
+ remainder(divisor: BigDecimal): BigDecimal;
457
+
458
+ /**
459
+ * Returns a {@code BigDecimal} whose value is {@code (this %
460
+ * divisor)}, with rounding according to the context settings.
461
+ * The {@code MathContext} settings affect the implicit divide
462
+ * used to compute the remainder. The remainder computation
463
+ * itself is by definition exact. Therefore, the remainder may
464
+ * contain more than {@code mc.getPrecision()} digits.
465
+ *
466
+ * <p>The remainder is given by
467
+ * {@code this.subtract(this.divideToIntegralValue(divisor,
468
+ * mc).multiply(divisor))}. Note that this is not the modulo
469
+ * operation (the result can be negative).
470
+ * @param divisor value by which this {@code BigDecimal} is to be divided.
471
+ * @param mc the context to use.
472
+ * @return {@code this % divisor}, rounded as necessary.
473
+ * @throws ArithmeticException if {@code divisor==0}
474
+ * @throws ArithmeticException if the result is inexact but the&#xA; rounding mode is {@code UNNECESSARY}, or {@code mc.precision}&#xA; {@literal >} 0 and the result of {@code this.divideToIntgralValue(divisor)} would&#xA; require a precision of more than {@code mc.precision} digits.
475
+ * @see #divideToIntegralValue(java.math.BigDecimal, java.math.MathContext)
476
+ * @since 1.5
477
+ */
478
+ remainder(divisor: BigDecimal, mc: MathContext): BigDecimal;
479
+
480
+ /**
481
+ * Returns a two-element {@code BigDecimal} array containing the
482
+ * result of {@code divideToIntegralValue} followed by the result of
483
+ * {@code remainder} on the two operands.
484
+ *
485
+ * <p>Note that if both the integer quotient and remainder are
486
+ * needed, this method is faster than using the
487
+ * {@code divideToIntegralValue} and {@code remainder} methods
488
+ * separately because the division need only be carried out once.
489
+ * @param divisor value by which this {@code BigDecimal} is to be divided,&#xA; and the remainder computed.
490
+ * @return a two element {@code BigDecimal} array: the quotient&#xA; (the result of {@code divideToIntegralValue}) is the initial element&#xA; and the remainder is the final element.
491
+ * @throws ArithmeticException if {@code divisor==0}
492
+ * @see #divideToIntegralValue(java.math.BigDecimal, java.math.MathContext)
493
+ * @see #remainder(java.math.BigDecimal, java.math.MathContext)
494
+ * @since 1.5
495
+ */
496
+ divideAndRemainder(divisor: BigDecimal): BigDecimal;
497
+
498
+ /**
499
+ * Returns a two-element {@code BigDecimal} array containing the
500
+ * result of {@code divideToIntegralValue} followed by the result of
501
+ * {@code remainder} on the two operands calculated with rounding
502
+ * according to the context settings.
503
+ *
504
+ * <p>Note that if both the integer quotient and remainder are
505
+ * needed, this method is faster than using the
506
+ * {@code divideToIntegralValue} and {@code remainder} methods
507
+ * separately because the division need only be carried out once.
508
+ * @param divisor value by which this {@code BigDecimal} is to be divided,&#xA; and the remainder computed.
509
+ * @param mc the context to use.
510
+ * @return a two element {@code BigDecimal} array: the quotient&#xA; (the result of {@code divideToIntegralValue}) is the&#xA; initial element and the remainder is the final element.
511
+ * @throws ArithmeticException if {@code divisor==0}
512
+ * @throws ArithmeticException if the result is inexact but the&#xA; rounding mode is {@code UNNECESSARY}, or {@code mc.precision}&#xA; {@literal >} 0 and the result of {@code this.divideToIntgralValue(divisor)} would&#xA; require a precision of more than {@code mc.precision} digits.
513
+ * @see #divideToIntegralValue(java.math.BigDecimal, java.math.MathContext)
514
+ * @see #remainder(java.math.BigDecimal, java.math.MathContext)
515
+ * @since 1.5
516
+ */
517
+ divideAndRemainder(divisor: BigDecimal, mc: MathContext): BigDecimal;
518
+
519
+ /**
520
+ * Returns a {@code BigDecimal} whose value is
521
+ * <tt>(this<sup>n</sup>)</tt>, The power is computed exactly, to
522
+ * unlimited precision.
523
+ *
524
+ * <p>The parameter {@code n} must be in the range 0 through
525
+ * 999999999, inclusive. {@code ZERO.pow(0)} returns {@link
526
+ * #ONE}.
527
+ *
528
+ * Note that future releases may expand the allowable exponent
529
+ * range of this method.
530
+ * @param n power to raise this {@code BigDecimal} to.
531
+ * @return <tt>this<sup>n</sup></tt>
532
+ * @throws ArithmeticException if {@code n} is out of range.
533
+ * @since 1.5
534
+ */
535
+ pow(n: number): BigDecimal;
536
+
537
+ /**
538
+ * Returns a {@code BigDecimal} whose value is
539
+ * <tt>(this<sup>n</sup>)</tt>. The current implementation uses
540
+ * the core algorithm defined in ANSI standard X3.274-1996 with
541
+ * rounding according to the context settings. In general, the
542
+ * returned numerical value is within two ulps of the exact
543
+ * numerical value for the chosen precision. Note that future
544
+ * releases may use a different algorithm with a decreased
545
+ * allowable error bound and increased allowable exponent range.
546
+ *
547
+ * <p>The X3.274-1996 algorithm is:
548
+ *
549
+ * <ul>
550
+ * <li> An {@code ArithmeticException} exception is thrown if
551
+ * <ul>
552
+ * <li>{@code abs(n) > 999999999}
553
+ * <li>{@code mc.precision == 0} and {@code n < 0}
554
+ * <li>{@code mc.precision > 0} and {@code n} has more than
555
+ * {@code mc.precision} decimal digits
556
+ * </ul>
557
+ *
558
+ * <li> if {@code n} is zero, {@link #ONE} is returned even if
559
+ * {@code this} is zero, otherwise
560
+ * <ul>
561
+ * <li> if {@code n} is positive, the result is calculated via
562
+ * the repeated squaring technique into a single accumulator.
563
+ * The individual multiplications with the accumulator use the
564
+ * same math context settings as in {@code mc} except for a
565
+ * precision increased to {@code mc.precision + elength + 1}
566
+ * where {@code elength} is the number of decimal digits in
567
+ * {@code n}.
568
+ *
569
+ * <li> if {@code n} is negative, the result is calculated as if
570
+ * {@code n} were positive; this value is then divided into one
571
+ * using the working precision specified above.
572
+ *
573
+ * <li> The final value from either the positive or negative case
574
+ * is then rounded to the destination precision.
575
+ * </ul>
576
+ * </ul>
577
+ * @param n power to raise this {@code BigDecimal} to.
578
+ * @param mc the context to use.
579
+ * @return <tt>this<sup>n</sup></tt> using the ANSI standard X3.274-1996&#xA; algorithm
580
+ * @throws ArithmeticException if the result is inexact but the&#xA; rounding mode is {@code UNNECESSARY}, or {@code n} is out&#xA; of range.
581
+ * @since 1.5
582
+ */
583
+ pow(n: number, mc: MathContext): BigDecimal;
584
+
585
+ /**
586
+ * Returns a {@code BigDecimal} whose value is the absolute value
587
+ * of this {@code BigDecimal}, and whose scale is
588
+ * {@code this.scale()}.
589
+ * @return {@code abs(this)}
590
+ */
591
+ abs(): BigDecimal;
592
+
593
+ /**
594
+ * Returns a {@code BigDecimal} whose value is the absolute value
595
+ * of this {@code BigDecimal}, with rounding according to the
596
+ * context settings.
597
+ * @param mc the context to use.
598
+ * @return {@code abs(this)}, rounded as necessary.
599
+ * @throws ArithmeticException if the result is inexact but the&#xA; rounding mode is {@code UNNECESSARY}.
600
+ * @since 1.5
601
+ */
602
+ abs(mc: MathContext): BigDecimal;
603
+
604
+ /**
605
+ * Returns a {@code BigDecimal} whose value is {@code (-this)},
606
+ * and whose scale is {@code this.scale()}.
607
+ * @return {@code -this}.
608
+ */
609
+ negate(): BigDecimal;
610
+
611
+ /**
612
+ * Returns a {@code BigDecimal} whose value is {@code (-this)},
613
+ * with rounding according to the context settings.
614
+ * @param mc the context to use.
615
+ * @return {@code -this}, rounded as necessary.
616
+ * @throws ArithmeticException if the result is inexact but the&#xA; rounding mode is {@code UNNECESSARY}.
617
+ * @since 1.5
618
+ */
619
+ negate(mc: MathContext): BigDecimal;
620
+
621
+ /**
622
+ * Returns a {@code BigDecimal} whose value is {@code (+this)}, and whose
623
+ * scale is {@code this.scale()}.
624
+ *
625
+ * <p>This method, which simply returns this {@code BigDecimal}
626
+ * is included for symmetry with the unary minus method {@link
627
+ * #negate()}.
628
+ * @return {@code this}.
629
+ * @see #negate()
630
+ * @since 1.5
631
+ */
632
+ plus(): BigDecimal;
633
+
634
+ /**
635
+ * Returns a {@code BigDecimal} whose value is {@code (+this)},
636
+ * with rounding according to the context settings.
637
+ *
638
+ * <p>The effect of this method is identical to that of the {@link
639
+ * #round(MathContext)} method.
640
+ * @param mc the context to use.
641
+ * @return {@code this}, rounded as necessary. A zero result will&#xA; have a scale of 0.
642
+ * @throws ArithmeticException if the result is inexact but the&#xA; rounding mode is {@code UNNECESSARY}.
643
+ * @see #round(MathContext)
644
+ * @since 1.5
645
+ */
646
+ plus(mc: MathContext): BigDecimal;
647
+
648
+ /**
649
+ * Returns the signum function of this {@code BigDecimal}.
650
+ * @return -1, 0, or 1 as the value of this {@code BigDecimal}&#xA; is negative, zero, or positive.
651
+ */
652
+ signum(): number;
653
+
654
+ /**
655
+ * Returns the <i>scale</i> of this {@code BigDecimal}. If zero
656
+ * or positive, the scale is the number of digits to the right of
657
+ * the decimal point. If negative, the unscaled value of the
658
+ * number is multiplied by ten to the power of the negation of the
659
+ * scale. For example, a scale of {@code -3} means the unscaled
660
+ * value is multiplied by 1000.
661
+ * @return the scale of this {@code BigDecimal}.
662
+ */
663
+ scale(): number;
664
+
665
+ /**
666
+ * Returns the <i>precision</i> of this {@code BigDecimal}. (The
667
+ * precision is the number of digits in the unscaled value.)
668
+ *
669
+ * <p>The precision of a zero value is 1.
670
+ * @return the precision of this {@code BigDecimal}.
671
+ * @since 1.5
672
+ */
673
+ precision(): number;
674
+
675
+ /**
676
+ * Returns a {@code BigInteger} whose value is the <i>unscaled
677
+ * value</i> of this {@code BigDecimal}. (Computes <tt>(this *
678
+ * 10<sup>this.scale()</sup>)</tt>.)
679
+ * @return the unscaled value of this {@code BigDecimal}.
680
+ * @since 1.2
681
+ */
682
+ unscaledValue(): BigInteger;
683
+
684
+ /**
685
+ * Returns a {@code BigDecimal} rounded according to the
686
+ * {@code MathContext} settings. If the precision setting is 0 then
687
+ * no rounding takes place.
688
+ *
689
+ * <p>The effect of this method is identical to that of the
690
+ * {@link #plus(MathContext)} method.
691
+ * @param mc the context to use.
692
+ * @return a {@code BigDecimal} rounded according to the&#xA; {@code MathContext} settings.
693
+ * @throws ArithmeticException if the rounding mode is&#xA; {@code UNNECESSARY} and the&#xA; {@code BigDecimal} operation would require rounding.
694
+ * @see #plus(MathContext)
695
+ * @since 1.5
696
+ */
697
+ round(mc: MathContext): BigDecimal;
698
+
699
+ /**
700
+ * Returns a {@code BigDecimal} whose scale is the specified
701
+ * value, and whose unscaled value is determined by multiplying or
702
+ * dividing this {@code BigDecimal}'s unscaled value by the
703
+ * appropriate power of ten to maintain its overall value. If the
704
+ * scale is reduced by the operation, the unscaled value must be
705
+ * divided (rather than multiplied), and the value may be changed;
706
+ * in this case, the specified rounding mode is applied to the
707
+ * division.
708
+ *
709
+ * <p>Note that since BigDecimal objects are immutable, calls of
710
+ * this method do <i>not</i> result in the original object being
711
+ * modified, contrary to the usual convention of having methods
712
+ * named <tt>set<i>X</i></tt> mutate field <i>{@code X}</i>.
713
+ * Instead, {@code setScale} returns an object with the proper
714
+ * scale; the returned object may or may not be newly allocated.
715
+ * @param newScale scale of the {@code BigDecimal} value to be returned.
716
+ * @param roundingMode The rounding mode to apply.
717
+ * @return a {@code BigDecimal} whose scale is the specified value,&#xA; and whose unscaled value is determined by multiplying or&#xA; dividing this {@code BigDecimal}'s unscaled value by the&#xA; appropriate power of ten to maintain its overall value.
718
+ * @throws ArithmeticException if {@code roundingMode==UNNECESSARY}&#xA; and the specified scaling operation would require&#xA; rounding.
719
+ * @see RoundingMode
720
+ * @since 1.5
721
+ */
722
+ setScale(newScale: number, roundingMode: RoundingMode): BigDecimal;
723
+
724
+ /**
725
+ * Returns a {@code BigDecimal} whose scale is the specified
726
+ * value, and whose unscaled value is determined by multiplying or
727
+ * dividing this {@code BigDecimal}'s unscaled value by the
728
+ * appropriate power of ten to maintain its overall value. If the
729
+ * scale is reduced by the operation, the unscaled value must be
730
+ * divided (rather than multiplied), and the value may be changed;
731
+ * in this case, the specified rounding mode is applied to the
732
+ * division.
733
+ *
734
+ * <p>Note that since BigDecimal objects are immutable, calls of
735
+ * this method do <i>not</i> result in the original object being
736
+ * modified, contrary to the usual convention of having methods
737
+ * named <tt>set<i>X</i></tt> mutate field <i>{@code X}</i>.
738
+ * Instead, {@code setScale} returns an object with the proper
739
+ * scale; the returned object may or may not be newly allocated.
740
+ *
741
+ * <p>The new {@link #setScale(int, RoundingMode)} method should
742
+ * be used in preference to this legacy method.
743
+ * @param newScale scale of the {@code BigDecimal} value to be returned.
744
+ * @param roundingMode The rounding mode to apply.
745
+ * @return a {@code BigDecimal} whose scale is the specified value,&#xA; and whose unscaled value is determined by multiplying or&#xA; dividing this {@code BigDecimal}'s unscaled value by the&#xA; appropriate power of ten to maintain its overall value.
746
+ * @throws ArithmeticException if {@code roundingMode==ROUND_UNNECESSARY}&#xA; and the specified scaling operation would require&#xA; rounding.
747
+ * @throws IllegalArgumentException if {@code roundingMode} does not&#xA; represent a valid rounding mode.
748
+ * @see #ROUND_UP
749
+ * @see #ROUND_DOWN
750
+ * @see #ROUND_CEILING
751
+ * @see #ROUND_FLOOR
752
+ * @see #ROUND_HALF_UP
753
+ * @see #ROUND_HALF_DOWN
754
+ * @see #ROUND_HALF_EVEN
755
+ * @see #ROUND_UNNECESSARY
756
+ */
757
+ setScale(newScale: number, roundingMode: number): BigDecimal;
758
+
759
+ /**
760
+ * Returns a {@code BigDecimal} whose scale is the specified
761
+ * value, and whose value is numerically equal to this
762
+ * {@code BigDecimal}'s. Throws an {@code ArithmeticException}
763
+ * if this is not possible.
764
+ *
765
+ * <p>This call is typically used to increase the scale, in which
766
+ * case it is guaranteed that there exists a {@code BigDecimal}
767
+ * of the specified scale and the correct value. The call can
768
+ * also be used to reduce the scale if the caller knows that the
769
+ * {@code BigDecimal} has sufficiently many zeros at the end of
770
+ * its fractional part (i.e., factors of ten in its integer value)
771
+ * to allow for the rescaling without changing its value.
772
+ *
773
+ * <p>This method returns the same result as the two-argument
774
+ * versions of {@code setScale}, but saves the caller the trouble
775
+ * of specifying a rounding mode in cases where it is irrelevant.
776
+ *
777
+ * <p>Note that since {@code BigDecimal} objects are immutable,
778
+ * calls of this method do <i>not</i> result in the original
779
+ * object being modified, contrary to the usual convention of
780
+ * having methods named <tt>set<i>X</i></tt> mutate field
781
+ * <i>{@code X}</i>. Instead, {@code setScale} returns an
782
+ * object with the proper scale; the returned object may or may
783
+ * not be newly allocated.
784
+ * @param newScale scale of the {@code BigDecimal} value to be returned.
785
+ * @return a {@code BigDecimal} whose scale is the specified value, and&#xA; whose unscaled value is determined by multiplying or dividing&#xA; this {@code BigDecimal}'s unscaled value by the appropriate&#xA; power of ten to maintain its overall value.
786
+ * @throws ArithmeticException if the specified scaling operation would&#xA; require rounding.
787
+ * @see #setScale(int, int)
788
+ * @see #setScale(int, RoundingMode)
789
+ */
790
+ setScale(newScale: number): BigDecimal;
791
+
792
+ /**
793
+ * Returns a {@code BigDecimal} which is equivalent to this one
794
+ * with the decimal point moved {@code n} places to the left. If
795
+ * {@code n} is non-negative, the call merely adds {@code n} to
796
+ * the scale. If {@code n} is negative, the call is equivalent
797
+ * to {@code movePointRight(-n)}. The {@code BigDecimal}
798
+ * returned by this call has value <tt>(this &times;
799
+ * 10<sup>-n</sup>)</tt> and scale {@code max(this.scale()+n,
800
+ * 0)}.
801
+ * @param n number of places to move the decimal point to the left.
802
+ * @return a {@code BigDecimal} which is equivalent to this one with the&#xA; decimal point moved {@code n} places to the left.
803
+ * @throws ArithmeticException if scale overflows.
804
+ */
805
+ movePointLeft(n: number): BigDecimal;
806
+
807
+ /**
808
+ * Returns a {@code BigDecimal} which is equivalent to this one
809
+ * with the decimal point moved {@code n} places to the right.
810
+ * If {@code n} is non-negative, the call merely subtracts
811
+ * {@code n} from the scale. If {@code n} is negative, the call
812
+ * is equivalent to {@code movePointLeft(-n)}. The
813
+ * {@code BigDecimal} returned by this call has value <tt>(this
814
+ * &times; 10<sup>n</sup>)</tt> and scale {@code max(this.scale()-n,
815
+ * 0)}.
816
+ * @param n number of places to move the decimal point to the right.
817
+ * @return a {@code BigDecimal} which is equivalent to this one&#xA; with the decimal point moved {@code n} places to the right.
818
+ * @throws ArithmeticException if scale overflows.
819
+ */
820
+ movePointRight(n: number): BigDecimal;
821
+
822
+ /**
823
+ * Returns a BigDecimal whose numerical value is equal to
824
+ * ({@code this} * 10<sup>n</sup>). The scale of
825
+ * the result is {@code (this.scale() - n)}.
826
+ * @param n the exponent power of ten to scale by
827
+ * @return a BigDecimal whose numerical value is equal to&#xA; ({@code this} * 10<sup>n</sup>)
828
+ * @throws ArithmeticException if the scale would be&#xA; outside the range of a 32-bit integer.
829
+ * @since 1.5
830
+ */
831
+ scaleByPowerOfTen(n: number): BigDecimal;
832
+
833
+ /**
834
+ * Returns a {@code BigDecimal} which is numerically equal to
835
+ * this one but with any trailing zeros removed from the
836
+ * representation. For example, stripping the trailing zeros from
837
+ * the {@code BigDecimal} value {@code 600.0}, which has
838
+ * [{@code BigInteger}, {@code scale}] components equals to
839
+ * [6000, 1], yields {@code 6E2} with [{@code BigInteger},
840
+ * {@code scale}] components equals to [6, -2]. If
841
+ * this BigDecimal is numerically equal to zero, then
842
+ * {@code BigDecimal.ZERO} is returned.
843
+ * @return a numerically equal {@code BigDecimal} with any&#xA; trailing zeros removed.
844
+ * @since 1.5
845
+ */
846
+ stripTrailingZeros(): BigDecimal;
847
+
848
+ /**
849
+ * Compares this {@code BigDecimal} with the specified
850
+ * {@code BigDecimal}. Two {@code BigDecimal} objects that are
851
+ * equal in value but have a different scale (like 2.0 and 2.00)
852
+ * are considered equal by this method. This method is provided
853
+ * in preference to individual methods for each of the six boolean
854
+ * comparison operators ({@literal <}, ==,
855
+ * {@literal >}, {@literal >=}, !=, {@literal <=}). The
856
+ * suggested idiom for performing these comparisons is:
857
+ * {@code (x.compareTo(y)} &lt;<i>op</i>&gt; {@code 0)}, where
858
+ * &lt;<i>op</i>&gt; is one of the six comparison operators.
859
+ * @param val {@code BigDecimal} to which this {@code BigDecimal} is&#xA; to be compared.
860
+ * @return -1, 0, or 1 as this {@code BigDecimal} is numerically&#xA; less than, equal to, or greater than {@code val}.
861
+ */
862
+ compareTo(val: BigDecimal): number;
863
+
864
+ /**
865
+ * Compares this {@code BigDecimal} with the specified
866
+ * {@code Object} for equality. Unlike {@link
867
+ * #compareTo(BigDecimal) compareTo}, this method considers two
868
+ * {@code BigDecimal} objects equal only if they are equal in
869
+ * value and scale (thus 2.0 is not equal to 2.00 when compared by
870
+ * this method).
871
+ * @param x {@code Object} to which this {@code BigDecimal} is&#xA; to be compared.
872
+ * @return {@code true} if and only if the specified {@code Object} is a&#xA; {@code BigDecimal} whose value and scale are equal to this&#xA; {@code BigDecimal}'s.
873
+ * @see #compareTo(java.math.BigDecimal)
874
+ * @see #hashCode
875
+ */
876
+ equals(x: unknown): boolean;
877
+
878
+ /**
879
+ * Returns the minimum of this {@code BigDecimal} and
880
+ * {@code val}.
881
+ * @param val value with which the minimum is to be computed.
882
+ * @return the {@code BigDecimal} whose value is the lesser of this&#xA; {@code BigDecimal} and {@code val}. If they are equal,&#xA; as defined by the {@link #compareTo(BigDecimal) compareTo}&#xA; method, {@code this} is returned.
883
+ * @see #compareTo(java.math.BigDecimal)
884
+ */
885
+ min(val: BigDecimal): BigDecimal;
886
+
887
+ /**
888
+ * Returns the maximum of this {@code BigDecimal} and {@code val}.
889
+ * @param val value with which the maximum is to be computed.
890
+ * @return the {@code BigDecimal} whose value is the greater of this&#xA; {@code BigDecimal} and {@code val}. If they are equal,&#xA; as defined by the {@link #compareTo(BigDecimal) compareTo}&#xA; method, {@code this} is returned.
891
+ * @see #compareTo(java.math.BigDecimal)
892
+ */
893
+ max(val: BigDecimal): BigDecimal;
894
+
895
+ /**
896
+ * Returns the hash code for this {@code BigDecimal}. Note that
897
+ * two {@code BigDecimal} objects that are numerically equal but
898
+ * differ in scale (like 2.0 and 2.00) will generally <i>not</i>
899
+ * have the same hash code.
900
+ * @return hash code for this {@code BigDecimal}.
901
+ * @see #equals(Object)
902
+ */
903
+ hashCode(): number;
904
+
905
+ /**
906
+ * Returns the string representation of this {@code BigDecimal},
907
+ * using scientific notation if an exponent is needed.
908
+ *
909
+ * <p>A standard canonical string form of the {@code BigDecimal}
910
+ * is created as though by the following steps: first, the
911
+ * absolute value of the unscaled value of the {@code BigDecimal}
912
+ * is converted to a string in base ten using the characters
913
+ * {@code '0'} through {@code '9'} with no leading zeros (except
914
+ * if its value is zero, in which case a single {@code '0'}
915
+ * character is used).
916
+ *
917
+ * <p>Next, an <i>adjusted exponent</i> is calculated; this is the
918
+ * negated scale, plus the number of characters in the converted
919
+ * unscaled value, less one. That is,
920
+ * {@code -scale+(ulength-1)}, where {@code ulength} is the
921
+ * length of the absolute value of the unscaled value in decimal
922
+ * digits (its <i>precision</i>).
923
+ *
924
+ * <p>If the scale is greater than or equal to zero and the
925
+ * adjusted exponent is greater than or equal to {@code -6}, the
926
+ * number will be converted to a character form without using
927
+ * exponential notation. In this case, if the scale is zero then
928
+ * no decimal point is added and if the scale is positive a
929
+ * decimal point will be inserted with the scale specifying the
930
+ * number of characters to the right of the decimal point.
931
+ * {@code '0'} characters are added to the left of the converted
932
+ * unscaled value as necessary. If no character precedes the
933
+ * decimal point after this insertion then a conventional
934
+ * {@code '0'} character is prefixed.
935
+ *
936
+ * <p>Otherwise (that is, if the scale is negative, or the
937
+ * adjusted exponent is less than {@code -6}), the number will be
938
+ * converted to a character form using exponential notation. In
939
+ * this case, if the converted {@code BigInteger} has more than
940
+ * one digit a decimal point is inserted after the first digit.
941
+ * An exponent in character form is then suffixed to the converted
942
+ * unscaled value (perhaps with inserted decimal point); this
943
+ * comprises the letter {@code 'E'} followed immediately by the
944
+ * adjusted exponent converted to a character form. The latter is
945
+ * in base ten, using the characters {@code '0'} through
946
+ * {@code '9'} with no leading zeros, and is always prefixed by a
947
+ * sign character {@code '-'} (<tt>'&#92;u002D'</tt>) if the
948
+ * adjusted exponent is negative, {@code '+'}
949
+ * (<tt>'&#92;u002B'</tt>) otherwise).
950
+ *
951
+ * <p>Finally, the entire string is prefixed by a minus sign
952
+ * character {@code '-'} (<tt>'&#92;u002D'</tt>) if the unscaled
953
+ * value is less than zero. No sign character is prefixed if the
954
+ * unscaled value is zero or positive.
955
+ *
956
+ * <p><b>Examples:</b>
957
+ * <p>For each representation [<i>unscaled value</i>, <i>scale</i>]
958
+ * on the left, the resulting string is shown on the right.
959
+ * <pre>
960
+ * [123,0] "123"
961
+ * [-123,0] "-123"
962
+ * [123,-1] "1.23E+3"
963
+ * [123,-3] "1.23E+5"
964
+ * [123,1] "12.3"
965
+ * [123,5] "0.00123"
966
+ * [123,10] "1.23E-8"
967
+ * [-123,12] "-1.23E-10"
968
+ * </pre>
969
+ *
970
+ * <b>Notes:</b>
971
+ * <ol>
972
+ *
973
+ * <li>There is a one-to-one mapping between the distinguishable
974
+ * {@code BigDecimal} values and the result of this conversion.
975
+ * That is, every distinguishable {@code BigDecimal} value
976
+ * (unscaled value and scale) has a unique string representation
977
+ * as a result of using {@code toString}. If that string
978
+ * representation is converted back to a {@code BigDecimal} using
979
+ * the {@link #BigDecimal(String)} constructor, then the original
980
+ * value will be recovered.
981
+ *
982
+ * <li>The string produced for a given number is always the same;
983
+ * it is not affected by locale. This means that it can be used
984
+ * as a canonical string representation for exchanging decimal
985
+ * data, or as a key for a Hashtable, etc. Locale-sensitive
986
+ * number formatting and parsing is handled by the {@link
987
+ * java.text.NumberFormat} class and its subclasses.
988
+ *
989
+ * <li>The {@link #toEngineeringString} method may be used for
990
+ * presenting numbers with exponents in engineering notation, and the
991
+ * {@link #setScale(int,RoundingMode) setScale} method may be used for
992
+ * rounding a {@code BigDecimal} so it has a known number of digits after
993
+ * the decimal point.
994
+ *
995
+ * <li>The digit-to-character mapping provided by
996
+ * {@code Character.forDigit} is used.
997
+ *
998
+ * </ol>
999
+ * @return string representation of this {@code BigDecimal}.
1000
+ * @see Character#forDigit
1001
+ * @see #BigDecimal(java.lang.String)
1002
+ */
1003
+ toString(): string;
1004
+
1005
+ /**
1006
+ * Returns a string representation of this {@code BigDecimal},
1007
+ * using engineering notation if an exponent is needed.
1008
+ *
1009
+ * <p>Returns a string that represents the {@code BigDecimal} as
1010
+ * described in the {@link #toString()} method, except that if
1011
+ * exponential notation is used, the power of ten is adjusted to
1012
+ * be a multiple of three (engineering notation) such that the
1013
+ * integer part of nonzero values will be in the range 1 through
1014
+ * 999. If exponential notation is used for zero values, a
1015
+ * decimal point and one or two fractional zero digits are used so
1016
+ * that the scale of the zero value is preserved. Note that
1017
+ * unlike the output of {@link #toString()}, the output of this
1018
+ * method is <em>not</em> guaranteed to recover the same [integer,
1019
+ * scale] pair of this {@code BigDecimal} if the output string is
1020
+ * converting back to a {@code BigDecimal} using the {@linkplain
1021
+ * #BigDecimal(String) string constructor}. The result of this method meets
1022
+ * the weaker constraint of always producing a numerically equal
1023
+ * result from applying the string constructor to the method's output.
1024
+ * @return string representation of this {@code BigDecimal}, using&#xA; engineering notation if an exponent is needed.
1025
+ * @since 1.5
1026
+ */
1027
+ toEngineeringString(): string;
1028
+
1029
+ /**
1030
+ * Returns a string representation of this {@code BigDecimal}
1031
+ * without an exponent field. For values with a positive scale,
1032
+ * the number of digits to the right of the decimal point is used
1033
+ * to indicate scale. For values with a zero or negative scale,
1034
+ * the resulting string is generated as if the value were
1035
+ * converted to a numerically equal value with zero scale and as
1036
+ * if all the trailing zeros of the zero scale value were present
1037
+ * in the result.
1038
+ *
1039
+ * The entire string is prefixed by a minus sign character '-'
1040
+ * (<tt>'&#92;u002D'</tt>) if the unscaled value is less than
1041
+ * zero. No sign character is prefixed if the unscaled value is
1042
+ * zero or positive.
1043
+ *
1044
+ * Note that if the result of this method is passed to the
1045
+ * {@linkplain #BigDecimal(String) string constructor}, only the
1046
+ * numerical value of this {@code BigDecimal} will necessarily be
1047
+ * recovered; the representation of the new {@code BigDecimal}
1048
+ * may have a different scale. In particular, if this
1049
+ * {@code BigDecimal} has a negative scale, the string resulting
1050
+ * from this method will have a scale of zero when processed by
1051
+ * the string constructor.
1052
+ *
1053
+ * (This method behaves analogously to the {@code toString}
1054
+ * method in 1.4 and earlier releases.)
1055
+ * @return a string representation of this {@code BigDecimal}&#xA; without an exponent field.
1056
+ * @since 1.5
1057
+ * @see #toString()
1058
+ * @see #toEngineeringString()
1059
+ */
1060
+ toPlainString(): string;
1061
+
1062
+ /**
1063
+ * Converts this {@code BigDecimal} to a {@code BigInteger}.
1064
+ * This conversion is analogous to the
1065
+ * <i>narrowing primitive conversion</i> from {@code double} to
1066
+ * {@code long} as defined in section 5.1.3 of
1067
+ * <cite>The Java&trade; Language Specification</cite>:
1068
+ * any fractional part of this
1069
+ * {@code BigDecimal} will be discarded. Note that this
1070
+ * conversion can lose information about the precision of the
1071
+ * {@code BigDecimal} value.
1072
+ * <p>
1073
+ * To have an exception thrown if the conversion is inexact (in
1074
+ * other words if a nonzero fractional part is discarded), use the
1075
+ * {@link #toBigIntegerExact()} method.
1076
+ * @return this {@code BigDecimal} converted to a {@code BigInteger}.
1077
+ */
1078
+ toBigInteger(): BigInteger;
1079
+
1080
+ /**
1081
+ * Converts this {@code BigDecimal} to a {@code BigInteger},
1082
+ * checking for lost information. An exception is thrown if this
1083
+ * {@code BigDecimal} has a nonzero fractional part.
1084
+ * @return this {@code BigDecimal} converted to a {@code BigInteger}.
1085
+ * @throws ArithmeticException if {@code this} has a nonzero&#xA; fractional part.
1086
+ * @since 1.5
1087
+ */
1088
+ toBigIntegerExact(): BigInteger;
1089
+
1090
+ /**
1091
+ * Converts this {@code BigDecimal} to a {@code long}.
1092
+ * This conversion is analogous to the
1093
+ * <i>narrowing primitive conversion</i> from {@code double} to
1094
+ * {@code short} as defined in section 5.1.3 of
1095
+ * <cite>The Java&trade; Language Specification</cite>:
1096
+ * any fractional part of this
1097
+ * {@code BigDecimal} will be discarded, and if the resulting
1098
+ * "{@code BigInteger}" is too big to fit in a
1099
+ * {@code long}, only the low-order 64 bits are returned.
1100
+ * Note that this conversion can lose information about the
1101
+ * overall magnitude and precision of this {@code BigDecimal} value as well
1102
+ * as return a result with the opposite sign.
1103
+ * @return this {@code BigDecimal} converted to a {@code long}.
1104
+ */
1105
+ longValue(): number;
1106
+
1107
+ /**
1108
+ * Converts this {@code BigDecimal} to a {@code long}, checking
1109
+ * for lost information. If this {@code BigDecimal} has a
1110
+ * nonzero fractional part or is out of the possible range for a
1111
+ * {@code long} result then an {@code ArithmeticException} is
1112
+ * thrown.
1113
+ * @return this {@code BigDecimal} converted to a {@code long}.
1114
+ * @throws ArithmeticException if {@code this} has a nonzero&#xA; fractional part, or will not fit in a {@code long}.
1115
+ * @since 1.5
1116
+ */
1117
+ longValueExact(): number;
1118
+
1119
+ /**
1120
+ * Converts this {@code BigDecimal} to an {@code int}.
1121
+ * This conversion is analogous to the
1122
+ * <i>narrowing primitive conversion</i> from {@code double} to
1123
+ * {@code short} as defined in section 5.1.3 of
1124
+ * <cite>The Java&trade; Language Specification</cite>:
1125
+ * any fractional part of this
1126
+ * {@code BigDecimal} will be discarded, and if the resulting
1127
+ * "{@code BigInteger}" is too big to fit in an
1128
+ * {@code int}, only the low-order 32 bits are returned.
1129
+ * Note that this conversion can lose information about the
1130
+ * overall magnitude and precision of this {@code BigDecimal}
1131
+ * value as well as return a result with the opposite sign.
1132
+ * @return this {@code BigDecimal} converted to an {@code int}.
1133
+ */
1134
+ intValue(): number;
1135
+
1136
+ /**
1137
+ * Converts this {@code BigDecimal} to an {@code int}, checking
1138
+ * for lost information. If this {@code BigDecimal} has a
1139
+ * nonzero fractional part or is out of the possible range for an
1140
+ * {@code int} result then an {@code ArithmeticException} is
1141
+ * thrown.
1142
+ * @return this {@code BigDecimal} converted to an {@code int}.
1143
+ * @throws ArithmeticException if {@code this} has a nonzero&#xA; fractional part, or will not fit in an {@code int}.
1144
+ * @since 1.5
1145
+ */
1146
+ intValueExact(): number;
1147
+
1148
+ /**
1149
+ * Converts this {@code BigDecimal} to a {@code short}, checking
1150
+ * for lost information. If this {@code BigDecimal} has a
1151
+ * nonzero fractional part or is out of the possible range for a
1152
+ * {@code short} result then an {@code ArithmeticException} is
1153
+ * thrown.
1154
+ * @return this {@code BigDecimal} converted to a {@code short}.
1155
+ * @throws ArithmeticException if {@code this} has a nonzero&#xA; fractional part, or will not fit in a {@code short}.
1156
+ * @since 1.5
1157
+ */
1158
+ shortValueExact(): number;
1159
+
1160
+ /**
1161
+ * Converts this {@code BigDecimal} to a {@code byte}, checking
1162
+ * for lost information. If this {@code BigDecimal} has a
1163
+ * nonzero fractional part or is out of the possible range for a
1164
+ * {@code byte} result then an {@code ArithmeticException} is
1165
+ * thrown.
1166
+ * @return this {@code BigDecimal} converted to a {@code byte}.
1167
+ * @throws ArithmeticException if {@code this} has a nonzero&#xA; fractional part, or will not fit in a {@code byte}.
1168
+ * @since 1.5
1169
+ */
1170
+ byteValueExact(): unknown;
1171
+
1172
+ /**
1173
+ * Converts this {@code BigDecimal} to a {@code float}.
1174
+ * This conversion is similar to the
1175
+ * <i>narrowing primitive conversion</i> from {@code double} to
1176
+ * {@code float} as defined in section 5.1.3 of
1177
+ * <cite>The Java&trade; Language Specification</cite>:
1178
+ * if this {@code BigDecimal} has too great a
1179
+ * magnitude to represent as a {@code float}, it will be
1180
+ * converted to {@link Float#NEGATIVE_INFINITY} or {@link
1181
+ * Float#POSITIVE_INFINITY} as appropriate. Note that even when
1182
+ * the return value is finite, this conversion can lose
1183
+ * information about the precision of the {@code BigDecimal}
1184
+ * value.
1185
+ * @return this {@code BigDecimal} converted to a {@code float}.
1186
+ */
1187
+ floatValue(): number;
1188
+
1189
+ /**
1190
+ * Converts this {@code BigDecimal} to a {@code double}.
1191
+ * This conversion is similar to the
1192
+ * <i>narrowing primitive conversion</i> from {@code double} to
1193
+ * {@code float} as defined in section 5.1.3 of
1194
+ * <cite>The Java&trade; Language Specification</cite>:
1195
+ * if this {@code BigDecimal} has too great a
1196
+ * magnitude represent as a {@code double}, it will be
1197
+ * converted to {@link Double#NEGATIVE_INFINITY} or {@link
1198
+ * Double#POSITIVE_INFINITY} as appropriate. Note that even when
1199
+ * the return value is finite, this conversion can lose
1200
+ * information about the precision of the {@code BigDecimal}
1201
+ * value.
1202
+ * @return this {@code BigDecimal} converted to a {@code double}.
1203
+ */
1204
+ doubleValue(): number;
1205
+
1206
+ /**
1207
+ * Returns the size of an ulp, a unit in the last place, of this
1208
+ * {@code BigDecimal}. An ulp of a nonzero {@code BigDecimal}
1209
+ * value is the positive distance between this value and the
1210
+ * {@code BigDecimal} value next larger in magnitude with the
1211
+ * same number of digits. An ulp of a zero value is numerically
1212
+ * equal to 1 with the scale of {@code this}. The result is
1213
+ * stored with the same scale as {@code this} so the result
1214
+ * for zero and nonzero values is equal to {@code [1,
1215
+ * this.scale()]}.
1216
+ * @return the size of an ulp of {@code this}
1217
+ * @since 1.5
1218
+ */
1219
+ ulp(): BigDecimal;
1220
+
1221
+ /**
1222
+ * The value 0, with a scale of 0.
1223
+ * @since 1.5
1224
+ */
1225
+ ZERO: BigDecimal;
1226
+
1227
+ /**
1228
+ * The value 1, with a scale of 0.
1229
+ * @since 1.5
1230
+ */
1231
+ ONE: BigDecimal;
1232
+
1233
+ /**
1234
+ * The value 10, with a scale of 0.
1235
+ * @since 1.5
1236
+ */
1237
+ TEN: BigDecimal;
1238
+
1239
+ /**
1240
+ * Rounding mode to round away from zero. Always increments the
1241
+ * digit prior to a nonzero discarded fraction. Note that this rounding
1242
+ * mode never decreases the magnitude of the calculated value.
1243
+
1244
+ */
1245
+ ROUND_UP: number;
1246
+
1247
+ /**
1248
+ * Rounding mode to round towards zero. Never increments the digit
1249
+ * prior to a discarded fraction (i.e., truncates). Note that this
1250
+ * rounding mode never increases the magnitude of the calculated value.
1251
+
1252
+ */
1253
+ ROUND_DOWN: number;
1254
+
1255
+ /**
1256
+ * Rounding mode to round towards positive infinity. If the
1257
+ * {@code BigDecimal} is positive, behaves as for
1258
+ * {@code ROUND_UP}; if negative, behaves as for
1259
+ * {@code ROUND_DOWN}. Note that this rounding mode never
1260
+ * decreases the calculated value.
1261
+
1262
+ */
1263
+ ROUND_CEILING: number;
1264
+
1265
+ /**
1266
+ * Rounding mode to round towards negative infinity. If the
1267
+ * {@code BigDecimal} is positive, behave as for
1268
+ * {@code ROUND_DOWN}; if negative, behave as for
1269
+ * {@code ROUND_UP}. Note that this rounding mode never
1270
+ * increases the calculated value.
1271
+
1272
+ */
1273
+ ROUND_FLOOR: number;
1274
+
1275
+ /**
1276
+ * Rounding mode to round towards {@literal "nearest neighbor"}
1277
+ * unless both neighbors are equidistant, in which case round up.
1278
+ * Behaves as for {@code ROUND_UP} if the discarded fraction is
1279
+ * &ge; 0.5; otherwise, behaves as for {@code ROUND_DOWN}. Note
1280
+ * that this is the rounding mode that most of us were taught in
1281
+ * grade school.
1282
+
1283
+ */
1284
+ ROUND_HALF_UP: number;
1285
+
1286
+ /**
1287
+ * Rounding mode to round towards {@literal "nearest neighbor"}
1288
+ * unless both neighbors are equidistant, in which case round
1289
+ * down. Behaves as for {@code ROUND_UP} if the discarded
1290
+ * fraction is {@literal >} 0.5; otherwise, behaves as for
1291
+ * {@code ROUND_DOWN}.
1292
+
1293
+ */
1294
+ ROUND_HALF_DOWN: number;
1295
+
1296
+ /**
1297
+ * Rounding mode to round towards the {@literal "nearest neighbor"}
1298
+ * unless both neighbors are equidistant, in which case, round
1299
+ * towards the even neighbor. Behaves as for
1300
+ * {@code ROUND_HALF_UP} if the digit to the left of the
1301
+ * discarded fraction is odd; behaves as for
1302
+ * {@code ROUND_HALF_DOWN} if it's even. Note that this is the
1303
+ * rounding mode that minimizes cumulative error when applied
1304
+ * repeatedly over a sequence of calculations.
1305
+
1306
+ */
1307
+ ROUND_HALF_EVEN: number;
1308
+
1309
+ /**
1310
+ * Rounding mode to assert that the requested operation has an exact
1311
+ * result, hence no rounding is necessary. If this rounding mode is
1312
+ * specified on an operation that yields an inexact result, an
1313
+ * {@code ArithmeticException} is thrown.
1314
+
1315
+ */
1316
+ ROUND_UNNECESSARY: number;
1317
+ };