beerdb 0.6.5 → 0.6.6

Sign up to get free protection for your applications and to get access to all the features.
@@ -16,21 +16,31 @@ class Beer < ActiveRecord::Base
16
16
 
17
17
  validates :key, :format => { :with => /^[a-z][a-z0-9]+$/, :message => 'expected two or more lowercase letters a-z or 0-9 digits' }
18
18
 
19
+
20
+ def self.rnd # find random beer - fix: use "generic" activerecord helper and include/extend class
21
+ rnd_offset = rand( Beer.count ) ## NB: call "global" std lib rand
22
+ Beer.offset( rnd_offset ).limit( 1 )
23
+ end
24
+
19
25
  ### support old names (read-only) for now (remove later)
20
26
 
21
27
  def color
28
+ puts "*** depreceated fn api - use srm"
22
29
  srm
23
30
  end
24
31
 
25
32
  def plato
33
+ puts "*** depreceated fn api - use og"
26
34
  og
27
35
  end
28
36
 
29
37
  def color=(value)
38
+ puts "*** depreceated fn api - use srm="
30
39
  self.srm = value
31
40
  end
32
41
 
33
42
  def plato=(value)
43
+ puts "*** depreceated fn api - use og="
34
44
  self.og = value
35
45
  end
36
46
 
@@ -18,6 +18,13 @@ class Brewery < ActiveRecord::Base
18
18
 
19
19
  validates :key, :format => { :with => /^[a-z][a-z0-9]+$/, :message => 'expected two or more lowercase letters a-z or 0-9 digits' }
20
20
 
21
+
22
+ def self.rnd # find random beer - fix: use "generic" activerecord helper and include/extend class
23
+ rnd_offset = rand( Brewery.count ) ## NB: call "global" std lib rand
24
+ Brewery.offset( rnd_offset ).limit( 1 )
25
+ end
26
+
27
+
21
28
  ### support old names (read-only) for now (remove later)
22
29
 
23
30
  def founded
@@ -201,9 +208,12 @@ class Brewery < ActiveRecord::Base
201
208
 
202
209
  end # method create_or_update_from_values
203
210
 
211
+
204
212
  ### todo/fix:
205
213
  # reuse method - put into helper in textutils or somewhere else ??
206
214
 
215
+ ### todo/fix - move to textutils !!!!! AddressHelper
216
+
207
217
  def self.normalize_address( old_address_line )
208
218
  # for now only checks german 5-digit zip code
209
219
  #
@@ -225,6 +235,18 @@ class Brewery < ActiveRecord::Base
225
235
  new_address_line
226
236
  end
227
237
 
238
+ ### todo/fix: move to textutils!!!
239
+ ## add options for
240
+ ## - remove translations e.g. []
241
+ ## - remove subtitles e.g. ()
242
+ ## - remove tags/extras e.g. {}
243
+
244
+ ##
245
+ ## fix: make strip_translations into fn
246
+ ## make strip_subtitles into fn # better name for () strip_
247
+ ## make strip_desc / tags (find better name strip_extras, strip_meta? strip_desc? strip_curly?)
248
+
249
+
228
250
  def self.title_to_key( title )
229
251
 
230
252
  ## NB: downcase does NOT work for accented chars (thus, include in alternatives)
data/lib/beerdb/reader.rb CHANGED
@@ -16,51 +16,17 @@ class Reader
16
16
  end
17
17
 
18
18
 
19
- def load_setup( setup )
20
- ary = load_fixture_setup( setup )
21
-
22
- ary.each do |name|
23
- load( name )
24
- end
25
- end # method load_setup
26
-
27
-
28
- ## fix/todo: rename ??
29
- def load_fixture_setup( name )
30
-
31
- ## todo/fix: cleanup quick and dirty code
32
-
19
+ def load_setup( name )
33
20
  path = "#{include_path}/#{name}.yml"
34
21
 
35
22
  logger.info "parsing data '#{name}' (#{path})..."
36
23
 
37
- text = File.read_utf8( path )
38
-
39
- hash = YAML.load( text )
40
-
41
- ### build up array for fixtures from hash
42
-
43
- ary = []
44
-
45
- hash.each do |key_wild, value_wild|
46
- key = key_wild.to_s.strip
47
-
48
- logger.debug "yaml key:#{key_wild.class.name} >>#{key}<<, value:#{value_wild.class.name} >>#{value_wild}<<"
49
-
50
- if value_wild.kind_of?( String ) # assume single fixture name
51
- ary << value_wild
52
- elsif value_wild.kind_of?( Array ) # assume array of fixture names as strings
53
- ary = ary + value_wild
54
- else
55
- logger.error "unknow fixture type in setup (yaml key:#{key_wild.class.name} >>#{key}<<, value:#{value_wild.class.name} >>#{value_wild}<<); skipping"
56
- end
24
+ reader = FixtureReader.new( path )
25
+
26
+ reader.each do |fixture_name|
27
+ load( fixture_name )
57
28
  end
58
-
59
- logger.debug "fixture setup:"
60
- logger.debug ary.to_json
61
-
62
- ary
63
- end # load_fixture_setup
29
+ end # method load_setup
64
30
 
65
31
 
66
32
  def load( name )
data/lib/beerdb/schema.rb CHANGED
@@ -29,6 +29,7 @@ create_table :beers do |t|
29
29
  t.decimal :abv # Alcohol by volume (abbreviated as ABV, abv, or alc/vol) e.g. 4.9 %
30
30
  t.decimal :og # malt extract (original gravity) in plato
31
31
  t.integer :srm # color in srm
32
+ t.integer :ibu # bitterness in ibu
32
33
 
33
34
  ### fix/todo: add bitterness field
34
35
 
data/lib/beerdb/server.rb CHANGED
@@ -72,8 +72,7 @@ class Server < Sinatra::Base
72
72
 
73
73
  if ['r', 'rnd', 'rand', 'random'].include?( key )
74
74
  # special key for random beer
75
- beer_id = rand( Beer.count )+1 # nb: assumes record ids sequence from 1-n
76
- beer = Beer.find( beer_id )
75
+ beer = Beer.rnd
77
76
  else
78
77
  beer = Beer.find_by_key!( key )
79
78
  end
@@ -108,8 +107,7 @@ class Server < Sinatra::Base
108
107
 
109
108
  if ['r', 'rnd', 'rand', 'random'].include?( key )
110
109
  # special key for random brewery
111
- brewery_id = rand( Brewery.count )+1 # nb: assumes record ids sequence from 1-n
112
- brewery = Brewery.find( brewery_id )
110
+ brewery = Brewery.rnd
113
111
  else
114
112
  brewery = Brewery.find_by_key!( key )
115
113
  end
@@ -1,4 +1,4 @@
1
1
 
2
2
  module BeerDb
3
- VERSION = '0.6.5'
3
+ VERSION = '0.6.6'
4
4
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: beerdb
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.6.5
4
+ version: 0.6.6
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2013-05-07 00:00:00.000000000 Z
12
+ date: 2013-05-08 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: activerecord
16
- requirement: &75736340 !ruby/object:Gem::Requirement
16
+ requirement: &71991960 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ~>
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '3.2'
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *75736340
24
+ version_requirements: *71991960
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: worlddb
27
- requirement: &75736120 !ruby/object:Gem::Requirement
27
+ requirement: &71991740 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ~>
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '1.6'
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *75736120
35
+ version_requirements: *71991740
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: commander
38
- requirement: &75735900 !ruby/object:Gem::Requirement
38
+ requirement: &71991520 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ~>
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: 4.1.3
44
44
  type: :runtime
45
45
  prerelease: false
46
- version_requirements: *75735900
46
+ version_requirements: *71991520
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: rdoc
49
- requirement: &75735680 !ruby/object:Gem::Requirement
49
+ requirement: &71991300 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ~>
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: '3.10'
55
55
  type: :development
56
56
  prerelease: false
57
- version_requirements: *75735680
57
+ version_requirements: *71991300
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: hoe
60
- requirement: &75735460 !ruby/object:Gem::Requirement
60
+ requirement: &71991080 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ~>
@@ -65,7 +65,7 @@ dependencies:
65
65
  version: '3.3'
66
66
  type: :development
67
67
  prerelease: false
68
- version_requirements: *75735460
68
+ version_requirements: *71991080
69
69
  description: beerdb - beer.db command line tool
70
70
  email: beerdb@googlegroups.com
71
71
  executables: