Stream 0.0.5 → 0.0.6

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.
data/.gitignore ADDED
@@ -0,0 +1,2 @@
1
+ pkg
2
+ .DS_Store
data/MIT-LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2008 James Golick
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.rdoc ADDED
@@ -0,0 +1,102 @@
1
+ = TimelineFu
2
+
3
+ Easily build timelines, much like GitHub's news feed.
4
+
5
+ == Usage
6
+
7
+ TimelineFu requires you to have a TimelineEvent model.
8
+ The simplest way is to use the generator.
9
+
10
+ $ script/generate timeline_fu && rake db:migrate
11
+ exists db/migrate
12
+ create db/migrate/20090333222034_create_timeline_events.rb
13
+ create app/models/timeline_event.rb
14
+ # Migration blabber...
15
+
16
+ Next step is to determine what generates an event in your various models.
17
+
18
+ class Post < ActiveRecord::Base
19
+ #...
20
+ belongs_to :author, :class_name => 'Person'
21
+ fires :new_post, :on => :create,
22
+ :actor => :author
23
+ end
24
+
25
+ You can add 'fires' statements to as many models as you want on as many models
26
+ as you want.
27
+
28
+ They are hooked for you after standard ActiveRecord events. In
29
+ the previous example, it's an after_create on Posts.
30
+
31
+ === Parameters for #fires
32
+
33
+ You can supply a few parameters to fires, two of them are mandatory.
34
+ - the first param is a custom name for the event type. It'll be your way of figuring out what events your reading back from the timeline_events table later.
35
+ - :new_post in the example
36
+
37
+ The rest all fit neatly in an options hash.
38
+
39
+ - :on => [ActiveRecord event]
40
+ - mandatory. You use it to specify whether you want the event created after a create, update or destroy. You can also supply an array of events, e.g. [:create, :update].
41
+ - :actor is your way of specifying who took this action.
42
+ - In the example, post.author is going to be this person.
43
+ - :subject is automatically set to self, which is good most of the time. You can however override it if you need to, using :subject.
44
+ - :secondary_subject can let you specify something else that's related to the event. A comment to a blog post would be a good example.
45
+ - :if => symbol or proc/lambda lets you put conditions on when a TimelineEvent is created. It's passed right to the after_xxx ActiveRecord event hook, so it's has the same behavior.
46
+
47
+ Here's another example:
48
+
49
+ class Comment < ActiveRecord::Base
50
+ #...
51
+ belongs_to :commenter, :class_name => 'Person'
52
+ belongs_to :post
53
+ fires :new_comment, :on => :create,
54
+ :actor => :commenter,
55
+ #implicit :subject => self,
56
+ :secondary_subject => 'post',
57
+ :if => lambda { |comment| comment.commenter != comment.post.author }
58
+ end
59
+
60
+ === TimelineEvent instantiation
61
+
62
+ The ActiveRecord event hook will automatically instantiate a
63
+ TimelineEvent instance for you.
64
+ It will receive the following parameters in #create!
65
+
66
+ - event_type
67
+ - "new_comment" in the comment example
68
+ - actor
69
+ - the commenter
70
+ - subject
71
+ - the comment instance
72
+ - secondary_subject
73
+ - the post instance
74
+
75
+ The generated model stores most of its info as polymorphic relationships.
76
+
77
+ class TimelineEvent < ActiveRecord::Base
78
+ belongs_to :actor, :polymorphic => true
79
+ belongs_to :subject, :polymorphic => true
80
+ belongs_to :secondary_subject, :polymorphic => true
81
+ end
82
+
83
+ == How you actually get your timeline
84
+
85
+ To get your timeline you'll probably have to create your own finder SQL or scopes
86
+ (if your situation is extremely simple).
87
+
88
+ TimelineFu is not currently providing anything to generate your timeline because
89
+ different situations will have wildly different requirements. Like access control
90
+ issues and actually just what crazy stuff you're cramming in that timeline.
91
+
92
+ We're not saying it can't be done, just that we haven't done it yet.
93
+ Contributions are welcome :-)
94
+
95
+ == Get it
96
+
97
+ # Gemfile
98
+ gem "timeline_fu"
99
+
100
+ == License
101
+
102
+ Copyright (c) 2008 James Golick, released under the MIT license
data/Rakefile ADDED
@@ -0,0 +1,36 @@
1
+ require 'rake'
2
+ require 'rake/testtask'
3
+ require 'rake/rdoctask'
4
+
5
+ desc 'Default: run unit tests.'
6
+ task :default => :test
7
+
8
+ desc 'Test the timeline_fu plugin.'
9
+ Rake::TestTask.new(:test) do |t|
10
+ t.libs << 'lib'
11
+ t.pattern = 'test/**/*_test.rb'
12
+ t.verbose = true
13
+ end
14
+
15
+ begin
16
+ require 'jeweler'
17
+ Jeweler::Tasks.new do |s|
18
+ s.name = "timeline_fu"
19
+ s.summary = %Q{Easily build timelines, much like GitHub's news feed}
20
+ s.email = "james@giraffesoft.ca"
21
+ s.homepage = "http://github.com/giraffesoft/timeline_fu"
22
+ s.description = "Easily build timelines, much like GitHub's news feed"
23
+ s.authors = ["James Golick", "Mathieu Martin", "Francois Beausoleil"]
24
+ end
25
+ rescue LoadError
26
+ puts "Jeweler not available. Install it with: sudo gem install technicalpickles-jeweler -s http://gems.github.com"
27
+ end
28
+
29
+ desc 'Generate documentation for the timeline_fu plugin.'
30
+ Rake::RDocTask.new(:rdoc) do |rdoc|
31
+ rdoc.rdoc_dir = 'rdoc'
32
+ rdoc.title = 'TimelineFu'
33
+ rdoc.options << '--line-numbers' << '--inline-source'
34
+ rdoc.rdoc_files.include('README*')
35
+ rdoc.rdoc_files.include('lib/**/*.rb')
36
+ end
data/VERSION.yml ADDED
@@ -0,0 +1,4 @@
1
+ ---
2
+ :major: 0
3
+ :minor: 4
4
+ :patch: 1
@@ -0,0 +1,2 @@
1
+ Generates both the TimelineEvent class and the migration to create its table. The table will have subject, actor and secondary actor as polymorphic associations.
2
+ The use of this generator is optional. See README for more details.
@@ -0,0 +1,9 @@
1
+ class StreamGenerator < Rails::Generator::Base
2
+ def manifest
3
+ record do |m|
4
+ m.migration_template 'migration.rb', 'db/migrate',
5
+ :migration_file_name => 'create_activities'
6
+ m.template 'model.rb', 'app/models/activity.rb'
7
+ end
8
+ end
9
+ end
@@ -0,0 +1,15 @@
1
+ class CreateActivities < ActiveRecord::Migration
2
+ def self.up
3
+ create_table :activities do |t|
4
+ t.string :activity_type, :subject_type, :actor_type, :secondary_subject_type
5
+ t.integer :subject_id, :actor_id, :secondary_subject_id
6
+ t.timestamps
7
+ end
8
+ end
9
+
10
+ def self.down
11
+ drop_table :activities
12
+ end
13
+ end
14
+
15
+
@@ -0,0 +1,5 @@
1
+ class Activity < ActiveRecord::Base
2
+ belongs_to :actor, :polymorphic => true
3
+ belongs_to :subject, :polymorphic => true
4
+ belongs_to :secondary_subject, :polymorphic => true
5
+ end
data/init.rb ADDED
@@ -0,0 +1 @@
1
+ require 'timeline_fu'
@@ -0,0 +1,42 @@
1
+ module Stream
2
+ module Fires
3
+ def self.included(klass)
4
+ klass.send(:extend, ClassMethods)
5
+ end
6
+
7
+ module ClassMethods
8
+ def fires(event_type, opts)
9
+ raise ArgumentError, "Argument :on is mandatory" unless opts.has_key?(:on)
10
+
11
+ # Array provided, set multiple callbacks
12
+ if opts[:on].kind_of?(Array)
13
+ opts[:on].each { |on| fires(event_type, opts.merge({:on => on})) }
14
+ return
15
+ end
16
+
17
+ opts[:subject] = :self unless opts.has_key?(:subject)
18
+
19
+ method_name = :"fire_#{event_type}_after_#{opts[:on]}"
20
+ define_method(method_name) do
21
+ create_options = [:actor, :subject, :secondary_subject].inject({}) do |memo, sym|
22
+ if opts[sym]
23
+ if opts[sym].respond_to?(:call)
24
+ memo[sym] = opts[sym].call(self)
25
+ elsif opts[sym] == :self
26
+ memo[sym] = self
27
+ else
28
+ memo[sym] = send(opts[sym])
29
+ end
30
+ end
31
+ memo
32
+ end
33
+ create_options[:event_type] = event_type.to_s
34
+
35
+ Activity.create!(create_options)
36
+ end
37
+
38
+ send(:"after_#{opts[:on]}", method_name, :if => opts[:if])
39
+ end
40
+ end
41
+ end
42
+ end
@@ -0,0 +1,20 @@
1
+ module Stream
2
+ module Macros
3
+ def should_fire_event(event_type, opts = {})
4
+ should "fire #{event_type} on #{opts[:on]}" do
5
+ matcher = fire_event(event_type, opts)
6
+
7
+ assert_accepts matcher, self.class.name.gsub(/Test$/, '').constantize
8
+ end
9
+ end
10
+
11
+ def should_not_fire_event(event_type, opts = {})
12
+ should "fire #{event_type} on #{opts[:on]}" do
13
+ matcher = fire_event(event_type, opts)
14
+
15
+ assert_rejects matcher, self.class.name.gsub(/Test$/, '').constantize
16
+ end
17
+ end
18
+
19
+ end
20
+ end
@@ -0,0 +1,58 @@
1
+ module Stream
2
+ module Matchers
3
+ class FireEvent
4
+ def initialize(event_type, opts = {})
5
+ @event_type = event_type
6
+ @opts = opts
7
+ @method = :"fire_#{@event_type}_after_#{@opts[:on]}"
8
+ end
9
+
10
+ def matches?(subject)
11
+ @subject = subject
12
+
13
+ defines_callback_method? && setups_up_callback?
14
+ end
15
+
16
+ def defines_callback_method?
17
+ if @subject.instance_methods.include?(@method.to_s)
18
+ true
19
+ else
20
+ @missing = "#{@subject.name} does not respond to #{@method}"
21
+ false
22
+ end
23
+ end
24
+
25
+ def setups_up_callback?
26
+ callback_chain_name = "after_#{@opts[:on]}_callback_chain"
27
+ callback_chain = @subject.send(callback_chain_name)
28
+ if callback_chain.any? {|chain| chain.method == @method }
29
+ true
30
+ else
31
+ @missing = "does setup after #{@opts[:on]} callback for #{@method}"
32
+ false
33
+ end
34
+ end
35
+
36
+ def description
37
+ "fire a #{@event_type} event"
38
+ end
39
+
40
+ def expectation
41
+ expected = "#{@subject.name} to #{description}"
42
+ end
43
+
44
+ def failure_message
45
+ "Expected #{expectation} (#{@missing})"
46
+ end
47
+
48
+ def negative_failure_message
49
+ "Did not expect #{expectation}"
50
+ end
51
+
52
+ end
53
+
54
+ def fire_event(event_type, opts)
55
+ FireEvent.new(event_type, opts)
56
+ end
57
+ end
58
+ end
data/lib/stream.rb ADDED
@@ -0,0 +1,6 @@
1
+ require 'stream/fires'
2
+
3
+ module Stream
4
+ end
5
+
6
+ ActiveRecord::Base.send :include, Stream::Fires
data/stream.gemspec ADDED
@@ -0,0 +1,43 @@
1
+ # -*- encoding: utf-8 -*-
2
+
3
+ Gem::Specification.new do |s|
4
+ s.name = %q{Stream}
5
+ s.version = "0.0.6"
6
+
7
+ s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
8
+ s.authors = ["Gretchen Gapol"]
9
+ s.date = %q{2011-06-27}
10
+ s.description = %q{news feed}
11
+ s.email = %q{ggapol@exist.com}
12
+ s.extra_rdoc_files = [
13
+ "README.rdoc"
14
+ ]
15
+ s.files = [
16
+ ".gitignore",
17
+ "MIT-LICENSE",
18
+ "README.rdoc",
19
+ "Rakefile",
20
+ "VERSION.yml",
21
+ "generators/stream/USAGE",
22
+ "generators/stream/templates/migration.rb",
23
+ "generators/stream/templates/model.rb",
24
+ "generators/stream/stream_generator.rb",
25
+ "init.rb",
26
+ "lib/stream.rb",
27
+ "lib/stream/fires.rb",
28
+ "lib/stream/macros.rb",
29
+ "lib/stream/matchers.rb",
30
+ "stream.gemspec"
31
+ ]
32
+ s.has_rdoc = true
33
+ s.homepage = %q{http://github.com/gretch}
34
+ s.rdoc_options = ["--charset=UTF-8"]
35
+ s.require_paths = ["lib"]
36
+ s.rubygems_version = %q{1.3.1}
37
+ s.summary = %q{news feed}
38
+
39
+ if s.respond_to? :specification_version then
40
+ current_version = Gem::Specification::CURRENT_SPECIFICATION_VERSION
41
+ s.specification_version = 2
42
+ end
43
+ end
metadata CHANGED
@@ -1,309 +1,45 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: Stream
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.5
4
+ version: 0.0.6
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
8
- - GING - DIT - UPM
9
- - CISE - ESPOL
8
+ - Gretchen Gapol
10
9
  autorequire:
11
10
  bindir: bin
12
11
  cert_chain: []
13
- date: 2011-06-23 00:00:00.000000000 +08:00
12
+ date: 2011-06-27 00:00:00.000000000 +08:00
14
13
  default_executable:
15
- dependencies:
16
- - !ruby/object:Gem::Dependency
17
- name: ancestry
18
- requirement: &12558400 !ruby/object:Gem::Requirement
19
- none: false
20
- requirements:
21
- - - ~>
22
- - !ruby/object:Gem::Version
23
- version: 1.2.3
24
- type: :runtime
25
- prerelease: false
26
- version_requirements: *12558400
27
- - !ruby/object:Gem::Dependency
28
- name: foreigner
29
- requirement: &12557900 !ruby/object:Gem::Requirement
30
- none: false
31
- requirements:
32
- - - ~>
33
- - !ruby/object:Gem::Version
34
- version: 0.9.1
35
- type: :runtime
36
- prerelease: false
37
- version_requirements: *12557900
38
- - !ruby/object:Gem::Dependency
39
- name: devise
40
- requirement: &12557440 !ruby/object:Gem::Requirement
41
- none: false
42
- requirements:
43
- - - ~>
44
- - !ruby/object:Gem::Version
45
- version: 1.2.rc
46
- type: :runtime
47
- prerelease: false
48
- version_requirements: *12557440
49
- - !ruby/object:Gem::Dependency
50
- name: inherited_resources
51
- requirement: &12556980 !ruby/object:Gem::Requirement
52
- none: false
53
- requirements:
54
- - - ~>
55
- - !ruby/object:Gem::Version
56
- version: 1.2.2
57
- type: :runtime
58
- prerelease: false
59
- version_requirements: *12556980
60
- - !ruby/object:Gem::Dependency
61
- name: stringex
62
- requirement: &12556520 !ruby/object:Gem::Requirement
63
- none: false
64
- requirements:
65
- - - ~>
66
- - !ruby/object:Gem::Version
67
- version: 1.2.0
68
- type: :runtime
69
- prerelease: false
70
- version_requirements: *12556520
71
- - !ruby/object:Gem::Dependency
72
- name: paperclip
73
- requirement: &12556060 !ruby/object:Gem::Requirement
74
- none: false
75
- requirements:
76
- - - ~>
77
- - !ruby/object:Gem::Version
78
- version: 2.3.4
79
- type: :runtime
80
- prerelease: false
81
- version_requirements: *12556060
82
- - !ruby/object:Gem::Dependency
83
- name: avatars_for_rails
84
- requirement: &12555600 !ruby/object:Gem::Requirement
85
- none: false
86
- requirements:
87
- - - ~>
88
- - !ruby/object:Gem::Version
89
- version: 0.0.9
90
- type: :runtime
91
- prerelease: false
92
- version_requirements: *12555600
93
- - !ruby/object:Gem::Dependency
94
- name: jquery-rails
95
- requirement: &12555140 !ruby/object:Gem::Requirement
96
- none: false
97
- requirements:
98
- - - ~>
99
- - !ruby/object:Gem::Version
100
- version: 0.2.5
101
- type: :runtime
102
- prerelease: false
103
- version_requirements: *12555140
104
- - !ruby/object:Gem::Dependency
105
- name: cancan
106
- requirement: &12591500 !ruby/object:Gem::Requirement
107
- none: false
108
- requirements:
109
- - - ~>
110
- - !ruby/object:Gem::Version
111
- version: 1.6.4
112
- type: :runtime
113
- prerelease: false
114
- version_requirements: *12591500
115
- - !ruby/object:Gem::Dependency
116
- name: will_paginate
117
- requirement: &12591040 !ruby/object:Gem::Requirement
118
- none: false
119
- requirements:
120
- - - ~>
121
- - !ruby/object:Gem::Version
122
- version: 3.0.pre2
123
- type: :runtime
124
- prerelease: false
125
- version_requirements: *12591040
126
- - !ruby/object:Gem::Dependency
127
- name: omniauth
128
- requirement: &12590580 !ruby/object:Gem::Requirement
129
- none: false
130
- requirements:
131
- - - ~>
132
- - !ruby/object:Gem::Version
133
- version: 0.2.6
134
- type: :runtime
135
- prerelease: false
136
- version_requirements: *12590580
137
- - !ruby/object:Gem::Dependency
138
- name: oauth-plugin
139
- requirement: &12590120 !ruby/object:Gem::Requirement
140
- none: false
141
- requirements:
142
- - - ~>
143
- - !ruby/object:Gem::Version
144
- version: 0.4.0.pre1
145
- type: :runtime
146
- prerelease: false
147
- version_requirements: *12590120
148
- - !ruby/object:Gem::Dependency
149
- name: rails_css_themes
150
- requirement: &12589660 !ruby/object:Gem::Requirement
151
- none: false
152
- requirements:
153
- - - ~>
154
- - !ruby/object:Gem::Version
155
- version: 1.0.0
156
- type: :runtime
157
- prerelease: false
158
- version_requirements: *12589660
159
- - !ruby/object:Gem::Dependency
160
- name: mailboxer
161
- requirement: &12589200 !ruby/object:Gem::Requirement
162
- none: false
163
- requirements:
164
- - - ~>
165
- - !ruby/object:Gem::Version
166
- version: 0.1.4
167
- type: :runtime
168
- prerelease: false
169
- version_requirements: *12589200
170
- - !ruby/object:Gem::Dependency
171
- name: rmagick
172
- requirement: &12588740 !ruby/object:Gem::Requirement
173
- none: false
174
- requirements:
175
- - - ~>
176
- - !ruby/object:Gem::Version
177
- version: 2.13.1
178
- type: :runtime
179
- prerelease: false
180
- version_requirements: *12588740
181
- - !ruby/object:Gem::Dependency
182
- name: acts-as-taggable-on
183
- requirement: &12588280 !ruby/object:Gem::Requirement
184
- none: false
185
- requirements:
186
- - - ~>
187
- - !ruby/object:Gem::Version
188
- version: 2.0.6
189
- type: :runtime
190
- prerelease: false
191
- version_requirements: *12588280
192
- - !ruby/object:Gem::Dependency
193
- name: formtastic
194
- requirement: &12587820 !ruby/object:Gem::Requirement
195
- none: false
196
- requirements:
197
- - - ~>
198
- - !ruby/object:Gem::Version
199
- version: 1.2.3
200
- type: :runtime
201
- prerelease: false
202
- version_requirements: *12587820
203
- - !ruby/object:Gem::Dependency
204
- name: rails
205
- requirement: &12587360 !ruby/object:Gem::Requirement
206
- none: false
207
- requirements:
208
- - - ~>
209
- - !ruby/object:Gem::Version
210
- version: 3.0.7
211
- type: :development
212
- prerelease: false
213
- version_requirements: *12587360
214
- - !ruby/object:Gem::Dependency
215
- name: capybara
216
- requirement: &12586900 !ruby/object:Gem::Requirement
217
- none: false
218
- requirements:
219
- - - ~>
220
- - !ruby/object:Gem::Version
221
- version: 0.3.9
222
- type: :development
223
- prerelease: false
224
- version_requirements: *12586900
225
- - !ruby/object:Gem::Dependency
226
- name: sqlite3-ruby
227
- requirement: &12586520 !ruby/object:Gem::Requirement
228
- none: false
229
- requirements:
230
- - - ! '>='
231
- - !ruby/object:Gem::Version
232
- version: '0'
233
- type: :development
234
- prerelease: false
235
- version_requirements: *12586520
236
- - !ruby/object:Gem::Dependency
237
- name: rspec-rails
238
- requirement: &12585960 !ruby/object:Gem::Requirement
239
- none: false
240
- requirements:
241
- - - ~>
242
- - !ruby/object:Gem::Version
243
- version: 2.5.0
244
- type: :development
245
- prerelease: false
246
- version_requirements: *12585960
247
- - !ruby/object:Gem::Dependency
248
- name: factory_girl
249
- requirement: &12585460 !ruby/object:Gem::Requirement
250
- none: false
251
- requirements:
252
- - - ~>
253
- - !ruby/object:Gem::Version
254
- version: 1.3.2
255
- type: :development
256
- prerelease: false
257
- version_requirements: *12585460
258
- - !ruby/object:Gem::Dependency
259
- name: forgery
260
- requirement: &12585000 !ruby/object:Gem::Requirement
261
- none: false
262
- requirements:
263
- - - ~>
264
- - !ruby/object:Gem::Version
265
- version: 0.3.6
266
- type: :development
267
- prerelease: false
268
- version_requirements: *12585000
269
- - !ruby/object:Gem::Dependency
270
- name: ci_reporter
271
- requirement: &12584540 !ruby/object:Gem::Requirement
272
- none: false
273
- requirements:
274
- - - ~>
275
- - !ruby/object:Gem::Version
276
- version: 1.6.4
277
- type: :development
278
- prerelease: false
279
- version_requirements: *12584540
280
- - !ruby/object:Gem::Dependency
281
- name: nifty-generators
282
- requirement: &12584080 !ruby/object:Gem::Requirement
283
- none: false
284
- requirements:
285
- - - ~>
286
- - !ruby/object:Gem::Version
287
- version: 0.4.5
288
- type: :development
289
- prerelease: false
290
- version_requirements: *12584080
291
- description: ! 'Social Stream is a Ruby on Rails engine providing your application
292
- with social networking features and activity streams.
293
-
294
-
295
- This gem packages the basic functionality, along with basic actors (user, group)
296
- and activity objects(post and comments)'
297
- email:
14
+ dependencies: []
15
+ description: news feed
16
+ email: ggapol@exist.com
298
17
  executables: []
299
18
  extensions: []
300
- extra_rdoc_files: []
301
- files: []
19
+ extra_rdoc_files:
20
+ - README.rdoc
21
+ files:
22
+ - .gitignore
23
+ - MIT-LICENSE
24
+ - README.rdoc
25
+ - Rakefile
26
+ - VERSION.yml
27
+ - generators/stream/USAGE
28
+ - generators/stream/templates/migration.rb
29
+ - generators/stream/templates/model.rb
30
+ - generators/stream/stream_generator.rb
31
+ - init.rb
32
+ - lib/stream.rb
33
+ - lib/stream/fires.rb
34
+ - lib/stream/macros.rb
35
+ - lib/stream/matchers.rb
36
+ - stream.gemspec
302
37
  has_rdoc: true
303
- homepage: http://social-stream.dit.upm.es/
38
+ homepage: http://github.com/gretch
304
39
  licenses: []
305
40
  post_install_message:
306
- rdoc_options: []
41
+ rdoc_options:
42
+ - --charset=UTF-8
307
43
  require_paths:
308
44
  - lib
309
45
  required_ruby_version: !ruby/object:Gem::Requirement
@@ -322,6 +58,6 @@ requirements: []
322
58
  rubyforge_project:
323
59
  rubygems_version: 1.6.2
324
60
  signing_key:
325
- specification_version: 3
326
- summary: Basic features for Social Stream, the core for building social network websites
61
+ specification_version: 2
62
+ summary: news feed
327
63
  test_files: []