mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-20 06:29:53 +01:00
Better argument handling and defaults
This commit is contained in:
parent
d0ad90456e
commit
12600446c2
1 changed files with 15 additions and 3 deletions
|
@ -7,13 +7,19 @@ if (plugins.isClient) {
|
||||||
var async = require("async");
|
var async = require("async");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
exports.bubbleExceptions = true
|
||||||
|
|
||||||
var hookCallWrapper = function (hook, hook_name, args, cb) {
|
var hookCallWrapper = function (hook, hook_name, args, cb) {
|
||||||
if (cb === undefined) cb = function (x) { return x; };
|
if (cb === undefined) cb = function (x) { return x; };
|
||||||
|
if (exports.bubbleExceptions) {
|
||||||
|
return hook.hook_fn(hook_name, args, cb);
|
||||||
|
} else {
|
||||||
try {
|
try {
|
||||||
return hook.hook_fn(hook_name, args, cb);
|
return hook.hook_fn(hook_name, args, cb);
|
||||||
} catch (ex) {
|
} catch (ex) {
|
||||||
console.error([hook_name, hook.part.full_name, ex.stack || ex]);
|
console.error([hook_name, hook.part.full_name, ex.stack || ex]);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -33,6 +39,7 @@ exports.flatten = function (lst) {
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.callAll = function (hook_name, args) {
|
exports.callAll = function (hook_name, args) {
|
||||||
|
if (!args) args = {};
|
||||||
if (plugins.hooks[hook_name] === undefined) return [];
|
if (plugins.hooks[hook_name] === undefined) return [];
|
||||||
return exports.flatten(plugins.hooks[hook_name].map(function (hook) {
|
return exports.flatten(plugins.hooks[hook_name].map(function (hook) {
|
||||||
return hookCallWrapper(hook, hook_name, args);
|
return hookCallWrapper(hook, hook_name, args);
|
||||||
|
@ -40,6 +47,8 @@ exports.callAll = function (hook_name, args) {
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.aCallAll = function (hook_name, args, cb) {
|
exports.aCallAll = function (hook_name, args, cb) {
|
||||||
|
if (!args) args = {};
|
||||||
|
if (!cb) cb = function () {};
|
||||||
if (plugins.hooks[hook_name] === undefined) return cb(null, []);
|
if (plugins.hooks[hook_name] === undefined) return cb(null, []);
|
||||||
async.map(
|
async.map(
|
||||||
plugins.hooks[hook_name],
|
plugins.hooks[hook_name],
|
||||||
|
@ -53,11 +62,14 @@ exports.aCallAll = function (hook_name, args, cb) {
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.callFirst = function (hook_name, args) {
|
exports.callFirst = function (hook_name, args) {
|
||||||
|
if (!args) args = {};
|
||||||
if (plugins.hooks[hook_name][0] === undefined) return [];
|
if (plugins.hooks[hook_name][0] === undefined) return [];
|
||||||
return exports.flatten(hookCallWrapper(plugins.hooks[hook_name][0], hook_name, args));
|
return exports.flatten(hookCallWrapper(plugins.hooks[hook_name][0], hook_name, args));
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.aCallFirst = function (hook_name, args, cb) {
|
exports.aCallFirst = function (hook_name, args, cb) {
|
||||||
|
if (!args) args = {};
|
||||||
|
if (!cb) cb = function () {};
|
||||||
if (plugins.hooks[hook_name][0] === undefined) return cb(null, []);
|
if (plugins.hooks[hook_name][0] === undefined) return cb(null, []);
|
||||||
hookCallWrapper(plugins.hooks[hook_name][0], hook_name, args, function (res) { cb(null, exports.flatten(res)); });
|
hookCallWrapper(plugins.hooks[hook_name][0], hook_name, args, function (res) { cb(null, exports.flatten(res)); });
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue