gdshowsdb 0.9.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (90) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +6 -0
  3. data/.rvmrc +4 -0
  4. data/.travis.yml +4 -0
  5. data/Gemfile +12 -0
  6. data/Gemfile.lock +106 -0
  7. data/LICENSE.txt +22 -0
  8. data/README.md +49 -0
  9. data/Rakefile +4 -0
  10. data/data/gdshowsdb/1965.yaml +78 -0
  11. data/data/gdshowsdb/1966.yaml +780 -0
  12. data/data/gdshowsdb/1967.yaml +857 -0
  13. data/data/gdshowsdb/1968.yaml +1252 -0
  14. data/data/gdshowsdb/1969.yaml +1799 -0
  15. data/data/gdshowsdb/1970.yaml +3547 -0
  16. data/data/gdshowsdb/1971.yaml +1396 -0
  17. data/data/gdshowsdb/1972.yaml +6849 -0
  18. data/data/gdshowsdb/1973.yaml +6229 -0
  19. data/data/gdshowsdb/1974.yaml +3516 -0
  20. data/data/gdshowsdb/1975.yaml +207 -0
  21. data/data/gdshowsdb/1976.yaml +3226 -0
  22. data/data/gdshowsdb/1977.yaml +4469 -0
  23. data/data/gdshowsdb/1978.yaml +5681 -0
  24. data/data/gdshowsdb/1979.yaml +5487 -0
  25. data/data/gdshowsdb/1980.yaml +7133 -0
  26. data/data/gdshowsdb/1981.yaml +6347 -0
  27. data/data/gdshowsdb/1982.yaml +4475 -0
  28. data/data/gdshowsdb/1983.yaml +4561 -0
  29. data/data/gdshowsdb/1984.yaml +4431 -0
  30. data/data/gdshowsdb/1985.yaml +4810 -0
  31. data/data/gdshowsdb/1986.yaml +3029 -0
  32. data/data/gdshowsdb/1987.yaml +5958 -0
  33. data/data/gdshowsdb/1988.yaml +5398 -0
  34. data/data/gdshowsdb/1989.yaml +4979 -0
  35. data/data/gdshowsdb/1990.yaml +4941 -0
  36. data/data/gdshowsdb/1991.yaml +5269 -0
  37. data/data/gdshowsdb/1992.yaml +3576 -0
  38. data/data/gdshowsdb/1993.yaml +5178 -0
  39. data/data/gdshowsdb/1994.yaml +5206 -0
  40. data/data/gdshowsdb/1995.yaml +2931 -0
  41. data/data/gdshowsdb/shows-debug.yaml +138 -0
  42. data/data/gdshowsdb/song_refs.yaml +411 -0
  43. data/gdshowsdb.gemspec +23 -0
  44. data/lib/gdshowsdb/db/migrations/001_create_song_ref_table.rb +15 -0
  45. data/lib/gdshowsdb/db/migrations/002_import_song_refs.rb +14 -0
  46. data/lib/gdshowsdb/db/migrations/003_create_show_table.rb +22 -0
  47. data/lib/gdshowsdb/db/migrations/004_create_show_set_table.rb +15 -0
  48. data/lib/gdshowsdb/db/migrations/005_create_song_table.rb +18 -0
  49. data/lib/gdshowsdb/db/migrations/006_create_song_occurences_table.rb +17 -0
  50. data/lib/gdshowsdb/db/migrations/008_add_count_to_song_ref_table.rb +11 -0
  51. data/lib/gdshowsdb/db/migrations/009_import_shows.rb +45 -0
  52. data/lib/gdshowsdb/diff.rb +36 -0
  53. data/lib/gdshowsdb/generators/gdshowsdatabase_generator.rb +17 -0
  54. data/lib/gdshowsdb/generators/gdshowsdatabase_upgrade_generator.rb +49 -0
  55. data/lib/gdshowsdb/models/extensions/uuid.rb +9 -0
  56. data/lib/gdshowsdb/models/show.rb +58 -0
  57. data/lib/gdshowsdb/models/show_set.rb +40 -0
  58. data/lib/gdshowsdb/models/song.rb +72 -0
  59. data/lib/gdshowsdb/models/song_occurence.rb +9 -0
  60. data/lib/gdshowsdb/models/song_ref.rb +32 -0
  61. data/lib/gdshowsdb/set_db_extractor.rb +19 -0
  62. data/lib/gdshowsdb/set_diff.rb +10 -0
  63. data/lib/gdshowsdb/set_yaml_parser.rb +29 -0
  64. data/lib/gdshowsdb/show_db_extractor.rb +19 -0
  65. data/lib/gdshowsdb/show_diff.rb +12 -0
  66. data/lib/gdshowsdb/show_yaml_parser.rb +20 -0
  67. data/lib/gdshowsdb/song_db_extractor.rb +21 -0
  68. data/lib/gdshowsdb/song_diff.rb +10 -0
  69. data/lib/gdshowsdb/song_ref_db_extractror.rb +18 -0
  70. data/lib/gdshowsdb/song_ref_diff.rb +12 -0
  71. data/lib/gdshowsdb/song_ref_yaml_parser.rb +19 -0
  72. data/lib/gdshowsdb/song_yaml_parser.rb +25 -0
  73. data/lib/gdshowsdb/templates/update_migration.rb.erb +53 -0
  74. data/lib/gdshowsdb/version.rb +3 -0
  75. data/lib/gdshowsdb.rb +45 -0
  76. data/sample.rb +29 -0
  77. data/spec/gdshowsdb/diff_spec.rb +69 -0
  78. data/spec/gdshowsdb/models/show_set_spec.rb +29 -0
  79. data/spec/gdshowsdb/models/show_spec.rb +13 -0
  80. data/spec/gdshowsdb/models/song_spec.rb +72 -0
  81. data/spec/gdshowsdb/set_db_extractor_spec.rb +37 -0
  82. data/spec/gdshowsdb/set_yaml_parser_spec.rb +74 -0
  83. data/spec/gdshowsdb/show_db_extractor_spec.rb +25 -0
  84. data/spec/gdshowsdb/show_yaml_parser_spec.rb +42 -0
  85. data/spec/gdshowsdb/song_db_extractor_spec.rb +47 -0
  86. data/spec/gdshowsdb/song_ref_db_extractor_spec.rb +20 -0
  87. data/spec/gdshowsdb/song_ref_yaml_parser_spec.rb +19 -0
  88. data/spec/gdshowsdb/song_yaml_parser_spec.rb +93 -0
  89. data/spec/spec_helper.rb +15 -0
  90. metadata +186 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: d12787330771b3ab9b4b1d109624efce13737b2c
4
+ data.tar.gz: ac014f427f685fd0989baab38d4ba49aa90dd809
5
+ SHA512:
6
+ metadata.gz: d8519d0aabc6b896192759151bf807d748a997bf1fe24944f8fa18e9e7d84e8370f5bff973e19f0773be9f9908b64c923db6e87640ed7980c9ade2ed394433d3
7
+ data.tar.gz: a8d1587ef7f4b13d4acabe4e673e050af7266d57c8966f8e98998d34efeaa9a30041255b4078337f74a00cde3ca12495f3e56d1f5d0fe608821c5c8ae3d0ce69
data/.gitignore ADDED
@@ -0,0 +1,6 @@
1
+ *.gem
2
+ .bundle
3
+ pkg/*
4
+ .rakeTasks
5
+ rake
6
+ gdshowsdb.db
data/.rvmrc ADDED
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env bash
2
+
3
+ rvm use --create --install ruby-1.9.3@gdshowsdb
4
+ bundle install
data/.travis.yml ADDED
@@ -0,0 +1,4 @@
1
+ language: ruby
2
+ rvm:
3
+ - "1.9.3"
4
+ script: bundle exec rake spec
data/Gemfile ADDED
@@ -0,0 +1,12 @@
1
+ source 'https://rubygems.org'
2
+
3
+ gem 'protected_attributes'
4
+
5
+ # Specify your gem's dependencies in gdshowsdb.gemspec
6
+ gemspec
7
+
8
+ group :development do
9
+ gem "rake", "~> 0.9.2.2"
10
+ gem "rspec"
11
+ gem "sqlite3"
12
+ end
data/Gemfile.lock ADDED
@@ -0,0 +1,106 @@
1
+ PATH
2
+ remote: .
3
+ specs:
4
+ gdshowsdb (0.9.0)
5
+ friendly_id (= 5.0.0.beta4)
6
+ protected_attributes
7
+ rails (~> 4.0.0)
8
+
9
+ GEM
10
+ remote: https://rubygems.org/
11
+ specs:
12
+ actionmailer (4.0.0)
13
+ actionpack (= 4.0.0)
14
+ mail (~> 2.5.3)
15
+ actionpack (4.0.0)
16
+ activesupport (= 4.0.0)
17
+ builder (~> 3.1.0)
18
+ erubis (~> 2.7.0)
19
+ rack (~> 1.5.2)
20
+ rack-test (~> 0.6.2)
21
+ activemodel (4.0.0)
22
+ activesupport (= 4.0.0)
23
+ builder (~> 3.1.0)
24
+ activerecord (4.0.0)
25
+ activemodel (= 4.0.0)
26
+ activerecord-deprecated_finders (~> 1.0.2)
27
+ activesupport (= 4.0.0)
28
+ arel (~> 4.0.0)
29
+ activerecord-deprecated_finders (1.0.3)
30
+ activesupport (4.0.0)
31
+ i18n (~> 0.6, >= 0.6.4)
32
+ minitest (~> 4.2)
33
+ multi_json (~> 1.3)
34
+ thread_safe (~> 0.1)
35
+ tzinfo (~> 0.3.37)
36
+ arel (4.0.0)
37
+ atomic (1.1.13)
38
+ builder (3.1.4)
39
+ diff-lcs (1.2.4)
40
+ erubis (2.7.0)
41
+ friendly_id (5.0.0.beta4)
42
+ activerecord (~> 4.0.0)
43
+ hike (1.2.3)
44
+ i18n (0.6.5)
45
+ mail (2.5.4)
46
+ mime-types (~> 1.16)
47
+ treetop (~> 1.4.8)
48
+ mime-types (1.24)
49
+ minitest (4.7.5)
50
+ multi_json (1.7.9)
51
+ polyglot (0.3.3)
52
+ protected_attributes (1.0.3)
53
+ activemodel (>= 4.0.0, < 5.0)
54
+ rack (1.5.2)
55
+ rack-test (0.6.2)
56
+ rack (>= 1.0)
57
+ rails (4.0.0)
58
+ actionmailer (= 4.0.0)
59
+ actionpack (= 4.0.0)
60
+ activerecord (= 4.0.0)
61
+ activesupport (= 4.0.0)
62
+ bundler (>= 1.3.0, < 2.0)
63
+ railties (= 4.0.0)
64
+ sprockets-rails (~> 2.0.0)
65
+ railties (4.0.0)
66
+ actionpack (= 4.0.0)
67
+ activesupport (= 4.0.0)
68
+ rake (>= 0.8.7)
69
+ thor (>= 0.18.1, < 2.0)
70
+ rake (0.9.2.2)
71
+ rspec (2.14.1)
72
+ rspec-core (~> 2.14.0)
73
+ rspec-expectations (~> 2.14.0)
74
+ rspec-mocks (~> 2.14.0)
75
+ rspec-core (2.14.5)
76
+ rspec-expectations (2.14.2)
77
+ diff-lcs (>= 1.1.3, < 2.0)
78
+ rspec-mocks (2.14.3)
79
+ sprockets (2.10.0)
80
+ hike (~> 1.2)
81
+ multi_json (~> 1.0)
82
+ rack (~> 1.0)
83
+ tilt (~> 1.1, != 1.3.0)
84
+ sprockets-rails (2.0.0)
85
+ actionpack (>= 3.0)
86
+ activesupport (>= 3.0)
87
+ sprockets (~> 2.8)
88
+ sqlite3 (1.3.8)
89
+ thor (0.18.1)
90
+ thread_safe (0.1.2)
91
+ atomic
92
+ tilt (1.4.1)
93
+ treetop (1.4.15)
94
+ polyglot
95
+ polyglot (>= 0.3.1)
96
+ tzinfo (0.3.37)
97
+
98
+ PLATFORMS
99
+ ruby
100
+
101
+ DEPENDENCIES
102
+ gdshowsdb!
103
+ protected_attributes
104
+ rake (~> 0.9.2.2)
105
+ rspec
106
+ sqlite3
data/LICENSE.txt ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2013 Jeff Smith
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,49 @@
1
+ # Gdshowsdb
2
+
3
+ [ ![Codeship Status for jefmsmit/gdshowsdb](https://www.codeship.io/projects/b1f0f820-f314-0131-9281-66e36f054ecd/status)](https://www.codeship.io/projects/27798)
4
+
5
+ All Grateful Dead show information in a relational database.
6
+
7
+ Hoping to make this freely available database the cannonical resource for all Grateful Dead concert information.
8
+
9
+ Additionally, This Gem can be used as an API to the data.
10
+
11
+ ## Using with Ruby
12
+
13
+ ```ruby
14
+ require 'gdshowsdb'
15
+
16
+ Gdshowsdb.init()
17
+ Gdshowsdb.load()
18
+
19
+ jack_straw_shows = SongRef.find_by_name('Jack Straw').shows
20
+
21
+ jack_straw_shows.each do |show|
22
+ puts show.title
23
+ end
24
+ ```
25
+
26
+ ## Using with Rails
27
+
28
+ Add this to your Gemfile
29
+ ```
30
+ gem 'gdshowsdb', :git => 'git://github.com/jefmsmit/gdshowsdb.git'
31
+ ```
32
+
33
+ Generate the database migrations
34
+ ```
35
+ rails generate gdshowsdatabase
36
+ ```
37
+
38
+ ## Understanding the Model
39
+
40
+ The `SongRef` class represents the reference data about a song. For example there is only one `SongRef` instance (or database row if you prefer) for "Wharf Rat". This allows us to normalize song names so its always "Goin' Down The Road Feeling Bad" and not sometimes "GDTRFB". A `SongRef` knows the `Shows` where it was performed.
41
+
42
+ The `Show` class is for reprsenting all the particulars about a performance. City, State, Venue, etc.
43
+
44
+ The `ShowSet` class is for representing a segment of a show. That way we can know what was played in the first set version the second versus the encore. I did not call it `Set` in order to avoid confusing with the Ruby class of the same name.
45
+
46
+ The `Song` class is for representing the occurence of a `SongRef`. `Song`s know which set the occurence of a `SongRef` happened in, its position in the `ShowSet` as well as wether it was segued out of.
47
+
48
+ The `SongOccurence` class is named association (think join table in sql) that allows a `Show` to know which `SongRef`s were performed without having to traverse throug the `ShowSet`s. I'm not convinced of this classes value and might remove it.
49
+
data/Rakefile ADDED
@@ -0,0 +1,4 @@
1
+ require "bundler/gem_tasks"
2
+
3
+ require 'rspec/core/rake_task'
4
+ RSpec::Core::RakeTask.new('spec')
@@ -0,0 +1,78 @@
1
+ ---
2
+ 1965/05/05:
3
+ :uuid: 45aa67cd-c459-45d4-9d7f-8d4bd0c0dfa7
4
+ :venue: Magoo's Pizza Parlor
5
+ :city: Menlo Park
6
+ :state: CA
7
+ :country: US
8
+ :sets: []
9
+ 1965/05/12:
10
+ :uuid: 5a7143b3-f269-4066-aaa9-c1f1bb9feabf
11
+ :venue: Magoo's Pizza Parlor
12
+ :city: Menlo Park
13
+ :state: CA
14
+ :country: US
15
+ :sets: []
16
+ 1965/05/27:
17
+ :uuid: 128971ef-286f-4401-a617-28e795a30fe8
18
+ :venue: Magoo's Pizza Parlor
19
+ :city: Menlo Park
20
+ :state: CA
21
+ :country: US
22
+ :sets: []
23
+ 1965/06/18:
24
+ :uuid: e7670295-e716-4f04-843c-e4411c82bda8
25
+ :venue: Frenchy's
26
+ :city: Hayward
27
+ :state: CA
28
+ :country: US
29
+ :sets: []
30
+ 1965/08/01:
31
+ :uuid: bcac6971-1cd7-4ecd-a895-56b1eebe68f8
32
+ :venue: Cinnamon A
33
+ :city: Redwood City
34
+ :state: CA
35
+ :country: US
36
+ :sets: []
37
+ 1965/09/01:
38
+ :uuid: 03db9d40-e739-4e9a-a304-54e090e67321
39
+ :venue: In Room
40
+ :city: Belmont
41
+ :state: CA
42
+ :country: US
43
+ :sets: []
44
+ 1965/12/01:
45
+ :uuid: a00ae8ca-7a6e-4b76-87f9-0c03873996f9
46
+ :venue: Pierre's
47
+ :city: San Francisco
48
+ :state: CA
49
+ :country: US
50
+ :sets: []
51
+ 1965/12/04:
52
+ :uuid: 39375335-6dc3-4b5b-8677-beaa752db89b
53
+ :venue: Big Nig's House
54
+ :city: San Jose
55
+ :state: CA
56
+ :country: US
57
+ :sets: []
58
+ 1965/12/10:
59
+ :uuid: 4c35959a-06f1-417a-8e69-67c4e1df9417
60
+ :venue: Fillmore Auditorium
61
+ :city: San Francisco
62
+ :state: CA
63
+ :country: US
64
+ :sets: []
65
+ 1965/12/11:
66
+ :uuid: 604da57f-3f8b-4e67-8bf6-1b4783d10e13
67
+ :venue: The Big Beat
68
+ :city: Palo Alto
69
+ :state: CA
70
+ :country: US
71
+ :sets: []
72
+ 1965/12/18:
73
+ :uuid: 5618738d-6841-4c1e-a71a-1f18b5ab879b
74
+ :venue: Muir Beach Lodge
75
+ :city: Muir Beach
76
+ :state: CA
77
+ :country: US
78
+ :sets: []