pg_triggers 0.2.0 → 0.2.1

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.
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