discorb 0.19.0 → 0.20.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/build_version.yml +2 -2
  3. data/.rubocop.yml +12 -75
  4. data/Changelog.md +10 -0
  5. data/Rakefile +482 -454
  6. data/lib/discorb/allowed_mentions.rb +68 -72
  7. data/lib/discorb/app_command/command.rb +466 -398
  8. data/lib/discorb/app_command/common.rb +65 -25
  9. data/lib/discorb/app_command/handler.rb +304 -266
  10. data/lib/discorb/app_command.rb +5 -5
  11. data/lib/discorb/application.rb +198 -197
  12. data/lib/discorb/asset.rb +101 -101
  13. data/lib/discorb/attachment.rb +134 -119
  14. data/lib/discorb/audit_logs.rb +412 -385
  15. data/lib/discorb/automod.rb +279 -269
  16. data/lib/discorb/channel/base.rb +107 -108
  17. data/lib/discorb/channel/category.rb +32 -32
  18. data/lib/discorb/channel/container.rb +44 -44
  19. data/lib/discorb/channel/dm.rb +26 -28
  20. data/lib/discorb/channel/guild.rb +311 -246
  21. data/lib/discorb/channel/stage.rb +156 -140
  22. data/lib/discorb/channel/text.rb +430 -336
  23. data/lib/discorb/channel/thread.rb +374 -325
  24. data/lib/discorb/channel/voice.rb +85 -79
  25. data/lib/discorb/channel.rb +5 -5
  26. data/lib/discorb/client.rb +635 -621
  27. data/lib/discorb/color.rb +178 -182
  28. data/lib/discorb/common.rb +168 -164
  29. data/lib/discorb/components/button.rb +107 -106
  30. data/lib/discorb/components/select_menu.rb +157 -145
  31. data/lib/discorb/components/text_input.rb +103 -106
  32. data/lib/discorb/components.rb +68 -66
  33. data/lib/discorb/dictionary.rb +135 -135
  34. data/lib/discorb/embed.rb +404 -398
  35. data/lib/discorb/emoji.rb +309 -302
  36. data/lib/discorb/emoji_table.rb +16099 -8857
  37. data/lib/discorb/error.rb +131 -131
  38. data/lib/discorb/event.rb +360 -314
  39. data/lib/discorb/event_handler.rb +39 -39
  40. data/lib/discorb/exe/about.rb +17 -17
  41. data/lib/discorb/exe/irb.rb +72 -67
  42. data/lib/discorb/exe/new.rb +323 -315
  43. data/lib/discorb/exe/run.rb +69 -68
  44. data/lib/discorb/exe/setup.rb +57 -55
  45. data/lib/discorb/exe/show.rb +12 -12
  46. data/lib/discorb/extend.rb +25 -45
  47. data/lib/discorb/extension.rb +89 -83
  48. data/lib/discorb/flag.rb +126 -128
  49. data/lib/discorb/gateway.rb +984 -804
  50. data/lib/discorb/gateway_events.rb +670 -638
  51. data/lib/discorb/gateway_requests.rb +45 -48
  52. data/lib/discorb/guild.rb +2115 -1626
  53. data/lib/discorb/guild_template.rb +280 -241
  54. data/lib/discorb/http.rb +247 -232
  55. data/lib/discorb/image.rb +42 -42
  56. data/lib/discorb/integration.rb +169 -161
  57. data/lib/discorb/intents.rb +161 -163
  58. data/lib/discorb/interaction/autocomplete.rb +76 -62
  59. data/lib/discorb/interaction/command.rb +279 -224
  60. data/lib/discorb/interaction/components.rb +114 -104
  61. data/lib/discorb/interaction/modal.rb +36 -32
  62. data/lib/discorb/interaction/response.rb +379 -336
  63. data/lib/discorb/interaction/root.rb +271 -257
  64. data/lib/discorb/interaction.rb +5 -5
  65. data/lib/discorb/invite.rb +154 -153
  66. data/lib/discorb/member.rb +344 -311
  67. data/lib/discorb/message.rb +615 -544
  68. data/lib/discorb/message_meta.rb +197 -186
  69. data/lib/discorb/modules.rb +371 -290
  70. data/lib/discorb/permission.rb +305 -291
  71. data/lib/discorb/presence.rb +352 -346
  72. data/lib/discorb/rate_limit.rb +81 -76
  73. data/lib/discorb/reaction.rb +55 -54
  74. data/lib/discorb/role.rb +272 -240
  75. data/lib/discorb/shard.rb +76 -74
  76. data/lib/discorb/sticker.rb +193 -171
  77. data/lib/discorb/user.rb +205 -188
  78. data/lib/discorb/utils/colored_puts.rb +16 -16
  79. data/lib/discorb/utils.rb +12 -16
  80. data/lib/discorb/voice_state.rb +305 -281
  81. data/lib/discorb/webhook.rb +537 -507
  82. data/lib/discorb.rb +62 -56
  83. data/sig/discorb/application.rbs +2 -0
  84. data/sig/discorb/automod.rbs +10 -1
  85. data/sig/discorb/guild.rbs +2 -0
  86. data/sig/discorb/message.rbs +2 -0
  87. data/sig/discorb/user.rbs +22 -20
  88. metadata +2 -2
@@ -1,135 +1,135 @@
1
- # frozen_string_literal: true
2
-
3
- module Discorb
4
- #
5
- # Extended hash class. This is used for storing pair of ID and object.
6
- #
7
- class Dictionary
8
- # @return [Integer] The maximum number of items in the dictionary.
9
- attr_accessor :limit
10
-
11
- #
12
- # Initialize a new Dictionary.
13
- #
14
- # @param [Hash] hash A hash of items to add to the dictionary.
15
- # @param [Integer] limit The maximum number of items in the dictionary.
16
- # @param [false, Proc] sort Whether to sort the items in the dictionary.
17
- #
18
- def initialize(hash = {}, limit: nil, sort: false)
19
- @cache = hash.transform_keys(&:to_s)
20
- @limit = limit
21
- @sort = sort
22
- @cache = @cache.sort_by(&@sort).to_h if @sort
23
- end
24
-
25
- #
26
- # Registers a new item in the dictionary.
27
- #
28
- # @param [#to_s] id The ID of the item.
29
- # @param [Object] body The item to register.
30
- #
31
- # @return [self] The dictionary.
32
- #
33
- def register(id, body)
34
- @cache[id.to_s] = body
35
- @cache = @cache.sort_by(&@sort).to_h if @sort
36
- @cache.delete(@cache.keys[0]) if !@limit.nil? && @cache.size > @limit
37
- self
38
- end
39
-
40
- #
41
- # Merges another dictionary into this one.
42
- #
43
- # @param [Discorb::Dictionary] other The dictionary to merge.
44
- #
45
- def merge(other)
46
- @cache.merge!(other.to_h)
47
- end
48
-
49
- #
50
- # Removes an item from the dictionary.
51
- #
52
- # @param [#to_s] id The ID of the item to remove.
53
- #
54
- def remove(id)
55
- @cache.delete(id.to_s)
56
- end
57
-
58
- alias delete remove
59
-
60
- #
61
- # Get an item from the dictionary.
62
- #
63
- # @param [#to_s] id The ID of the item.
64
- # @return [Object] The item.
65
- # @return [nil] if the item was not found.
66
- #
67
- # @overload get(index)
68
- # @param [Integer] index The index of the item.
69
- #
70
- # @return [Object] The item.
71
- # @return [nil] if the item is not found.
72
- #
73
- def get(id)
74
- res = @cache[id.to_s]
75
- if res.nil? && id.is_a?(Integer) && id < @cache.length
76
- @cache.values[id]
77
- else
78
- res
79
- end
80
- end
81
-
82
- #
83
- # Convert the dictionary to a hash.
84
- #
85
- def to_h
86
- @cache
87
- end
88
-
89
- #
90
- # Returns the values of the dictionary.
91
- #
92
- # @return [Array] The values of the dictionary.
93
- #
94
- def values
95
- @cache.values
96
- end
97
-
98
- #
99
- # Checks if the dictionary has an ID.
100
- #
101
- # @param [#to_s] id The ID to check.
102
- #
103
- # @return [Boolean] `true` if the dictionary has the ID, `false` otherwise.
104
- #
105
- def has?(id)
106
- !self[id].nil?
107
- end
108
-
109
- #
110
- # Send a message to the array of values.
111
- #
112
- def method_missing(name, ...)
113
- if values.respond_to?(name)
114
- values.send(name, ...)
115
- else
116
- super
117
- end
118
- end
119
-
120
- def respond_to_missing?(name, ...)
121
- if values.respond_to?(name)
122
- true
123
- else
124
- super
125
- end
126
- end
127
-
128
- alias [] get
129
- alias []= register
130
-
131
- def inspect
132
- "#<#{self.class} #{values.length} items>"
133
- end
134
- end
135
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Discorb
4
+ #
5
+ # Extended hash class. This is used for storing pair of ID and object.
6
+ #
7
+ class Dictionary
8
+ # @return [Integer] The maximum number of items in the dictionary.
9
+ attr_accessor :limit
10
+
11
+ #
12
+ # Initialize a new Dictionary.
13
+ #
14
+ # @param [Hash] hash A hash of items to add to the dictionary.
15
+ # @param [Integer] limit The maximum number of items in the dictionary.
16
+ # @param [false, Proc] sort Whether to sort the items in the dictionary.
17
+ #
18
+ def initialize(hash = {}, limit: nil, sort: false)
19
+ @cache = hash.transform_keys(&:to_s)
20
+ @limit = limit
21
+ @sort = sort
22
+ @cache = @cache.sort_by(&@sort).to_h if @sort
23
+ end
24
+
25
+ #
26
+ # Registers a new item in the dictionary.
27
+ #
28
+ # @param [#to_s] id The ID of the item.
29
+ # @param [Object] body The item to register.
30
+ #
31
+ # @return [self] The dictionary.
32
+ #
33
+ def register(id, body)
34
+ @cache[id.to_s] = body
35
+ @cache = @cache.sort_by(&@sort).to_h if @sort
36
+ @cache.delete(@cache.keys[0]) if !@limit.nil? && @cache.size > @limit
37
+ self
38
+ end
39
+
40
+ #
41
+ # Merges another dictionary into this one.
42
+ #
43
+ # @param [Discorb::Dictionary] other The dictionary to merge.
44
+ #
45
+ def merge(other)
46
+ @cache.merge!(other.to_h)
47
+ end
48
+
49
+ #
50
+ # Removes an item from the dictionary.
51
+ #
52
+ # @param [#to_s] id The ID of the item to remove.
53
+ #
54
+ def remove(id)
55
+ @cache.delete(id.to_s)
56
+ end
57
+
58
+ alias delete remove
59
+
60
+ #
61
+ # Get an item from the dictionary.
62
+ #
63
+ # @param [#to_s] id The ID of the item.
64
+ # @return [Object] The item.
65
+ # @return [nil] if the item was not found.
66
+ #
67
+ # @overload get(index)
68
+ # @param [Integer] index The index of the item.
69
+ #
70
+ # @return [Object] The item.
71
+ # @return [nil] if the item is not found.
72
+ #
73
+ def get(id)
74
+ res = @cache[id.to_s]
75
+ if res.nil? && id.is_a?(Integer) && id < @cache.length
76
+ @cache.values[id]
77
+ else
78
+ res
79
+ end
80
+ end
81
+
82
+ #
83
+ # Convert the dictionary to a hash.
84
+ #
85
+ def to_h
86
+ @cache
87
+ end
88
+
89
+ #
90
+ # Returns the values of the dictionary.
91
+ #
92
+ # @return [Array] The values of the dictionary.
93
+ #
94
+ def values
95
+ @cache.values
96
+ end
97
+
98
+ #
99
+ # Checks if the dictionary has an ID.
100
+ #
101
+ # @param [#to_s] id The ID to check.
102
+ #
103
+ # @return [Boolean] `true` if the dictionary has the ID, `false` otherwise.
104
+ #
105
+ def has?(id)
106
+ !self[id].nil?
107
+ end
108
+
109
+ #
110
+ # Send a message to the array of values.
111
+ #
112
+ def method_missing(name, ...)
113
+ if values.respond_to?(name)
114
+ values.send(name, ...)
115
+ else
116
+ super
117
+ end
118
+ end
119
+
120
+ def respond_to_missing?(name, ...)
121
+ if values.respond_to?(name)
122
+ true
123
+ else
124
+ super
125
+ end
126
+ end
127
+
128
+ alias [] get
129
+ alias []= register
130
+
131
+ def inspect
132
+ "#<#{self.class} #{values.length} items>"
133
+ end
134
+ end
135
+ end