Comparing version 0.3.2 to 0.3.3
/* | ||
*fqueue.js v 0.3.2 | ||
*fqueue.js v 0.3.3 | ||
*Author: Sudhanshu Yadav | ||
@@ -94,3 +94,3 @@ *s-yadav.github.com | ||
this.current = index - 1; | ||
this.next(argToArray(arguments, 1)); | ||
this.next.apply(argToArray(arguments, 1)); | ||
}, | ||
@@ -97,0 +97,0 @@ stop: function () { |
@@ -9,3 +9,3 @@ { | ||
}, | ||
"version": "0.3.2", | ||
"version": "0.3.3", | ||
"repository": { | ||
@@ -27,3 +27,11 @@ "type": "git", | ||
], | ||
"readmeFilename": "README.md" | ||
"readmeFilename": "README.md", | ||
"readme": "fqueue\r\n======\r\n\r\nfqueue is a micro-plugin to queue function execution to handle asyncronous flow and stepping though functions.\r\n <ul>\r\n <li> It support adding or removing of function after initialization of queue.</li>\r\n <li>Support storing of data which can be used to all function whithin that queue</li>\r\n <li>Support parrallel and series async call.</li>\r\n <li>Give full control over queue like, stop , start (from any index), hold, continue, call next function.</li>\r\n <li>Can define ignore indexes if you are running queue again and don't want to run ignore some functions.</li>\r\n <li>Make your code more clean (especially if you are node - mongo developer it can save you from dirty callbacks)</li>\r\n </ul>\r\n <p>** fqueue passes queue object as this in all function but be sure to store this on some variable and use that inside any callback function, because there value of this will be different.</p>\r\n \r\n <p><strong>Installation</strong></p>\r\n <p>\r\n \tFor node \r\n <pre>\r\nnpm install f-queue\r\n\t</pre>\r\n <br/>\r\n For browser just include fqueue.min.js file or fqueue.js in your directory.\r\n </p>\r\n\r\n<p><strong>Updates</strong></p>\r\n <p>\r\n In version 0.3.0, Added step method.\r\n <br /><br /> \r\n In version 0.2.0 , code to include f-queue\r\n <pre>\r\nvar fqueue=require(\"f-queue\");\r\n\t</pre>\r\n In version 0.1.* , code to include f-queue \r\n <pre>\r\nvar fqueue=require(\"f-queue\").fqueue;\r\n\t</pre>\r\n</p>\r\n \r\n \r\n <p><strong>Methods</strong></p>\r\n <table width=\"100%\" border=\"0\" cellspacing=\"0\" cellpadding=\"10\">\r\n <tr>\r\n <td width=\"20%\">Methods</td>\r\n <td width=\"40%\">Parameters</td>\r\n <td width=\"40%\">Description</td>\r\n </tr>\r\n <tr>\r\n <td>next</td>\r\n <td>Any number of arguments which you want to pass on next function of queue.</td>\r\n <td>Execute the next method in queue.</td>\r\n </tr>\r\n <tr>\r\n <td>step</td>\r\n <td>Any number of arguments which you want to pass on next function of queue.</td>\r\n <td>Execute the next method in queue after all functions in particular index of queue is finished. However it is different form next and complete as next and complete can't be pass directly to callback functions. Whereas step can be passed and will maintain this as fqueue object for next method. Originial this (passed on callback by any way ) will be stored on originialThis key of fqueue object. </td>\r\n </tr>\r\n <tr>\r\n <td>add</td>\r\n <td>1. function (mandatory) : function you want to add<br>\r\n 2. pos (optional) : Index at which function will be add. If not defined, add function on last.</td>\r\n <td>To add function on the queue after initialization.</td>\r\n </tr>\r\n <tr>\r\n <td>remove</td>\r\n <td>1. index (mandatory) : Index of function which you want to remove.</td>\r\n <td>Remove a function at particular index from a queue.</td>\r\n </tr>\r\n <tr>\r\n <td>hold</td>\r\n <td>no parameter</td>\r\n <td>To hold the queue to go next item if autoStep option is enabled.</td>\r\n </tr>\r\n <tr>\r\n <td>continue</td>\r\n <td>no parameter</td>\r\n <td>Continue the queue to go to next item.</td>\r\n </tr>\r\n <tr>\r\n <td>complete</td>\r\n <td>Any number of arguments which you want to pass on next function of queue.</td>\r\n <td>To tell an async call have been finished</td>\r\n </tr>\r\n <tr>\r\n <td>start</td>\r\n <td><p>index (mandatory) : Index at which you want to start the queue. <br>\r\n <br>\r\n Any arguments starting followed by first argument will be passed to to function through which queue is starting.</p></td>\r\n <td>To start the queue.</td>\r\n </tr>\r\n <tr>\r\n <td>stop</td>\r\n <td>no parameter</td>\r\n <td>To stop the queue.</td>\r\n </tr>\r\n <tr>\r\n <td>ignore</td>\r\n <td>idxAry : A array of indexes for which you don't want to execute your function.</td>\r\n <td>To define array of indexes to ignore.</td>\r\n </tr>\r\n </table>\r\n <p><br>\r\n <strong>Options</strong></p>\r\n <table width=\"100%\" border=\"0\" cellspacing=\"0\" cellpadding=\"10\">\r\n <tr>\r\n <td width=\"17%\">Options</td>\r\n <td width=\"25%\">Default</td>\r\n <td width=\"58%\">Parameters</td>\r\n </tr>\r\n <tr>\r\n <td>autoStart</td>\r\n <td>true</td>\r\n <td>Auto start a queue.</td>\r\n </tr>\r\n <tr>\r\n <td>autoStep</td>\r\n <td>true</td>\r\n <td>Auto step to next function in a queue on finish of a function execution.</td>\r\n </tr>\r\n <tr>\r\n <td>startParams</td>\r\n <td>[] - empty array</td>\r\n <td>An array of parameters which you want to pass on first function.</td>\r\n </tr>\r\n </table>\r\n <p>You can change the defauls globally like<br>\r\n <pre><code>\r\n fqueue.defaults.autoStart=false; \r\n </code></pre> \r\n </p>\r\n <p><strong>Examples</strong></p>\r\n <p>Simple Example<br>\r\n <pre>\r\nvar queue=fqueue(\r\nfunction(){\r\n //do somthing synchronous\r\n },\r\nfunction(){\r\n //do somthing synchronous\r\n },\r\nfunction(){\r\n //do somthing synchronous\r\n }\t\t\r\n);\r\n </pre>\r\n In this example queue will start during initialization and auto step through each function. If you don't want so you can disable those options like. \r\n <pre>\r\nvar queue=fqueue({autoStart:false,autoStep:false}\r\nfunction(){\r\n //do somthing synchronous\r\n },\r\nfunction(){\r\n //do somthing synchronous\r\n },\r\nfunction(){\r\n //do somthing synchronous\r\n }\t\t\r\n);\r\n </pre>\r\n <p>And then when you want you can start it using <em><strong>queue.start(index)</strong></em> and step through functions using <em><strong>queue.next()</strong></em>;\r\n </p>\r\n </p>\r\n <p>You can use <strong><em>.add()</em></strong> method to add function in queue after initializtion of queue or inside a function of queue.</p>\r\n <pre>\r\nvar queue=fqueue({autoStart:false}\r\nfunction(){\r\n //do somthing synchronous\r\n },\r\nfunction(){\r\n //do somthing synchronous\r\n //to get current index\r\n var index=this.current;\r\n //to add function next to current function\r\n this.add(function(){\r\n //do something else \r\n },++index);\r\n },\r\nfunction(){\r\n //do somthing synchronous\r\n }\t\t\r\n);\r\n\r\nor\r\nqueue.add(function(){\r\n //do something else\r\n});\r\n </pre>\r\n <p>Same you can use <em><strong>.remove()</strong></em> method.\r\n </p>\r\n <p>You can step to next method in middle of any function too.</p>\r\n <pre>\r\nvar queue=fqueue(\r\nfunction(){\r\n //do somthing synchronous\r\n this.next();\r\n //do something else\r\n },\r\nfunction(){\r\n //do somthing synchronous\r\n },\r\nfunction(){\r\n //do somthing synchronous\r\n }\t\t\r\n);\r\n\r\n </pre>\r\n <p>** However if you are using .next() method when execution of the function completes it bypass all those function which are already been called by .next() method. </p>\r\n\r\n <p>To run asynchronous function you have to use one or two methods among <strong><em>.hold()</em> </strong>, <em><strong>.complete()</strong></em> and <em><strong>.step()</strong></em>. <br/>\r\nYou need to use .hold() method only if autoStep is enabled. <br />\r\n<strong><em>.hold()</em> </strong>and <em><strong>.complete()</strong></em> tells that a async function is completed and now to step to next method. While it go to next method only after executing all parallel method in particular index of queue. </br>\r\n\r\nYou can also use <strong><em>.next()</em> </strong> method if there is only one function on a particular index of queue. </br>\r\n\r\n**step method can be directly passed as callback while next and and complete can't be. And this method is very handy while you are dealing of hierarchy of callbacks in node.js. \r\n\r\n <pre>\r\nvar queue=fqueue(\r\n\tfunction(){\r\n\t\tqueue.hold(); //only required if autoStep option is true\r\n\t\t$.get('get.php',function(){\r\n\t\t\t\t//do something\r\n\t\t\t\t//you can pass parameter to next function \r\n\t\t\t\tqueue.complete('Sudhanshu','23');\r\n\t\t\t});\r\n },\r\nfunction(name,age){\r\n //do somthing synchronous\r\n },\r\nfunction(){\r\n queue.hold();\r\n $.get('get.php',function(){\r\n //do something\r\n queue.complete();\r\n });\r\n }\t\t\r\n);\r\n\r\nor with steps\r\n\r\nvar queue=fqueue(\r\nfunction(){\r\n $.get('get.php',this.step);\r\n },\r\nfunction(result){\r\n\t //do something\r\n\t $.get('get1.php',this.step);\r\n },\r\nfunction(result){\r\n \t//do something\r\n\tconsole.log(\"queue is finished\");\r\n }\r\n);\r\n\r\n\r\nor\r\n\r\nvar queue=fqueue({autoStep:false}\r\nfunction(){\r\n $.get('get.php',function(){\r\n //do something\r\n //you can pass parameter to next function \r\n queue.next('Sudhanshu','23');\r\n });\r\n },\r\nfunction(name,age){\r\n //do somthing synchronous\r\n queue.next();\r\n },\r\nfunction(){\r\n //you can also use this instead of queue name, but be sure to save it on some variable\r\n // because \"this\" will change inside callback function.\r\n self=this;\r\n $.get('get.php',function(){\r\n //do something\r\n self.next();\r\n });\r\n }\t\t\r\n);\r\n </pre>\r\n <p>You can also run async functions in parrallel by sending those functions in a array.</p>\r\n <pre>\r\nvar queue=fqueue(\r\n//send function in array to run them in parrallel\r\n[function(){\r\n queue.hold();\r\n $.get('get.php',function(){\r\n //do something\r\n queue.complete();\r\n });\r\n },\r\nfunction(){\r\n queue.hold();\r\n $.get('get.php',function(){\r\n //do something\r\n queue.complete();\r\n });\r\n }],\r\nfunction(){\r\n //this will be executed after first two parrallel function's execution completes.\r\n //do somthing synchronous\r\n }\t\t\r\n);\r\n\r\n </pre>\r\n\r\nYou can use .data,.previousResult,.results to store data, get return value of previous function and to get result of all functions.\r\n <pre>\r\nvar queue=fqueue(\r\nfunction(){\r\n //do somthing synchronous\r\n var name=\"Sudhanshu\";\r\n this.data.name=name;\r\n return 1;\r\n },\r\nfunction(){\r\n //do somthing synchronous\r\n console.log(this.data.name);\r\n //will log Sudhanshu\r\n return 2;\r\n },\r\nfunction(){\r\n //do somthing synchronous\r\n console.log(this.previousResult);\r\n //will log 2;\r\n return 3;\r\n },\r\nfunction(){\r\n //do something synchronous\r\n return 4;\r\n} \r\n \r\n);\r\n\r\nconsole.log(queue.results);\r\n//will log [1,2,3,4];\r\n\r\n </pre>\r\n In some case you want to call the same queue but you want to ignore some functions in the queue. Suppose the first function was used only to get name and third function only log was done and while calling again the queue you want to ignore first and third function.\r\n<pre>\r\nqueue.ignore([0,2]) //you have to give the index of function in a array which you want to ignore.\r\nqueue.start(0); //this will ignore the first and third function.\r\n</pre>\r\n", | ||
"homepage": "https://github.com/s-yadav/fqueue", | ||
"_id": "f-queue@0.3.2", | ||
"dist": { | ||
"shasum": "7e62d146e9c287de507d75f0a0759aef0ae970ac" | ||
}, | ||
"_from": "f-queue@*", | ||
"_resolved": "https://registry.npmjs.org/f-queue/-/f-queue-0.3.2.tgz" | ||
} |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
No website
QualityPackage does not have a website.
Found 1 instance in 1 package
29197
1