pg_triggers 0.2.0 → 0.2.1

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: 4c8e5d7162ea64f110cae96cb207f761a3a03f5f
4
- data.tar.gz: 9a47381f9bba876a570abe52c81bb30e66d3182a
3
+ metadata.gz: 7cf39423a3020619969aa1b391430c208a7c4f51
4
+ data.tar.gz: 3bd05b9d325a80182451ea7e48d854dc019f358b
5
5
  SHA512:
6
- metadata.gz: 6020076643bec765f6815d43fb0559120e8585f4cbc94dcaa23e86c641b835eea248e5112407168b2cbcc26168c32ec8fa6f4b9467c9395029e5f5257ce23f3f
7
- data.tar.gz: 730068add4d00c160ce2fbc634a0c8e2b7ce93a57f8a67a3449fee746922cc220bb16a74c517058c982f6bc3eb2cedf2e89c48239c8db230a9f312d3baded8d6
6
+ metadata.gz: 83754258a0258ad61666dc1e1efcda3139dd7b1a06b9d443a1b68748d34e60aa3fe7ac07a721292d210f29ed7d98933c2cfa42ebc7d79d85d82e3e10c0dff760
7
+ data.tar.gz: ea9522861e095a447c9b3ce1352e26920a960ed4e9b6e7657bb76c81e6123289db1fc8e2c85e3bf66c3d0023818871bad000c7c5c3a2e7af4e284e6aec96b468
data/CHANGELOG.md CHANGED
@@ -1,3 +1,7 @@
1
+ ### 0.2.1 (2014-10-31)
2
+
3
+ * Add :name option to counter_cache to support custom names for the function and trigger.
4
+
1
5
  ### 0.2.0 (2014-09-19)
2
6
 
3
7
  * Add :value option to counter_cache to support incrementing/decrementing counters by a specific amount.
@@ -1,3 +1,3 @@
1
1
  module PgTriggers
2
- VERSION = '0.2.0'
2
+ VERSION = '0.2.1'
3
3
  end
data/lib/pg_triggers.rb CHANGED
@@ -7,6 +7,7 @@ module PgTriggers
7
7
  columns = relationship.values
8
8
  changed = columns.map{|c| "((OLD.#{c} <> NEW.#{c}) OR (OLD.#{c} IS NULL <> NEW.#{c} IS NULL))"}.join(' OR ')
9
9
  value = (options[:value] || 1).to_i
10
+ name = options[:name] || "pt_cc_#{main_table}_#{counter_column}"
10
11
 
11
12
  condition = proc do |source|
12
13
  a = []
@@ -16,7 +17,7 @@ module PgTriggers
16
17
  end
17
18
 
18
19
  <<-SQL
19
- CREATE OR REPLACE FUNCTION pt_cc_#{main_table}_#{counter_column}() RETURNS trigger
20
+ CREATE OR REPLACE FUNCTION #{name}() RETURNS trigger
20
21
  LANGUAGE plpgsql
21
22
  AS $$
22
23
  BEGIN
@@ -44,11 +45,11 @@ module PgTriggers
44
45
  END;
45
46
  $$;
46
47
 
47
- DROP TRIGGER IF EXISTS pt_cc_#{main_table}_#{counter_column} ON #{counted_table};
48
+ DROP TRIGGER IF EXISTS #{name} ON #{counted_table};
48
49
 
49
- CREATE TRIGGER pt_cc_#{main_table}_#{counter_column}
50
+ CREATE TRIGGER #{name}
50
51
  AFTER INSERT OR UPDATE OR DELETE ON #{counted_table}
51
- FOR EACH ROW EXECUTE PROCEDURE pt_cc_#{main_table}_#{counter_column}();
52
+ FOR EACH ROW EXECUTE PROCEDURE #{name}();
52
53
  SQL
53
54
  end
54
55
 
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: pg_triggers
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.0
4
+ version: 0.2.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Chris Hanks
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2014-09-19 00:00:00.000000000 Z
11
+ date: 2014-10-31 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler