async-rails 1.1.0 → 1.2.0

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: 0b75772d99ec34fbeddd4bb669debffbe1a77739
4
- data.tar.gz: 29fb194713a6d44c72f620f47babc381a7cf9d63
3
+ metadata.gz: 2a30d7f145cc38f1a7e9c0f6a0d3f1c64efe9f79
4
+ data.tar.gz: 39cc938b5f03511c54e29c7a3f59a8cb21d9b02b
5
5
  SHA512:
6
- metadata.gz: b815f5630a1a01ca09d37bdde7e882c783ab7a04162227ea401c6a168cd02a5b13adc7f2412f1448d965743c91d02cf8f597085a1f6131c635fa55722d9977a9
7
- data.tar.gz: 0bb53625bab9d1cc06b384f915049684827ce286bc2eb2b369cad70d5ee0660af79a9d90e520bb4964acdad1fccc47993ee988b88dafee03445127bd5661724f
6
+ metadata.gz: 16d787632b9edb8eac0c524c969e7bd0aea6ae5dce34441b31eba011eb5ea5552dc30cb0522e392e9bab4c536f5162630f099b763a41848dd1ad7cd17d8acb69
7
+ data.tar.gz: b844c7f70252045afe71e599c0566926784478c9acfe92bfdb9bd81e693909c35782fba43b05d43c009870f05b25d03d620ec172700dec353a4a50d4be61e316
@@ -1,5 +1,5 @@
1
1
  module Async
2
2
  module Rails
3
- VERSION = "1.1.0"
3
+ VERSION = "1.2.0"
4
4
  end
5
5
  end
@@ -93,6 +93,10 @@
93
93
  return result;
94
94
  }
95
95
 
96
+ function _range(count) {
97
+ return _map(Array(count), function (v, i) { return i; });
98
+ }
99
+
96
100
  function _reduce(arr, iterator, memo) {
97
101
  _arrayEach(arr, function (x, i, a) {
98
102
  memo = iterator(memo, x, i, a);
@@ -217,7 +221,7 @@
217
221
  async.eachOf = function (object, iterator, callback) {
218
222
  callback = _once(callback || noop);
219
223
  object = object || [];
220
- var size = object.length || _keys(object).length;
224
+ var size = _isArrayLike(object) ? object.length : _keys(object).length;
221
225
  var completed = 0;
222
226
  if (!size) {
223
227
  return callback(null);
@@ -834,8 +838,21 @@
834
838
  if (q.tasks.length === q.concurrency) {
835
839
  q.saturated();
836
840
  }
837
- async.setImmediate(q.process);
838
841
  });
842
+ async.setImmediate(q.process);
843
+ }
844
+ function _next(q, tasks) {
845
+ return function(){
846
+ workers -= 1;
847
+ var args = arguments;
848
+ _arrayEach(tasks, function (task) {
849
+ task.callback.apply(task, args);
850
+ });
851
+ if (q.tasks.length + workers === 0) {
852
+ q.drain();
853
+ }
854
+ q.process();
855
+ };
839
856
  }
840
857
 
841
858
  var workers = 0;
@@ -859,32 +876,22 @@
859
876
  },
860
877
  process: function () {
861
878
  if (!q.paused && workers < q.concurrency && q.tasks.length) {
862
- var tasks = payload ?
863
- q.tasks.splice(0, payload) :
864
- q.tasks.splice(0, q.tasks.length);
865
-
866
- var data = _map(tasks, function (task) {
867
- return task.data;
868
- });
879
+ while(workers < q.concurrency && q.tasks.length){
880
+ var tasks = payload ?
881
+ q.tasks.splice(0, payload) :
882
+ q.tasks.splice(0, q.tasks.length);
869
883
 
870
- if (q.tasks.length === 0) {
871
- q.empty();
872
- }
873
- workers += 1;
874
- var cb = only_once(next);
875
- worker(data, cb);
876
- }
884
+ var data = _map(tasks, function (task) {
885
+ return task.data;
886
+ });
877
887
 
878
- function next() {
879
- workers -= 1;
880
- var args = arguments;
881
- _arrayEach(tasks, function (task) {
882
- task.callback.apply(task, args);
883
- });
884
- if (q.tasks.length + workers === 0) {
885
- q.drain();
888
+ if (q.tasks.length === 0) {
889
+ q.empty();
890
+ }
891
+ workers += 1;
892
+ var cb = only_once(_next(q, tasks));
893
+ worker(data, cb);
886
894
  }
887
- q.process();
888
895
  }
889
896
  },
890
897
  length: function () {
@@ -1056,20 +1063,16 @@
1056
1063
  };
1057
1064
  };
1058
1065
 
1059
- async.times = function (count, iterator, callback) {
1060
- var counter = [];
1061
- for (var i = 0; i < count; i++) {
1062
- counter.push(i);
1063
- }
1064
- return async.map(counter, iterator, callback);
1065
- };
1066
+ function _times(mapper) {
1067
+ return function (count, iterator, callback) {
1068
+ mapper(_range(count), iterator, callback);
1069
+ };
1070
+ }
1066
1071
 
1067
- async.timesSeries = function (count, iterator, callback) {
1068
- var counter = [];
1069
- for (var i = 0; i < count; i++) {
1070
- counter.push(i);
1071
- }
1072
- return async.mapSeries(counter, iterator, callback);
1072
+ async.times = _times(async.map);
1073
+ async.timesSeries = _times(async.mapSeries);
1074
+ async.timesLimit = function (count, limit, iterator, callback) {
1075
+ return async.mapLimit(_range(count), limit, iterator, callback);
1073
1076
  };
1074
1077
 
1075
1078
  async.seq = function (/* functions... */) {
@@ -1181,4 +1184,4 @@
1181
1184
  root.async = async;
1182
1185
  }
1183
1186
 
1184
- }());
1187
+ }());
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: async-rails
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.1.0
4
+ version: 1.2.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Jason Chen
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2015-06-02 00:00:00.000000000 Z
11
+ date: 2015-06-08 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: railties