botemon 0.6 → 0.7

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: d4b33f9b3680eba8a49a93540c02b5069d4e947f
4
- data.tar.gz: 514881bafa725f4be10fb02fd1885bde69bbfa58
3
+ metadata.gz: 3df70fe78c7cdd0135358fd8c09c20b436ed76ff
4
+ data.tar.gz: 3524bccd5236fc147fcfef51a708be301b486e88
5
5
  SHA512:
6
- metadata.gz: 593b18b57aece77d20fe50216eeacd4af3d686b4b9c603e8a3f78694af3efc51f6c8e66001f8f412fbfb3631325032cc796cb3d8fd7908de31991f40cac1f8e1
7
- data.tar.gz: ef8279e8f0bede5678db236b1ca4781f77b701a7298a34b0affb3b365b5d323696d6de10ac10e1d2ca2f04b161abefbc3899038136de6fd8e28a0d7050645c5f
6
+ metadata.gz: 64120d70649dc92f119c50fdc22244e8f54076ec5af6ff4bfbc9ccc80dcddb68217e0c9fb5874b9ad03d0cdcbc63ca657d798b8defc10a596af4030f87b63679
7
+ data.tar.gz: 78c531ef41dabda70f93b6caaec73bfa83e008172880eff7301e58b9acbf38fdfee97f83e1e544c7c1a0e2eb46e34c9c68b7c895bd14f5303f8258534401663e
@@ -32,10 +32,10 @@ Cinch::Bot.new {
32
32
  c.password = ARGV[1]
33
33
  c.server = ARGV[2]
34
34
  c.channels = ARGV.drop(3).map { |c| "\##{c}" }
35
-
35
+
36
36
  c.plugins.plugins = [Cinch::Plugins::Login]
37
37
  c.plugins.options[Cinch::Plugins::Login] = { :password => ARGV[1] }
38
-
38
+
39
39
  @storage = Storage.new './cache.db'
40
40
  @pokemon_trivia = nil
41
41
  @players = []
@@ -45,22 +45,22 @@ Cinch::Bot.new {
45
45
 
46
46
  on :message, /^pkmn (.+)/ do |m, name|
47
47
  @storage = Storage.new('./cache.db') unless @storage
48
-
48
+
49
49
  name = Smogon::Pokemon.id2name(name) if name.numeric?
50
50
 
51
- pokemon = Pokedex.get name.delete(?'), @storage
51
+ pokemon = Pokedex.get name, @storage
52
52
  m.reply pokemon ? "#{pokemon.to_s}\n#{pokemon.url}".split("\n").map(&:colorize).join("\n") : 'Pokémon not found.'.colorize
53
53
  end
54
54
 
55
- on :message, /^ability (.+)/ do |m, name|
55
+ on :message, /^ability (.+)/ do |m, name|
56
56
  ability = Abilitydex.get name
57
-
57
+
58
58
  m.reply ability ? "#{ability.to_s}\n#{ability.url}".split("\n").map(&:colorize).join("\n") : 'Ability not found.'.colorize
59
59
  end
60
60
 
61
- on :message, /^item (.+)/ do |m, name|
61
+ on :message, /^item (.+)/ do |m, name|
62
62
  item = Itemdex.get name
63
-
63
+
64
64
  m.reply item ? "#{item.to_s}\n#{item.url}".split("\n").map(&:colorize).join("\n") : 'Item not found.'.colorize
65
65
  end
66
66
 
@@ -73,10 +73,16 @@ Cinch::Bot.new {
73
73
  on :message, /^moveset (.+) (.+) (.+)/ do |m, name, tier, metagame|
74
74
  name = Smogon::Pokemon.id2name(name) if name.numeric?
75
75
 
76
- movesets = Movesetdex.get name.delete(?'), tier, (metagame.empty? ? 'bw' : metagame)
77
- if movesets != nil || movesets.any?
78
- m.reply "--- #{movesets.first.pokemon} (#{movesets.first.tier}) ---".colorize
79
- movesets.each { |moveset| m.reply " -- #{moveset.name} --\n#{moveset.to_s.split("\n").map(&:colorize).join("\n")}\n".colorize }
76
+ tier = nil if tier.empty?
77
+ metagame = nil if metagame.empty?
78
+
79
+ movesets = Movesetdex.get name, tier, metagame
80
+ if movesets && movesets.any?
81
+ m.reply "--- #{movesets.first.pokemon} ---".colorize
82
+
83
+ movesets.each do |moveset|
84
+ m.reply " -- #{moveset.name} (#{moveset.tier}) --\n#{moveset.to_s.split("\n").map(&:colorize).join("\n")}\n"
85
+ end
80
86
  else
81
87
  m.reply 'Moveset not found.'.colorize
82
88
  end
@@ -86,7 +92,7 @@ Cinch::Bot.new {
86
92
  @storage = Storage.new('./cache.db') unless @storage
87
93
 
88
94
  name = Smogon::Pokemon.id2name(name) if name.numeric?
89
- pokemon = Pokedex.get name.delete(?'), @storage
95
+ pokemon = Pokedex.get name, @storage
90
96
 
91
97
  hidden_values = evs.strip.split
92
98
  if hidden_values.length == 2
@@ -96,28 +102,28 @@ Cinch::Bot.new {
96
102
  evs = evs.split ?/
97
103
  ivs = '31/31/31/31/31/31'.split ?/
98
104
  end
99
-
105
+
100
106
  m.reply "#{pokemon.name}: (#{pokemon.types.join(?-)}) #{pokemon.stats(level.to_i, nature, evs, ivs).join(?/)}"
101
107
  end
102
108
 
103
109
  on :message, /^pkrandom$/ do |m|
104
110
  @storage = Storage.new('./cache.db') unless @storage
105
-
106
- pokemon = Pokedex.get Smogon::Pokemon.id2name(Random.new.rand(1..649)).delete(?'), @storage
111
+
112
+ pokemon = Pokedex.get Smogon::Pokemon.id2name(Random.new.rand(1..649)), @storage
107
113
  m.reply pokemon ? "#{pokemon.to_s}\n#{pokemon.url}".split("\n").map(&:colorize).join("\n") : 'Pokémon not found.'.colorize
108
114
  end
109
115
 
110
116
  on :message, /^pktrivia$/ do |m|
111
117
  @storage = Storage.new('./cache.db') unless @storage
112
-
118
+
113
119
  if @pokemon_trivia != nil
114
120
  m.reply 'Other players are playing, please wait until they finish.'.colorize
115
121
  m.reply @pokemon_trivia.clues.colorize
116
122
  else
117
- @pokemon_trivia = Pokedex.get Smogon::Pokemon.id2name(Random.new.rand(1..649)).delete(?'), @storage
123
+ @pokemon_trivia = Pokedex.get Smogon::Pokemon.id2name(Random.new.rand(1..649)), @storage
118
124
  @trivia_owner = m.user.nick
119
125
  @trivia_wrong = 0
120
-
126
+
121
127
  if @pokemon_trivia
122
128
  m.reply @pokemon_trivia.clues.split("\n").map(&:colorize).join("\n")
123
129
  m.reply 'You have 3 chances to try to say which Pokémon is this!'.colorize
@@ -168,17 +174,17 @@ Cinch::Bot.new {
168
174
  m.reply proverbs.colorize
169
175
  end
170
176
  end
171
-
177
+
172
178
  on :message, /^pkcache$/ do |m|
173
179
  if m.user.nick.to_s.oper? bot
174
180
  File.delete('./cache.db') if File.exists? './cache.db'
175
-
181
+
176
182
  @storage = Storage.new './cache.db'
177
183
  @pokemon_trivia = nil
178
184
  @players = []
179
185
  @trivia_owner = ''
180
186
  @trivia_wrong = 0
181
-
187
+
182
188
  m.reply 'Cache created.'.colorize
183
189
  else
184
190
  proverbs = open('http://pastebin.com/raw.php?i=qWF65TcP').read.each_line.to_a.sample.strip
@@ -187,8 +193,8 @@ Cinch::Bot.new {
187
193
  end
188
194
 
189
195
  on :message, /^pkversion$/ do |m|
190
- m.reply "Botémon: #{Botemon::version}".colorize
191
- m.reply "Smogon-API: #{Smogon::version}".colorize
196
+ m.reply "Botémon: #{Botemon::VERSION}".colorize
197
+ m.reply "Smogon-API: #{Smogon::VERSION}".colorize
192
198
  end
193
199
 
194
200
  on :message, /^pkhelp$/ do |m|
@@ -18,8 +18,6 @@
18
18
  #++
19
19
 
20
20
  require 'open-uri'
21
- require 'nokogiri'
22
- require 'sanitize'
23
21
  require 'json'
24
22
 
25
23
  require 'cinch'
@@ -1,5 +1,5 @@
1
1
  #--
2
- # Copyright(C) 2013 Giovanni Capuano <webmaster@giovannicapuano.net>
2
+ # Copyright(C) 2015 Giovanni Capuano <webmaster@giovannicapuano.net>
3
3
  #
4
4
  # This file is part of Botémon.
5
5
  #
@@ -17,8 +17,8 @@
17
17
  # along with Botémon. If not, see <http://www.gnu.org/licenses/>.
18
18
  #++
19
19
 
20
- class Movesetdex
20
+ class Movesetdex
21
21
  def self.get(name, tier, metagame)
22
- name && tier ? Smogon::Movesetdex.get(name, tier, metagame) : nil
22
+ name ? Smogon::Movesetdex.get(name, tier, metagame) : nil
23
23
  end
24
- end
24
+ end
@@ -1,12 +1,12 @@
1
1
  #--
2
- # Copyright(C) 2013 Giovanni Capuano <webmaster@giovannicapuano.net>
2
+ # Copyright(C) 2015 Giovanni Capuano <webmaster@giovannicapuano.net>
3
3
  #
4
4
  # This file is part of Botémon.
5
5
  #
6
6
  # Botémon is free software: you can redistribute it and/or modify
7
7
  # it under the terms of the GNU General Public License as published by
8
8
  # the Free Software Foundation, either version 3 of the License, or
9
- # (at your option) any later version.
9
+ # (at your option) any later version.d
10
10
  #
11
11
  # Botémon is distributed in the hope that it will be useful,
12
12
  # but WITHOUT ANY WARRANTY; without even the implied warranty of
@@ -27,10 +27,9 @@ module Smogon
27
27
  @nature = []
28
28
  @moves = []
29
29
  end
30
-
31
- def to_s
32
- "Item: #{item.join(' / ')}\nAbility: #{ability.join(' / ')}\nNature: #{nature.join(' / ')}\nMoves: #{''.tap { |s| moves.each { |move| s << move.join(' / ') + ', '}}[0..-3]}\nEVs: #{evs}"
33
- end
34
-
30
+
31
+ # def to_s
32
+ # "Set: #{@name}\nItem: #{@item.join(' / ')}\nAbility: #{@ability.join(' / ')}\nNature: #{@nature.join(' / ')}\nMoves: #{''.tap { |s| @moves.each { |move| s << move.join(' / ') + ', '}}[0..-3]}\nEVs: #{@evs}"
33
+ # end
35
34
  end
36
- end
35
+ end
@@ -1,5 +1,5 @@
1
1
  #--
2
- # Copyright(C) 2013 Giovanni Capuano <webmaster@giovannicapuano.net>
2
+ # Copyright(C) 2015 Giovanni Capuano <webmaster@giovannicapuano.net>
3
3
  #
4
4
  # This file is part of Botémon.
5
5
  #
@@ -20,11 +20,11 @@
20
20
  module Smogon
21
21
  class Pokemon
22
22
  attr_accessor :name, :_name, :types, :tier, :abilities, :base_stats, :moves
23
-
23
+
24
24
  def clues
25
25
  "Ability: #{@abilities.join(', ')}\nType: #{@types.join(?/)}\nTier: #{@tier}\nBase stats: #{@base_stats.join(?/)}"
26
26
  end
27
-
27
+
28
28
  def self.to_pokemon(ary)
29
29
  Pokemon.new.tap { |pokemon|
30
30
  pokemon.name = ary['name' ]
@@ -36,7 +36,7 @@ module Smogon
36
36
  pokemon.moves = ary['moves' ]
37
37
  }
38
38
  end
39
-
39
+
40
40
  def to_ary
41
41
  {
42
42
  'name' => @name,
@@ -104,4 +104,4 @@ module Smogon
104
104
  }
105
105
  end
106
106
  end
107
- end
107
+ end
@@ -1,5 +1,5 @@
1
1
  #--
2
- # Copyright(C) 2013 Giovanni Capuano <webmaster@giovannicapuano.net>
2
+ # Copyright(C) 2015 Giovanni Capuano <webmaster@giovannicapuano.net>
3
3
  #
4
4
  # This file is part of Botémon.
5
5
  #
@@ -18,7 +18,5 @@
18
18
  #++
19
19
 
20
20
  module Botemon
21
- def self.version
22
- '0.6'
23
- end
21
+ VERSION = '0.7'
24
22
  end
metadata CHANGED
@@ -1,43 +1,15 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: botemon
3
3
  version: !ruby/object:Gem::Version
4
- version: '0.6'
4
+ version: '0.7'
5
5
  platform: ruby
6
6
  authors:
7
7
  - Giovanni Capuano
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2014-01-21 00:00:00.000000000 Z
11
+ date: 2015-01-17 00:00:00.000000000 Z
12
12
  dependencies:
13
- - !ruby/object:Gem::Dependency
14
- name: nokogiri
15
- requirement: !ruby/object:Gem::Requirement
16
- requirements:
17
- - - ">="
18
- - !ruby/object:Gem::Version
19
- version: '0'
20
- type: :runtime
21
- prerelease: false
22
- version_requirements: !ruby/object:Gem::Requirement
23
- requirements:
24
- - - ">="
25
- - !ruby/object:Gem::Version
26
- version: '0'
27
- - !ruby/object:Gem::Dependency
28
- name: sanitize
29
- requirement: !ruby/object:Gem::Requirement
30
- requirements:
31
- - - ">="
32
- - !ruby/object:Gem::Version
33
- version: '0'
34
- type: :runtime
35
- prerelease: false
36
- version_requirements: !ruby/object:Gem::Requirement
37
- requirements:
38
- - - ">="
39
- - !ruby/object:Gem::Version
40
- version: '0'
41
13
  - !ruby/object:Gem::Dependency
42
14
  name: cinch
43
15
  requirement: !ruby/object:Gem::Requirement
@@ -102,6 +74,8 @@ executables:
102
74
  extensions: []
103
75
  extra_rdoc_files: []
104
76
  files:
77
+ - bin/botemon
78
+ - lib/botemon.rb
105
79
  - lib/botemon/abilitydex.rb
106
80
  - lib/botemon/itemdex.rb
107
81
  - lib/botemon/movedex.rb
@@ -112,8 +86,6 @@ files:
112
86
  - lib/botemon/storage.rb
113
87
  - lib/botemon/string.rb
114
88
  - lib/botemon/version.rb
115
- - lib/botemon.rb
116
- - bin/botemon
117
89
  homepage: http://www.giovannicapuano.net
118
90
  licenses:
119
91
  - GPL-3
@@ -134,7 +106,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
134
106
  version: '0'
135
107
  requirements: []
136
108
  rubyforge_project:
137
- rubygems_version: 2.0.3
109
+ rubygems_version: 2.2.2
138
110
  signing_key:
139
111
  specification_version: 4
140
112
  summary: IRC bot for Pokéfags.