code_ownership 2.0.0.pre.1 → 2.0.0.pre.3

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 (973) hide show
  1. checksums.yaml +4 -4
  2. data/.cargo/config +2 -2
  3. data/Cargo.lock +22 -31
  4. data/ext/cargo-vendor/codeowners-0.2.17/.cargo-checksum.json +1 -0
  5. data/ext/cargo-vendor/codeowners-0.2.17/Cargo.lock +1257 -0
  6. data/ext/cargo-vendor/codeowners-0.2.17/Cargo.toml +111 -0
  7. data/ext/cargo-vendor/codeowners-0.2.17/README.md +287 -0
  8. data/ext/cargo-vendor/codeowners-0.2.17/dev/run_benchmarks_for_gv.sh +12 -0
  9. data/ext/cargo-vendor/codeowners-0.2.17/rust-toolchain.toml +4 -0
  10. data/ext/cargo-vendor/codeowners-0.2.17/src/cache/file.rs +179 -0
  11. data/ext/cargo-vendor/codeowners-0.2.17/src/cli.rs +129 -0
  12. data/ext/cargo-vendor/codeowners-0.2.17/src/common_test.rs +358 -0
  13. data/ext/cargo-vendor/codeowners-0.2.17/src/config.rs +126 -0
  14. data/ext/cargo-vendor/codeowners-0.2.17/src/crosscheck.rs +90 -0
  15. data/ext/cargo-vendor/codeowners-0.2.17/src/lib.rs +11 -0
  16. data/ext/cargo-vendor/codeowners-0.2.17/src/main.rs +43 -0
  17. data/ext/cargo-vendor/codeowners-0.2.17/src/ownership/codeowners_file_parser.rs +504 -0
  18. data/ext/cargo-vendor/codeowners-0.2.17/src/ownership/codeowners_query.rs +32 -0
  19. data/ext/cargo-vendor/codeowners-0.2.17/src/ownership/file_generator.rs +203 -0
  20. data/ext/cargo-vendor/codeowners-0.2.17/src/ownership/file_owner_resolver.rs +414 -0
  21. data/ext/cargo-vendor/codeowners-0.2.17/src/ownership/mapper/annotated_file_mapper.rs +158 -0
  22. data/ext/cargo-vendor/codeowners-0.2.17/src/ownership/mapper/package_mapper.rs +220 -0
  23. data/ext/cargo-vendor/codeowners-0.2.17/src/ownership/mapper.rs +249 -0
  24. data/ext/cargo-vendor/codeowners-0.2.17/src/ownership/validator.rs +218 -0
  25. data/ext/cargo-vendor/codeowners-0.2.17/src/ownership.rs +223 -0
  26. data/ext/cargo-vendor/codeowners-0.2.17/src/path_utils.rs +49 -0
  27. data/ext/cargo-vendor/codeowners-0.2.17/src/project.rs +229 -0
  28. data/ext/cargo-vendor/codeowners-0.2.17/src/project_builder.rs +337 -0
  29. data/ext/cargo-vendor/codeowners-0.2.17/src/project_file_builder.rs +107 -0
  30. data/ext/cargo-vendor/codeowners-0.2.17/src/runner/api.rs +141 -0
  31. data/ext/cargo-vendor/codeowners-0.2.17/src/runner/types.rs +37 -0
  32. data/ext/cargo-vendor/codeowners-0.2.17/src/runner.rs +390 -0
  33. data/ext/cargo-vendor/codeowners-0.2.17/src/tracked_files.rs +58 -0
  34. data/ext/cargo-vendor/codeowners-0.2.17/tests/common/mod.rs +179 -0
  35. data/ext/cargo-vendor/codeowners-0.2.17/tests/crosscheck_owners_test.rs +74 -0
  36. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/javascript_only_project/.github/CODEOWNERS +9 -0
  37. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/javascript_only_project/.keep +3 -0
  38. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/javascript_only_project/config/code_ownership.yml +12 -0
  39. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/javascript_only_project/config/teams/design.yml +7 -0
  40. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/javascript_only_project/config/teams/frontend.yml +6 -0
  41. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/javascript_only_project/frontend/apps/public/index.tsx +6 -0
  42. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/javascript_only_project/frontend/packages/dashboard/package.json +9 -0
  43. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/javascript_only_project/frontend/packages/dashboard/src/index.tsx +6 -0
  44. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/javascript_only_project/frontend/packages/ui-kit/.codeowner +3 -0
  45. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/javascript_only_project/frontend/packages/ui-kit/src/button.tsx +5 -0
  46. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/multiple-directory-owners/config/code_ownership.yml +10 -0
  47. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project/.github/CODEOWNERS +41 -0
  48. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project/config/code_ownership.yml +10 -0
  49. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project/javascript/packages/list/page-admin.tsx +1 -0
  50. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project/ruby/app/models/payroll.rb +3 -0
  51. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project/ruby/app/views/foos/edit.erb +1 -0
  52. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project/ruby/app/views/foos/index.html.erb +1 -0
  53. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project/ruby/app/views/foos/new.html.erb +1 -0
  54. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/.github/CODEOWNERS +53 -0
  55. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/config/code_ownership.yml +10 -0
  56. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/config/teams/brewers.yml +11 -0
  57. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/config/teams/cubs.yml +9 -0
  58. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/config/teams/giants.yml +8 -0
  59. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/config/teams/rockies.yml +8 -0
  60. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/frontend/packages/components/datepicker/package.json +5 -0
  61. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/frontend/packages/components/datepicker/src/picks/dp.tsx +3 -0
  62. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/frontend/packages/components/list/package.json +5 -0
  63. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/frontend/packages/components/list/src/item.tsx +3 -0
  64. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/frontend/packages/components/textfield/package.json +5 -0
  65. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/frontend/packages/components/textfield/src/field.tsx +3 -0
  66. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/frontend/packages/components/textfield/src/fields/small.tsx +3 -0
  67. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/gems/apollo/lib/apollo.rb +6 -0
  68. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/gems/ivy/lib/ivy.rb +6 -0
  69. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/gems/lager/lib/lager.rb +6 -0
  70. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/gems/summit/lib/summit.rb +6 -0
  71. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/packs/games/package.yml +1 -0
  72. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/packs/locations/app/services/capacity.rb +0 -0
  73. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/packs/locations/package.yml +1 -0
  74. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/packs/schedule/app/services/date.rb +0 -0
  75. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/packs/schedule/package.yml +1 -0
  76. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/ruby/app/brewers/lib/util.rb +3 -0
  77. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/ruby/app/brewers/services/play.rb +9 -0
  78. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/ruby/app/cubs/.codeowner +3 -0
  79. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/ruby/app/cubs/services/models/.codeowner +1 -0
  80. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/ruby/app/cubs/services/models/db/price.rb +5 -0
  81. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/ruby/app/cubs/services/models/entertainment.rb +0 -0
  82. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/ruby/app/cubs/services/play.rb +5 -0
  83. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/ruby/app/giants/services/play.rb +0 -0
  84. data/ext/cargo-vendor/codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/ruby/app/rockies/services/play.rb +0 -0
  85. data/ext/cargo-vendor/codeowners-0.2.17/tests/invalid_project_test.rs +144 -0
  86. data/ext/cargo-vendor/codeowners-0.2.17/tests/multiple_directory_owners_test.rs +41 -0
  87. data/ext/cargo-vendor/codeowners-0.2.17/tests/runner_api.rs +181 -0
  88. data/ext/cargo-vendor/codeowners-0.2.17/tests/untracked_files_test.rs +38 -0
  89. data/ext/cargo-vendor/codeowners-0.2.17/tests/valid_project_test.rs +348 -0
  90. data/ext/cargo-vendor/codeowners-0.2.17/tests/valid_project_with_overrides_test.rs +38 -0
  91. data/ext/cargo-vendor/codeowners-0.2.17/tmp/.gitkeep +0 -0
  92. data/ext/cargo-vendor/glob-0.3.3/.cargo-checksum.json +1 -0
  93. data/ext/cargo-vendor/glob-0.3.3/.cargo_vcs_info.json +6 -0
  94. data/ext/cargo-vendor/glob-0.3.3/.github/workflows/rust.yml +99 -0
  95. data/ext/cargo-vendor/glob-0.3.3/CHANGELOG.md +44 -0
  96. data/ext/cargo-vendor/glob-0.3.3/Cargo.lock +107 -0
  97. data/ext/cargo-vendor/glob-0.3.3/Cargo.toml +45 -0
  98. data/ext/cargo-vendor/glob-0.3.3/Cargo.toml.orig +18 -0
  99. data/ext/cargo-vendor/glob-0.3.3/README.md +38 -0
  100. data/ext/cargo-vendor/glob-0.3.3/src/lib.rs +1511 -0
  101. data/ext/cargo-vendor/glob-0.3.3/tests/glob-std.rs +477 -0
  102. data/ext/cargo-vendor/indexmap-2.11.0/.cargo-checksum.json +1 -0
  103. data/ext/cargo-vendor/indexmap-2.11.0/.cargo_vcs_info.json +6 -0
  104. data/ext/cargo-vendor/indexmap-2.11.0/.github/workflows/ci.yml +165 -0
  105. data/ext/cargo-vendor/indexmap-2.11.0/Cargo.lock +243 -0
  106. data/ext/cargo-vendor/indexmap-2.11.0/Cargo.toml +148 -0
  107. data/ext/cargo-vendor/indexmap-2.11.0/Cargo.toml.orig +62 -0
  108. data/ext/cargo-vendor/indexmap-2.11.0/RELEASES.md +575 -0
  109. data/ext/cargo-vendor/indexmap-2.11.0/src/lib.rs +290 -0
  110. data/ext/cargo-vendor/indexmap-2.11.0/src/map/core/entry.rs +625 -0
  111. data/ext/cargo-vendor/indexmap-2.11.0/src/map/core.rs +764 -0
  112. data/ext/cargo-vendor/indexmap-2.11.0/src/map/mutable.rs +165 -0
  113. data/ext/cargo-vendor/indexmap-2.11.0/src/map/slice.rs +800 -0
  114. data/ext/cargo-vendor/indexmap-2.11.0/src/map/tests.rs +1312 -0
  115. data/ext/cargo-vendor/indexmap-2.11.0/src/map.rs +1832 -0
  116. data/ext/cargo-vendor/indexmap-2.11.0/src/rayon/map.rs +686 -0
  117. data/ext/cargo-vendor/indexmap-2.11.0/src/rayon/set.rs +777 -0
  118. data/ext/cargo-vendor/indexmap-2.11.0/src/set/mutable.rs +86 -0
  119. data/ext/cargo-vendor/indexmap-2.11.0/src/set/slice.rs +427 -0
  120. data/ext/cargo-vendor/indexmap-2.11.0/src/set/tests.rs +1060 -0
  121. data/ext/cargo-vendor/indexmap-2.11.0/src/set.rs +1454 -0
  122. data/ext/cargo-vendor/indexmap-2.11.0/src/sval.rs +36 -0
  123. data/ext/cargo-vendor/indexmap-2.11.0/tests/quick.rs +894 -0
  124. data/ext/cargo-vendor/rayon-1.11.0/.cargo-checksum.json +1 -0
  125. data/ext/cargo-vendor/rayon-1.11.0/.cargo_vcs_info.json +6 -0
  126. data/ext/cargo-vendor/rayon-1.11.0/Cargo.lock +318 -0
  127. data/ext/cargo-vendor/rayon-1.11.0/Cargo.toml +130 -0
  128. data/ext/cargo-vendor/rayon-1.11.0/Cargo.toml.orig +57 -0
  129. data/ext/cargo-vendor/rayon-1.11.0/FAQ.md +213 -0
  130. data/ext/cargo-vendor/rayon-1.11.0/README.md +150 -0
  131. data/ext/cargo-vendor/rayon-1.11.0/RELEASES.md +922 -0
  132. data/ext/cargo-vendor/rayon-1.11.0/src/array.rs +85 -0
  133. data/ext/cargo-vendor/rayon-1.11.0/src/collections/binary_heap.rs +129 -0
  134. data/ext/cargo-vendor/rayon-1.11.0/src/collections/btree_map.rs +66 -0
  135. data/ext/cargo-vendor/rayon-1.11.0/src/collections/btree_set.rs +52 -0
  136. data/ext/cargo-vendor/rayon-1.11.0/src/collections/hash_map.rs +93 -0
  137. data/ext/cargo-vendor/rayon-1.11.0/src/collections/hash_set.rs +79 -0
  138. data/ext/cargo-vendor/rayon-1.11.0/src/collections/linked_list.rs +66 -0
  139. data/ext/cargo-vendor/rayon-1.11.0/src/collections/mod.rs +84 -0
  140. data/ext/cargo-vendor/rayon-1.11.0/src/collections/vec_deque.rs +159 -0
  141. data/ext/cargo-vendor/rayon-1.11.0/src/iter/blocks.rs +129 -0
  142. data/ext/cargo-vendor/rayon-1.11.0/src/iter/chain.rs +258 -0
  143. data/ext/cargo-vendor/rayon-1.11.0/src/iter/chunks.rs +216 -0
  144. data/ext/cargo-vendor/rayon-1.11.0/src/iter/cloned.rs +219 -0
  145. data/ext/cargo-vendor/rayon-1.11.0/src/iter/collect/mod.rs +114 -0
  146. data/ext/cargo-vendor/rayon-1.11.0/src/iter/collect/test.rs +368 -0
  147. data/ext/cargo-vendor/rayon-1.11.0/src/iter/copied.rs +219 -0
  148. data/ext/cargo-vendor/rayon-1.11.0/src/iter/empty.rs +108 -0
  149. data/ext/cargo-vendor/rayon-1.11.0/src/iter/enumerate.rs +128 -0
  150. data/ext/cargo-vendor/rayon-1.11.0/src/iter/filter.rs +137 -0
  151. data/ext/cargo-vendor/rayon-1.11.0/src/iter/filter_map.rs +141 -0
  152. data/ext/cargo-vendor/rayon-1.11.0/src/iter/find_first_last/mod.rs +230 -0
  153. data/ext/cargo-vendor/rayon-1.11.0/src/iter/find_first_last/test.rs +102 -0
  154. data/ext/cargo-vendor/rayon-1.11.0/src/iter/flat_map.rs +153 -0
  155. data/ext/cargo-vendor/rayon-1.11.0/src/iter/flat_map_iter.rs +145 -0
  156. data/ext/cargo-vendor/rayon-1.11.0/src/iter/flatten.rs +134 -0
  157. data/ext/cargo-vendor/rayon-1.11.0/src/iter/flatten_iter.rs +124 -0
  158. data/ext/cargo-vendor/rayon-1.11.0/src/iter/fold.rs +289 -0
  159. data/ext/cargo-vendor/rayon-1.11.0/src/iter/fold_chunks.rs +224 -0
  160. data/ext/cargo-vendor/rayon-1.11.0/src/iter/fold_chunks_with.rs +220 -0
  161. data/ext/cargo-vendor/rayon-1.11.0/src/iter/from_par_iter.rs +280 -0
  162. data/ext/cargo-vendor/rayon-1.11.0/src/iter/inspect.rs +253 -0
  163. data/ext/cargo-vendor/rayon-1.11.0/src/iter/interleave.rs +326 -0
  164. data/ext/cargo-vendor/rayon-1.11.0/src/iter/interleave_shortest.rs +80 -0
  165. data/ext/cargo-vendor/rayon-1.11.0/src/iter/intersperse.rs +401 -0
  166. data/ext/cargo-vendor/rayon-1.11.0/src/iter/len.rs +262 -0
  167. data/ext/cargo-vendor/rayon-1.11.0/src/iter/map.rs +255 -0
  168. data/ext/cargo-vendor/rayon-1.11.0/src/iter/map_with.rs +565 -0
  169. data/ext/cargo-vendor/rayon-1.11.0/src/iter/mod.rs +3627 -0
  170. data/ext/cargo-vendor/rayon-1.11.0/src/iter/multizip.rs +335 -0
  171. data/ext/cargo-vendor/rayon-1.11.0/src/iter/once.rs +70 -0
  172. data/ext/cargo-vendor/rayon-1.11.0/src/iter/panic_fuse.rs +338 -0
  173. data/ext/cargo-vendor/rayon-1.11.0/src/iter/par_bridge.rs +157 -0
  174. data/ext/cargo-vendor/rayon-1.11.0/src/iter/plumbing/mod.rs +476 -0
  175. data/ext/cargo-vendor/rayon-1.11.0/src/iter/positions.rs +133 -0
  176. data/ext/cargo-vendor/rayon-1.11.0/src/iter/repeat.rs +295 -0
  177. data/ext/cargo-vendor/rayon-1.11.0/src/iter/rev.rs +119 -0
  178. data/ext/cargo-vendor/rayon-1.11.0/src/iter/skip.rs +93 -0
  179. data/ext/cargo-vendor/rayon-1.11.0/src/iter/skip_any.rs +140 -0
  180. data/ext/cargo-vendor/rayon-1.11.0/src/iter/skip_any_while.rs +162 -0
  181. data/ext/cargo-vendor/rayon-1.11.0/src/iter/splitter.rs +172 -0
  182. data/ext/cargo-vendor/rayon-1.11.0/src/iter/step_by.rs +135 -0
  183. data/ext/cargo-vendor/rayon-1.11.0/src/iter/take.rs +84 -0
  184. data/ext/cargo-vendor/rayon-1.11.0/src/iter/take_any.rs +140 -0
  185. data/ext/cargo-vendor/rayon-1.11.0/src/iter/take_any_while.rs +162 -0
  186. data/ext/cargo-vendor/rayon-1.11.0/src/iter/test.rs +2392 -0
  187. data/ext/cargo-vendor/rayon-1.11.0/src/iter/try_fold.rs +282 -0
  188. data/ext/cargo-vendor/rayon-1.11.0/src/iter/unzip.rs +524 -0
  189. data/ext/cargo-vendor/rayon-1.11.0/src/iter/update.rs +323 -0
  190. data/ext/cargo-vendor/rayon-1.11.0/src/iter/walk_tree.rs +524 -0
  191. data/ext/cargo-vendor/rayon-1.11.0/src/iter/while_some.rs +150 -0
  192. data/ext/cargo-vendor/rayon-1.11.0/src/iter/zip.rs +153 -0
  193. data/ext/cargo-vendor/rayon-1.11.0/src/iter/zip_eq.rs +67 -0
  194. data/ext/cargo-vendor/rayon-1.11.0/src/lib.rs +156 -0
  195. data/ext/cargo-vendor/rayon-1.11.0/src/math.rs +25 -0
  196. data/ext/cargo-vendor/rayon-1.11.0/src/option.rs +197 -0
  197. data/ext/cargo-vendor/rayon-1.11.0/src/range.rs +457 -0
  198. data/ext/cargo-vendor/rayon-1.11.0/src/range_inclusive.rs +381 -0
  199. data/ext/cargo-vendor/rayon-1.11.0/src/result.rs +132 -0
  200. data/ext/cargo-vendor/rayon-1.11.0/src/slice/chunk_by.rs +239 -0
  201. data/ext/cargo-vendor/rayon-1.11.0/src/slice/chunks.rs +387 -0
  202. data/ext/cargo-vendor/rayon-1.11.0/src/slice/mod.rs +1242 -0
  203. data/ext/cargo-vendor/rayon-1.11.0/src/slice/rchunks.rs +385 -0
  204. data/ext/cargo-vendor/rayon-1.11.0/src/slice/sort.rs +1686 -0
  205. data/ext/cargo-vendor/rayon-1.11.0/src/slice/test.rs +216 -0
  206. data/ext/cargo-vendor/rayon-1.11.0/src/str.rs +1005 -0
  207. data/ext/cargo-vendor/rayon-1.11.0/src/vec.rs +292 -0
  208. data/ext/cargo-vendor/rayon-1.11.0/tests/clones.rs +222 -0
  209. data/ext/cargo-vendor/rayon-1.11.0/tests/collect.rs +113 -0
  210. data/ext/cargo-vendor/rayon-1.11.0/tests/debug.rs +233 -0
  211. data/ext/cargo-vendor/rayon-1.11.0/tests/named-threads.rs +25 -0
  212. data/ext/cargo-vendor/rayon-1.11.0/tests/producer_split_at.rs +386 -0
  213. data/ext/cargo-vendor/rayon-1.11.0/tests/sort-panic-safe.rs +164 -0
  214. data/ext/cargo-vendor/rayon-1.11.0/tests/str.rs +122 -0
  215. data/ext/cargo-vendor/rayon-core-1.13.0/.cargo-checksum.json +1 -0
  216. data/ext/cargo-vendor/rayon-core-1.13.0/.cargo_vcs_info.json +6 -0
  217. data/ext/cargo-vendor/rayon-core-1.13.0/Cargo.lock +309 -0
  218. data/ext/cargo-vendor/rayon-core-1.13.0/Cargo.toml +93 -0
  219. data/ext/cargo-vendor/rayon-core-1.13.0/Cargo.toml.orig +35 -0
  220. data/ext/cargo-vendor/rayon-core-1.13.0/README.md +11 -0
  221. data/ext/cargo-vendor/rayon-core-1.13.0/src/broadcast/mod.rs +150 -0
  222. data/ext/cargo-vendor/rayon-core-1.13.0/src/join/mod.rs +186 -0
  223. data/ext/cargo-vendor/rayon-core-1.13.0/src/join/test.rs +150 -0
  224. data/ext/cargo-vendor/rayon-core-1.13.0/src/latch.rs +457 -0
  225. data/ext/cargo-vendor/rayon-core-1.13.0/src/lib.rs +864 -0
  226. data/ext/cargo-vendor/rayon-core-1.13.0/src/registry.rs +1002 -0
  227. data/ext/cargo-vendor/rayon-core-1.13.0/src/scope/mod.rs +773 -0
  228. data/ext/cargo-vendor/rayon-core-1.13.0/src/scope/test.rs +621 -0
  229. data/ext/cargo-vendor/rayon-core-1.13.0/src/sleep/README.md +219 -0
  230. data/ext/cargo-vendor/rayon-core-1.13.0/src/sleep/counters.rs +273 -0
  231. data/ext/cargo-vendor/rayon-core-1.13.0/src/sleep/mod.rs +324 -0
  232. data/ext/cargo-vendor/rayon-core-1.13.0/src/spawn/mod.rs +163 -0
  233. data/ext/cargo-vendor/rayon-core-1.13.0/src/spawn/test.rs +255 -0
  234. data/ext/cargo-vendor/rayon-core-1.13.0/src/test.rs +200 -0
  235. data/ext/cargo-vendor/rayon-core-1.13.0/src/thread_pool/mod.rs +502 -0
  236. data/ext/cargo-vendor/rayon-core-1.13.0/src/thread_pool/test.rs +418 -0
  237. data/ext/cargo-vendor/rayon-core-1.13.0/tests/use_current_thread.rs +57 -0
  238. data/ext/cargo-vendor/serde_json-1.0.143/.cargo-checksum.json +1 -0
  239. data/ext/cargo-vendor/serde_json-1.0.143/.cargo_vcs_info.json +6 -0
  240. data/ext/cargo-vendor/serde_json-1.0.143/.github/workflows/ci.yml +156 -0
  241. data/ext/cargo-vendor/serde_json-1.0.143/Cargo.lock +419 -0
  242. data/ext/cargo-vendor/serde_json-1.0.143/Cargo.toml +157 -0
  243. data/ext/cargo-vendor/serde_json-1.0.143/Cargo.toml.orig +91 -0
  244. data/ext/cargo-vendor/serde_json-1.0.143/src/lib.rs +438 -0
  245. data/ext/cargo-vendor/serde_json-1.0.143/src/map.rs +1181 -0
  246. data/ext/cargo-vendor/serde_json-1.0.143/src/ser.rs +2285 -0
  247. data/ext/cargo-vendor/serde_json-1.0.143/src/value/de.rs +1507 -0
  248. data/ext/cargo-vendor/tempfile-3.21.0/.cargo-checksum.json +1 -0
  249. data/ext/cargo-vendor/tempfile-3.21.0/.cargo_vcs_info.json +6 -0
  250. data/ext/cargo-vendor/tempfile-3.21.0/.github/workflows/ci.yml +109 -0
  251. data/ext/cargo-vendor/tempfile-3.21.0/CHANGELOG.md +364 -0
  252. data/ext/cargo-vendor/tempfile-3.21.0/Cargo.lock +196 -0
  253. data/ext/cargo-vendor/tempfile-3.21.0/Cargo.toml +98 -0
  254. data/ext/cargo-vendor/tempfile-3.21.0/Cargo.toml.orig +47 -0
  255. data/ext/cargo-vendor/winapi-util-0.1.10/.cargo-checksum.json +1 -0
  256. data/ext/cargo-vendor/winapi-util-0.1.10/.cargo_vcs_info.json +6 -0
  257. data/ext/cargo-vendor/winapi-util-0.1.10/.github/FUNDING.yml +1 -0
  258. data/ext/cargo-vendor/winapi-util-0.1.10/Cargo.lock +83 -0
  259. data/ext/cargo-vendor/winapi-util-0.1.10/Cargo.toml +54 -0
  260. data/ext/cargo-vendor/winapi-util-0.1.10/Cargo.toml.orig +25 -0
  261. data/ext/code_ownership/Cargo.toml +9 -9
  262. data/ext/code_ownership/src/lib.rs +40 -6
  263. data/lib/code_ownership/cli.rb +5 -18
  264. data/lib/code_ownership/private/for_file_output_builder.rb +83 -0
  265. data/lib/code_ownership/private/team_finder.rb +21 -7
  266. data/lib/code_ownership/version.rb +1 -1
  267. data/lib/code_ownership.rb +173 -6
  268. metadata +513 -706
  269. data/ext/cargo-vendor/codeowners-0.2.7/.cargo-checksum.json +0 -1
  270. data/ext/cargo-vendor/codeowners-0.2.7/Cargo.lock +0 -1230
  271. data/ext/cargo-vendor/codeowners-0.2.7/Cargo.toml +0 -95
  272. data/ext/cargo-vendor/codeowners-0.2.7/README.md +0 -204
  273. data/ext/cargo-vendor/codeowners-0.2.7/dev/run_benchmarks_for_gv.sh +0 -13
  274. data/ext/cargo-vendor/codeowners-0.2.7/rust-toolchain.toml +0 -4
  275. data/ext/cargo-vendor/codeowners-0.2.7/src/cache/file.rs +0 -181
  276. data/ext/cargo-vendor/codeowners-0.2.7/src/cli.rs +0 -119
  277. data/ext/cargo-vendor/codeowners-0.2.7/src/common_test.rs +0 -338
  278. data/ext/cargo-vendor/codeowners-0.2.7/src/config.rs +0 -118
  279. data/ext/cargo-vendor/codeowners-0.2.7/src/lib.rs +0 -8
  280. data/ext/cargo-vendor/codeowners-0.2.7/src/main.rs +0 -43
  281. data/ext/cargo-vendor/codeowners-0.2.7/src/ownership/file_generator.rs +0 -203
  282. data/ext/cargo-vendor/codeowners-0.2.7/src/ownership/for_file_fast.rs +0 -425
  283. data/ext/cargo-vendor/codeowners-0.2.7/src/ownership/mapper/package_mapper.rs +0 -220
  284. data/ext/cargo-vendor/codeowners-0.2.7/src/ownership/mapper/team_file_mapper.rs +0 -123
  285. data/ext/cargo-vendor/codeowners-0.2.7/src/ownership/mapper.rs +0 -249
  286. data/ext/cargo-vendor/codeowners-0.2.7/src/ownership/parser.rs +0 -486
  287. data/ext/cargo-vendor/codeowners-0.2.7/src/ownership/tests.rs +0 -219
  288. data/ext/cargo-vendor/codeowners-0.2.7/src/ownership/validator.rs +0 -218
  289. data/ext/cargo-vendor/codeowners-0.2.7/src/ownership.rs +0 -220
  290. data/ext/cargo-vendor/codeowners-0.2.7/src/project.rs +0 -229
  291. data/ext/cargo-vendor/codeowners-0.2.7/src/project_builder.rs +0 -319
  292. data/ext/cargo-vendor/codeowners-0.2.7/src/project_file_builder.rs +0 -75
  293. data/ext/cargo-vendor/codeowners-0.2.7/src/runner.rs +0 -312
  294. data/ext/cargo-vendor/codeowners-0.2.7/tests/common/mod.rs +0 -113
  295. data/ext/cargo-vendor/codeowners-0.2.7/tests/fixtures/multiple-directory-owners/config/code_ownership.yml +0 -10
  296. data/ext/cargo-vendor/codeowners-0.2.7/tests/fixtures/valid_project/.github/CODEOWNERS +0 -37
  297. data/ext/cargo-vendor/codeowners-0.2.7/tests/fixtures/valid_project/config/code_ownership.yml +0 -10
  298. data/ext/cargo-vendor/codeowners-0.2.7/tests/fixtures/valid_project/ruby/app/models/payroll.rb +0 -3
  299. data/ext/cargo-vendor/codeowners-0.2.7/tests/invalid_project_test.rs +0 -90
  300. data/ext/cargo-vendor/codeowners-0.2.7/tests/multiple_directory_owners_test.rs +0 -35
  301. data/ext/cargo-vendor/codeowners-0.2.7/tests/valid_project_test.rs +0 -284
  302. data/ext/cargo-vendor/glob-0.3.2/.cargo-checksum.json +0 -1
  303. data/ext/cargo-vendor/glob-0.3.2/.cargo_vcs_info.json +0 -6
  304. data/ext/cargo-vendor/glob-0.3.2/.github/workflows/rust.yml +0 -65
  305. data/ext/cargo-vendor/glob-0.3.2/CHANGELOG.md +0 -33
  306. data/ext/cargo-vendor/glob-0.3.2/Cargo.lock +0 -107
  307. data/ext/cargo-vendor/glob-0.3.2/Cargo.toml +0 -45
  308. data/ext/cargo-vendor/glob-0.3.2/Cargo.toml.orig +0 -19
  309. data/ext/cargo-vendor/glob-0.3.2/README.md +0 -37
  310. data/ext/cargo-vendor/glob-0.3.2/src/lib.rs +0 -1501
  311. data/ext/cargo-vendor/glob-0.3.2/tests/glob-std.rs +0 -474
  312. data/ext/cargo-vendor/indexmap-2.10.0/.cargo-checksum.json +0 -1
  313. data/ext/cargo-vendor/indexmap-2.10.0/.cargo_vcs_info.json +0 -6
  314. data/ext/cargo-vendor/indexmap-2.10.0/.github/workflows/ci.yml +0 -159
  315. data/ext/cargo-vendor/indexmap-2.10.0/Cargo.lock +0 -236
  316. data/ext/cargo-vendor/indexmap-2.10.0/Cargo.toml +0 -142
  317. data/ext/cargo-vendor/indexmap-2.10.0/Cargo.toml.orig +0 -61
  318. data/ext/cargo-vendor/indexmap-2.10.0/RELEASES.md +0 -563
  319. data/ext/cargo-vendor/indexmap-2.10.0/src/lib.rs +0 -288
  320. data/ext/cargo-vendor/indexmap-2.10.0/src/map/core/entry.rs +0 -574
  321. data/ext/cargo-vendor/indexmap-2.10.0/src/map/core.rs +0 -735
  322. data/ext/cargo-vendor/indexmap-2.10.0/src/map/mutable.rs +0 -165
  323. data/ext/cargo-vendor/indexmap-2.10.0/src/map/slice.rs +0 -751
  324. data/ext/cargo-vendor/indexmap-2.10.0/src/map/tests.rs +0 -1228
  325. data/ext/cargo-vendor/indexmap-2.10.0/src/map.rs +0 -1697
  326. data/ext/cargo-vendor/indexmap-2.10.0/src/rayon/map.rs +0 -662
  327. data/ext/cargo-vendor/indexmap-2.10.0/src/rayon/set.rs +0 -755
  328. data/ext/cargo-vendor/indexmap-2.10.0/src/set/mutable.rs +0 -86
  329. data/ext/cargo-vendor/indexmap-2.10.0/src/set/slice.rs +0 -380
  330. data/ext/cargo-vendor/indexmap-2.10.0/src/set/tests.rs +0 -999
  331. data/ext/cargo-vendor/indexmap-2.10.0/src/set.rs +0 -1340
  332. data/ext/cargo-vendor/indexmap-2.10.0/tests/quick.rs +0 -800
  333. data/ext/cargo-vendor/rayon-1.10.0/.cargo-checksum.json +0 -1
  334. data/ext/cargo-vendor/rayon-1.10.0/.cargo_vcs_info.json +0 -6
  335. data/ext/cargo-vendor/rayon-1.10.0/Cargo.toml +0 -61
  336. data/ext/cargo-vendor/rayon-1.10.0/Cargo.toml.orig +0 -39
  337. data/ext/cargo-vendor/rayon-1.10.0/FAQ.md +0 -227
  338. data/ext/cargo-vendor/rayon-1.10.0/README.md +0 -151
  339. data/ext/cargo-vendor/rayon-1.10.0/RELEASES.md +0 -909
  340. data/ext/cargo-vendor/rayon-1.10.0/src/array.rs +0 -85
  341. data/ext/cargo-vendor/rayon-1.10.0/src/collections/binary_heap.rs +0 -120
  342. data/ext/cargo-vendor/rayon-1.10.0/src/collections/btree_map.rs +0 -66
  343. data/ext/cargo-vendor/rayon-1.10.0/src/collections/btree_set.rs +0 -52
  344. data/ext/cargo-vendor/rayon-1.10.0/src/collections/hash_map.rs +0 -96
  345. data/ext/cargo-vendor/rayon-1.10.0/src/collections/hash_set.rs +0 -80
  346. data/ext/cargo-vendor/rayon-1.10.0/src/collections/linked_list.rs +0 -66
  347. data/ext/cargo-vendor/rayon-1.10.0/src/collections/mod.rs +0 -84
  348. data/ext/cargo-vendor/rayon-1.10.0/src/collections/vec_deque.rs +0 -159
  349. data/ext/cargo-vendor/rayon-1.10.0/src/iter/blocks.rs +0 -131
  350. data/ext/cargo-vendor/rayon-1.10.0/src/iter/chain.rs +0 -267
  351. data/ext/cargo-vendor/rayon-1.10.0/src/iter/chunks.rs +0 -224
  352. data/ext/cargo-vendor/rayon-1.10.0/src/iter/cloned.rs +0 -223
  353. data/ext/cargo-vendor/rayon-1.10.0/src/iter/collect/mod.rs +0 -116
  354. data/ext/cargo-vendor/rayon-1.10.0/src/iter/collect/test.rs +0 -373
  355. data/ext/cargo-vendor/rayon-1.10.0/src/iter/copied.rs +0 -223
  356. data/ext/cargo-vendor/rayon-1.10.0/src/iter/empty.rs +0 -104
  357. data/ext/cargo-vendor/rayon-1.10.0/src/iter/enumerate.rs +0 -133
  358. data/ext/cargo-vendor/rayon-1.10.0/src/iter/filter.rs +0 -141
  359. data/ext/cargo-vendor/rayon-1.10.0/src/iter/filter_map.rs +0 -142
  360. data/ext/cargo-vendor/rayon-1.10.0/src/iter/find_first_last/mod.rs +0 -230
  361. data/ext/cargo-vendor/rayon-1.10.0/src/iter/find_first_last/test.rs +0 -105
  362. data/ext/cargo-vendor/rayon-1.10.0/src/iter/flat_map.rs +0 -154
  363. data/ext/cargo-vendor/rayon-1.10.0/src/iter/flat_map_iter.rs +0 -147
  364. data/ext/cargo-vendor/rayon-1.10.0/src/iter/flatten.rs +0 -140
  365. data/ext/cargo-vendor/rayon-1.10.0/src/iter/flatten_iter.rs +0 -132
  366. data/ext/cargo-vendor/rayon-1.10.0/src/iter/fold.rs +0 -302
  367. data/ext/cargo-vendor/rayon-1.10.0/src/iter/fold_chunks.rs +0 -236
  368. data/ext/cargo-vendor/rayon-1.10.0/src/iter/fold_chunks_with.rs +0 -231
  369. data/ext/cargo-vendor/rayon-1.10.0/src/iter/from_par_iter.rs +0 -310
  370. data/ext/cargo-vendor/rayon-1.10.0/src/iter/inspect.rs +0 -257
  371. data/ext/cargo-vendor/rayon-1.10.0/src/iter/interleave.rs +0 -335
  372. data/ext/cargo-vendor/rayon-1.10.0/src/iter/interleave_shortest.rs +0 -85
  373. data/ext/cargo-vendor/rayon-1.10.0/src/iter/intersperse.rs +0 -410
  374. data/ext/cargo-vendor/rayon-1.10.0/src/iter/len.rs +0 -270
  375. data/ext/cargo-vendor/rayon-1.10.0/src/iter/map.rs +0 -259
  376. data/ext/cargo-vendor/rayon-1.10.0/src/iter/map_with.rs +0 -573
  377. data/ext/cargo-vendor/rayon-1.10.0/src/iter/mod.rs +0 -3656
  378. data/ext/cargo-vendor/rayon-1.10.0/src/iter/multizip.rs +0 -338
  379. data/ext/cargo-vendor/rayon-1.10.0/src/iter/once.rs +0 -68
  380. data/ext/cargo-vendor/rayon-1.10.0/src/iter/panic_fuse.rs +0 -342
  381. data/ext/cargo-vendor/rayon-1.10.0/src/iter/par_bridge.rs +0 -159
  382. data/ext/cargo-vendor/rayon-1.10.0/src/iter/plumbing/mod.rs +0 -483
  383. data/ext/cargo-vendor/rayon-1.10.0/src/iter/positions.rs +0 -137
  384. data/ext/cargo-vendor/rayon-1.10.0/src/iter/repeat.rs +0 -241
  385. data/ext/cargo-vendor/rayon-1.10.0/src/iter/rev.rs +0 -123
  386. data/ext/cargo-vendor/rayon-1.10.0/src/iter/skip.rs +0 -94
  387. data/ext/cargo-vendor/rayon-1.10.0/src/iter/skip_any.rs +0 -144
  388. data/ext/cargo-vendor/rayon-1.10.0/src/iter/skip_any_while.rs +0 -166
  389. data/ext/cargo-vendor/rayon-1.10.0/src/iter/splitter.rs +0 -174
  390. data/ext/cargo-vendor/rayon-1.10.0/src/iter/step_by.rs +0 -141
  391. data/ext/cargo-vendor/rayon-1.10.0/src/iter/take.rs +0 -85
  392. data/ext/cargo-vendor/rayon-1.10.0/src/iter/take_any.rs +0 -144
  393. data/ext/cargo-vendor/rayon-1.10.0/src/iter/take_any_while.rs +0 -166
  394. data/ext/cargo-vendor/rayon-1.10.0/src/iter/test.rs +0 -2333
  395. data/ext/cargo-vendor/rayon-1.10.0/src/iter/try_fold.rs +0 -298
  396. data/ext/cargo-vendor/rayon-1.10.0/src/iter/unzip.rs +0 -525
  397. data/ext/cargo-vendor/rayon-1.10.0/src/iter/update.rs +0 -327
  398. data/ext/cargo-vendor/rayon-1.10.0/src/iter/walk_tree.rs +0 -529
  399. data/ext/cargo-vendor/rayon-1.10.0/src/iter/while_some.rs +0 -154
  400. data/ext/cargo-vendor/rayon-1.10.0/src/iter/zip.rs +0 -158
  401. data/ext/cargo-vendor/rayon-1.10.0/src/iter/zip_eq.rs +0 -72
  402. data/ext/cargo-vendor/rayon-1.10.0/src/lib.rs +0 -160
  403. data/ext/cargo-vendor/rayon-1.10.0/src/math.rs +0 -54
  404. data/ext/cargo-vendor/rayon-1.10.0/src/option.rs +0 -203
  405. data/ext/cargo-vendor/rayon-1.10.0/src/range.rs +0 -454
  406. data/ext/cargo-vendor/rayon-1.10.0/src/range_inclusive.rs +0 -381
  407. data/ext/cargo-vendor/rayon-1.10.0/src/result.rs +0 -132
  408. data/ext/cargo-vendor/rayon-1.10.0/src/slice/chunk_by.rs +0 -244
  409. data/ext/cargo-vendor/rayon-1.10.0/src/slice/chunks.rs +0 -388
  410. data/ext/cargo-vendor/rayon-1.10.0/src/slice/mergesort.rs +0 -755
  411. data/ext/cargo-vendor/rayon-1.10.0/src/slice/mod.rs +0 -1226
  412. data/ext/cargo-vendor/rayon-1.10.0/src/slice/quicksort.rs +0 -902
  413. data/ext/cargo-vendor/rayon-1.10.0/src/slice/rchunks.rs +0 -386
  414. data/ext/cargo-vendor/rayon-1.10.0/src/slice/test.rs +0 -216
  415. data/ext/cargo-vendor/rayon-1.10.0/src/str.rs +0 -1010
  416. data/ext/cargo-vendor/rayon-1.10.0/src/vec.rs +0 -283
  417. data/ext/cargo-vendor/rayon-1.10.0/tests/clones.rs +0 -222
  418. data/ext/cargo-vendor/rayon-1.10.0/tests/collect.rs +0 -113
  419. data/ext/cargo-vendor/rayon-1.10.0/tests/debug.rs +0 -233
  420. data/ext/cargo-vendor/rayon-1.10.0/tests/named-threads.rs +0 -25
  421. data/ext/cargo-vendor/rayon-1.10.0/tests/producer_split_at.rs +0 -391
  422. data/ext/cargo-vendor/rayon-1.10.0/tests/sort-panic-safe.rs +0 -167
  423. data/ext/cargo-vendor/rayon-1.10.0/tests/str.rs +0 -119
  424. data/ext/cargo-vendor/rayon-core-1.12.1/.cargo-checksum.json +0 -1
  425. data/ext/cargo-vendor/rayon-core-1.12.1/.cargo_vcs_info.json +0 -6
  426. data/ext/cargo-vendor/rayon-core-1.12.1/Cargo.toml +0 -88
  427. data/ext/cargo-vendor/rayon-core-1.12.1/Cargo.toml.orig +0 -68
  428. data/ext/cargo-vendor/rayon-core-1.12.1/README.md +0 -11
  429. data/ext/cargo-vendor/rayon-core-1.12.1/src/broadcast/mod.rs +0 -150
  430. data/ext/cargo-vendor/rayon-core-1.12.1/src/join/mod.rs +0 -188
  431. data/ext/cargo-vendor/rayon-core-1.12.1/src/join/test.rs +0 -151
  432. data/ext/cargo-vendor/rayon-core-1.12.1/src/latch.rs +0 -461
  433. data/ext/cargo-vendor/rayon-core-1.12.1/src/lib.rs +0 -875
  434. data/ext/cargo-vendor/rayon-core-1.12.1/src/registry.rs +0 -996
  435. data/ext/cargo-vendor/rayon-core-1.12.1/src/scope/mod.rs +0 -769
  436. data/ext/cargo-vendor/rayon-core-1.12.1/src/scope/test.rs +0 -619
  437. data/ext/cargo-vendor/rayon-core-1.12.1/src/sleep/README.md +0 -219
  438. data/ext/cargo-vendor/rayon-core-1.12.1/src/sleep/counters.rs +0 -277
  439. data/ext/cargo-vendor/rayon-core-1.12.1/src/sleep/mod.rs +0 -325
  440. data/ext/cargo-vendor/rayon-core-1.12.1/src/spawn/mod.rs +0 -163
  441. data/ext/cargo-vendor/rayon-core-1.12.1/src/spawn/test.rs +0 -255
  442. data/ext/cargo-vendor/rayon-core-1.12.1/src/test.rs +0 -200
  443. data/ext/cargo-vendor/rayon-core-1.12.1/src/thread_pool/mod.rs +0 -508
  444. data/ext/cargo-vendor/rayon-core-1.12.1/src/thread_pool/test.rs +0 -418
  445. data/ext/cargo-vendor/rayon-core-1.12.1/tests/use_current_thread.rs +0 -57
  446. data/ext/cargo-vendor/serde_json-1.0.142/.cargo-checksum.json +0 -1
  447. data/ext/cargo-vendor/serde_json-1.0.142/.cargo_vcs_info.json +0 -6
  448. data/ext/cargo-vendor/serde_json-1.0.142/.github/workflows/ci.yml +0 -158
  449. data/ext/cargo-vendor/serde_json-1.0.142/Cargo.lock +0 -419
  450. data/ext/cargo-vendor/serde_json-1.0.142/Cargo.toml +0 -157
  451. data/ext/cargo-vendor/serde_json-1.0.142/Cargo.toml.orig +0 -91
  452. data/ext/cargo-vendor/serde_json-1.0.142/src/lib.rs +0 -438
  453. data/ext/cargo-vendor/serde_json-1.0.142/src/map.rs +0 -1174
  454. data/ext/cargo-vendor/serde_json-1.0.142/src/ser.rs +0 -2285
  455. data/ext/cargo-vendor/serde_json-1.0.142/src/value/de.rs +0 -1500
  456. data/ext/cargo-vendor/tempfile-3.20.0/.cargo-checksum.json +0 -1
  457. data/ext/cargo-vendor/tempfile-3.20.0/.cargo_vcs_info.json +0 -6
  458. data/ext/cargo-vendor/tempfile-3.20.0/.github/workflows/ci.yml +0 -107
  459. data/ext/cargo-vendor/tempfile-3.20.0/CHANGELOG.md +0 -360
  460. data/ext/cargo-vendor/tempfile-3.20.0/Cargo.lock +0 -183
  461. data/ext/cargo-vendor/tempfile-3.20.0/Cargo.toml +0 -98
  462. data/ext/cargo-vendor/tempfile-3.20.0/Cargo.toml.orig +0 -47
  463. data/ext/cargo-vendor/winapi-util-0.1.9/.cargo-checksum.json +0 -1
  464. data/ext/cargo-vendor/winapi-util-0.1.9/.cargo_vcs_info.json +0 -6
  465. data/ext/cargo-vendor/winapi-util-0.1.9/Cargo.toml +0 -53
  466. data/ext/cargo-vendor/winapi-util-0.1.9/Cargo.toml.orig +0 -25
  467. data/ext/cargo-vendor/windows-sys-0.59.0/.cargo-checksum.json +0 -1
  468. data/ext/cargo-vendor/windows-sys-0.59.0/.cargo_vcs_info.json +0 -6
  469. data/ext/cargo-vendor/windows-sys-0.59.0/Cargo.toml +0 -298
  470. data/ext/cargo-vendor/windows-sys-0.59.0/Cargo.toml.orig +0 -274
  471. data/ext/cargo-vendor/windows-sys-0.59.0/license-apache-2.0 +0 -201
  472. data/ext/cargo-vendor/windows-sys-0.59.0/license-mit +0 -21
  473. data/ext/cargo-vendor/windows-sys-0.59.0/readme.md +0 -87
  474. data/ext/cargo-vendor/windows-sys-0.59.0/rustfmt.toml +0 -2
  475. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/Devices/Bluetooth/mod.rs +0 -32
  476. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/Devices/HumanInterfaceDevice/mod.rs +0 -39
  477. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/Devices/mod.rs +0 -4
  478. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/Foundation/mod.rs +0 -1317
  479. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/Graphics/Direct3D/mod.rs +0 -9170
  480. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/Graphics/mod.rs +0 -2
  481. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/NetworkManagement/Ndis/mod.rs +0 -3892
  482. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/NetworkManagement/WindowsFilteringPlatform/mod.rs +0 -269
  483. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/NetworkManagement/mod.rs +0 -4
  484. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/Storage/FileSystem/Minifilters/mod.rs +0 -1392
  485. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/Storage/FileSystem/mod.rs +0 -4503
  486. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/Storage/mod.rs +0 -2
  487. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/System/IO/mod.rs +0 -2
  488. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/System/Memory/mod.rs +0 -11
  489. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/System/OfflineRegistry/mod.rs +0 -28
  490. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/System/Registry/mod.rs +0 -180
  491. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/System/SystemInformation/mod.rs +0 -18
  492. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/System/SystemServices/mod.rs +0 -13663
  493. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/System/Threading/mod.rs +0 -155
  494. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/System/mod.rs +0 -14
  495. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Wdk/mod.rs +0 -12
  496. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Data/HtmlHelp/mod.rs +0 -447
  497. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Data/RightsManagement/mod.rs +0 -237
  498. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Data/mod.rs +0 -4
  499. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/AllJoyn/mod.rs +0 -1273
  500. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/BiometricFramework/mod.rs +0 -1481
  501. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Bluetooth/mod.rs +0 -1419
  502. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Communication/mod.rs +0 -312
  503. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/DeviceAndDriverInstallation/mod.rs +0 -3969
  504. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/DeviceQuery/mod.rs +0 -141
  505. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Display/mod.rs +0 -3141
  506. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Enumeration/Pnp/mod.rs +0 -96
  507. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Enumeration/mod.rs +0 -2
  508. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Fax/mod.rs +0 -1203
  509. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/HumanInterfaceDevice/mod.rs +0 -3684
  510. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/PortableDevices/mod.rs +0 -1999
  511. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Properties/mod.rs +0 -261
  512. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Pwm/mod.rs +0 -73
  513. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Sensors/mod.rs +0 -687
  514. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/SerialCommunication/mod.rs +0 -230
  515. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Tapi/mod.rs +0 -3217
  516. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/Usb/mod.rs +0 -2694
  517. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/WebServicesOnDevices/mod.rs +0 -660
  518. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Devices/mod.rs +0 -36
  519. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Foundation/mod.rs +0 -10318
  520. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Gaming/mod.rs +0 -99
  521. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Globalization/mod.rs +0 -5135
  522. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Graphics/Dwm/mod.rs +0 -232
  523. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Graphics/Gdi/mod.rs +0 -3857
  524. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Graphics/GdiPlus/mod.rs +0 -2307
  525. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Graphics/Hlsl/mod.rs +0 -2
  526. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Graphics/OpenGL/mod.rs +0 -1276
  527. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Graphics/Printing/PrintTicket/mod.rs +0 -28
  528. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Graphics/Printing/mod.rs +0 -4147
  529. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Graphics/mod.rs +0 -12
  530. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Management/MobileDeviceManagementRegistration/mod.rs +0 -101
  531. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Management/mod.rs +0 -2
  532. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Media/Audio/mod.rs +0 -2052
  533. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Media/DxMediaObjects/mod.rs +0 -94
  534. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Media/KernelStreaming/mod.rs +0 -5281
  535. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Media/Multimedia/mod.rs +0 -6442
  536. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Media/Streaming/mod.rs +0 -117
  537. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Media/WindowsMediaFormat/mod.rs +0 -910
  538. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Media/mod.rs +0 -187
  539. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/Dhcp/mod.rs +0 -1926
  540. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/Dns/mod.rs +0 -1564
  541. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/InternetConnectionWizard/mod.rs +0 -22
  542. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/IpHelper/mod.rs +0 -3004
  543. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/Multicast/mod.rs +0 -59
  544. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/Ndis/mod.rs +0 -3334
  545. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/NetBios/mod.rs +0 -211
  546. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/NetManagement/mod.rs +0 -4814
  547. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/NetShell/mod.rs +0 -160
  548. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/NetworkDiagnosticsFramework/mod.rs +0 -222
  549. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/P2P/mod.rs +0 -1196
  550. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/QoS/mod.rs +0 -1447
  551. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/Rras/mod.rs +0 -3212
  552. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/Snmp/mod.rs +0 -381
  553. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/WNet/mod.rs +0 -363
  554. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/WebDav/mod.rs +0 -47
  555. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/WiFi/mod.rs +0 -4311
  556. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/WindowsConnectionManager/mod.rs +0 -119
  557. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/WindowsFilteringPlatform/mod.rs +0 -3818
  558. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/WindowsFirewall/mod.rs +0 -281
  559. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/WindowsNetworkVirtualization/mod.rs +0 -104
  560. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/NetworkManagement/mod.rs +0 -42
  561. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Networking/ActiveDirectory/mod.rs +0 -2383
  562. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Networking/Clustering/mod.rs +0 -3900
  563. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Networking/HttpServer/mod.rs +0 -1239
  564. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Networking/Ldap/mod.rs +0 -817
  565. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Networking/WebSocket/mod.rs +0 -88
  566. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Networking/WinHttp/mod.rs +0 -1109
  567. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Networking/WinInet/mod.rs +0 -2168
  568. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Networking/WinSock/mod.rs +0 -4786
  569. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Networking/WindowsWebServices/mod.rs +0 -3480
  570. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Networking/mod.rs +0 -18
  571. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/AppLocker/mod.rs +0 -172
  572. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/Authentication/Identity/mod.rs +0 -5701
  573. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/Authentication/mod.rs +0 -2
  574. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/Authorization/mod.rs +0 -984
  575. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/Credentials/mod.rs +0 -797
  576. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/Cryptography/Catalog/mod.rs +0 -151
  577. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/Cryptography/Certificates/mod.rs +0 -2315
  578. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/Cryptography/Sip/mod.rs +0 -155
  579. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/Cryptography/UI/mod.rs +0 -545
  580. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/Cryptography/mod.rs +0 -8528
  581. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/DiagnosticDataQuery/mod.rs +0 -156
  582. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/DirectoryServices/mod.rs +0 -19
  583. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/EnterpriseData/mod.rs +0 -36
  584. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/ExtensibleAuthenticationProtocol/mod.rs +0 -998
  585. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/Isolation/mod.rs +0 -20
  586. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/LicenseProtection/mod.rs +0 -8
  587. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/NetworkAccessProtection/mod.rs +0 -149
  588. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/WinTrust/mod.rs +0 -863
  589. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/WinWlx/mod.rs +0 -335
  590. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Security/mod.rs +0 -1156
  591. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/Cabinets/mod.rs +0 -209
  592. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/CloudFilters/mod.rs +0 -666
  593. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/Compression/mod.rs +0 -36
  594. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/DistributedFileSystem/mod.rs +0 -342
  595. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/FileHistory/mod.rs +0 -97
  596. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/FileSystem/mod.rs +0 -3699
  597. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/Imapi/mod.rs +0 -697
  598. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/IndexServer/mod.rs +0 -279
  599. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/InstallableFileSystems/mod.rs +0 -331
  600. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/IscsiDisc/mod.rs +0 -1291
  601. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/Jet/mod.rs +0 -2593
  602. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/Nvme/mod.rs +0 -3428
  603. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/OfflineFiles/mod.rs +0 -276
  604. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/OperationRecorder/mod.rs +0 -20
  605. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/Packaging/Appx/mod.rs +0 -377
  606. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/Packaging/mod.rs +0 -2
  607. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/ProjectedFileSystem/mod.rs +0 -246
  608. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/StructuredStorage/mod.rs +0 -3
  609. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/Vhd/mod.rs +0 -720
  610. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/Xps/mod.rs +0 -415
  611. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Storage/mod.rs +0 -38
  612. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/AddressBook/mod.rs +0 -938
  613. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Antimalware/mod.rs +0 -112
  614. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/ApplicationInstallationAndServicing/mod.rs +0 -2145
  615. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/ApplicationVerifier/mod.rs +0 -58
  616. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/ClrHosting/mod.rs +0 -322
  617. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Com/Marshal/mod.rs +0 -172
  618. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Com/StructuredStorage/mod.rs +0 -655
  619. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Com/Urlmon/mod.rs +0 -905
  620. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Com/mod.rs +0 -1227
  621. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/ComponentServices/mod.rs +0 -574
  622. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Console/mod.rs +0 -373
  623. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/CorrelationVector/mod.rs +0 -15
  624. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/DataExchange/mod.rs +0 -428
  625. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/DeploymentServices/mod.rs +0 -565
  626. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/DeveloperLicensing/mod.rs +0 -3
  627. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Diagnostics/Ceip/mod.rs +0 -1
  628. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Diagnostics/Debug/Extensions/mod.rs +0 -3710
  629. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Diagnostics/Debug/mod.rs +0 -5557
  630. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Diagnostics/Etw/mod.rs +0 -2042
  631. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Diagnostics/ProcessSnapshotting/mod.rs +0 -293
  632. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Diagnostics/ToolHelp/mod.rs +0 -119
  633. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Diagnostics/TraceLogging/mod.rs +0 -105
  634. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Diagnostics/mod.rs +0 -12
  635. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/DistributedTransactionCoordinator/mod.rs +0 -308
  636. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Environment/mod.rs +0 -202
  637. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/ErrorReporting/mod.rs +0 -393
  638. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/EventCollector/mod.rs +0 -117
  639. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/EventLog/mod.rs +0 -379
  640. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/EventNotificationService/mod.rs +0 -35
  641. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/GroupPolicy/mod.rs +0 -424
  642. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/HostCompute/mod.rs +0 -1
  643. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/HostComputeNetwork/mod.rs +0 -86
  644. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/HostComputeSystem/mod.rs +0 -171
  645. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Hypervisor/mod.rs +0 -1983
  646. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/IO/mod.rs +0 -53
  647. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Iis/mod.rs +0 -1411
  648. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Ioctl/mod.rs +0 -6216
  649. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/JobObjects/mod.rs +0 -434
  650. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Js/mod.rs +0 -154
  651. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Kernel/mod.rs +0 -295
  652. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/LibraryLoader/mod.rs +0 -106
  653. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Mailslots/mod.rs +0 -6
  654. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Mapi/mod.rs +0 -150
  655. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Memory/NonVolatile/mod.rs +0 -20
  656. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Memory/mod.rs +0 -464
  657. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/MessageQueuing/mod.rs +0 -712
  658. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/MixedReality/mod.rs +0 -14
  659. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Ole/mod.rs +0 -2599
  660. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/PasswordManagement/mod.rs +0 -22
  661. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Performance/HardwareCounterProfiling/mod.rs +0 -27
  662. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Performance/mod.rs +0 -1091
  663. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Pipes/mod.rs +0 -42
  664. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Power/mod.rs +0 -1413
  665. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/ProcessStatus/mod.rs +0 -200
  666. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Recovery/mod.rs +0 -15
  667. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Registry/mod.rs +0 -1114
  668. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/RemoteDesktop/mod.rs +0 -1771
  669. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/RemoteManagement/mod.rs +0 -935
  670. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/RestartManager/mod.rs +0 -86
  671. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Restore/mod.rs +0 -66
  672. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Rpc/mod.rs +0 -2668
  673. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Search/Common/mod.rs +0 -21
  674. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Search/mod.rs +0 -5993
  675. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/SecurityCenter/mod.rs +0 -41
  676. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Services/mod.rs +0 -587
  677. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/SetupAndMigration/mod.rs +0 -4
  678. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Shutdown/mod.rs +0 -111
  679. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/StationsAndDesktops/mod.rs +0 -99
  680. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/SubsystemForLinux/mod.rs +0 -12
  681. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/SystemInformation/mod.rs +0 -751
  682. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/SystemServices/mod.rs +0 -4541
  683. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Threading/mod.rs +0 -1148
  684. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Time/mod.rs +0 -50
  685. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/TpmBaseServices/mod.rs +0 -89
  686. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/UserAccessLogging/mod.rs +0 -17
  687. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Variant/mod.rs +0 -321
  688. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/VirtualDosMachines/mod.rs +0 -297
  689. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/WindowsProgramming/mod.rs +0 -1633
  690. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/Wmi/mod.rs +0 -2435
  691. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/System/mod.rs +0 -132
  692. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Accessibility/mod.rs +0 -1788
  693. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/ColorSystem/mod.rs +0 -702
  694. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Controls/Dialogs/mod.rs +0 -1128
  695. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Controls/mod.rs +0 -7276
  696. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/HiDpi/mod.rs +0 -66
  697. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Input/Ime/mod.rs +0 -1394
  698. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Input/KeyboardAndMouse/mod.rs +0 -765
  699. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Input/Pointer/mod.rs +0 -168
  700. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Input/Touch/mod.rs +0 -89
  701. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Input/XboxController/mod.rs +0 -151
  702. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Input/mod.rs +0 -182
  703. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/InteractionContext/mod.rs +0 -230
  704. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Magnification/mod.rs +0 -52
  705. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Shell/Common/mod.rs +0 -104
  706. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Shell/PropertiesSystem/mod.rs +0 -322
  707. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/Shell/mod.rs +0 -6704
  708. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/TabletPC/mod.rs +0 -1537
  709. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/TextServices/mod.rs +0 -794
  710. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/WindowsAndMessaging/mod.rs +0 -3760
  711. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/UI/mod.rs +0 -22
  712. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Web/InternetExplorer/mod.rs +0 -628
  713. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/Web/mod.rs +0 -2
  714. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/Win32/mod.rs +0 -30
  715. data/ext/cargo-vendor/windows-sys-0.59.0/src/Windows/mod.rs +0 -4
  716. data/ext/cargo-vendor/windows-sys-0.59.0/src/core/literals.rs +0 -114
  717. data/ext/cargo-vendor/windows-sys-0.59.0/src/core/mod.rs +0 -33
  718. data/ext/cargo-vendor/windows-sys-0.59.0/src/includes/Win32/UI/WindowsAndMessaging/WindowLong.rs +0 -8
  719. data/ext/cargo-vendor/windows-sys-0.59.0/src/lib.rs +0 -17
  720. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/.github/workflows/audit.yml +0 -0
  721. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/.github/workflows/ci.yml +0 -0
  722. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/.github/workflows/dotslash-config.json +0 -0
  723. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/.rustfmt.toml +0 -0
  724. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/.rusty-hook.toml +0 -0
  725. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/dev/run_benchmarks_for_file.sh +0 -0
  726. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/src/cache/mod.rs +0 -0
  727. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/src/cache/noop.rs +0 -0
  728. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/src/ownership/file_owner_finder.rs +0 -0
  729. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/src/ownership/mapper/directory_mapper.rs +0 -0
  730. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/src/ownership/mapper/escaper.rs +0 -0
  731. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/src/ownership/mapper/team_gem_mapper.rs +0 -0
  732. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/src/ownership/mapper/team_glob_mapper.rs +0 -0
  733. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/src/ownership/mapper/team_yml_mapper.rs +0 -0
  734. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/cache_test.rs +0 -0
  735. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/.github/CODEOWNERS +0 -0
  736. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/config/code_ownership.yml +0 -0
  737. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/config/teams/payments.yml +0 -0
  738. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/config/teams/payroll.yml +0 -0
  739. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/gems/payroll_calculator/calculator.rb +0 -0
  740. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/ruby/app/models/bank_account.rb +0 -0
  741. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/ruby/app/models/blockchain.rb +0 -0
  742. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/ruby/app/models/payroll.rb +0 -0
  743. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/ruby/app/payments/nacha.rb +0 -0
  744. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/ruby/app/services/.codeowner +0 -0
  745. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/ruby/app/services/multi_owned.rb +0 -0
  746. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/ruby/app/unowned.rb +0 -0
  747. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/invalid_project/ruby/packages/payroll_flow/package.yml +0 -0
  748. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/multiple-directory-owners/.github/CODEOWNERS +0 -0
  749. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/multiple-directory-owners/app/consumers/.codeowner +0 -0
  750. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/multiple-directory-owners/app/consumers/deep/nesting/nestdir/deep_file.rb +0 -0
  751. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/multiple-directory-owners/app/consumers/one_owner.rb +0 -0
  752. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/multiple-directory-owners/app/services/.codeowner +0 -0
  753. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/multiple-directory-owners/app/services/exciting/.codeowner +0 -0
  754. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/multiple-directory-owners/app/services/exciting/some_other_file.rb +0 -0
  755. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/multiple-directory-owners/config/teams/bar.yml +0 -0
  756. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/multiple-directory-owners/config/teams/foo.yml +0 -0
  757. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/.ignore +0 -0
  758. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/config/teams/payments.yml +0 -0
  759. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/config/teams/payroll.yml +0 -0
  760. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/config/teams/ux.yml +0 -0
  761. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/gems/payroll_calculator/calculator.rb +0 -0
  762. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/gems/pets/dog.rb +0 -0
  763. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/javascript/packages/PayrollFlow/index.tsx +0 -0
  764. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/javascript/packages/PayrollFlow/package.json +0 -0
  765. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/javascript/packages/items/(special)/.codeowner +0 -0
  766. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/javascript/packages/items/(special)/pay.ts +0 -0
  767. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/javascript/packages/items/.codeowner +0 -0
  768. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/javascript/packages/items/item.ts +0 -0
  769. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/ruby/app/models/bank_account.rb +0 -0
  770. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/ruby/app/payments/foo/.codeowner +0 -0
  771. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/ruby/app/payments/foo/ownedby_payroll.rb +0 -0
  772. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/ruby/app/payments/nacha.rb +0 -0
  773. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/ruby/app/payroll/.codeowner +0 -0
  774. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/ruby/app/payroll/payroll.rb +0 -0
  775. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/ruby/ignored_files/git_ignored.rb +0 -0
  776. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/ruby/packages/payroll_flow/package.yml +0 -0
  777. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/fixtures/valid_project/should_be_ignored/an_ignored_file.rb +0 -0
  778. /data/ext/cargo-vendor/{codeowners-0.2.7/tmp/.gitkeep → codeowners-0.2.17/tests/fixtures/valid_project_with_overrides/packs/games/app/services/stats.rb} +0 -0
  779. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/git_stage_test.rs +0 -0
  780. /data/ext/cargo-vendor/{codeowners-0.2.7 → codeowners-0.2.17}/tests/invalid_project_structure_test.rs +0 -0
  781. /data/ext/cargo-vendor/{glob-0.3.2 → glob-0.3.3}/.github/dependabot.yml +0 -0
  782. /data/ext/cargo-vendor/{glob-0.3.2 → glob-0.3.3}/.github/workflows/publish.yml +0 -0
  783. /data/ext/cargo-vendor/{glob-0.3.2 → glob-0.3.3}/LICENSE-APACHE +0 -0
  784. /data/ext/cargo-vendor/{glob-0.3.2 → glob-0.3.3}/LICENSE-MIT +0 -0
  785. /data/ext/cargo-vendor/{glob-0.3.2 → glob-0.3.3}/triagebot.toml +0 -0
  786. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/.rustfmt.toml +0 -0
  787. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/LICENSE-APACHE +0 -0
  788. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/LICENSE-MIT +0 -0
  789. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/README.md +0 -0
  790. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/benches/bench.rs +0 -0
  791. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/benches/faststring.rs +0 -0
  792. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/arbitrary.rs +0 -0
  793. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/borsh.rs +0 -0
  794. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/macros.rs +0 -0
  795. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/map/core/extract.rs +0 -0
  796. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/map/core/raw_entry_v1.rs +0 -0
  797. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/map/iter.rs +0 -0
  798. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/map/serde_seq.rs +0 -0
  799. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/rayon/mod.rs +0 -0
  800. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/serde.rs +0 -0
  801. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/set/iter.rs +0 -0
  802. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/src/util.rs +0 -0
  803. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/tests/equivalent_trait.rs +0 -0
  804. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/tests/macros_full_path.rs +0 -0
  805. /data/ext/cargo-vendor/{indexmap-2.10.0 → indexmap-2.11.0}/tests/tests.rs +0 -0
  806. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/LICENSE-APACHE +0 -0
  807. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/LICENSE-MIT +0 -0
  808. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/compile_fail/cannot_collect_filtermap_data.rs +0 -0
  809. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/compile_fail/cannot_zip_filtered_data.rs +0 -0
  810. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/compile_fail/cell_par_iter.rs +0 -0
  811. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/compile_fail/mod.rs +0 -0
  812. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/compile_fail/must_use.rs +0 -0
  813. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/compile_fail/no_send_par_iter.rs +0 -0
  814. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/compile_fail/rc_par_iter.rs +0 -0
  815. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/delegate.rs +0 -0
  816. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/collect/consumer.rs +0 -0
  817. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/extend.rs +0 -0
  818. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/find.rs +0 -0
  819. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/for_each.rs +0 -0
  820. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/noop.rs +0 -0
  821. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/plumbing/README.md +0 -0
  822. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/product.rs +0 -0
  823. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/reduce.rs +0 -0
  824. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/sum.rs +0 -0
  825. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/try_reduce.rs +0 -0
  826. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/iter/try_reduce_with.rs +0 -0
  827. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/par_either.rs +0 -0
  828. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/prelude.rs +0 -0
  829. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/private.rs +0 -0
  830. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/split_producer.rs +0 -0
  831. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/src/string.rs +0 -0
  832. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/tests/chars.rs +0 -0
  833. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/tests/cross-pool.rs +0 -0
  834. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/tests/drain_vec.rs +0 -0
  835. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/tests/intersperse.rs +0 -0
  836. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/tests/issue671-unzip.rs +0 -0
  837. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/tests/issue671.rs +0 -0
  838. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/tests/iter_panic.rs +0 -0
  839. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/tests/octillion.rs +0 -0
  840. /data/ext/cargo-vendor/{rayon-1.10.0 → rayon-1.11.0}/tests/par_bridge_recursion.rs +0 -0
  841. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/LICENSE-APACHE +0 -0
  842. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/LICENSE-MIT +0 -0
  843. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/build.rs +0 -0
  844. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/broadcast/test.rs +0 -0
  845. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/compile_fail/mod.rs +0 -0
  846. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/compile_fail/quicksort_race1.rs +0 -0
  847. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/compile_fail/quicksort_race2.rs +0 -0
  848. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/compile_fail/quicksort_race3.rs +0 -0
  849. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/compile_fail/rc_return.rs +0 -0
  850. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/compile_fail/rc_upvar.rs +0 -0
  851. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/compile_fail/scope_join_bad.rs +0 -0
  852. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/job.rs +0 -0
  853. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/private.rs +0 -0
  854. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/src/unwind.rs +0 -0
  855. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/tests/double_init_fail.rs +0 -0
  856. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/tests/init_zero_threads.rs +0 -0
  857. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/tests/scope_join.rs +0 -0
  858. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/tests/scoped_threadpool.rs +0 -0
  859. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/tests/simple_panic.rs +0 -0
  860. /data/ext/cargo-vendor/{rayon-core-1.12.1 → rayon-core-1.13.0}/tests/stack_overflow_crash.rs +0 -0
  861. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/CONTRIBUTING.md +0 -0
  862. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/LICENSE-APACHE +0 -0
  863. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/LICENSE-MIT +0 -0
  864. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/README.md +0 -0
  865. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/build.rs +0 -0
  866. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/de.rs +0 -0
  867. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/error.rs +0 -0
  868. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/io/core.rs +0 -0
  869. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/io/mod.rs +0 -0
  870. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/iter.rs +0 -0
  871. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/algorithm.rs +0 -0
  872. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/bhcomp.rs +0 -0
  873. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/bignum.rs +0 -0
  874. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/cached.rs +0 -0
  875. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/cached_float80.rs +0 -0
  876. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/digit.rs +0 -0
  877. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/errors.rs +0 -0
  878. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/exponent.rs +0 -0
  879. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/float.rs +0 -0
  880. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/large_powers.rs +0 -0
  881. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/large_powers32.rs +0 -0
  882. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/large_powers64.rs +0 -0
  883. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/math.rs +0 -0
  884. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/mod.rs +0 -0
  885. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/num.rs +0 -0
  886. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/parse.rs +0 -0
  887. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/rounding.rs +0 -0
  888. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/shift.rs +0 -0
  889. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/lexical/small_powers.rs +0 -0
  890. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/macros.rs +0 -0
  891. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/number.rs +0 -0
  892. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/raw.rs +0 -0
  893. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/read.rs +0 -0
  894. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/value/from.rs +0 -0
  895. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/value/index.rs +0 -0
  896. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/value/mod.rs +0 -0
  897. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/value/partial_eq.rs +0 -0
  898. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/src/value/ser.rs +0 -0
  899. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/compiletest.rs +0 -0
  900. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/debug.rs +0 -0
  901. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/lexical/algorithm.rs +0 -0
  902. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/lexical/exponent.rs +0 -0
  903. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/lexical/float.rs +0 -0
  904. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/lexical/math.rs +0 -0
  905. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/lexical/num.rs +0 -0
  906. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/lexical/parse.rs +0 -0
  907. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/lexical/rounding.rs +0 -0
  908. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/lexical.rs +0 -0
  909. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/macros/mod.rs +0 -0
  910. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/map.rs +0 -0
  911. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/regression/issue1004.rs +0 -0
  912. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/regression/issue520.rs +0 -0
  913. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/regression/issue795.rs +0 -0
  914. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/regression/issue845.rs +0 -0
  915. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/regression/issue953.rs +0 -0
  916. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/regression.rs +0 -0
  917. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/stream.rs +0 -0
  918. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/test.rs +0 -0
  919. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/missing_colon.rs +0 -0
  920. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/missing_colon.stderr +0 -0
  921. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/missing_comma.rs +0 -0
  922. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/missing_comma.stderr +0 -0
  923. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/missing_value.rs +0 -0
  924. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/missing_value.stderr +0 -0
  925. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/not_found.rs +0 -0
  926. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/not_found.stderr +0 -0
  927. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/parse_expr.rs +0 -0
  928. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/parse_expr.stderr +0 -0
  929. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/parse_key.rs +0 -0
  930. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/parse_key.stderr +0 -0
  931. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/unexpected_after_array_element.rs +0 -0
  932. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/unexpected_after_array_element.stderr +0 -0
  933. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/unexpected_after_map_entry.rs +0 -0
  934. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/unexpected_after_map_entry.stderr +0 -0
  935. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/unexpected_colon.rs +0 -0
  936. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/unexpected_colon.stderr +0 -0
  937. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/unexpected_comma.rs +0 -0
  938. /data/ext/cargo-vendor/{serde_json-1.0.142 → serde_json-1.0.143}/tests/ui/unexpected_comma.stderr +0 -0
  939. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/.github/dependabot.yml +0 -0
  940. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/LICENSE-APACHE +0 -0
  941. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/LICENSE-MIT +0 -0
  942. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/README.md +0 -0
  943. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/deny.toml +0 -0
  944. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/dir/imp/any.rs +0 -0
  945. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/dir/imp/mod.rs +0 -0
  946. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/dir/imp/unix.rs +0 -0
  947. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/dir/mod.rs +0 -0
  948. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/env.rs +0 -0
  949. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/error.rs +0 -0
  950. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/file/imp/mod.rs +0 -0
  951. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/file/imp/other.rs +0 -0
  952. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/file/imp/unix.rs +0 -0
  953. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/file/imp/windows.rs +0 -0
  954. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/file/mod.rs +0 -0
  955. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/lib.rs +0 -0
  956. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/spooled.rs +0 -0
  957. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/src/util.rs +0 -0
  958. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/tests/env.rs +0 -0
  959. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/tests/namedtempfile.rs +0 -0
  960. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/tests/spooled.rs +0 -0
  961. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/tests/tempdir.rs +0 -0
  962. /data/ext/cargo-vendor/{tempfile-3.20.0 → tempfile-3.21.0}/tests/tempfile.rs +0 -0
  963. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/.github/workflows/ci.yml +0 -0
  964. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/COPYING +0 -0
  965. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/LICENSE-MIT +0 -0
  966. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/README.md +0 -0
  967. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/UNLICENSE +0 -0
  968. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/rustfmt.toml +0 -0
  969. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/src/console.rs +0 -0
  970. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/src/file.rs +0 -0
  971. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/src/lib.rs +0 -0
  972. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/src/sysinfo.rs +0 -0
  973. /data/ext/cargo-vendor/{winapi-util-0.1.9 → winapi-util-0.1.10}/src/win.rs +0 -0
@@ -0,0 +1,1454 @@
1
+ //! A hash set implemented using [`IndexMap`]
2
+
3
+ mod iter;
4
+ mod mutable;
5
+ mod slice;
6
+
7
+ #[cfg(test)]
8
+ mod tests;
9
+
10
+ pub use self::iter::{
11
+ Difference, Drain, ExtractIf, Intersection, IntoIter, Iter, Splice, SymmetricDifference, Union,
12
+ };
13
+ pub use self::mutable::MutableValues;
14
+ pub use self::slice::Slice;
15
+
16
+ #[cfg(feature = "rayon")]
17
+ pub use crate::rayon::set as rayon;
18
+ use crate::TryReserveError;
19
+
20
+ #[cfg(feature = "std")]
21
+ use std::collections::hash_map::RandomState;
22
+
23
+ use crate::util::try_simplify_range;
24
+ use alloc::boxed::Box;
25
+ use alloc::vec::Vec;
26
+ use core::cmp::Ordering;
27
+ use core::fmt;
28
+ use core::hash::{BuildHasher, Hash};
29
+ use core::ops::{BitAnd, BitOr, BitXor, Index, RangeBounds, Sub};
30
+
31
+ use super::{Equivalent, IndexMap};
32
+
33
+ type Bucket<T> = super::Bucket<T, ()>;
34
+
35
+ /// A hash set where the iteration order of the values is independent of their
36
+ /// hash values.
37
+ ///
38
+ /// The interface is closely compatible with the standard
39
+ /// [`HashSet`][std::collections::HashSet],
40
+ /// but also has additional features.
41
+ ///
42
+ /// # Order
43
+ ///
44
+ /// The values have a consistent order that is determined by the sequence of
45
+ /// insertion and removal calls on the set. The order does not depend on the
46
+ /// values or the hash function at all. Note that insertion order and value
47
+ /// are not affected if a re-insertion is attempted once an element is
48
+ /// already present.
49
+ ///
50
+ /// All iterators traverse the set *in order*. Set operation iterators like
51
+ /// [`IndexSet::union`] produce a concatenated order, as do their matching "bitwise"
52
+ /// operators. See their documentation for specifics.
53
+ ///
54
+ /// The insertion order is preserved, with **notable exceptions** like the
55
+ /// [`.remove()`][Self::remove] or [`.swap_remove()`][Self::swap_remove] methods.
56
+ /// Methods such as [`.sort_by()`][Self::sort_by] of
57
+ /// course result in a new order, depending on the sorting order.
58
+ ///
59
+ /// # Indices
60
+ ///
61
+ /// The values are indexed in a compact range without holes in the range
62
+ /// `0..self.len()`. For example, the method `.get_full` looks up the index for
63
+ /// a value, and the method `.get_index` looks up the value by index.
64
+ ///
65
+ /// # Complexity
66
+ ///
67
+ /// Internally, `IndexSet<T, S>` just holds an [`IndexMap<T, (), S>`](IndexMap). Thus the complexity
68
+ /// of the two are the same for most methods.
69
+ ///
70
+ /// # Examples
71
+ ///
72
+ /// ```
73
+ /// use indexmap::IndexSet;
74
+ ///
75
+ /// // Collects which letters appear in a sentence.
76
+ /// let letters: IndexSet<_> = "a short treatise on fungi".chars().collect();
77
+ ///
78
+ /// assert!(letters.contains(&'s'));
79
+ /// assert!(letters.contains(&'t'));
80
+ /// assert!(letters.contains(&'u'));
81
+ /// assert!(!letters.contains(&'y'));
82
+ /// ```
83
+ #[cfg(feature = "std")]
84
+ pub struct IndexSet<T, S = RandomState> {
85
+ pub(crate) map: IndexMap<T, (), S>,
86
+ }
87
+ #[cfg(not(feature = "std"))]
88
+ pub struct IndexSet<T, S> {
89
+ pub(crate) map: IndexMap<T, (), S>,
90
+ }
91
+
92
+ impl<T, S> Clone for IndexSet<T, S>
93
+ where
94
+ T: Clone,
95
+ S: Clone,
96
+ {
97
+ fn clone(&self) -> Self {
98
+ IndexSet {
99
+ map: self.map.clone(),
100
+ }
101
+ }
102
+
103
+ fn clone_from(&mut self, other: &Self) {
104
+ self.map.clone_from(&other.map);
105
+ }
106
+ }
107
+
108
+ impl<T, S> fmt::Debug for IndexSet<T, S>
109
+ where
110
+ T: fmt::Debug,
111
+ {
112
+ #[cfg(not(feature = "test_debug"))]
113
+ fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
114
+ f.debug_set().entries(self.iter()).finish()
115
+ }
116
+
117
+ #[cfg(feature = "test_debug")]
118
+ fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
119
+ // Let the inner `IndexMap` print all of its details
120
+ f.debug_struct("IndexSet").field("map", &self.map).finish()
121
+ }
122
+ }
123
+
124
+ #[cfg(feature = "std")]
125
+ #[cfg_attr(docsrs, doc(cfg(feature = "std")))]
126
+ impl<T> IndexSet<T> {
127
+ /// Create a new set. (Does not allocate.)
128
+ pub fn new() -> Self {
129
+ IndexSet {
130
+ map: IndexMap::new(),
131
+ }
132
+ }
133
+
134
+ /// Create a new set with capacity for `n` elements.
135
+ /// (Does not allocate if `n` is zero.)
136
+ ///
137
+ /// Computes in **O(n)** time.
138
+ pub fn with_capacity(n: usize) -> Self {
139
+ IndexSet {
140
+ map: IndexMap::with_capacity(n),
141
+ }
142
+ }
143
+ }
144
+
145
+ impl<T, S> IndexSet<T, S> {
146
+ /// Create a new set with capacity for `n` elements.
147
+ /// (Does not allocate if `n` is zero.)
148
+ ///
149
+ /// Computes in **O(n)** time.
150
+ pub fn with_capacity_and_hasher(n: usize, hash_builder: S) -> Self {
151
+ IndexSet {
152
+ map: IndexMap::with_capacity_and_hasher(n, hash_builder),
153
+ }
154
+ }
155
+
156
+ /// Create a new set with `hash_builder`.
157
+ ///
158
+ /// This function is `const`, so it
159
+ /// can be called in `static` contexts.
160
+ pub const fn with_hasher(hash_builder: S) -> Self {
161
+ IndexSet {
162
+ map: IndexMap::with_hasher(hash_builder),
163
+ }
164
+ }
165
+
166
+ #[inline]
167
+ pub(crate) fn into_entries(self) -> Vec<Bucket<T>> {
168
+ self.map.into_entries()
169
+ }
170
+
171
+ #[inline]
172
+ pub(crate) fn as_entries(&self) -> &[Bucket<T>] {
173
+ self.map.as_entries()
174
+ }
175
+
176
+ pub(crate) fn with_entries<F>(&mut self, f: F)
177
+ where
178
+ F: FnOnce(&mut [Bucket<T>]),
179
+ {
180
+ self.map.with_entries(f);
181
+ }
182
+
183
+ /// Return the number of elements the set can hold without reallocating.
184
+ ///
185
+ /// This number is a lower bound; the set might be able to hold more,
186
+ /// but is guaranteed to be able to hold at least this many.
187
+ ///
188
+ /// Computes in **O(1)** time.
189
+ pub fn capacity(&self) -> usize {
190
+ self.map.capacity()
191
+ }
192
+
193
+ /// Return a reference to the set's `BuildHasher`.
194
+ pub fn hasher(&self) -> &S {
195
+ self.map.hasher()
196
+ }
197
+
198
+ /// Return the number of elements in the set.
199
+ ///
200
+ /// Computes in **O(1)** time.
201
+ pub fn len(&self) -> usize {
202
+ self.map.len()
203
+ }
204
+
205
+ /// Returns true if the set contains no elements.
206
+ ///
207
+ /// Computes in **O(1)** time.
208
+ pub fn is_empty(&self) -> bool {
209
+ self.map.is_empty()
210
+ }
211
+
212
+ /// Return an iterator over the values of the set, in their order
213
+ pub fn iter(&self) -> Iter<'_, T> {
214
+ Iter::new(self.as_entries())
215
+ }
216
+
217
+ /// Remove all elements in the set, while preserving its capacity.
218
+ ///
219
+ /// Computes in **O(n)** time.
220
+ pub fn clear(&mut self) {
221
+ self.map.clear();
222
+ }
223
+
224
+ /// Shortens the set, keeping the first `len` elements and dropping the rest.
225
+ ///
226
+ /// If `len` is greater than the set's current length, this has no effect.
227
+ pub fn truncate(&mut self, len: usize) {
228
+ self.map.truncate(len);
229
+ }
230
+
231
+ /// Clears the `IndexSet` in the given index range, returning those values
232
+ /// as a drain iterator.
233
+ ///
234
+ /// The range may be any type that implements [`RangeBounds<usize>`],
235
+ /// including all of the `std::ops::Range*` types, or even a tuple pair of
236
+ /// `Bound` start and end values. To drain the set entirely, use `RangeFull`
237
+ /// like `set.drain(..)`.
238
+ ///
239
+ /// This shifts down all entries following the drained range to fill the
240
+ /// gap, and keeps the allocated memory for reuse.
241
+ ///
242
+ /// ***Panics*** if the starting point is greater than the end point or if
243
+ /// the end point is greater than the length of the set.
244
+ #[track_caller]
245
+ pub fn drain<R>(&mut self, range: R) -> Drain<'_, T>
246
+ where
247
+ R: RangeBounds<usize>,
248
+ {
249
+ Drain::new(self.map.core.drain(range))
250
+ }
251
+
252
+ /// Creates an iterator which uses a closure to determine if a value should be removed,
253
+ /// for all values in the given range.
254
+ ///
255
+ /// If the closure returns true, then the value is removed and yielded.
256
+ /// If the closure returns false, the value will remain in the list and will not be yielded
257
+ /// by the iterator.
258
+ ///
259
+ /// The range may be any type that implements [`RangeBounds<usize>`],
260
+ /// including all of the `std::ops::Range*` types, or even a tuple pair of
261
+ /// `Bound` start and end values. To check the entire set, use `RangeFull`
262
+ /// like `set.extract_if(.., predicate)`.
263
+ ///
264
+ /// If the returned `ExtractIf` is not exhausted, e.g. because it is dropped without iterating
265
+ /// or the iteration short-circuits, then the remaining elements will be retained.
266
+ /// Use [`retain`] with a negated predicate if you do not need the returned iterator.
267
+ ///
268
+ /// [`retain`]: IndexSet::retain
269
+ ///
270
+ /// ***Panics*** if the starting point is greater than the end point or if
271
+ /// the end point is greater than the length of the set.
272
+ ///
273
+ /// # Examples
274
+ ///
275
+ /// Splitting a set into even and odd values, reusing the original set:
276
+ ///
277
+ /// ```
278
+ /// use indexmap::IndexSet;
279
+ ///
280
+ /// let mut set: IndexSet<i32> = (0..8).collect();
281
+ /// let extracted: IndexSet<i32> = set.extract_if(.., |v| v % 2 == 0).collect();
282
+ ///
283
+ /// let evens = extracted.into_iter().collect::<Vec<_>>();
284
+ /// let odds = set.into_iter().collect::<Vec<_>>();
285
+ ///
286
+ /// assert_eq!(evens, vec![0, 2, 4, 6]);
287
+ /// assert_eq!(odds, vec![1, 3, 5, 7]);
288
+ /// ```
289
+ #[track_caller]
290
+ pub fn extract_if<F, R>(&mut self, range: R, pred: F) -> ExtractIf<'_, T, F>
291
+ where
292
+ F: FnMut(&T) -> bool,
293
+ R: RangeBounds<usize>,
294
+ {
295
+ ExtractIf::new(&mut self.map.core, range, pred)
296
+ }
297
+
298
+ /// Splits the collection into two at the given index.
299
+ ///
300
+ /// Returns a newly allocated set containing the elements in the range
301
+ /// `[at, len)`. After the call, the original set will be left containing
302
+ /// the elements `[0, at)` with its previous capacity unchanged.
303
+ ///
304
+ /// ***Panics*** if `at > len`.
305
+ #[track_caller]
306
+ pub fn split_off(&mut self, at: usize) -> Self
307
+ where
308
+ S: Clone,
309
+ {
310
+ Self {
311
+ map: self.map.split_off(at),
312
+ }
313
+ }
314
+
315
+ /// Reserve capacity for `additional` more values.
316
+ ///
317
+ /// Computes in **O(n)** time.
318
+ pub fn reserve(&mut self, additional: usize) {
319
+ self.map.reserve(additional);
320
+ }
321
+
322
+ /// Reserve capacity for `additional` more values, without over-allocating.
323
+ ///
324
+ /// Unlike `reserve`, this does not deliberately over-allocate the entry capacity to avoid
325
+ /// frequent re-allocations. However, the underlying data structures may still have internal
326
+ /// capacity requirements, and the allocator itself may give more space than requested, so this
327
+ /// cannot be relied upon to be precisely minimal.
328
+ ///
329
+ /// Computes in **O(n)** time.
330
+ pub fn reserve_exact(&mut self, additional: usize) {
331
+ self.map.reserve_exact(additional);
332
+ }
333
+
334
+ /// Try to reserve capacity for `additional` more values.
335
+ ///
336
+ /// Computes in **O(n)** time.
337
+ pub fn try_reserve(&mut self, additional: usize) -> Result<(), TryReserveError> {
338
+ self.map.try_reserve(additional)
339
+ }
340
+
341
+ /// Try to reserve capacity for `additional` more values, without over-allocating.
342
+ ///
343
+ /// Unlike `try_reserve`, this does not deliberately over-allocate the entry capacity to avoid
344
+ /// frequent re-allocations. However, the underlying data structures may still have internal
345
+ /// capacity requirements, and the allocator itself may give more space than requested, so this
346
+ /// cannot be relied upon to be precisely minimal.
347
+ ///
348
+ /// Computes in **O(n)** time.
349
+ pub fn try_reserve_exact(&mut self, additional: usize) -> Result<(), TryReserveError> {
350
+ self.map.try_reserve_exact(additional)
351
+ }
352
+
353
+ /// Shrink the capacity of the set as much as possible.
354
+ ///
355
+ /// Computes in **O(n)** time.
356
+ pub fn shrink_to_fit(&mut self) {
357
+ self.map.shrink_to_fit();
358
+ }
359
+
360
+ /// Shrink the capacity of the set with a lower limit.
361
+ ///
362
+ /// Computes in **O(n)** time.
363
+ pub fn shrink_to(&mut self, min_capacity: usize) {
364
+ self.map.shrink_to(min_capacity);
365
+ }
366
+ }
367
+
368
+ impl<T, S> IndexSet<T, S>
369
+ where
370
+ T: Hash + Eq,
371
+ S: BuildHasher,
372
+ {
373
+ /// Insert the value into the set.
374
+ ///
375
+ /// If an equivalent item already exists in the set, it returns
376
+ /// `false` leaving the original value in the set and without
377
+ /// altering its insertion order. Otherwise, it inserts the new
378
+ /// item and returns `true`.
379
+ ///
380
+ /// Computes in **O(1)** time (amortized average).
381
+ pub fn insert(&mut self, value: T) -> bool {
382
+ self.map.insert(value, ()).is_none()
383
+ }
384
+
385
+ /// Insert the value into the set, and get its index.
386
+ ///
387
+ /// If an equivalent item already exists in the set, it returns
388
+ /// the index of the existing item and `false`, leaving the
389
+ /// original value in the set and without altering its insertion
390
+ /// order. Otherwise, it inserts the new item and returns the index
391
+ /// of the inserted item and `true`.
392
+ ///
393
+ /// Computes in **O(1)** time (amortized average).
394
+ pub fn insert_full(&mut self, value: T) -> (usize, bool) {
395
+ let (index, existing) = self.map.insert_full(value, ());
396
+ (index, existing.is_none())
397
+ }
398
+
399
+ /// Insert the value into the set at its ordered position among sorted values.
400
+ ///
401
+ /// This is equivalent to finding the position with
402
+ /// [`binary_search`][Self::binary_search], and if needed calling
403
+ /// [`insert_before`][Self::insert_before] for a new value.
404
+ ///
405
+ /// If the sorted item is found in the set, it returns the index of that
406
+ /// existing item and `false`, without any change. Otherwise, it inserts the
407
+ /// new item and returns its sorted index and `true`.
408
+ ///
409
+ /// If the existing items are **not** already sorted, then the insertion
410
+ /// index is unspecified (like [`slice::binary_search`]), but the value
411
+ /// is moved to or inserted at that position regardless.
412
+ ///
413
+ /// Computes in **O(n)** time (average). Instead of repeating calls to
414
+ /// `insert_sorted`, it may be faster to call batched [`insert`][Self::insert]
415
+ /// or [`extend`][Self::extend] and only call [`sort`][Self::sort] or
416
+ /// [`sort_unstable`][Self::sort_unstable] once.
417
+ pub fn insert_sorted(&mut self, value: T) -> (usize, bool)
418
+ where
419
+ T: Ord,
420
+ {
421
+ let (index, existing) = self.map.insert_sorted(value, ());
422
+ (index, existing.is_none())
423
+ }
424
+
425
+ /// Insert the value into the set at its ordered position among values
426
+ /// sorted by `cmp`.
427
+ ///
428
+ /// This is equivalent to finding the position with
429
+ /// [`binary_search_by`][Self::binary_search_by], then calling
430
+ /// [`insert_before`][Self::insert_before].
431
+ ///
432
+ /// If the existing items are **not** already sorted, then the insertion
433
+ /// index is unspecified (like [`slice::binary_search`]), but the value
434
+ /// is moved to or inserted at that position regardless.
435
+ ///
436
+ /// Computes in **O(n)** time (average).
437
+ pub fn insert_sorted_by<F>(&mut self, value: T, mut cmp: F) -> (usize, bool)
438
+ where
439
+ T: Ord,
440
+ F: FnMut(&T, &T) -> Ordering,
441
+ {
442
+ let (index, existing) = self
443
+ .map
444
+ .insert_sorted_by(value, (), |a, (), b, ()| cmp(a, b));
445
+ (index, existing.is_none())
446
+ }
447
+
448
+ /// Insert the value into the set at its ordered position among values
449
+ /// using a sort-key extraction function.
450
+ ///
451
+ /// This is equivalent to finding the position with
452
+ /// [`binary_search_by_key`][Self::binary_search_by_key] with `sort_key(key)`,
453
+ /// then calling [`insert_before`][Self::insert_before].
454
+ ///
455
+ /// If the existing items are **not** already sorted, then the insertion
456
+ /// index is unspecified (like [`slice::binary_search`]), but the value
457
+ /// is moved to or inserted at that position regardless.
458
+ ///
459
+ /// Computes in **O(n)** time (average).
460
+ pub fn insert_sorted_by_key<B, F>(&mut self, value: T, mut sort_key: F) -> (usize, bool)
461
+ where
462
+ B: Ord,
463
+ F: FnMut(&T) -> B,
464
+ {
465
+ let (index, existing) = self.map.insert_sorted_by_key(value, (), |k, _| sort_key(k));
466
+ (index, existing.is_none())
467
+ }
468
+
469
+ /// Insert the value into the set before the value at the given index, or at the end.
470
+ ///
471
+ /// If an equivalent item already exists in the set, it returns `false` leaving the
472
+ /// original value in the set, but moved to the new position. The returned index
473
+ /// will either be the given index or one less, depending on how the value moved.
474
+ /// (See [`shift_insert`](Self::shift_insert) for different behavior here.)
475
+ ///
476
+ /// Otherwise, it inserts the new value exactly at the given index and returns `true`.
477
+ ///
478
+ /// ***Panics*** if `index` is out of bounds.
479
+ /// Valid indices are `0..=set.len()` (inclusive).
480
+ ///
481
+ /// Computes in **O(n)** time (average).
482
+ ///
483
+ /// # Examples
484
+ ///
485
+ /// ```
486
+ /// use indexmap::IndexSet;
487
+ /// let mut set: IndexSet<char> = ('a'..='z').collect();
488
+ ///
489
+ /// // The new value '*' goes exactly at the given index.
490
+ /// assert_eq!(set.get_index_of(&'*'), None);
491
+ /// assert_eq!(set.insert_before(10, '*'), (10, true));
492
+ /// assert_eq!(set.get_index_of(&'*'), Some(10));
493
+ ///
494
+ /// // Moving the value 'a' up will shift others down, so this moves *before* 10 to index 9.
495
+ /// assert_eq!(set.insert_before(10, 'a'), (9, false));
496
+ /// assert_eq!(set.get_index_of(&'a'), Some(9));
497
+ /// assert_eq!(set.get_index_of(&'*'), Some(10));
498
+ ///
499
+ /// // Moving the value 'z' down will shift others up, so this moves to exactly 10.
500
+ /// assert_eq!(set.insert_before(10, 'z'), (10, false));
501
+ /// assert_eq!(set.get_index_of(&'z'), Some(10));
502
+ /// assert_eq!(set.get_index_of(&'*'), Some(11));
503
+ ///
504
+ /// // Moving or inserting before the endpoint is also valid.
505
+ /// assert_eq!(set.len(), 27);
506
+ /// assert_eq!(set.insert_before(set.len(), '*'), (26, false));
507
+ /// assert_eq!(set.get_index_of(&'*'), Some(26));
508
+ /// assert_eq!(set.insert_before(set.len(), '+'), (27, true));
509
+ /// assert_eq!(set.get_index_of(&'+'), Some(27));
510
+ /// assert_eq!(set.len(), 28);
511
+ /// ```
512
+ #[track_caller]
513
+ pub fn insert_before(&mut self, index: usize, value: T) -> (usize, bool) {
514
+ let (index, existing) = self.map.insert_before(index, value, ());
515
+ (index, existing.is_none())
516
+ }
517
+
518
+ /// Insert the value into the set at the given index.
519
+ ///
520
+ /// If an equivalent item already exists in the set, it returns `false` leaving
521
+ /// the original value in the set, but moved to the given index.
522
+ /// Note that existing values **cannot** be moved to `index == set.len()`!
523
+ /// (See [`insert_before`](Self::insert_before) for different behavior here.)
524
+ ///
525
+ /// Otherwise, it inserts the new value at the given index and returns `true`.
526
+ ///
527
+ /// ***Panics*** if `index` is out of bounds.
528
+ /// Valid indices are `0..set.len()` (exclusive) when moving an existing value, or
529
+ /// `0..=set.len()` (inclusive) when inserting a new value.
530
+ ///
531
+ /// Computes in **O(n)** time (average).
532
+ ///
533
+ /// # Examples
534
+ ///
535
+ /// ```
536
+ /// use indexmap::IndexSet;
537
+ /// let mut set: IndexSet<char> = ('a'..='z').collect();
538
+ ///
539
+ /// // The new value '*' goes exactly at the given index.
540
+ /// assert_eq!(set.get_index_of(&'*'), None);
541
+ /// assert_eq!(set.shift_insert(10, '*'), true);
542
+ /// assert_eq!(set.get_index_of(&'*'), Some(10));
543
+ ///
544
+ /// // Moving the value 'a' up to 10 will shift others down, including the '*' that was at 10.
545
+ /// assert_eq!(set.shift_insert(10, 'a'), false);
546
+ /// assert_eq!(set.get_index_of(&'a'), Some(10));
547
+ /// assert_eq!(set.get_index_of(&'*'), Some(9));
548
+ ///
549
+ /// // Moving the value 'z' down to 9 will shift others up, including the '*' that was at 9.
550
+ /// assert_eq!(set.shift_insert(9, 'z'), false);
551
+ /// assert_eq!(set.get_index_of(&'z'), Some(9));
552
+ /// assert_eq!(set.get_index_of(&'*'), Some(10));
553
+ ///
554
+ /// // Existing values can move to len-1 at most, but new values can insert at the endpoint.
555
+ /// assert_eq!(set.len(), 27);
556
+ /// assert_eq!(set.shift_insert(set.len() - 1, '*'), false);
557
+ /// assert_eq!(set.get_index_of(&'*'), Some(26));
558
+ /// assert_eq!(set.shift_insert(set.len(), '+'), true);
559
+ /// assert_eq!(set.get_index_of(&'+'), Some(27));
560
+ /// assert_eq!(set.len(), 28);
561
+ /// ```
562
+ ///
563
+ /// ```should_panic
564
+ /// use indexmap::IndexSet;
565
+ /// let mut set: IndexSet<char> = ('a'..='z').collect();
566
+ ///
567
+ /// // This is an invalid index for moving an existing value!
568
+ /// set.shift_insert(set.len(), 'a');
569
+ /// ```
570
+ #[track_caller]
571
+ pub fn shift_insert(&mut self, index: usize, value: T) -> bool {
572
+ self.map.shift_insert(index, value, ()).is_none()
573
+ }
574
+
575
+ /// Adds a value to the set, replacing the existing value, if any, that is
576
+ /// equal to the given one, without altering its insertion order. Returns
577
+ /// the replaced value.
578
+ ///
579
+ /// Computes in **O(1)** time (average).
580
+ pub fn replace(&mut self, value: T) -> Option<T> {
581
+ self.replace_full(value).1
582
+ }
583
+
584
+ /// Adds a value to the set, replacing the existing value, if any, that is
585
+ /// equal to the given one, without altering its insertion order. Returns
586
+ /// the index of the item and its replaced value.
587
+ ///
588
+ /// Computes in **O(1)** time (average).
589
+ pub fn replace_full(&mut self, value: T) -> (usize, Option<T>) {
590
+ let hash = self.map.hash(&value);
591
+ match self.map.core.replace_full(hash, value, ()) {
592
+ (i, Some((replaced, ()))) => (i, Some(replaced)),
593
+ (i, None) => (i, None),
594
+ }
595
+ }
596
+
597
+ /// Replaces the value at the given index. The new value does not need to be
598
+ /// equivalent to the one it is replacing, but it must be unique to the rest
599
+ /// of the set.
600
+ ///
601
+ /// Returns `Ok(old_value)` if successful, or `Err((other_index, value))` if
602
+ /// an equivalent value already exists at a different index. The set will be
603
+ /// unchanged in the error case.
604
+ ///
605
+ /// ***Panics*** if `index` is out of bounds.
606
+ ///
607
+ /// Computes in **O(1)** time (average).
608
+ #[track_caller]
609
+ pub fn replace_index(&mut self, index: usize, value: T) -> Result<T, (usize, T)> {
610
+ self.map.replace_index(index, value)
611
+ }
612
+
613
+ /// Return an iterator over the values that are in `self` but not `other`.
614
+ ///
615
+ /// Values are produced in the same order that they appear in `self`.
616
+ pub fn difference<'a, S2>(&'a self, other: &'a IndexSet<T, S2>) -> Difference<'a, T, S2>
617
+ where
618
+ S2: BuildHasher,
619
+ {
620
+ Difference::new(self, other)
621
+ }
622
+
623
+ /// Return an iterator over the values that are in `self` or `other`,
624
+ /// but not in both.
625
+ ///
626
+ /// Values from `self` are produced in their original order, followed by
627
+ /// values from `other` in their original order.
628
+ pub fn symmetric_difference<'a, S2>(
629
+ &'a self,
630
+ other: &'a IndexSet<T, S2>,
631
+ ) -> SymmetricDifference<'a, T, S, S2>
632
+ where
633
+ S2: BuildHasher,
634
+ {
635
+ SymmetricDifference::new(self, other)
636
+ }
637
+
638
+ /// Return an iterator over the values that are in both `self` and `other`.
639
+ ///
640
+ /// Values are produced in the same order that they appear in `self`.
641
+ pub fn intersection<'a, S2>(&'a self, other: &'a IndexSet<T, S2>) -> Intersection<'a, T, S2>
642
+ where
643
+ S2: BuildHasher,
644
+ {
645
+ Intersection::new(self, other)
646
+ }
647
+
648
+ /// Return an iterator over all values that are in `self` or `other`.
649
+ ///
650
+ /// Values from `self` are produced in their original order, followed by
651
+ /// values that are unique to `other` in their original order.
652
+ pub fn union<'a, S2>(&'a self, other: &'a IndexSet<T, S2>) -> Union<'a, T, S>
653
+ where
654
+ S2: BuildHasher,
655
+ {
656
+ Union::new(self, other)
657
+ }
658
+
659
+ /// Creates a splicing iterator that replaces the specified range in the set
660
+ /// with the given `replace_with` iterator and yields the removed items.
661
+ /// `replace_with` does not need to be the same length as `range`.
662
+ ///
663
+ /// The `range` is removed even if the iterator is not consumed until the
664
+ /// end. It is unspecified how many elements are removed from the set if the
665
+ /// `Splice` value is leaked.
666
+ ///
667
+ /// The input iterator `replace_with` is only consumed when the `Splice`
668
+ /// value is dropped. If a value from the iterator matches an existing entry
669
+ /// in the set (outside of `range`), then the original will be unchanged.
670
+ /// Otherwise, the new value will be inserted in the replaced `range`.
671
+ ///
672
+ /// ***Panics*** if the starting point is greater than the end point or if
673
+ /// the end point is greater than the length of the set.
674
+ ///
675
+ /// # Examples
676
+ ///
677
+ /// ```
678
+ /// use indexmap::IndexSet;
679
+ ///
680
+ /// let mut set = IndexSet::from([0, 1, 2, 3, 4]);
681
+ /// let new = [5, 4, 3, 2, 1];
682
+ /// let removed: Vec<_> = set.splice(2..4, new).collect();
683
+ ///
684
+ /// // 1 and 4 kept their positions, while 5, 3, and 2 were newly inserted.
685
+ /// assert!(set.into_iter().eq([0, 1, 5, 3, 2, 4]));
686
+ /// assert_eq!(removed, &[2, 3]);
687
+ /// ```
688
+ #[track_caller]
689
+ pub fn splice<R, I>(&mut self, range: R, replace_with: I) -> Splice<'_, I::IntoIter, T, S>
690
+ where
691
+ R: RangeBounds<usize>,
692
+ I: IntoIterator<Item = T>,
693
+ {
694
+ Splice::new(self, range, replace_with.into_iter())
695
+ }
696
+
697
+ /// Moves all values from `other` into `self`, leaving `other` empty.
698
+ ///
699
+ /// This is equivalent to calling [`insert`][Self::insert] for each value
700
+ /// from `other` in order, which means that values that already exist
701
+ /// in `self` are unchanged in their current position.
702
+ ///
703
+ /// See also [`union`][Self::union] to iterate the combined values by
704
+ /// reference, without modifying `self` or `other`.
705
+ ///
706
+ /// # Examples
707
+ ///
708
+ /// ```
709
+ /// use indexmap::IndexSet;
710
+ ///
711
+ /// let mut a = IndexSet::from([3, 2, 1]);
712
+ /// let mut b = IndexSet::from([3, 4, 5]);
713
+ /// let old_capacity = b.capacity();
714
+ ///
715
+ /// a.append(&mut b);
716
+ ///
717
+ /// assert_eq!(a.len(), 5);
718
+ /// assert_eq!(b.len(), 0);
719
+ /// assert_eq!(b.capacity(), old_capacity);
720
+ ///
721
+ /// assert!(a.iter().eq(&[3, 2, 1, 4, 5]));
722
+ /// ```
723
+ pub fn append<S2>(&mut self, other: &mut IndexSet<T, S2>) {
724
+ self.map.append(&mut other.map);
725
+ }
726
+ }
727
+
728
+ impl<T, S> IndexSet<T, S>
729
+ where
730
+ S: BuildHasher,
731
+ {
732
+ /// Return `true` if an equivalent to `value` exists in the set.
733
+ ///
734
+ /// Computes in **O(1)** time (average).
735
+ pub fn contains<Q>(&self, value: &Q) -> bool
736
+ where
737
+ Q: ?Sized + Hash + Equivalent<T>,
738
+ {
739
+ self.map.contains_key(value)
740
+ }
741
+
742
+ /// Return a reference to the value stored in the set, if it is present,
743
+ /// else `None`.
744
+ ///
745
+ /// Computes in **O(1)** time (average).
746
+ pub fn get<Q>(&self, value: &Q) -> Option<&T>
747
+ where
748
+ Q: ?Sized + Hash + Equivalent<T>,
749
+ {
750
+ self.map.get_key_value(value).map(|(x, &())| x)
751
+ }
752
+
753
+ /// Return item index and value
754
+ pub fn get_full<Q>(&self, value: &Q) -> Option<(usize, &T)>
755
+ where
756
+ Q: ?Sized + Hash + Equivalent<T>,
757
+ {
758
+ self.map.get_full(value).map(|(i, x, &())| (i, x))
759
+ }
760
+
761
+ /// Return item index, if it exists in the set
762
+ ///
763
+ /// Computes in **O(1)** time (average).
764
+ pub fn get_index_of<Q>(&self, value: &Q) -> Option<usize>
765
+ where
766
+ Q: ?Sized + Hash + Equivalent<T>,
767
+ {
768
+ self.map.get_index_of(value)
769
+ }
770
+
771
+ /// Remove the value from the set, and return `true` if it was present.
772
+ ///
773
+ /// **NOTE:** This is equivalent to [`.swap_remove(value)`][Self::swap_remove], replacing this
774
+ /// value's position with the last element, and it is deprecated in favor of calling that
775
+ /// explicitly. If you need to preserve the relative order of the values in the set, use
776
+ /// [`.shift_remove(value)`][Self::shift_remove] instead.
777
+ #[deprecated(note = "`remove` disrupts the set order -- \
778
+ use `swap_remove` or `shift_remove` for explicit behavior.")]
779
+ pub fn remove<Q>(&mut self, value: &Q) -> bool
780
+ where
781
+ Q: ?Sized + Hash + Equivalent<T>,
782
+ {
783
+ self.swap_remove(value)
784
+ }
785
+
786
+ /// Remove the value from the set, and return `true` if it was present.
787
+ ///
788
+ /// Like [`Vec::swap_remove`], the value is removed by swapping it with the
789
+ /// last element of the set and popping it off. **This perturbs
790
+ /// the position of what used to be the last element!**
791
+ ///
792
+ /// Return `false` if `value` was not in the set.
793
+ ///
794
+ /// Computes in **O(1)** time (average).
795
+ pub fn swap_remove<Q>(&mut self, value: &Q) -> bool
796
+ where
797
+ Q: ?Sized + Hash + Equivalent<T>,
798
+ {
799
+ self.map.swap_remove(value).is_some()
800
+ }
801
+
802
+ /// Remove the value from the set, and return `true` if it was present.
803
+ ///
804
+ /// Like [`Vec::remove`], the value is removed by shifting all of the
805
+ /// elements that follow it, preserving their relative order.
806
+ /// **This perturbs the index of all of those elements!**
807
+ ///
808
+ /// Return `false` if `value` was not in the set.
809
+ ///
810
+ /// Computes in **O(n)** time (average).
811
+ pub fn shift_remove<Q>(&mut self, value: &Q) -> bool
812
+ where
813
+ Q: ?Sized + Hash + Equivalent<T>,
814
+ {
815
+ self.map.shift_remove(value).is_some()
816
+ }
817
+
818
+ /// Removes and returns the value in the set, if any, that is equal to the
819
+ /// given one.
820
+ ///
821
+ /// **NOTE:** This is equivalent to [`.swap_take(value)`][Self::swap_take], replacing this
822
+ /// value's position with the last element, and it is deprecated in favor of calling that
823
+ /// explicitly. If you need to preserve the relative order of the values in the set, use
824
+ /// [`.shift_take(value)`][Self::shift_take] instead.
825
+ #[deprecated(note = "`take` disrupts the set order -- \
826
+ use `swap_take` or `shift_take` for explicit behavior.")]
827
+ pub fn take<Q>(&mut self, value: &Q) -> Option<T>
828
+ where
829
+ Q: ?Sized + Hash + Equivalent<T>,
830
+ {
831
+ self.swap_take(value)
832
+ }
833
+
834
+ /// Removes and returns the value in the set, if any, that is equal to the
835
+ /// given one.
836
+ ///
837
+ /// Like [`Vec::swap_remove`], the value is removed by swapping it with the
838
+ /// last element of the set and popping it off. **This perturbs
839
+ /// the position of what used to be the last element!**
840
+ ///
841
+ /// Return `None` if `value` was not in the set.
842
+ ///
843
+ /// Computes in **O(1)** time (average).
844
+ pub fn swap_take<Q>(&mut self, value: &Q) -> Option<T>
845
+ where
846
+ Q: ?Sized + Hash + Equivalent<T>,
847
+ {
848
+ self.map.swap_remove_entry(value).map(|(x, ())| x)
849
+ }
850
+
851
+ /// Removes and returns the value in the set, if any, that is equal to the
852
+ /// given one.
853
+ ///
854
+ /// Like [`Vec::remove`], the value is removed by shifting all of the
855
+ /// elements that follow it, preserving their relative order.
856
+ /// **This perturbs the index of all of those elements!**
857
+ ///
858
+ /// Return `None` if `value` was not in the set.
859
+ ///
860
+ /// Computes in **O(n)** time (average).
861
+ pub fn shift_take<Q>(&mut self, value: &Q) -> Option<T>
862
+ where
863
+ Q: ?Sized + Hash + Equivalent<T>,
864
+ {
865
+ self.map.shift_remove_entry(value).map(|(x, ())| x)
866
+ }
867
+
868
+ /// Remove the value from the set return it and the index it had.
869
+ ///
870
+ /// Like [`Vec::swap_remove`], the value is removed by swapping it with the
871
+ /// last element of the set and popping it off. **This perturbs
872
+ /// the position of what used to be the last element!**
873
+ ///
874
+ /// Return `None` if `value` was not in the set.
875
+ pub fn swap_remove_full<Q>(&mut self, value: &Q) -> Option<(usize, T)>
876
+ where
877
+ Q: ?Sized + Hash + Equivalent<T>,
878
+ {
879
+ self.map.swap_remove_full(value).map(|(i, x, ())| (i, x))
880
+ }
881
+
882
+ /// Remove the value from the set return it and the index it had.
883
+ ///
884
+ /// Like [`Vec::remove`], the value is removed by shifting all of the
885
+ /// elements that follow it, preserving their relative order.
886
+ /// **This perturbs the index of all of those elements!**
887
+ ///
888
+ /// Return `None` if `value` was not in the set.
889
+ pub fn shift_remove_full<Q>(&mut self, value: &Q) -> Option<(usize, T)>
890
+ where
891
+ Q: ?Sized + Hash + Equivalent<T>,
892
+ {
893
+ self.map.shift_remove_full(value).map(|(i, x, ())| (i, x))
894
+ }
895
+ }
896
+
897
+ impl<T, S> IndexSet<T, S> {
898
+ /// Remove the last value
899
+ ///
900
+ /// This preserves the order of the remaining elements.
901
+ ///
902
+ /// Computes in **O(1)** time (average).
903
+ #[doc(alias = "pop_last")] // like `BTreeSet`
904
+ pub fn pop(&mut self) -> Option<T> {
905
+ self.map.pop().map(|(x, ())| x)
906
+ }
907
+
908
+ /// Scan through each value in the set and keep those where the
909
+ /// closure `keep` returns `true`.
910
+ ///
911
+ /// The elements are visited in order, and remaining elements keep their
912
+ /// order.
913
+ ///
914
+ /// Computes in **O(n)** time (average).
915
+ pub fn retain<F>(&mut self, mut keep: F)
916
+ where
917
+ F: FnMut(&T) -> bool,
918
+ {
919
+ self.map.retain(move |x, &mut ()| keep(x))
920
+ }
921
+
922
+ /// Sort the set's values by their default ordering.
923
+ ///
924
+ /// This is a stable sort -- but equivalent values should not normally coexist in
925
+ /// a set at all, so [`sort_unstable`][Self::sort_unstable] is preferred
926
+ /// because it is generally faster and doesn't allocate auxiliary memory.
927
+ ///
928
+ /// See [`sort_by`](Self::sort_by) for details.
929
+ pub fn sort(&mut self)
930
+ where
931
+ T: Ord,
932
+ {
933
+ self.map.sort_keys()
934
+ }
935
+
936
+ /// Sort the set's values in place using the comparison function `cmp`.
937
+ ///
938
+ /// Computes in **O(n log n)** time and **O(n)** space. The sort is stable.
939
+ pub fn sort_by<F>(&mut self, mut cmp: F)
940
+ where
941
+ F: FnMut(&T, &T) -> Ordering,
942
+ {
943
+ self.map.sort_by(move |a, (), b, ()| cmp(a, b));
944
+ }
945
+
946
+ /// Sort the values of the set and return a by-value iterator of
947
+ /// the values with the result.
948
+ ///
949
+ /// The sort is stable.
950
+ pub fn sorted_by<F>(self, mut cmp: F) -> IntoIter<T>
951
+ where
952
+ F: FnMut(&T, &T) -> Ordering,
953
+ {
954
+ let mut entries = self.into_entries();
955
+ entries.sort_by(move |a, b| cmp(&a.key, &b.key));
956
+ IntoIter::new(entries)
957
+ }
958
+
959
+ /// Sort the set's values in place using a key extraction function.
960
+ ///
961
+ /// Computes in **O(n log n)** time and **O(n)** space. The sort is stable.
962
+ pub fn sort_by_key<K, F>(&mut self, mut sort_key: F)
963
+ where
964
+ K: Ord,
965
+ F: FnMut(&T) -> K,
966
+ {
967
+ self.with_entries(move |entries| {
968
+ entries.sort_by_key(move |a| sort_key(&a.key));
969
+ });
970
+ }
971
+
972
+ /// Sort the set's values by their default ordering.
973
+ ///
974
+ /// See [`sort_unstable_by`](Self::sort_unstable_by) for details.
975
+ pub fn sort_unstable(&mut self)
976
+ where
977
+ T: Ord,
978
+ {
979
+ self.map.sort_unstable_keys()
980
+ }
981
+
982
+ /// Sort the set's values in place using the comparison function `cmp`.
983
+ ///
984
+ /// Computes in **O(n log n)** time. The sort is unstable.
985
+ pub fn sort_unstable_by<F>(&mut self, mut cmp: F)
986
+ where
987
+ F: FnMut(&T, &T) -> Ordering,
988
+ {
989
+ self.map.sort_unstable_by(move |a, _, b, _| cmp(a, b))
990
+ }
991
+
992
+ /// Sort the values of the set and return a by-value iterator of
993
+ /// the values with the result.
994
+ pub fn sorted_unstable_by<F>(self, mut cmp: F) -> IntoIter<T>
995
+ where
996
+ F: FnMut(&T, &T) -> Ordering,
997
+ {
998
+ let mut entries = self.into_entries();
999
+ entries.sort_unstable_by(move |a, b| cmp(&a.key, &b.key));
1000
+ IntoIter::new(entries)
1001
+ }
1002
+
1003
+ /// Sort the set's values in place using a key extraction function.
1004
+ ///
1005
+ /// Computes in **O(n log n)** time. The sort is unstable.
1006
+ pub fn sort_unstable_by_key<K, F>(&mut self, mut sort_key: F)
1007
+ where
1008
+ K: Ord,
1009
+ F: FnMut(&T) -> K,
1010
+ {
1011
+ self.with_entries(move |entries| {
1012
+ entries.sort_unstable_by_key(move |a| sort_key(&a.key));
1013
+ });
1014
+ }
1015
+
1016
+ /// Sort the set's values in place using a key extraction function.
1017
+ ///
1018
+ /// During sorting, the function is called at most once per entry, by using temporary storage
1019
+ /// to remember the results of its evaluation. The order of calls to the function is
1020
+ /// unspecified and may change between versions of `indexmap` or the standard library.
1021
+ ///
1022
+ /// Computes in **O(m n + n log n + c)** time () and **O(n)** space, where the function is
1023
+ /// **O(m)**, *n* is the length of the map, and *c* the capacity. The sort is stable.
1024
+ pub fn sort_by_cached_key<K, F>(&mut self, mut sort_key: F)
1025
+ where
1026
+ K: Ord,
1027
+ F: FnMut(&T) -> K,
1028
+ {
1029
+ self.with_entries(move |entries| {
1030
+ entries.sort_by_cached_key(move |a| sort_key(&a.key));
1031
+ });
1032
+ }
1033
+
1034
+ /// Search over a sorted set for a value.
1035
+ ///
1036
+ /// Returns the position where that value is present, or the position where it can be inserted
1037
+ /// to maintain the sort. See [`slice::binary_search`] for more details.
1038
+ ///
1039
+ /// Computes in **O(log(n))** time, which is notably less scalable than looking the value up
1040
+ /// using [`get_index_of`][IndexSet::get_index_of], but this can also position missing values.
1041
+ pub fn binary_search(&self, x: &T) -> Result<usize, usize>
1042
+ where
1043
+ T: Ord,
1044
+ {
1045
+ self.as_slice().binary_search(x)
1046
+ }
1047
+
1048
+ /// Search over a sorted set with a comparator function.
1049
+ ///
1050
+ /// Returns the position where that value is present, or the position where it can be inserted
1051
+ /// to maintain the sort. See [`slice::binary_search_by`] for more details.
1052
+ ///
1053
+ /// Computes in **O(log(n))** time.
1054
+ #[inline]
1055
+ pub fn binary_search_by<'a, F>(&'a self, f: F) -> Result<usize, usize>
1056
+ where
1057
+ F: FnMut(&'a T) -> Ordering,
1058
+ {
1059
+ self.as_slice().binary_search_by(f)
1060
+ }
1061
+
1062
+ /// Search over a sorted set with an extraction function.
1063
+ ///
1064
+ /// Returns the position where that value is present, or the position where it can be inserted
1065
+ /// to maintain the sort. See [`slice::binary_search_by_key`] for more details.
1066
+ ///
1067
+ /// Computes in **O(log(n))** time.
1068
+ #[inline]
1069
+ pub fn binary_search_by_key<'a, B, F>(&'a self, b: &B, f: F) -> Result<usize, usize>
1070
+ where
1071
+ F: FnMut(&'a T) -> B,
1072
+ B: Ord,
1073
+ {
1074
+ self.as_slice().binary_search_by_key(b, f)
1075
+ }
1076
+
1077
+ /// Checks if the values of this set are sorted.
1078
+ #[inline]
1079
+ pub fn is_sorted(&self) -> bool
1080
+ where
1081
+ T: PartialOrd,
1082
+ {
1083
+ self.as_slice().is_sorted()
1084
+ }
1085
+
1086
+ /// Checks if this set is sorted using the given comparator function.
1087
+ #[inline]
1088
+ pub fn is_sorted_by<'a, F>(&'a self, cmp: F) -> bool
1089
+ where
1090
+ F: FnMut(&'a T, &'a T) -> bool,
1091
+ {
1092
+ self.as_slice().is_sorted_by(cmp)
1093
+ }
1094
+
1095
+ /// Checks if this set is sorted using the given sort-key function.
1096
+ #[inline]
1097
+ pub fn is_sorted_by_key<'a, F, K>(&'a self, sort_key: F) -> bool
1098
+ where
1099
+ F: FnMut(&'a T) -> K,
1100
+ K: PartialOrd,
1101
+ {
1102
+ self.as_slice().is_sorted_by_key(sort_key)
1103
+ }
1104
+
1105
+ /// Returns the index of the partition point of a sorted set according to the given predicate
1106
+ /// (the index of the first element of the second partition).
1107
+ ///
1108
+ /// See [`slice::partition_point`] for more details.
1109
+ ///
1110
+ /// Computes in **O(log(n))** time.
1111
+ #[must_use]
1112
+ pub fn partition_point<P>(&self, pred: P) -> usize
1113
+ where
1114
+ P: FnMut(&T) -> bool,
1115
+ {
1116
+ self.as_slice().partition_point(pred)
1117
+ }
1118
+
1119
+ /// Reverses the order of the set's values in place.
1120
+ ///
1121
+ /// Computes in **O(n)** time and **O(1)** space.
1122
+ pub fn reverse(&mut self) {
1123
+ self.map.reverse()
1124
+ }
1125
+
1126
+ /// Returns a slice of all the values in the set.
1127
+ ///
1128
+ /// Computes in **O(1)** time.
1129
+ pub fn as_slice(&self) -> &Slice<T> {
1130
+ Slice::from_slice(self.as_entries())
1131
+ }
1132
+
1133
+ /// Converts into a boxed slice of all the values in the set.
1134
+ ///
1135
+ /// Note that this will drop the inner hash table and any excess capacity.
1136
+ pub fn into_boxed_slice(self) -> Box<Slice<T>> {
1137
+ Slice::from_boxed(self.into_entries().into_boxed_slice())
1138
+ }
1139
+
1140
+ /// Get a value by index
1141
+ ///
1142
+ /// Valid indices are `0 <= index < self.len()`.
1143
+ ///
1144
+ /// Computes in **O(1)** time.
1145
+ pub fn get_index(&self, index: usize) -> Option<&T> {
1146
+ self.as_entries().get(index).map(Bucket::key_ref)
1147
+ }
1148
+
1149
+ /// Returns a slice of values in the given range of indices.
1150
+ ///
1151
+ /// Valid indices are `0 <= index < self.len()`.
1152
+ ///
1153
+ /// Computes in **O(1)** time.
1154
+ pub fn get_range<R: RangeBounds<usize>>(&self, range: R) -> Option<&Slice<T>> {
1155
+ let entries = self.as_entries();
1156
+ let range = try_simplify_range(range, entries.len())?;
1157
+ entries.get(range).map(Slice::from_slice)
1158
+ }
1159
+
1160
+ /// Get the first value
1161
+ ///
1162
+ /// Computes in **O(1)** time.
1163
+ pub fn first(&self) -> Option<&T> {
1164
+ self.as_entries().first().map(Bucket::key_ref)
1165
+ }
1166
+
1167
+ /// Get the last value
1168
+ ///
1169
+ /// Computes in **O(1)** time.
1170
+ pub fn last(&self) -> Option<&T> {
1171
+ self.as_entries().last().map(Bucket::key_ref)
1172
+ }
1173
+
1174
+ /// Remove the value by index
1175
+ ///
1176
+ /// Valid indices are `0 <= index < self.len()`.
1177
+ ///
1178
+ /// Like [`Vec::swap_remove`], the value is removed by swapping it with the
1179
+ /// last element of the set and popping it off. **This perturbs
1180
+ /// the position of what used to be the last element!**
1181
+ ///
1182
+ /// Computes in **O(1)** time (average).
1183
+ pub fn swap_remove_index(&mut self, index: usize) -> Option<T> {
1184
+ self.map.swap_remove_index(index).map(|(x, ())| x)
1185
+ }
1186
+
1187
+ /// Remove the value by index
1188
+ ///
1189
+ /// Valid indices are `0 <= index < self.len()`.
1190
+ ///
1191
+ /// Like [`Vec::remove`], the value is removed by shifting all of the
1192
+ /// elements that follow it, preserving their relative order.
1193
+ /// **This perturbs the index of all of those elements!**
1194
+ ///
1195
+ /// Computes in **O(n)** time (average).
1196
+ pub fn shift_remove_index(&mut self, index: usize) -> Option<T> {
1197
+ self.map.shift_remove_index(index).map(|(x, ())| x)
1198
+ }
1199
+
1200
+ /// Moves the position of a value from one index to another
1201
+ /// by shifting all other values in-between.
1202
+ ///
1203
+ /// * If `from < to`, the other values will shift down while the targeted value moves up.
1204
+ /// * If `from > to`, the other values will shift up while the targeted value moves down.
1205
+ ///
1206
+ /// ***Panics*** if `from` or `to` are out of bounds.
1207
+ ///
1208
+ /// Computes in **O(n)** time (average).
1209
+ #[track_caller]
1210
+ pub fn move_index(&mut self, from: usize, to: usize) {
1211
+ self.map.move_index(from, to)
1212
+ }
1213
+
1214
+ /// Swaps the position of two values in the set.
1215
+ ///
1216
+ /// ***Panics*** if `a` or `b` are out of bounds.
1217
+ ///
1218
+ /// Computes in **O(1)** time (average).
1219
+ #[track_caller]
1220
+ pub fn swap_indices(&mut self, a: usize, b: usize) {
1221
+ self.map.swap_indices(a, b)
1222
+ }
1223
+ }
1224
+
1225
+ /// Access [`IndexSet`] values at indexed positions.
1226
+ ///
1227
+ /// # Examples
1228
+ ///
1229
+ /// ```
1230
+ /// use indexmap::IndexSet;
1231
+ ///
1232
+ /// let mut set = IndexSet::new();
1233
+ /// for word in "Lorem ipsum dolor sit amet".split_whitespace() {
1234
+ /// set.insert(word.to_string());
1235
+ /// }
1236
+ /// assert_eq!(set[0], "Lorem");
1237
+ /// assert_eq!(set[1], "ipsum");
1238
+ /// set.reverse();
1239
+ /// assert_eq!(set[0], "amet");
1240
+ /// assert_eq!(set[1], "sit");
1241
+ /// set.sort();
1242
+ /// assert_eq!(set[0], "Lorem");
1243
+ /// assert_eq!(set[1], "amet");
1244
+ /// ```
1245
+ ///
1246
+ /// ```should_panic
1247
+ /// use indexmap::IndexSet;
1248
+ ///
1249
+ /// let mut set = IndexSet::new();
1250
+ /// set.insert("foo");
1251
+ /// println!("{:?}", set[10]); // panics!
1252
+ /// ```
1253
+ impl<T, S> Index<usize> for IndexSet<T, S> {
1254
+ type Output = T;
1255
+
1256
+ /// Returns a reference to the value at the supplied `index`.
1257
+ ///
1258
+ /// ***Panics*** if `index` is out of bounds.
1259
+ fn index(&self, index: usize) -> &T {
1260
+ if let Some(value) = self.get_index(index) {
1261
+ value
1262
+ } else {
1263
+ panic!(
1264
+ "index out of bounds: the len is {len} but the index is {index}",
1265
+ len = self.len()
1266
+ );
1267
+ }
1268
+ }
1269
+ }
1270
+
1271
+ impl<T, S> FromIterator<T> for IndexSet<T, S>
1272
+ where
1273
+ T: Hash + Eq,
1274
+ S: BuildHasher + Default,
1275
+ {
1276
+ fn from_iter<I: IntoIterator<Item = T>>(iterable: I) -> Self {
1277
+ let iter = iterable.into_iter().map(|x| (x, ()));
1278
+ IndexSet {
1279
+ map: IndexMap::from_iter(iter),
1280
+ }
1281
+ }
1282
+ }
1283
+
1284
+ #[cfg(feature = "std")]
1285
+ #[cfg_attr(docsrs, doc(cfg(feature = "std")))]
1286
+ impl<T, const N: usize> From<[T; N]> for IndexSet<T, RandomState>
1287
+ where
1288
+ T: Eq + Hash,
1289
+ {
1290
+ /// # Examples
1291
+ ///
1292
+ /// ```
1293
+ /// use indexmap::IndexSet;
1294
+ ///
1295
+ /// let set1 = IndexSet::from([1, 2, 3, 4]);
1296
+ /// let set2: IndexSet<_> = [1, 2, 3, 4].into();
1297
+ /// assert_eq!(set1, set2);
1298
+ /// ```
1299
+ fn from(arr: [T; N]) -> Self {
1300
+ Self::from_iter(arr)
1301
+ }
1302
+ }
1303
+
1304
+ impl<T, S> Extend<T> for IndexSet<T, S>
1305
+ where
1306
+ T: Hash + Eq,
1307
+ S: BuildHasher,
1308
+ {
1309
+ fn extend<I: IntoIterator<Item = T>>(&mut self, iterable: I) {
1310
+ let iter = iterable.into_iter().map(|x| (x, ()));
1311
+ self.map.extend(iter);
1312
+ }
1313
+ }
1314
+
1315
+ impl<'a, T, S> Extend<&'a T> for IndexSet<T, S>
1316
+ where
1317
+ T: Hash + Eq + Copy + 'a,
1318
+ S: BuildHasher,
1319
+ {
1320
+ fn extend<I: IntoIterator<Item = &'a T>>(&mut self, iterable: I) {
1321
+ let iter = iterable.into_iter().copied();
1322
+ self.extend(iter);
1323
+ }
1324
+ }
1325
+
1326
+ impl<T, S> Default for IndexSet<T, S>
1327
+ where
1328
+ S: Default,
1329
+ {
1330
+ /// Return an empty [`IndexSet`]
1331
+ fn default() -> Self {
1332
+ IndexSet {
1333
+ map: IndexMap::default(),
1334
+ }
1335
+ }
1336
+ }
1337
+
1338
+ impl<T, S1, S2> PartialEq<IndexSet<T, S2>> for IndexSet<T, S1>
1339
+ where
1340
+ T: Hash + Eq,
1341
+ S1: BuildHasher,
1342
+ S2: BuildHasher,
1343
+ {
1344
+ fn eq(&self, other: &IndexSet<T, S2>) -> bool {
1345
+ self.len() == other.len() && self.is_subset(other)
1346
+ }
1347
+ }
1348
+
1349
+ impl<T, S> Eq for IndexSet<T, S>
1350
+ where
1351
+ T: Eq + Hash,
1352
+ S: BuildHasher,
1353
+ {
1354
+ }
1355
+
1356
+ impl<T, S> IndexSet<T, S>
1357
+ where
1358
+ T: Eq + Hash,
1359
+ S: BuildHasher,
1360
+ {
1361
+ /// Returns `true` if `self` has no elements in common with `other`.
1362
+ pub fn is_disjoint<S2>(&self, other: &IndexSet<T, S2>) -> bool
1363
+ where
1364
+ S2: BuildHasher,
1365
+ {
1366
+ if self.len() <= other.len() {
1367
+ self.iter().all(move |value| !other.contains(value))
1368
+ } else {
1369
+ other.iter().all(move |value| !self.contains(value))
1370
+ }
1371
+ }
1372
+
1373
+ /// Returns `true` if all elements of `self` are contained in `other`.
1374
+ pub fn is_subset<S2>(&self, other: &IndexSet<T, S2>) -> bool
1375
+ where
1376
+ S2: BuildHasher,
1377
+ {
1378
+ self.len() <= other.len() && self.iter().all(move |value| other.contains(value))
1379
+ }
1380
+
1381
+ /// Returns `true` if all elements of `other` are contained in `self`.
1382
+ pub fn is_superset<S2>(&self, other: &IndexSet<T, S2>) -> bool
1383
+ where
1384
+ S2: BuildHasher,
1385
+ {
1386
+ other.is_subset(self)
1387
+ }
1388
+ }
1389
+
1390
+ impl<T, S1, S2> BitAnd<&IndexSet<T, S2>> for &IndexSet<T, S1>
1391
+ where
1392
+ T: Eq + Hash + Clone,
1393
+ S1: BuildHasher + Default,
1394
+ S2: BuildHasher,
1395
+ {
1396
+ type Output = IndexSet<T, S1>;
1397
+
1398
+ /// Returns the set intersection, cloned into a new set.
1399
+ ///
1400
+ /// Values are collected in the same order that they appear in `self`.
1401
+ fn bitand(self, other: &IndexSet<T, S2>) -> Self::Output {
1402
+ self.intersection(other).cloned().collect()
1403
+ }
1404
+ }
1405
+
1406
+ impl<T, S1, S2> BitOr<&IndexSet<T, S2>> for &IndexSet<T, S1>
1407
+ where
1408
+ T: Eq + Hash + Clone,
1409
+ S1: BuildHasher + Default,
1410
+ S2: BuildHasher,
1411
+ {
1412
+ type Output = IndexSet<T, S1>;
1413
+
1414
+ /// Returns the set union, cloned into a new set.
1415
+ ///
1416
+ /// Values from `self` are collected in their original order, followed by
1417
+ /// values that are unique to `other` in their original order.
1418
+ fn bitor(self, other: &IndexSet<T, S2>) -> Self::Output {
1419
+ self.union(other).cloned().collect()
1420
+ }
1421
+ }
1422
+
1423
+ impl<T, S1, S2> BitXor<&IndexSet<T, S2>> for &IndexSet<T, S1>
1424
+ where
1425
+ T: Eq + Hash + Clone,
1426
+ S1: BuildHasher + Default,
1427
+ S2: BuildHasher,
1428
+ {
1429
+ type Output = IndexSet<T, S1>;
1430
+
1431
+ /// Returns the set symmetric-difference, cloned into a new set.
1432
+ ///
1433
+ /// Values from `self` are collected in their original order, followed by
1434
+ /// values from `other` in their original order.
1435
+ fn bitxor(self, other: &IndexSet<T, S2>) -> Self::Output {
1436
+ self.symmetric_difference(other).cloned().collect()
1437
+ }
1438
+ }
1439
+
1440
+ impl<T, S1, S2> Sub<&IndexSet<T, S2>> for &IndexSet<T, S1>
1441
+ where
1442
+ T: Eq + Hash + Clone,
1443
+ S1: BuildHasher + Default,
1444
+ S2: BuildHasher,
1445
+ {
1446
+ type Output = IndexSet<T, S1>;
1447
+
1448
+ /// Returns the set difference, cloned into a new set.
1449
+ ///
1450
+ /// Values are collected in the same order that they appear in `self`.
1451
+ fn sub(self, other: &IndexSet<T, S2>) -> Self::Output {
1452
+ self.difference(other).cloned().collect()
1453
+ }
1454
+ }